Philips Semiconductors
System Boot
PRELIMINARY SPECIFICATION
13-5
13.2.2
Initial DSPCPU Program Load for
Autonomous Bootstrap
In a system where PNX1300 serves as the host CPU, the
system boot block performs an autonomous boot proce-
dure. For an autonomous boot, the system boot block
reads all the information described in
Section 13.2.1,
“
Boot Procedure Common to Both Autonomous and
Host-Assisted Bootstrap,
”
and then
—
because the au-
tonomous boot bit is set
—
continues reading information
from the EEPROM. After this part of the system boot pro-
cedure is done, the DSPCPU starts executing. See
Table 13-4
.
The DSPCPU bootstrap program byte count encodes the
number of bytes of DSPCPU program code contained in
the EEPROM(s). This 11-bit unsigned byte count can en-
code up to 2048 bytes, which is also the maximum
amount of EEPROM storage supported. The actual
amount of EEPROM available for the DSPCPU boot-
strap program is limited to 2000 bytes. Other information
consumes 47 bytes, and the DSPCPU code must be an
integral number of 32-bit words.
Four pairs of 32-bit MMIO-register addresses and values
follow the bootstrap program byte count. Each address
tells the boot block where in the 32-bit DSPCPU address
space to store the corresponding 32-bit value.
The first pair initializes the MMIO_BASE. The
MMIO_BASE sets the base address of the 2-MB MMIO-
register address aperture within the DSPCPU 32-bit ad-
dress space. All MMIO registers are addressed using an
offset that is relative to the value of MMIO_BASE. For
this pair, the address is required to be 0xEFF00400 be-
cause that is the default MMIO_BASE enforced when
PNX1300 is reset. The new value for MMIO_BASE is en-
coded in the corresponding value.
The DRAM_BASE address/value pair determine the
base address of the SDRAM address aperture within the
32-bit DSPCPU address space. The address must be
equal to 0x100000 plus the new value of MMIO_BASE
set previously in the boot procedure. The DRAM_BASE
value must be naturally aligned given the rounded DRAM
aperture size, i.e. a 6 MB DRAM aperture should start on
a 8 MB address multiple.
The DRAM_LIMIT address/value pair determine the ex-
tent of the SDRAM address aperture. The address must
be equal to 0x100004 plus the new value of
MMIO_BASE set previously in the boot procedure. The
value in DRAM_LIMIT should be 1 higher than the ad-
dress of the last valid byte of SDRAM memory, and must
be a 64 KB multiple.
The DRAM_CACHEABLE_LIMIT address/value pair de-
termine the extent of the cacheable aperture of the
SDRAM address space. The address must be equal to
0x100008 plus the value of MMIO_BASE set previously
in the boot procedure. The cacheable aperture always
begins at the address value in DRAM_BASE; the value
in DRAM_CACHEABLE_LIMIT is one higher than the
address of the last byte of cacheable SDRAM memory,
and must be a 64 KB multiple. It is safe to initially set the
value
of
DRAM_CACHEABLE_LIMIT
equal
to
DRAM_LIMIT. The RTOS can, if desired, change the val-
ue later.
The next 32-bit value in boot EEPROM memory is a copy
of the DRAM_BASE value encoded previously. The sys-
tem boot hardware loads the DSPCPU bootstrap pro-
gram into SDRAM starting at DRAM_BASE.
The bytes of the DSPCPU bootstrap program follow the
copy of the SDRAM_BASE value. The bootstrap pro-
Table 13-4. Information Loaded During Second Part
of Bootstrapping Procedure for Autonomous Boot
Information
Size
Interpretation
DSPCPU bootstrap pro-
gram byte count
n
11 bits
up to 500 32-bit words
(2048 bytes less 47 header
bytes)
Value must be
0xEFF00400
Value is simply written to
0xEFF00400 to determine
new base address of 2-MB
MMIO register aperture
within 32-bit DSPCPU
address space
MMIO_BASE + 0x100000
Value is simply written to
DRAM_BASE to determine
base address of SDRAM
aperture within 32-bit
DSPCPU address space
MMIO_BASE + 0x100004
MMIO_BASE address
32 bits
MMIO_BASE value
32 bits
DRAM_BASE address
DRAM_BASE value
32 bits
32-
bits
DRAM_LIMIT address
32-
bits
32-
bits
DRAM_LIMIT value
Value is simply written to
DRAM_LIMIT to deter-
mine limit address of
SDRAM aperture within
32-bit DSPCPU address
space
MMIO_BASE + 0x100008
DRAM_CACHEABLE_
LIMIT address
DRAM_CACHEABLE_
LIMIT value
32-
bits
32-
bits
Value is simply written to
DRAM_CACHEABLE_LIM
IT to determine limit
address of cacheable part
of SDRAM aperture within
32-bit DSPCPU address
space
Copy of the DRAM_BASE;
must be equal to value
specified above
First 32-bit word of initial
DSPCPU bootstrap pro-
gram
Second 32-bit word of ini-
tial DSPCPU bootstrap
program
.
.
.
Last 32-bit word of initial
DSPCPU bootstrap pro-
gram
DRAM_BASE value
32-
bits
SDRAM code word 0
32-
bits
SDRAM code word 1
32-
bits
.
.
.
.
.
.
SDRAM code word
n
/4
32 bits