
Chapter 3 Assembly Language Programming
191
additional Reset mode conditions established, such as disabling cache memory
where appropriate.
Instruction execution begins at address 0. For processors supporting both
Instruction memory space and read–only memory (ROM) space, ROM space is used
when fetching instructions from external memory. However, many Am29000 pro-
cessor systems apply no distinction when decoding instruction and ROM memory
space.
The programmer must establish control of the processor and available re-
sources. Section 7.4 discusses how this is achieved with the OS–boot operating sys-
tem. OS–boot is made available by AMD, and is used to implement a single–task
application environment which supports HIF (see Chapter 2) system call services.
Because OS–boot is so freely available to the 29K community, it is convenient to use
the included processor start–up code sequence for any new designs.
3.9
ASSEMBLER SYNTAX
Assembly language, like all languages, has a character set and a set of grammar
rules. Purchasers of the ASM29K
assembly language tool package from AMD or
other tool company, normally obtain a copy of the assembly language syntax specifi-
cation. There are a number of assembler tools available and all of them comply (but
not always fully) with the AMD defined syntax for assembly level programming.
Many of the assemblers have options which are unique, but it has been my expe-
rience that assemblers will generally accept code which is produced by any of the
available compilers.
3.9.1 The AMD Assembler
The AMD assembly language tool package, ASM29K, was used to develop all
of the assembly language examples shown in this book. The assembler, linker and
librarian tools included in the package were developed by Microrec Research Inc.
(MRI) for AMD. The tools are available on a number of platforms; the most popular
being SUN and HP workstations and IBM PCs and compatibles. This section does
not cover the details of the AMD assembler (as29) and its options as they are well
documented in the literature supplied with each purchased tool package.
During the introduction of the Am29000 processor, AMD had a second assem-
bly level tool package developed by Information Processing Techniques Corp. (IPT).
This second tool chain forms the basis of a number of elaborate tool packages made
available by third party tool suppliers. All of the tool suppliers are listed in the AMD
Fusion29K
sm
Catalogue [AMD 1992a][AMD 1993b]. Both assemblers fully com-
ply with the AMD assembler syntax for 29K code. However, the librarian tools sup-
plied with the different tool packages maintain library code in different formats. This
means libraries cannot be shared unless reformatting is applied.