2019-05-31 08:46:41 +02:00
|
|
|
|
# SplitFspBin.py is a python script to support some operations on Intel FSP 2.0 image.
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
|
|
|
|
It supports:
|
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
- Split Intel FSP 2.0 image into individual FSP-T/M/S/O component
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
- Rebase Intel FSP 2.0 components to different base addresses
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
- Generate Intel FSP 2.0 C header file
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
- Display Intel FSP 2.0 information header for each FSP component
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
## Split Intel FSP 2.0 image
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
To split individual FSP component in Intel FSP 2.0 image, the following
|
2016-06-15 04:44:43 +02:00
|
|
|
|
command can be used:
|
|
|
|
|
|
|
|
|
|
**python SplitFspBin.py split [-h] -f FSPBINARY [-o OUTPUTDIR] [-n NAMETEMPLATE]**
|
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
For example:
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
|
|
|
|
`python SplitFspBin.py split -f FSP.bin`
|
|
|
|
|
|
|
|
|
|
It will create FSP_T.bin, FSP_M.bin and FSP_S.bin in current directory.
|
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
## Rebase Intel FSP 2.0 components
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
To rebase one or multiple FSP components in Intel FSP 2.0 image, the following
|
2016-06-15 04:44:43 +02:00
|
|
|
|
command can be used:
|
|
|
|
|
|
|
|
|
|
**python SplitFspBin.py rebase [-h] -f FSPBINARY -c {t,m,s,o} [{t,m,s,o} ...] -b FSPBASE [FSPBASE ...] [-o OUTPUTDIR] [-n OUTPUTFILE]**
|
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
For example:
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
`python SplitFspBin.py rebase -f FSP.bin –c t –b 0xFFF00000 –n FSP_new.bin`
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
|
|
|
|
It will rebase FSP-T component inside FSP.bin to new base 0xFFF00000 and save the
|
2019-05-31 08:46:41 +02:00
|
|
|
|
rebased Intel FSP 2.0 image into file FSP_new.bin.
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
`python SplitFspBin.py rebase -f FSP.bin –c t m –b 0xFFF00000 0xFEF80000 –n FSP_new.bin`
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
|
|
|
|
It will rebase FSP-T and FSP-M components inside FSP.bin to new base 0xFFF00000
|
2019-05-31 08:46:41 +02:00
|
|
|
|
and 0xFEF80000 respectively, and save the rebased Intel FSP 2.0 image into file
|
2016-06-15 04:44:43 +02:00
|
|
|
|
FSP_new.bin file.
|
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
## Generate Intel FSP 2.0 C header file
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
To generate Intel FSP 2.0 C header file, the following command can be used:
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
|
|
|
|
**Python SplitFspBin.py genhdr [-h] -f FSPBINARY [-o OUTPUTDIR] [-n HFILENAME]**
|
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
For example:
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
`python SplitFspBin.py genhdr -f FSP.bin –n FSP.h`
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
|
|
|
|
It will create the C header file FSP.h containing the image ID, revision, offset
|
|
|
|
|
and size for each individual FSP component.
|
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
## Display Intel FSP 2.0 information header
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
To display Intel FSP 2.0 information headers, the following command can be used:
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
|
|
|
|
**Python SplitFspBin.py info [-h] -f FSPBINARY**
|
|
|
|
|
|
2019-05-31 08:46:41 +02:00
|
|
|
|
For example:
|
2016-06-15 04:44:43 +02:00
|
|
|
|
|
|
|
|
|
`python SplitFspBin.py info -f FSP.bin`
|
|
|
|
|
|
|
|
|
|
It will print out the FSP information header for each FSP component.
|