C-Boot ROM Description
617
SPRUHE8E – October 2012 – Revised November 2019
Copyright © 2012–2019, Texas Instruments Incorporated
ROM Code and Peripheral Booting
•
IQisqrt N= 15, 20, 24, 29
•
IQNmag N= 15, 20, 24, 29
•
IQNsin N= 15, 20, 24, 29
•
IQNsqrt N= 15, 20, 24, 29
These functions can be accessed using the IQmath boot ROM symbol library included with the boot ROM
source. If this library is linked in the project before the IQmath library, and the linker-priority option is used,
then any math tables and IQmath functions within the boot ROM will be used first. Refer to the
IQMath
Library
documentation for more information.
6.6.1.3
C-Boot ROM Version and Checksum
C-Boot ROM contains its own version number located at 0x003FFF7A, as shown in
. This
version is incremented each time C-Boot ROM code is modified. The next word contains the month and
year (MM/YY in decimal) that the boot code was released. The next 42 words contain a checksum value
for C-Boot ROM. A proprietary checksum algorithm is used on this device to allow boot ROM to be tested
more efficiently. The checksum algorithm used is also embedded in ROM and will be published along with
the device boot ROM sources.
Table 6-11. C-Boot ROM Version and Checksum Information
C-Boot ROM Address
Contents
0x003FFF7A
Revision No = 0x0100
0x003FFF7B
Release Date = 0x1211 (12/2011)
0x003FFF7C - 0x003FFFBD
Checksum
6.6.1.4
C-Boot ROM PIE Vector Mismatch Handler
As explained in the Control Subsystem PIE Vector Address Validity Check section of the
System Control
and Interrupts
chapter, whenever the control subsystem detects that PIE Vector address of the current
interrupt vector fetch or current NMI vector fetch is corrupted the CPU program control will jump to location
0x003FFFBE and starts executing code at that location. As shown in the memory map and below table C-
BootROM has a branch instruction installed at this 32-bit location to handle the PIE Vector mismatch
event. This branch instruction branches to cbrom_pie_vect_mismatch_handler function. Please refer to
and
for more details on what this function does whenever it is executed.
Table 6-12. C-Boot ROM PIE Mismatch Handler
C-Boot ROM Address
Contents
0x003FFFBE – 0x003FFFBF
BF _cbrom_pie_vect_mismatch_handler, UNC
Note:
This function will be called when the control subsystem detects a mismatch for both normal vector
fetch and NMI vector fetch. The master subsystem will receive and NMI if the mismatch on the control
subsystem happens during an NMI vector fetch. M-Boot ROM handling of this NMI on the master
subsystem is explained in the M-Boot ROM chapter. The master subsystem will not receive any NMI if the
mismatch on the control subsystem is while doing a normal PIE interrupt vector fetch, in which case C-
Boot ROM sends an IPC message to the master subsystem as shown in
and
.