# MEMORY MANAGEMENT TECHNIQUES USING THE MC6829 Prepared by Charles Melear Microprocessor Applications Engineer and Ed Rupp MOS System Design Engineer Austin, Texas #### INTRODUCTION Eight-bit systems have been the work horse of the computer industry for a long time. This trend will continue because 8-bit systems are easy to build, small-sized, and economical. Most modern microprocessors have a 16-bit address range which limits their memory address range to 64 kilobytes. Many systems need additional memory and utilize inexpensive solid state memory (about 1/50 cent per bit) for mass storage. The access time required for large programs is virtually instantaneous when stored in solid state RAM as compared to the time required in fetching those programs from a disk or tape. The management of this memory is a major concern. Various techniques are used to allow an 8-bit processor to use these large memories. Basically, bank select and mapping RAM techniques can be used (see Figures 1 and 2). Bank select involves using an addressable latch to select one of several memory banks. That is, the outputs of the latch form part of the chip select circuitry. With the mapping RAM technique, various data can be written to sequential addresses which will correspond to the upper N bits of an expanded address. Usually the mapping RAM will contain a power of 2 words; i.e., 2, 4, 8, 16, 32, etc. The width of the memory is arbitrary. The required number of address lines from the MPU to address the mapping RAM are applied to it and the remaining address lines go to the system address bus. For instance, the upper three address lines of the MPU could address eight words of mapping RAM. The data output of the mapping RAM then forms the upper address bits. This is basically the technique used in the system presented in this application note. To understand the system, an explanation of all major components is needed. The building blocks of the system consist of the MC6809 microprocessor unit (MPU), MC6829 memory management unit (MMU), MC6850 asynchronous communications interface adapter (ACIA), MC6840 programmable timer module (PTM), MC6844 direct memory controller (DMAC), and MC6854 advanced data link controller (ADLC). Each of these parts will be discussed here in order to outline their function in the total system under consideration. The function of the system is to act as a satellite processing station to be down loaded from a host computer with programs and data. The local operator can invoke these programs and digest data as the need arises. ## SYSTEM CONFIGURATION The MPU used in the system is an MC6809. With the aid of an MC6829 memory management unit, the memory capability of this system is increased to a maximum of 2 megabytes. One MC6829 MMU can be programmed to address any given 256 kilobytes of the 2 megabytes (the same MMU can be reprogrammed to address a different 256 kilobytes). An MC6850 asynchronous communications interface adapter (ACIA) provides communications to a local terminal. To enable rapid data transfer via a serial link to the main computer, a synchronous data link control (SDLC) protocol network is employed using the MC6854 advanced data link controller (ADLC). Only minimal ROM is needed to operate the system since application programs reside in RAM. The major function of the resident software is to FIGURE 1 - Bank Select Technique FIGURE 2 - Mapping RAM Technique allow the local operator to control the system and to maintain control of, and assign memory to, the various tasks as needed. The system block diagram of Figure 3 illustrates the placement of peripheral devices and buffers. See Figure 4 for a complete schematic diagram. Except for the MMU and DMAC, the address bus is applied to the rest of the system via 74LS244 buffers. The DMAC must appear exactly like the MPU to the entire system; therefore, the MPU and DMAC address buses are connected directly together on the input side of the address bus buffers. The MPU address bus is also connected directly to the MMU input address lines. The DMAC address bus could be applied to the output side of the address buffers; however, extra logic would be required to place the 74LS244 buffers in the high-impedance state whenever the DMAC is active. Since the MC6809 MPU can interface directly with the MC6844 DMAC, it is best to connect their address pins together. This allows the DMAC addresses to be mapped the same as the MPU address. The chip select signal for the DMAC, as well as all other peripherals, is generated from the entire 21-bit address bus. At first it might appear that the DMAC chip select should be generated only from A0-A15 since this part directly feeds the MPU address bus. This is definitely not the case, as it would allow the DMAC to have a valid chip select signal in every one of the tasks handled by the MC6829 MMU. In the example of Figure 3, the MC6854 ADLC drives the data bus during a DMA transfer. The read/write line for the ADLC is inverted during DMA and this places the ADLC data bus drivers in conflict with the 74LS245 data bus buffer; i.e., both devices would be driving the data bus. The problem is solved by disabling the 74LS245 data bus buffer during a DMA transfer. This can be accomplished by using Tx STB of the DMAC to act as a disable signal for the 74LS245. During a read of any MMU register, a conflict with the 74LS245 will again occur; therefore, the chip select signal for the MMUs must be used to disable the data bus drivers just as Tx STB was used when the ADLC was in the DMA mode. In general, data bus drivers must always be disabled when a peripheral device is connected to the MPU in parallel with the data bus buffer. Two problems associated with random garbage accesses to memory must be solved. The first has to do with the timing of the $R/\overline{W}$ line with respect to the address lines. The second problem is associated with the dead cycles which precede and follow DMA cycles. The mode 1 timing (TSC steal mode) in Figure 5 shows that the internal MPU E clock is stretched during these dead cycle times. The MC6809 automatically places its address bus in the high-impedance state in response to a low bus request $(\overline{DMA}/\overline{BREQ})$ . The DMAC comes out of or goes into the high-impedance state whenever the MPU does the opposite. During these dead cycles, neither device FIGURE 3 — MC6809 MPU System With Memory Management, Block Diagram has control of the bus; therefore, it is possible for the address bus to float and possibly provide a valid chip select signal to some system device. If this happens, the affected memory location will be written with whatever random information is appearing on the data bus at that time. This problem can be eliminated by generating a DMAVMA signal using the circuit shown in Figure 6. The output of an exclusive OR gate (SN74LS86) is low while the inputs to it are alike and high when they differ. The MC6809 BA and BS outputs go high during the first dead cycle (generate DGRNT) and return low during the second dead cycle. The DMAVMA signal goes high during the dead cycle as shown in Figure 7 and can be used as a memory deselect. Both BA and BS are asserted during the first dead cycle; however, the resulting DGRNT output (see Figure 4) is not clocked through the 74LS74 flip-flop until the next negative transition of E. For this cycle the output of the exclusive OR gate is high and provides a memory deselect. Thus, during the time shown as dead in Figure 5, the system cannot be enabled and memories and peripherals are protected during exchange of bus control. Both BA and BS are released in the dead cycle immediately following the DMA transfer; therefore, the inputs to the exclusive OR gate do not match and the output goes high. Thus, while there is is no active bus master (dead cycle), the memory cannot be inadvertently accessed. FIGURE 4 — System Schematic Diagram FIGURE 5 — Mode 1 Timing (TSC Steal Mode) As previously mentioned, the timing of the $R/\overline{W}$ line can cause a problem if a peripheral or memory becomes selected and $R/\overline{W}$ is recognized as a write before all address lines become stable. This problem arises in devices, such a memories, that do not use the enable signal. By gating $R/\overline{W}$ with E or Q of the MC6809 MPU, $R/\overline{W}$ cannot go low until after the address lines have become stable. The circuit in Figure 8 shows a simple circuit to accomplish the proper conditioning of $R/\overline{W}$ . The timing for the read/write delay circuit is shown in Figure 9. This problem does not always occur since it depends upon the individual characteristics of each MPU; however, at some point it may destroy the memory of certain systems in a random fashion if the conditioning circuit shown in Figure 8 is not used. New interrupts must be delayed if they occur during an interrupt stacking operation for the current interrupt. Refer to the Interrupt Handling paragraph for more interrupt information. As shown in the system schematic diagram (Figure 4), FIRQ and IRQ are logical ORed with the BA line from the processor. This guarantees that the first instruction of every interrupt routine will be executed. That instruction can mask further interrupts. The NMI input to the MPU is not handled in this way and its use in an MMU system for memory management is not advised. There are two monitor programs used in this system. The first is ASSIST09, a debug program, which makes use of NMI when doing single step traces through various programs. Its use is limited to task 0 only and it will not function in any other task because of its extensive use of SWI. The other monitor is CONST which helps program and use the memory management units in this system. The use of CONST is also restricted to task 0; however, this is a function of the software interrupts. This program is called by SWI, thus a task switch is required to enter it. In addition, an initialization program (MMUINIT) allows the MMU to be initialized. The ASSIST09 source code is available in the MC6809-MC6809E Micorprocessor Programming Manual, MC6809PM(AD). The source code for CONST and MMUINIT is included at the end of this application note. Synchronous communications are implemented using the MC6854 advanced data link controller (ADLC). A block diagram of the ADLC is shown in Figure 10. The ADLC is a full duplex communications device which is compatible with IBM SDLC format. The transmit and receive baud rates do not necessarily have to be equal. Modem interface pins are provided although they are not used in this example. In addition to the processor interface pins, there are two DMA service request outputs associated with the transmit FIGURE 6 - DMAVMA Generation Circuit FIGURE 7 - MC6809 Bus Timing During MPU-DMA-MPU Bus Control Transfer and receive channels, respectively. When enabled, these pins will drive the TxRQ pins of the DMAC. The TDSR (transmit data service request) will be asserted when the transmit data FIFO is empty. The RDSR (receive data service request) is asserted when data is ready to be read from the receive data FIFO. The transmission format for SDLC is shown in Figure 11. Every message begins with an opening flag of 01111110. The FIGURE 8 - R/W Conditioning Circuit, Gated By E FIGURE 9 — R/W Conditioning Circuit Gated By E, Timing Diagram next byte is an 8-bit address field and it may be extended in 8-bit increments. The control field follows the address field and is normally eight bits, but it may also be extended in 8-bit increments. The information field can be of any length and contains the data which is to be transmitted. The ADLC automatically calculates and appends a cyclic redundancy check character (CRCC). The polynomial used is $x^{16} + x^{12} + x^5 + 1$ . A closing flag (01111110) is appended after the frame check sequence field. The ADLC contains two read-only status registers, four write-only control registers, a receive data register, a transmit data register, and a transmit last data register. See Table 1 for an internal register structure and Table 2 for a register addressing map. The ADLC functions similar to other serial transmission devices. A receive data available bit and a transmit data register empty bit are monitored. The receive data register is read or the transmit data register is written when the respective bits are asserted. Unlike the MC6850 ACIA, the transmit shift register must always be kept full. The transmit FIFO must be written at a sufficient rate to insure that a transmitter underflow never occurs. Likewise, the receive data register must be read often enough so that a receive overrun does not occur. The application of SDLC protocol and the MC6854 is considerably more complex than the explanation presented here; however, the basic ideas apply. The main purpose of the ADLC in this application note is to demonstrate a peripheral device using a DMAC in an MC6809-MC6829 system. The MC6844 direct memory access controller (DMAC) performs the function of transferring data directly between memory and peripheral device controllers (See Figure 12 for block diagram). It accomplishes this transfer by supplying a bus address (instead of being supplied by the MPU) and controlling the data bus such that a memory or peripheral device drives the data bus. Only consecutive-memory-locations-to-peripheral or peripheral-to-consecutive-memory-locations transfers can be handled. The transferred data does not go through the DMA controller. There are four independent channels, all of which can operate in any of three modes; i.e., TSC steal, halt-steal, and halt-burst. The timing diagrams for these three modes are presented in Figures 13, 14, and 15. To fully understand a typical transfer, a study of the internal DMAC registers, shown in Tables 3 and 4, must be made. For each channel, the starting address for the transfer and the number of bytes to be sent are loaded into the respective address high/low and byte count high/low registers. A control register is associated with each channel to specify the transfer mode, the direction of the data transfer, and if the data is to be accessed in ascending or descending order. The priority control register is used to enable transfer requests (TxRQ 0-3). It also causes the channels to rotate in priority (channel 0, then 1, and 2, . . .) or have a fixed priority (channel 0 is highest and channel 3 is lowest). The interrupt control register is used to enable the IRO/DEND signal for each individual channel. A data chain enable register allows the address and byte count registers, for either channel 0, 1, or 2, to be loaded with the contents of the channel 3 register when the chained channel byte count register is decremented to \$0000. The data chain register also selects either two or four channels to be active. A typical sequence for data transfer for the TSC steal mode (see Figure 13) begins with a peripheral device asserting its DMA service request which would be connected to a Tx-RQ (transfer request) input to the MC6844 DMAC. The high TxRQ input will be recognized within one E clock cycle. The DRQ1 output of the DMAC is connected to bus request (DMA/BREQ) of an MC6809 and it will be asserted during the cycle in which TxRQ is recognized; see Figure 4. The DMAC activates its address bus during the following cycle while the MPU places its bus in the high-impedance state and issues a bus grant to the DGRNT pin of the DMAC. This cycle is known as a dead cycle. Following the dead cycle is a DMA transfer cycle. During this cycle, the DMAC outputs the address for the data (to be written or read), asserts the proper state on the read/write line, and asserts transfer strobe (TxSTB). The transfer strobe acts similar to a chip FIGURE 10 - MC6854 ADLC Block Diagram FIGURE 11 — Data Format of a Frame TABLE 1 — ADLC Internal Register Structure | | | RS1 RS0 = 00 | RS1 RS0 = 01 | RS1 RS0 = 10 | RS1 RS0 = 11 | |-----------|-------|---------------------------------|-------------------------------|---------------------------|-----------------------| | 1 | Bit # | Status Register #1 | Status Register #2 | Receiver Data<br>Register | | | | 0 | RDA | Address Present | Bit 0 | | | Registers | 1 | Status #2<br>Read Request | Frame Valid | Bit 1 | | | | 2 | Loop | Inactive Idle Received | Bit 2 | | | d Only | 3 | Flag Detected<br>(When Enabled) | Abort Received | Bit 3 | Same as RS1, RS0 = 10 | | Read | 4 | CTS | FCS Error | Bit 4 | | | <u> </u> | 5 | Tx Underrun | DCD | Bit 5 | | | | 6 | TDRA/Frame<br>Complete | Rx Overrun | Bit 6 | | | | 7 | IRQ Present | RDA (Receiver Data Available) | Bit 7 | | | | | | | | Transmitter<br>Data | Transmitter<br>Data | | |----------------------|-------|---------------------------------------|---------------------------------------------------------|------------------------------------|---------------------|----------------------------------------------------|------------------------------------------------------------| | | Bit # | Control Register #1 | Control Register #2 (C <sub>1</sub> b <sub>0</sub> = 0) | Control Register #3 $(C_1b_0 = 1)$ | (Continue Data) | (Last Data)<br>(C <sub>1</sub> b <sub>0</sub> = 0) | Control Register #4<br>(C <sub>1</sub> b <sub>0</sub> = 1) | | | 0 | Address Control (AC) | Prioritized Status<br>Enable | Logical Control<br>Field Select | Bit 0 | Bit 0 | Double Flag/Single<br>Flag Interframe Control | | sters | 1 | Receiver Interrupt<br>Enable (RIE) | 2 Byte/1 Byte<br>Transfer | Extended Control<br>Fixed Select | Bit 1 | Bit 1 | Word Length Select<br>Transmit #1 | | Write Only Registers | 2 | Transmitter Interrupt<br>Enable (TIE) | Flag/Mark Idle | Auto, Address<br>Extension Mode | Bit 2 | Bit 2 | Word Length Select<br>Transmit #2 | | ite Onl | 3 | RDSR Mode (DMA) | Frame Complete/<br>TDRA Select | 01/11 Idle | Bit 3 | Bit 3 | Word Length Select<br>Receive #1 | | × | 4 | TDSR Mode (DMA) | Transmit Last Data | Flag Detected<br>Status Enable | Bit 4 | Bit 4 | Word Length Select<br>Receive #2 | | | 5 | Rx Frame<br>Discontinue | CLR Rx Status | Loop/Non-Loop<br>Mode | Bit 5 | Bit 5 | Transmit Abort | | | 6 | Rx RESET | CLR Tx Status | Go Active on Poll/Test | Bit 6 | Bit 6 | Abort Extend | | | 7 | Tx RESET | RTS Control | Loop On-Line<br>Control DTR | Bit 7 | Bit 7 | NRZI/NRZ | TABLE 2 — Register Addressing | Register Selected | R/W | RS1 | RS0 | Address<br>Control Bit<br>(C <sub>1</sub> b0) | |---------------------------------------|-----|-----|-----|-----------------------------------------------| | Write Control Register #1 | 0 | 0 | 0 | X | | Write Control Register #2 | 0 | 0 | 1 | 0 | | Write Control Register #3 | 0 | 0 | 1 | 1 | | Write Transmit FIFO (Frame Contine) | 0 | 1 | 0 | X | | Write Transmit FIFO (Frame Terminate) | 0 | 1 | 1 | 0 | | Write Control Register #4 | 0 | 1 | 1 | 1 | | Read Status Register #1 | 1 | 0 | 0 | X | | Read Status Register #2 | 1 | 0 | 1 | X | | Read Receiver FIFO | 1 | 1 | Х | X | select signal to the peripheral device which is supplying/receiving the data. Following the DMA transfer cycle is a dead cycle which allows the MPU to regain the address bus and the DMAC returns its bus to the high-impedance state. The halt steal mode is very similar to the TSC steal mode (refer to Figure 14). In this case, $\overline{DRQ2}$ , which drives the $\overline{HALT}$ pin of the MPU, is asserted in response to TxRQ. When the current instruction has finished execution, a dead cycle occurs and the processor issues a bus grant (DGRNT). The TxRQ signal must remain valid until after the falling edge of E of the cycle preceding the DMA transfer cycle. A DMA cycle and second dead cycle follow. The $\overline{DRQ2}$ line is released during the DMA cycle. The halt burst mode is identical to halt steal with one major exception (refer to Figure 15). The $\overline{DRQ2}$ output (driving $\overline{HALT}$ of the MPU) is not released until the byte count has been decremented to \$0000, indicating that all transfers have taken place. As shown in Figure 15, the TxRQ FIGURE 12 - DMAC Block Diagram | Register | Address | | | | Register | Content | | | | |----------------------|---------|---------------------------|--------------------|----------|----------|-------------------------------------|-----------------------------------|-----------------------------------|---------------------------------| | negistei | (Hex) | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | Channel<br>Control | 1x* | DMA End<br>Flag<br>(DEND) | Busy/Ready<br>Flag | Not Used | Not Used | Address<br>Up/Down | МСА | МСВ | Read/Write<br>(R/W) | | Priority<br>Control | 14 | Rotate<br>Control | Not Used | Not Used | Not Used | Request<br>Enable #3<br>(RE3) | Request<br>Enable #2<br>(RE2) | Request<br>Enable #1<br>(RE1) | Request<br>Enable #0<br>(RE0) | | Interrupt<br>Control | 15 | DEND<br>IRQ<br>Flag | Not Used | Not Used | Not Used | DEND IRQ<br>Enable #3<br>(DIE3) | DEND IRQ<br>Enable #2<br>' (DIE2) | DEND IRQ<br>Enable #1<br>(DIE1) | DEND IRQ<br>Enable #0<br>(DIE0) | | Data Chain | 16 | Not Used | Not Used | Not Used | Not Used | Two/Four<br>Channel<br>Select (2/4) | Data Chain<br>Channel<br>Select B | Data Chain<br>Channel<br>Select A | Data Chain<br>Enable | <sup>\*</sup>The x represents the binary equivalent of the channel desired. TABLE 4 — Address and Byte Count Registers | Register | Channel | Address<br>(Hex) | |-----------------|---------|------------------| | Address High | 0 | 0 | | Address Low | 0 | 1 | | Byte Count High | 0 | 2 | | Byte Count Low | 0 | 3 | | Address High | 1 | 4 | | Address Low | 1 | 5 | | Byte Count High | 1 | 6 | | Byte Count Low | 1 | 7 | | Address High | 2 | 8 | | Address Low | 2 | 9 | | Byte Count High | 2 | А | | Byte Count Low | 2 | В | | Address High | 3 | С | | Address Low | 3 | D | | Byte Count High | 3 | E | | Byte Count Low | 3 | F | line is sampled on the following edge of E for each DMA cycle. If TxRQ is high, a transfer takes place; if low, a dummy cycle occurs. The byte count and address registers are not affected by a dummy cycle. Remember, once a halt burst mode has begun, the MPU cannot regain control of the bus until the entire transfer has taken place. This problem can be circumvented by removing DGRNT from the DMAC (thus HALT from the MPU) with external circuitry, then writing the byte count register of the active channel to \$0000. Asynchronous communications to a local terminal are provided by the MC6850 asynchronous communications interface adapter (ACIA). See Figure 16 for block diagram. This device can be operated in full duplex at speeds up to one megabit per second. Four registers are provided: a transmit data register, a receive data register, a control register, and a status register. The definition of the ACIA register contents is presented in Table 5. In order to activate the communications link via the ACIA, the control register must be configured. From a power fail/restore or a power-on condition, the ACIA should be placed in a master reset condition. This is done by writing the lower two bits of the control register (CR0-CR1) to 1s, as shown in Table 6. A master reset clears the status register except for data carrier detect ( $\overline{DCD}$ ) or clear to send ( $\overline{CTS}$ ); however, it does not affect any control register bit. In addition to providing master reset, control register bits CR0 to CR1 are also used to select the clock divide ratio for both the transmitter and receiver sections (also shown in Table 6). Three bits are used as word select bits (CR2, CR3, and CR4) and the configuration of these bits select word length, parity, and number of stop bits. The encoding format is as shown in Table 7. Two transmitter control bits (CR5 and CR6) provide for the control of the interrupt from a transmit data register empty condition, the request-to-send (RTS) output, and the transmission of a break level. The encoding format and controlled function are as shown in Table 8. The remaining bit, CR7, is the receive interrupt enable. It allows interrupts caused by the following conditions to be reflected at the IRQ output: receive data register full, receiver overrun, or a positive transition on the data carrier detect (DCD) signal line. The status register bits provide information on the status of the ACIA; i.e., the conditions present. The bits of the status register are shown in Table 5. The overall functioning of the MC6850 ACIA can be understood by an examination of the block diagram shown in Figure 16 together with the registers shown in Table 5. The control register is loaded with the appropriate information to configure the device. When ready to transmit data, the status register is checked to see that the $\overline{\text{CTS}}$ input is low and the transmit data register is empty. Once both of these conditions are met, a data byte can be written to the ACIA transmit data register. Incoming data will then set the receive data register full (RDRF) flag in the status register. Upon polling the status register and finding the RDRF bit set, the data carrier detect ( $\overline{\text{DCD}}$ ), framing error (FE), receiver overrun (OVRN), and parity error (PE) bits should be examined. If no errors are found, the receive data can be read from the receive data register. Memory expansion to 2 megabytes is made possible by use of the MC6829 memory management unit (MMU). The MMU allows the system to address 32 blocks of memory in 2 kilobyte increments for a total of 64 kilobytes. These blocks are not required to be in any certain order or to be contiguous. Different sections of memory can be accessed by FIGURE 13 — Mode 1 Timing (TSC Steal Mode) reprogramming the MMU. Each MMU is capable of mapping four tasks and each task allows the addressing of 32 2-kilobyte blocks of memory. Only one task at a time may be active. Provisions are made so that eight MMUs can be used in a system. Only one 64-kilobyte task can be active at a given time. To switch to different memory, the MMU must be reprogrammed or a different task must be used. To explain the functional aspects of the MC6829 MMU, a register mode 1 is shown in Figure 17 and a logical-to-physical address translation diagram is shown in Figure 18. In each task, 30 10-bit registers are used for address translation. The upper five address lines from the MPU select a register and the contents of this register are gated onto the physical address bus. A particular task is activated by programming the task number to the appropriate register of the MMU. Figure 17 illustrates the the MMU functions as a memory mapping RAM. To program the MC6829 MMU, a thorough explanation of the internal registers is needed. See Figure 19 for a block diagram of registers. There are 32 pairs of registers associated with a task. Examination of the MMU register model in Figure 18 shows that these registers are arranged alternately as a 2-bit register and then an 8-bit register. When programming these registers, the register select lines (RS0- RS6) are used. Figure 20 provides pin assignment details. Thus, to program all of the mapping registers 64 8-bit accesses to the MMU are required. When the MMU has been fully programmed and is in operation, these register pairs are selected by A11-A15. That is, a particular combination of inputs on A11-A15 will cause the contents of a register pair to be applied to the physical address bus. Locations \$40-\$47 address the same register on the MMU; i.e., only one register exists and it responds to any of these eight addresses. The key value register is at this address. Each MMU must have a unique value in this 3-bit register since it determines which MMU in a system will be active. The S bit at location \$48 is the system/user bit. The S bit is set to a 1 by a reset or any interrupt including software interrupts. It is cleared by writing a value to the fuse register and allowing the fuse register to decrement to 0. Only when the S bit is set can the internal MMU registers be modified. Also, the system will be automatically placed in task 0 as long as the S bit is set, regardless of any other register values. The mapping registers for task 0 will be active even when the S bit is set. The MMUs are internally decoded to appear at A11-A15=1 and $\overline{RA}=0$ . At this address, the internal registers can be accessed as per the register map in Figure 18. In task 0, whether the S bit is set or not, the mapping FIGURE 14 — Mode 2 Timing (Halt-Steal Mode) registers function normally with one exception. When an MMU register is accessed, the physical address bus (PA10-PA20) is driven to all 1s if S = 1. The access key allows the MPU to address the internal registers of the MMU. The upper three bits of this 5-bit register must match the key value register and the S bit must be set before the MMU register can be changed or examined. The lower two bits of the access key select the particular task to be modified. The operate key register is active only when the S bit is not set and a DMA transfer is not occurring. This assumes that the MMU has been initialized by programming the appropriate registers and initializing the key value register. The upper three bits of the 5-bit operate key register of an MMU must match the key value register to select a particular MMU; otherwise, the physical address bus will be in the high-impedence state. The lower two bits are used to choose the task to be used. The fuse register is used to determine the exact timing of a task switch. A task switch is always to or from task 0 except for DMA. A number is loaded into the fuse register, and when the fuse register is decremented to zero the MMU automatically switches to the task called for by the operate key. On each successive valid (non-DMA) processor cycle, the fuse register is decremented by one. Consider the programming example shown in Figure 21. A jump instruction takes 4 cycles to execute. On the 4th cycle after the jump opcode has been fetched, the fuse register will have been decremented to zero and the program counter will output the destination address of the jump. The next opcode fetch which occurs will be from task N. It is possible to jump to task 0 from task 0. This allows the system to use task 0 like any other task. By jumping to task 0 via the fuse register, the system will not be able to change the internal MMU registers until after an interrupt occurs. # INITIALIZATION OF THE MEMORY MANAGEMENT UNIT Once the MC6809-MC6829 system is built it must be initialized. However, it is important to understand the state of the system when RESET is released. This includes: An internal MMU reset flag remains set — This causes all of the physical address lines to be driven high (logical 1, not high-impedance state). This flag does not appear in any register and is cleared by writing to the key value register. It is important to have the physical address lines driven to a known state so that a specific section of memory can always be used for the system FIGURE 15 - Mode 3 Timing (Halt-Burst Mode) TABLE 5 - Definition of ACIA Register Contents | | Buffer Address | | | | | | | | |-------------------------------|---------------------|--------------|------------------------------------------|----------------------------------------|--|--|--|--| | Data<br>Bus<br>Line<br>Number | RS ● R/W RS ● R/W | | RS • R/W Control Register (Write Only) | RS • R/W Status Register (Read Only) | | | | | | 0 | Data Bit 0* | Data Bit 0 | Counter Divide<br>Select 1 (CR0) | Receiver Data Register Full (RDRF) | | | | | | 1 | Data Bit 1 | Data Bit 1 | Counter Divide<br>Select 2 (CR1) | Transmit Data Register<br>Empty (TDRE) | | | | | | 2 | Data Bit 2 | Data Bit 2 | Word Select 1<br>(CR2) | Data Carrier Detect (DCD) | | | | | | 3 | Data Bit 3 | Data Bit 3 | Word Select 2<br>(CR3) | Clear to Send<br>(CTS) | | | | | | 4 | Data Bit 4 | Data Bit 4 | Word Select 3<br>(CR4) | Framing Error<br>(FE) | | | | | | 5 | Data Bit 5 | Data Bit 5 | Transmit Control 1<br>(CR5) | Receiver Overrun<br>(OVRN) | | | | | | 6 | Data Bit 6 | Data Bit 6 | Transmit Control 2<br>(CR6) | Parity Error<br>(PE) | | | | | | 7 | Data Bit 7*** | Data Bit 7** | Receive Interrupt<br>Enable (CR7) | Interrupt Request<br>(IRQ) | | | | | <sup>\*</sup>Leading bit = LSB = Bit 0 initialization. In the first two cycles after RESET is released, the restart vectors are fetched. At this time, the MMU mapping registers are not used; however, by having PA20-PA11 driven high, the restart vector will always come from \$1FFFFE-\$1FFFFF. - 2. The fuse register is disabled A write to this register will have no effect until the key value register is written and the upper three bits of the operate key register and the key value register are equal. - 3. The system state bit (S bit) is set This bit must be set to access any MMU register. It is cleared when the fuse register is written and then decremented to zero which means task 0 is being exited. In order to set the S bit, the BA and BS lines must be 0 and 1, respectively. This occurs when the processor responds to RESET, NMI, FIRQ, TRQ, SWI, SWI2, or SWI3. If the system is operating with the S bit clear and the program needs to change an MMU register, the program must execute a software interrupt or cause some external device to input a hardware interrupt. - 4. The operate key register and access key register are both cleared Even though contents of these two registers will match the key value register, the internal flag still causes the physical address lines to be high. Not until a byte is written to the key value register will the mapping registers be used for address generation. - 5. The key value register is also cleared after reset This register must be written to clear the internal reset bit. This is true even if \$00 is to be written to the key value register. To initialize a system from reset, the key value register of MMUs 1-7 must be written. Figure 22 is an example of eight MMUs in a single system. For convience, MMU1 will have \$01 written to its key value register, MMU2 will have \$02, . . ., and MMU7 will have \$07. This causes their physical address buses to assume a high-impedance condition. The program must be careful not to write the key value register of MMU0 until enough of its mapping registers, in task 0, have been programmed to define the address space. By not writing to the key value register of MMU0, the MPU will stay in the range of \$1FF800-\$1FFFFF. Remember the physical address lines remain high until the key value register is written in MMU0 clearing its internal reset bit. With the mapping registers of MMU0 task 0 programmed, its (MMU0) key value register may be written. The MC6809-MC6829 system is now using the mapping registers of MMU0, task 0 to generate physical addresses. The following conditions exist: - The mapping registers (32 mapping registers per task, 4 tasks per MMU, 8 MMUs per system) have been programmed to the desired values. - 2. The system state bit (S bit) is set in all MMUs. - 3. All internal reset bits are clear. This is a mandatory condition to use the mapping registers. - Each of the MMU key value registers contains a unique 3-bit value. (Writing the key value register clears the internal reset bit.) - 5. The access key and operate key registers are the same for all MMUs. - 6. The fuse register in all MMUs are enabled. - 7. The system is operating in task 0, MMU0. Now consider the following program (see Figure 23). The microprocessor stores the A register to the key value register of MMU0. The lower 11 address lines of the microprocessor drives the physical memory directly. As the microprocessor program counter steps from \$F850 through \$F852, the 10 physical address lines are high. This means the 21-bit physical address (A0-A10 of the MPU and PA11-PA20 of the MMU) is \$1FF850 through \$1FF852. As soon as the key value register is written (physical address \$1FF852), the mapping <sup>\*\*</sup>Data bit will be zero in 7-bit plus parity modes. <sup>\*\*\*</sup>Data bit is "don't care" in 7-bit plus parity modes. FIGURE 16 - ACIA Block Diagram TABLE 6 — Counter Divide Select Bits (CR0-CR1) | CR1 | CR0 | Function | |-----|-----|--------------| | 0 | 0 | ÷ 1 | | 0 | 1 | ÷ 16 | | 1 | 0 | ÷ 64 | | 1 | 1 | Master Reset | TABLE 7 — Word Select Bits (CR2, CR3, and CR4) | CR4 | CR3 | CR2 | Function | |-----|-----|-----|------------------------------------| | 0 | 0 | 0 | 7 Bits + Even Parity + 2 Stop Bits | | 0 | 0 | 1 | 7 Bits + Odd Parity + 2 Stop Bits | | 0 | 1 | 0 | 7 Bits + Even Parity + 1 Stop Bit | | 0 | 1 | 1 | 7 Bits + Odd Parity + 1 Stop Bit | | 1 | 0 | 0 | 8 Bits+2 Stop Bits | | 1 | 0 | 1 | 8 Bits+1 Stop Bit | | 1 | 1 | 0 | 8 Bits + Even Parity + 1 Stop Bit | | 1 | 1 | 1 | 8 Bits + Odd Parity + 1 Stop Bit | TABLE 8 — Transmitter Control Bits (CR5 and CR6) | CR6 | CR5 | Function | |-----|-----|---------------------------------------------------| | 0 | 0 | RTS = Low, Transmitting Interrupt Disabled | | 0 | 1 | RTS = Low, Transmitting Interrupt Enabled | | 1 | 0 | RTS = High, Transmitting Interrupt Disabled | | 1 | 1 | RTS = Low, Transmit a Break level on the Transmit | | | | Data Output. Transmitting Interrupt Disabled | TABLE 9 — Condition Codes Bits Set by Interrupts | Interrupt | l Bit | F Bit | |-----------|-------|-------| | NMI | S | S | | FIRQ | S | S | | ĪRQ | S | * | | SWI | S | S | | SWI2 | * | * | | SWI3 | * | * | <sup>\*</sup>Indicates interrupt has no effect on this bit. FIGURE 17 - Logic-To-Physical Address Translation Diagram register becomes active; therefore, when the MPU program counter steps to \$F853, the 21-bit physical address is composed of PA20-PA11 of the mapping register selected by the upper five address lines of the MPU and A10-A0 of the MPU. In this example the upper five address lines of the MPU are all high, selecting the highest order mapping register. The operate key register still contains \$00 since it has never been written and, thus, its contents match the MMU0 key value register. The system is still in task 0 because of the S bit is set and the operate key register is not used. As a matter of convience and logical program flow, the high order mapping register should contain all 1s so that the next instruction following the write to the key value register (Figure 23) will be fetched from the next physical memory location; i.e., \$1FF853. This is by no means necessary; it is just convenient and will make system software easier to follow. An examination of the MMU registers show all needed mapping registers are programmed and each key value register contains a unique value. The S bit is set meaning that task 0 of MMU0 is being used. The access key register will contain the key value and task number of the last MMU in which the registers were modified. The operate key will contain the key value and task number that will be used when the program jumps from the operating system. It is absolutely essential to note that as long as the S bit is set, only task 0, of the MMU in which the key value register is \$00 can be used. Only a DMA transfer indicated by BA=1, BS=1 will override this condition. Then task 1 of MMU0 is used. To switch from task 0, the fuse register of all MMUs must be written. This is the only method that can be used to leave task 0 except for DMA cycles. The fuse register is loaded with the number of cycles which must occur after the write to the fuse register until task N is entered. The instruction following the write to the fuse register will generally be a branch, jump, or return from interrupt. The fuse register will be decremented on each successive valid (non-DMA) processor cycle. When the fuse register reaches zero, the system will be operating in task N. ### INTERRUPT HANDLING If an interrupt is received by the processor, it will switch automatically to task 0 as soon as the stacking operation is complete. The stacking operation interrupt timing for IRQ and NMI is presented in Figure 24 and is shown in Figure 25 for FIRQ. The stack pointer is not saved on the stack; therefore, it is the responsibility of the operating system in task 0 to retrieve and store the stack pointer from the task that was just exited. Normally this would be fairly straightforward. Special cases arise when one or more interrupts are recognized during the stacking operation for a current interrupt. For recognition of an additional interrupt to occur, the second interrupt must be valid beginning with cycle 16 of an NMI, IRQ, SWI, SWI2, or SWI3 stacking operation. Recognition must occur by cycle 7 of an FIRQ stacking operation. For NMI to be recognized, only a transition must be detected. Once the negative transition is recognized, the logic level on the NMI pin is no longer important. However, IRO and FIRO must remain at a logic 0 level for the three cycles immediately preceding cycle 16 or cycle 17 of the particular stacking operation or they will not be recognized. If another stacking operation begins before the stack pointer for the prior task has been stored, data in task 0 may be lost. This means that the program will not be able to find its way back to task N. A method must be found to hold off other interrupts until information can be stored which directs the processor back to task N. An understanding of the interrupts and how they work is needed to develop a simple system of allowing multiple interrupts. The interrupts set the I and F bits according to Table 9. If NMI occurs first, it will set both interrupt bits of the condition code register, masking further hardware interrupts. The only way for a software interrupt to occur before the stack pointer, from the prior task, could be saved, is for a software interrupt to be the first instruction of the NMI service routine. By causing the NMI service routine to immediately save the task N stack pointer, this problem will never be encountered in returning to task N. An $\overline{FIRQ}$ is the next highest priority hardware interrupt. If software interrupts are treated the same as with $\overline{NMI}$ , then SWIs will not be a problem. However, if $\overline{NMI}$ is recognized before the stack pointer is stored, that data will probably be lost. Since the $\overline{NMI}$ input is level sensitive, there is nothing that can be done to hold off an $\overline{NMI}$ once it occurs. This means that there is no way to absolutely guarantee that the - Unused bits of defined registers always read zeros. - 4. Locations \$40-\$47 are accessible only when $\overline{KVA} = 0$ . - In multiple MMU configurations, the MMU whose Key Value Register matches the upper three bits of the access key will respond to a processor read of locations \$48-\$4B. Processor writes to these registers will cause the data to be written to all MMUs simultaneously. FIGURE 18 - MMU Register Model return information can be saved if NMIs are allowed. An FIRO does set both interrupt bits. Thus it will automatically hold off an IRQ should it occur. An IRQ only sets the I bit of the condition code register. This does not allow it to automatically mask an $\overline{FIRQ}$ if it occurs. Since both an IRQ and FIRQ must remain valid for three cycles to be recognized, a hardware property of the MC6809 can be employed to hold off FIRQ. If an interrupt signal is ORed with BS before connection to the FIRQ input, then FIRQ will never be recognized during a stacking operation since FIRQ will be removed during cycles 17 and 18 of the stacking operation for $\overline{IRQ}$ . This will allow the $\overline{IRQ}$ service routine to execute at least one instruction. If that instruction sets the F bit in the condition code register, FIRQ will successfully be masked. The interrupt routine can enable interrupts when it has saved all necessary information. An SWI sets both the I and F bits. This keeps IRQ and FIRQ from preventing the return information from being lost. An NMI cannot be held off; therefore, the system should be designed such that NMIs occur only in response to system crashes or the like. Software interrupts SWI2 and SWI3 do not set either the I or F bits. This means that either IRO or FIRO can prevent the return information from being saved. By ORing IRQ and FIRQ with BS before applying them to their respective inputs on the MC6809, sufficient time will be allowed to mask off the I and F bits in the condition code register by SWI2 and SWI3. An NMI cannot be handled safely as in the case of all other interrupts. Once again, it must be emphasized that there is not a software method to disable NMI; therefore, its use, except for system crash recovery, should be discouraged. Generally speaking, NMI can be successfully handled while operating in task 0. This is because there is no task switch since the program is already in task 0. The stack pointer will remain valid as long as no task switch takes place. If hardware is built to disable NMI and if the system is FIGURE 19 - MC6829 MMU BLock Diagram in any task but task 0, then \overline{NMI} cannot be used to recover from system crashes. Designers must be cautioned again that \overline{NMI} should not be used for program control in systems using the MC6829 unless all possible avenues for the program to lose the return information have been explored and remedied. # TASK SWITCHING The operating system must eventually execute an RTI instruction to allow the processor to reload the MPU registers. The map switch must occur after the opcode for the RTI is fetched and before the first register is pulled from the stack. Prior to the RTI, the operating system must reload the saved stack pointer for the task about to run. There must be no interrupts from the time the stack pointer is reloaded until the RTI is executed. An interrupt here would cause the system to treat the task N stack pointer as the task 0 stack pointer. The signal to the MMU that the map should be returned to the user task is noted by a write to the fuse register. When a write to this register is detected, the value written is loaded into the counter and it begins to decrement by one for every non-DMA processor cycle. When the counter underflows (reaches zero), the S bit is cleared and the next processor cycle will be mapped using the task number in the operate key. For most systems, a 1 would be written to the fuse register immediately before the RTI opcode is executed. This delay allows enough time for the RTI opcode to be fetched (registers are not pulled from the stack until the third cycle of the RTI). Note that DMA operations are still possible within this critical section. The fuse register will count only non-DMA cycles after the write to the fuse register in order to be sure of when to switch the map. Bus dead cycles are also excluded when clocking the fuse register. Thus, the fuse register is inhibited from counting whenever BA is high and for the cycle after the BA high to low transition. The common exit point for all operating system functions is detailed in the programming example shown in Figure 26. The I and F bits of the condition code register are used to mask interrupts during the RTI (return from interrupt) instruction. When the operating system masks and unmasks these bits, no problem is encountered in properly restoring the MPU registers using an RTI instruction. Any time an interrupt occurs, the E bit of the condition code register will be properly set and then the MPU registers will be stacked in the current task. The last register stacked is the condition code register. The condition code register is the first one pulled from the stack upon return. The E and F bits are immediately examined to determine if a return from a fast interrupt is being executed or if the entire status needs to be FIGURE 20 — MC6829 MMU Pin Assignment | | Change from Task #0 to Task n | | | | | | | |-------------------|-------------------------------|-------|---------|---------|-------|--------|--| | LDA #n | | | | | | | | | STA OP | ERATE | | | | | | | | LDA #4 | | | | | | | | | STA FU | | | | | | | | | JMP \$X | XXX | | | | | | | | Cycle by<br>Cycle | Write #4<br>to Fuse | | Address | Address | | Task N | | | Operation | Register | JMP | High | Low | VMA | Opcode | | | | Negistei | JIVIF | 1 11911 | LOW | VIVIA | Opcode | | | Fuse Register | 0 | 4 | 3 | 2 | 1 | 0 | | | Contents | 1 | | | | | | | FIGURE 21 — Programming Example to Change from Task 0 FIGURE 22 - MMU System Configuration | F84E | LDA | 86 | #\$00 | | |------|---------|-----------|--------|----------------------------------------------------------------------------------------------------------------| | F850 | STA | B7 | \$F840 | Write MMU0 Key Value Register 1<br>PA11-PA20=1<br>Physical Address=\$1FF850 | | F853 | Next In | struction | | PA11-PA20 = Contents of Register<br>3F of MMU0, Task 0<br>Physical Address = \$1FF853<br>if 3F contains \$03FF | FIGURE 23 - Program for MMU0 and Key Value Initialization retrieved. This allows the MPU to pull the proper number of bytes from the stack. #### **PROGRAMMING** Each of the system MMUs must be initialized before the system can be utilized. Only the upper 2 kilobytes of memory are available until after the initialization is complete. The MMUINIT program first writes key values to MMUs 1 through 7, followed by programming the mapping registers of MMU0, task 0. The key value for MMU0 is then loaded. Table 10 contains a copy of the initial MMU memory map. After each MMU is initialized per Table 10, ASSIST09 is entered. The ASSIST09 monitor program is a useful monitor that allows tracing through programs in task 0 only (because it uses $\overline{\text{NMI}}$ ). Also, ASSIST09 contains routines PUNCH and LOAD. These two routines allow the writing and reading of programs contained on the audio cassette tapes. The system can be further configured using ASSIST09. Once the MMUs and peripheral devices are initialized, ASSIST09 would not generally be used except for interrupt vector processing. A complete listing of the MMUINIT (MC6829 MMU INITIALIZATION) program can be found at the back of this application note. The CONST program (MC6809-MC6829 MMU MONITOR PROGRAM) controls the use of the MMUs. It allows pages to be added and deleted from tasks, examination and change of memory, display of MPU registers, and display of MMU registers for the current task. This program forms the basis of an MMU operating system and a complete command summary is found at the back of this application note. #### **CONCLUSION** In future systems, memory management will become a topic of increasing importance. RAM densities are sure to increase into the 512 kilobit range in a relatively short time. This means just one RAM chip could fill the entire address space of the current 8-bit processor. Obviously, a system cannot function only from RAM as it would have no restart vectors or boot strap programs. If history repeats itself, the cost per bit in these RAMs will not appreciably increase over the cost per bit of smaller RAMs; this, of course, encourages their use. With the prospect of a single RAM or ROM chip filling an entire memory space, memory management not only becomes desirable but necessary. With the elements presented in this application note, everything is in place to begin large 8-bit MPU system design. FIGURE 24 — Stack Operation Timing for IRQ and NMI FIGURE 25 — Stack Operation Timing for FIRQ | EXIT | LDA<br>STA<br>STS<br>ORCC<br>LDS<br>LDA<br>STA<br>BTI | TASK OPFRAT OSSP #F+1 SAVESP #1 FUSF | GET NEXT TASK TO RUN AND PLACE IS IN THE OPERATE KEY SAVE CURRENT OS STACK POINTER SET F AND I (ENTER CRITICAL SECTION) RESTORE USERS STACK POINTER CAUSE MAP SWITCH 1 CYCLE AFTER WRITE TO FUSE REGISTER RETURN TO USER TASK | |------|-------------------------------------------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | • | MAP SWIT | TCH OCCURS, USER TASK RESUMES | FIGURE 26 — Exit Routine from Task 0 TABLE 10 — Initial MMU Memory Map | MMU | Doto | | Physical Address | |----------|------|--------|----------------------------| | Register | Data | 4550 | Physical Address | | 31 | 03FF | 1FF8xx | INITMMU + MMUs | | 30 | 03FE | 1FF0xx | ASSIST09 | | 29 | 03FD | 1FE8xx | (Reserved for Peripherals) | | 28 | 03FC | 1FE0xx | DMA, ACIA, PTM, ADLC | | 27 | 001B | 00D8xx | Task 0 Stack RAM | | 26 | 001A | 00D0xx | Task 0 Stack ROM | | 25 | 03F9 | 1FC8xx | CONST | | 24 | 03F8 | 1FC0xx | CONST | | 23 | 0017 | 00B8xx | RAM | | 22 | 0016 | 00B0xx | RAM | | 21 | 0015 | 00A8xx | RAM | | 20 | 0014 | 00A0xx | RAM | | 19 | 0013 | 0098xx | RAM | | 18 | 0012 | 0090xx | RAM | | 17 | 0011 | 0088xx | RAM | | 16 | 0010 | 0080xx | RAM | | 15 | 000F | 0078xx | RAM | | 14 | 000E | 0070xx | RAM | | 13 | 000D | 0068xx | RAM | | 12 | 000C | 0060xx | RAM | | 11 | 000B | 0058xx | RAM | | 10 | 000A | 0050xx | RAM | | 9 | 0009 | 0048xx | RAM | | 8 | 0008 | 0040xx | RAM | | 7 | 0007 | 0038xx | RAM | | 6 | 0006 | 0030xx | RAM | | 5 | 0005 | 0028xx | RAM | | 4 | 0004 | 0020xx | RAM | | 3 | 0003 | 0018xx | RAM | | 2 | 0002 | 0010xx | RAM | | 1 | 0001 | 0008xx | RAM | | 0 | 0000 | 0000xx | RAM | | PAGE | 001 | MMUIN | IT .S | A:1 | | MC6829 I | MMU INITI | [ALIZA] | rion | | | | |----------------------------|------|-------|--------------------|-----------|--------|-------------------|--------------------|-----------|----------------|---------------------|-----|----| | 00001<br>00002 | | | | | | | | | | | | | | 00002<br>00003<br>00004 | | | | | | TTL | MC6829 N | MMU IN: | ITIAL: | IZATION | | | | 00005A<br>00006 | FC00 | | | | | ORG<br>OPT | \$FCOO<br>ABS,LLE= | - 9.2 ° ( | . D.E. | | | | | 00007<br>00008 | | | | | *<br>* | 071 | ADS, ELL- | -02,3,0 | , K.L. | | | | | 00009<br>00010A | FC00 | 0.5 | TO 4.1 | | * | LDV | #\$F841 | MMU | #1 AD | | | | | 00011A | FC03 | 86 | F841 | A<br>A | NEVE | LDX<br>LDA | #\$01 | | #1 AD[ | | | | | 00012A<br>00013A | FC07 | 4 C | 80 | | NEXT | STA<br>INCA | 0,X+ | NEXT | MMU | VALUE TO MMU | | | | 00014A<br>00015A | | | 08<br>F9 | A<br>FCO5 | * | CMPA<br>BNE | #\$08<br>NEXT | LAST | MMU? | | | | | 00016<br>00017<br>00018 | | | | | * ALL | MAPPING | REGISTER | RS FOR | MMU ( | O ARE INITIALIZE | D | | | 00019A<br>00020A | FCOF | BF | 03FF<br>F83E | A<br>A | | LDX<br>STX | #\$03FF<br>\$F83E | PHYS | ADDR | \$1FF800-\$1FFFFF | REG | 31 | | 00021A<br>00022A | FC14 | BF | 1F<br>F83C | Α | | DEX<br>STX | \$F83C | PHYS | ADDR | \$1FF000-\$1FF7FF | REG | 30 | | 00023A<br>00024A | FC19 | BF | 1F<br>F83A | Α | | DEX<br>STX | \$F83A | PHYS | ADDR | \$1FE800-\$1FEFFF | REG | 29 | | 00025A<br>00026A<br>00027A | FC1E | BF | 1F<br>F838 | A | | DEX<br>STX | \$F838 | PHYS | ADDR | \$1FE000-\$1FE7FF | REG | 28 | | 00027A<br>00028A<br>00029A | FC24 | BF | 001B<br>F836<br>1F | A<br>A | | LDX<br>STX<br>DEX | #\$001B<br>\$F836 | PHYS | ADDR | \$00D800-\$00DFFF | REG | 27 | | 00029A<br>00030A<br>00031A | FC29 | BF | F834<br>1F | Α | | STX | \$F834 | PHYS | ADDR | \$00D000-\$00D7FF | REG | 26 | | 00031A<br>00032A<br>00033A | FC2E | 108E | 03F9 | A<br>A | | LDY<br>STY | #\$03F9<br>\$F832 | puvc | <b>V</b> U U D | \$1FC800-\$1FCFFF | DEC | 25 | | 00034A<br>00035A | FC36 | 31 | 3F | A<br>A | | LEAY<br>STY | -1,Y<br>\$F830 | | | \$1FC000-\$1FC7FF | | | | 00036A<br>00037A | FC3C | 30 | 1F<br>1F | ,, | | DEX<br>DEX | <b>\$1 000</b> | 11113 | ADDK | \$11 COOO-\$11 C/11 | KEG | 24 | | 00038A<br>00039A | FC40 | BF | F82E<br>1F | Α | | STX<br>DEX | \$F82E | PHYS | ADDR | \$00B800-\$00BFFF | REG | 23 | | 00040A<br>00041A | FC45 | BF | F82C | Α | | STX<br>DEX | \$F82C | PHYS | ADDR | \$00B000-\$00B7FF | REG | 22 | | 00042A<br>00043A | FC4A | BF | F82A<br>1F | Α | | STX | \$F82A | PHYS | ADDR | \$00A800-\$00AFFF | REG | 21 | | 00044A<br>00045A | FC4F | BF | F828<br>1F | Α | | STX<br>DEX | \$F828 | PHYS | ADDR | \$00A000-\$00A7FF | REG | 20 | | 00046A<br>00047A | FC54 | BF | F826<br>1F | Α | | STX | \$F826 | PHYS | ADDR | \$009800-\$009FFF | REG | 19 | | 00048A<br>00049A | FC59 | BF | F824<br>1F | Α | | STX | \$F824 | PHYS | ADDR | \$009000-\$0097FF | REG | 18 | | 00050A<br>00051A | FC5E | BF | F822<br>1F | А | | STX | \$F822 | PHYS | ADDR | \$008800-\$008FFF | REG | 17 | | 00052A<br>00053A | FC63 | BF | F820<br>1F | Α | | STX<br>DEX | \$F820 | PHYS | ADDR | \$008000-\$0087FF | REG | 16 | | 00054A<br>00055A | | | F81E<br>1F | Α | | STX<br>DEX | \$F81E | PHYS | ADDR | \$007800-\$007FFF | REG | 15 | | 00056A<br>00057A | FC6D | BF | F81C<br>1F | Α | | STX<br>DEX | \$F81C | PHYS | ADDR | \$007000-\$0077FF | REG | 14 | | 00058A | | | F81A | Α | | STX | \$F81A | PHYS | ADDR | \$006800-\$006FFF | REG | 13 | | | | | | | | | | | | | | | | 00060A FC77 BF F818 A STX \$F818 PHYS ADDR \$006000-\$0067FF REG 12 00061A FC76 30 1F DEX ST816 PHYS ADDR \$005000-\$0057FF REG 12 00063A FC76 30 1F DEX ST816 PHYS ADDR \$005000-\$0057FF REG 12 00063A FC77 30 1F DEX ST816 PHYS ADDR \$005000-\$0057FF REG 12 00066A FC81 BF F814 A STX \$F814 PHYS ADDR \$005000-\$0057FF REG 12 00066A FC88 BF F812 A STX \$F812 PHYS ADDR \$004000-\$0047FF REG 9 00067A FC89 30 1F DEX ST816 PHYS ADDR \$004000-\$0047FF REG 8 00060A FC88 BF F810 A STX \$F810 PHYS ADDR \$004000-\$0047FF REG 8 00070A FC90 BF F800 A STX \$F800 PHYS ADDR \$003000-\$0037FF REG 7 00071A FC93 30 1F DEX ST816 PHYS ADDR \$003000-\$0037FF REG 6 00073A FC98 30 1F DEX ST816 PHYS ADDR \$003000-\$0037FF REG 6 00073A FC98 30 1F DEX ST800 PHYS ADDR \$003000-\$0037FF REG 6 00073A FC99 BF F800 A STX \$F800 PHYS ADDR \$003000-\$0037FF REG 6 00073A FC99 BF F800 A STX \$F800 PHYS ADDR \$003000-\$0027FF REG 5 00075A FC99 BF F800 A STX \$F800 PHYS ADDR \$003000-\$0027FF REG 5 00075A FC99 BF F800 A STX \$F800 PHYS ADDR \$002000-\$0027FF REG 5 00075A FC99 BF F800 A STX \$F800 PHYS ADDR \$002000-\$0027FF REG 4 DEX ST800 PHYS ADDR \$002000-\$0027FF REG 4 DEX ST800 PHYS ADDR \$002000-\$0027FF REG 6 00075A FC99 BF F800 A STX \$F800 PHYS ADDR \$001000-\$0017FF REG 2 DEX ST800 PHYS ADDR \$000000-\$0017FF REG 2 DEX ST800 PHYS ADDR \$000000-\$0017FF REG 2 DEX ST800 PHYS ADDR \$000000-\$0017FF REG 2 DEX ST800 PHYS ADDR \$000000-\$0007FF REG 1 \$000000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$0000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$ | 00059A FC75 | | 1F | | DEX | | | | | | | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------|--------|------|------------|----------------|----------|---------|--------------|--------------------|-------|-----| | 00062A FC7C BF F816 A STX \$F816 PHYS ADDR \$005800-\$005FFF REG 17 00064A FC81 BF F814 A STX \$F814 PHYS ADDR \$005000-\$0057FF REG 17 00066A FC86 BF F812 A STX \$F812 PHYS ADDR \$005000-\$0047FF REG 9 00066A FC86 BF F812 A STX \$F812 PHYS ADDR \$004000-\$0047FF REG 9 00066A FC88 BF F810 A STX \$F810 PHYS ADDR \$004000-\$0047FF REG 8 00069A FC88 30 1F DEX 00070A FC90 BF F80E A STX \$F80E PHYS ADDR \$003800-\$003FFF REG 7 00071A FC93 30 1F DEX 00070A FC95 BF F80E A STX \$F80E PHYS ADDR \$003000-\$0037FF REG 6 00073A FC98 30 1F DEX | | | | Α | | \$F818 | PHYS | ADDR | \$00600 | 0 <b>-</b> \$0067F | F REG | 12 | | 00063A FC7F 30 1F 00064A FC8B 8F F814 A STX SF814 PHYS ADDR \$005000-\$0057F REG 10 00065A FC88 8F F812 A STX SF812 PHYS ADDR \$004800-\$0047F REG 9 00066A FC88 8F F812 A STX SF812 PHYS ADDR \$004800-\$0047F REG 9 00066A FC88 8F F810 A STX SF810 PHYS ADDR \$004000-\$0047F REG 8 00069A FC8B 30 1F 00070A FC90 8F F80E A STX SF80E PHYS ADDR \$003800-\$0037F REG 7 00071A FC93 30 1F 00071A FC93 30 1F 00072A FC93 30 1F 00073A FC93 8F F80C A STX SF80E PHYS ADDR \$003000-\$0037F REG 6 00073A FC93 8F F80A A STX SF80E PHYS ADDR \$003000-\$0037F REG 6 00073A FC98 8F F80A A STX SF80A PHYS ADDR \$002800-\$0027FF REG 5 00076A FC90 BF F80A A STX SF80A PHYS ADDR \$002000-\$0027FF REG 5 00077A FC90 BF F80A A STX SF80A PHYS ADDR \$002000-\$0027FF REG 5 00076A FC90 BF F80A A STX SF80A PHYS ADDR \$002000-\$0027FF REG 4 00077A FCA2 30 1F 00080A FCA3 30 1F 00080A FCA3 30 1F 00080A FCA3 30 1F 00080A FCA3 30 1F 00080A FCA3 30 1F 00080A FCA3 30 1F 00080A FCA4 BF F806 A STX SF80A PHYS ADDR \$001800-\$0017FF REG 3 00079A FCA7 30 1F 00080A FCA6 BF F80A A STX SF80A PHYS ADDR \$001800-\$0017FF REG 3 00079A FCA7 30 1F 00080A FCA6 BF F80A A STX SF80A PHYS ADDR \$001800-\$0017FF REG 3 00079A FCA7 30 1F 00080A FCA9 BF F80A A STX SF80A PHYS ADDR \$0001000-\$0017FF REG 2 00081A FCA8 BF F80A A STX SF80A PHYS ADDR \$0001000-\$0017FF REG 2 00081A FCA8 BF F80A A STX SF80A PHYS ADDR \$000800-\$0007FF REG 1 00081A FCA8 BF F80A A STX SF80A PHYS ADDR \$000800-\$0007FF REG 1 00085A FCB6 FF F00A A STX SF80A PHYS ADDR \$000000-\$0007FF REG 0 00086A FFA0 FCB6 FF F00A A STX SF80A PHYS ADDR \$000000-\$0007FF REG 0 00097A FCB7 BF F00 A STX SF80A PHYS ADDR \$000800-\$0000FFF REG 1 00081A FCB8 BF F80A A STX SF80A PHYS ADDR \$000000-\$0007FF REG 0 00099A FFFA FOR A F08A PHYS ADDR \$000000-\$00000-\$0007FF REG 0 00099A FFFA FOR A F08A PHYS ADDR \$000000-\$00000-\$0007FF REG 0 00099A FFFA FOR A F08A PHYS ADDR \$000000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$00000-\$000000 | | | | | | | | | | | | | | 00066A FC84 30 | | | | Α | | \$F816 | PHYS | ADDR | \$00580 | 0-\$005FF | F REG | 11 | | 00065A FC84 30 | | | | ٨ | | ¢ = Q 1 /I | puvc | V D D D | ¢00500 | 0 400575 | E DEC | 1.0 | | 00066A FC86 BF F812 A STX \$F812 PHYS ADDR \$004800-\$004FFF REG 9 00067A FC89 30 1F DEX 00068A FC8B BF F810 A STX \$F810 PHYS ADDR \$004000-\$0047FF REG 8 00070A FC80 BF F80c A STX \$F80E PHYS ADDR \$003800-\$003FFF REG 7 00071A FC93 BF F80C A STX \$F80E PHYS ADDR \$003000-\$0037FF REG 6 00073A FC98 BF F80C A STX \$F80C PHYS ADDR \$003000-\$0037FF REG 6 00075A FC98 BF F80A A STX \$F80A PHYS ADDR \$002800-\$002FFF REG 5 00076A FC99 BF F80B A STX \$F80B PHYS ADDR \$002800-\$002FFF REG 5 00076A FC99 BF F80B A STX \$F80B PHYS ADDR \$002000-\$002FFF REG 5 00077A FCA2 30 1F DEX 000079A FCA2 30 1F DEX 000080 FCA9 BF F804 A STX \$F80B PHYS ADDR \$001000-\$001FFF REG 3 00079A FCA2 30 1F DEX 00080A FCA9 BF F80B A STX \$F80B PHYS ADDR \$001000-\$001FFF REG 3 00080A FCA9 BF F80B A STX \$F80B PHYS ADDR \$001000-\$001FFF REG 2 00081A FCAC 30 1F DEX 00080A FCA9 BF F80B A STX \$F80B PHYS ADDR \$000000-\$001FFF REG 2 00081A FCAC 30 1F DEX 00080A FCA9 BF F80B A STX \$F80B PHYS ADDR \$000000-\$001FFF REG 2 00081A FCAC 30 1F DEX 00080A FCA9 BF F80B A STX \$F80B PHYS ADDR \$000000-\$001FFF REG 1 00081A FCAC 30 1F DEX 00080A FCA9 BF F80B A STX \$F80B PHYS ADDR \$000000-\$001FFF REG 1 00081A FCAC 30 1F DEX 00080A FCB9 BF F80B A STX \$F80B PHYS ADDR \$000000-\$0000FFF REG 1 00081A FCAC 30 1F DEX 00080A FCB9 BF F80B A STX \$F80B PHYS ADDR \$000000-\$0000FFF REG 1 00081A FCBB BF F80B A STX \$F80B PHYS ADDR \$000000-\$0000FFF REG 1 00081A FCBB BF F80B A STX \$F80B PHYS ADDR \$000000-\$0000FFF REG 1 00081A FCBB BF F80B A STX \$F80B PHYS ADDR \$000000-\$0000FFF REG 1 00081A FCBB BF F80B A STX \$F80B PHYS ADDR \$000000-\$0000FFF REG 1 00081A FCBB BF F80B A STX \$F80B PHYS ADDR \$000000-\$0000FFF REG 1 00081A FCBB BF F80B A STX \$F80B PHYS ADDR \$000000-\$0000FFF REG 1 00081A FCBB BF F80B A STX \$F80B PHYS ADDR \$000000-\$0000FFF REG 1 00081A FCBB BF F80B | | | | ^ | | \$1014 | FILIS | AUUK | \$00300 | U-\$0057F | r KEG | 10 | | 00067A FC89 30 | | - | | Α | | \$F812 | PHYS | ADDR | \$00480 | 0-\$004FF | F REG | 9 | | 00069A FC8E 30 | 00067A FC89 | 30 | 1F | | DEX | | | | | | | | | 00070A FC90 BF F80E A STX \$F80E PHYS ADDR \$003800-\$003FFF REG 7 00071A FC93 30 1F DEX 00071A FC95 BF F80C A STX \$F80C PHYS ADDR \$003000-\$0037FF REG 6 00074A FC98 BF F80C A STX \$F80A PHYS ADDR \$002800-\$002FFF REG 5 00075A FC9D 30 1F DEX 00075A FC9D 30 1F DEX 00077A FC42 30 1F DEX 00077A FCA2 30 1F DEX 00077A FCA2 30 1F DEX 00079A FCA3 30 1F DEX 00080A FCA9 BF F806 A STX \$F80B PHYS ADDR \$002000-\$0027FF REG 4 DEX 00080A FCA9 BF F806 A STX \$F806 PHYS ADDR \$001800-\$001FFF REG 3 DEX 00080A FCA9 BF F806 A STX \$F806 PHYS ADDR \$001000-\$001FFF REG 3 DEX 00080A FCA9 BF F804 A STX \$F806 PHYS ADDR \$001000-\$001FFF REG 3 DEX 00080A FCA9 BF F802 A STX \$F804 PHYS ADDR \$001000-\$001FFF REG 2 DEX 00081A FCAC 30 1F DEX 00081A FCAB BF F802 A STX \$F802 PHYS ADDR \$001000-\$001FFF REG 1 DEX 00081A FCAB BF F802 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F802 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$0000000-\$0007FF REG 1 DEX 00081A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$ | | | F810 | Α | | \$F810 | PHYS | ADDR' | \$00400 | 0-\$0047F | F REG | 8 | | 00071A FC93 30 1F | | | | _ | | | | | | | | _ | | 00072A FC98 BF F80C A STX \$F80C PHYS ADDR \$003000-\$0037FF REG 6 00073A FC98 30 1F DEX 00074A FC9A BF F80A A STX \$F80A PHYS ADDR \$002800-\$002FFF REG 5 00076A FC9B BF F80B A STX \$F80B PHYS ADDR \$002000-\$002FFF REG 5 00076A FC9F BF F80B A STX \$F80B PHYS ADDR \$002000-\$002FFF REG 4 00077A FCA2 30 1F DEX 00077A FCA2 30 1F DEX 00079A FCA7 30 1F DEX 00086A FCA7 30 1F DEX 00081A FCAC 30 1F DEX 00081A FCAB BF F804 A STX \$F80B PHYS ADDR \$001800-\$001FFF REG 2 00081A FCAB BF F802 A STX \$F80B PHYS ADDR \$001000-\$001FFF REG 2 00081A FCAB BF F802 A STX \$F80B PHYS ADDR \$001000-\$001FFF REG 1 00081A FCAB BF F80A A STX \$F80A PHYS ADDR \$000800-\$000FFF REG 1 00081A FCAB BF F80A A STX \$F80A PHYS ADDR \$000800-\$000FFF REG 1 00081A FCBB BF F80A A STX \$F80A PHYS ADDR \$000800-\$000FFF REG 1 00081A FCBB BF F80A A STX \$F80A PHYS ADDR \$000800-\$000FFF REG 1 00081A FCBB BF F80A A STX \$F80A PHYS ADDR \$000800-\$000FFF REG 1 00081A FCBB BF F80A A STX \$F80A PHYS ADDR \$000800-\$000FFF REG 1 00081A FCBB BF F80A A STX \$F80A PHYS ADDR \$000800-\$000FFF REG 1 00081A FCBB BF F80A A STX \$F80A PHYS ADDR \$000800-\$000FFF REG 1 00081A FCBB BF F80A A STX \$F80A PHYS ADDR \$000800-\$000FFF REG 1 00081A FCBB BF F80A A STX \$F80A PHYS ADDR \$000800-\$000FFF REG 1 00081A FCBB BF F80A A STX \$F80A PHYS ADDR \$000800-\$000FFF REG 1 00081A FCBB BF F80A A STX \$F80A PHYS ADDR \$000800-\$000FFF REG 1 00081A FCBB BF F80A A STX \$F80A PHYS ADDR \$000800-\$000FFF REG 1 00081A FCBB BF F80A A STX \$F80A PHYS ADDR \$000800-\$000FFF REG 1 00081A FCBB BF F80A A STX \$F80A PHYS ADDR \$000800-\$00107FF REG 1 0EX TYPE TABLE TO THE MMU MONITOR IN THE MMU MONITOR IN THE MMU MONITOR IN THE MMU MONITOR AND ASSISTOR WILL WORK ONLY IN THE MMU MONITOR AND ASSISTOR WILL WORK ONLY IN THE MMU MONITOR AND ASSISTOR WILL WORK ONLY IN THE MMU MONITOR AND ASSISTOR WILL WORK ONLY IN THE MMU MONITOR AND ASSISTOR WILL WORK ONLY IN THE MMU MONITOR AND ASSISTOR WILL WORK ONLY IN THE MMU MONITOR AND ASSISTOR WILL WORK ONLY IN THE MMU MONITOR AND ASSISTOR WILL WORK ONLY IN THE MMU MONITOR AND ASSISTOR WILL WORK ONL | | | | Α | | \$F80E | PHYS | ADDR | \$00380 | 0-\$003FF | F REG | 7 | | 00073A FC98 30 | | | | Α. | | ¢E000 | DUVC | ADDD | ¢00200 | 0 400275 | E DEC | 6 | | 00074A FC9A BF F80A A STX \$F80A PHYS ADDR \$002800-\$002FFF REG 5 00075A FC9P BF F808 A STX \$F808 PHYS ADDR \$002000-\$0027FF REG 4 00077A FCA2 30 1F DEX 00078A FCA4 BF F806 A STX \$F806 PHYS ADDR \$001800-\$001FFF REG 3 0079A FCA7 30 1F DEX 00080A FCA9 BF F804 A STX \$F806 PHYS ADDR \$001000-\$0017FF REG 2 00081A FCAC 30 1F DEX 00082A FCAE BF F802 A STX \$F804 PHYS ADDR \$001000-\$0017FF REG 2 00082A FCAE BF F800 A STX \$F800 PHYS ADDR \$000800-\$000FFF REG 1 0083A FCB1 30 1F DEX 00086A FCB6 7E F037 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 1 00085A FCB6 7E F037 A JMP \$F037 JM | | | | А | | \$F00C | PH 13 | AUUK | \$00300 | U-\$UU3/F | r KEG | O | | 00075A FC9D 30 | | | | Α | | \$F80A | PHYS | ADDR | \$00280 | 0-\$002FF | F REG | 5 | | 00077A FCA2 30 | 00075A FC9D | 30 | | | DEX | , | | | | | | | | 00078A FCA4 BF F806 A DEX STX \$F806 PHYS ADDR \$001800-\$001FFF REG 3 00079A FCA7 30 1F DEX 00080A FCA9 BF F804 A STX \$F804 PHYS ADDR \$001000-\$0017FF REG 2 00081A FCAC 30 1F DEX 00082A FCAE BF F802 A STX \$F802 PHYS ADDR \$000800-\$000FFF REG 1 DEX 00083A FCB1 30 1F DEX 00083A FCB1 30 1F DEX 00085A FCB6 7E F037 A JMP \$F037 00086 ** 00085A FCB6 7E F037 A JMP \$F037 00088 ** THE START ADDRESS FOR THE MMU MONITOR IS \$C008. IT | | | | Α | | \$F808 | PHYS | ADDR | \$00200 | 0-\$0027F | F REG | 4 | | 00079A FCA7 30 | | | | _ | | 45006 | 5,1,17,0 | | **** | | | _ | | 00080A FCA9 BF F804 A STX \$F804 PHYS ADDR \$001000-\$0017FF REG 2 00081A FCAC 30 1F DEX 00082A FCAE BF F802 A STX \$F802 PHYS ADDR \$000800-\$000FFF REG 1 00083A FCB1 30 1F DEX 00084A FCB3 BF F800 A STX \$F800 PHYS ADDR \$000000-\$0007FF REG 0 00085A FCB6 7E F037 A JMP \$F037 00086 00087 * THE START ADDRESS FOR THE MMU MONITOR IS \$C008. IT IS 00089 * THIS JUMP INSTRUCTION. HOWEVER, ASSISTO9 MUST BE IN 00090 * PLACE BECAUSE THE INTERRUPT VECTORS IN THIS PROGRAM 00091 * ARE BASED ON ASSISTO9. ** 00093 * BOTH THE MMU MONITOR AND ASSISTO9 WILL WORK ONLY IN 00094 * TASK 0 00095 ** 00097A FFF0 F704 A FDB \$F704 RESERVED VECTOR 00099A FFF0 F704 A FDB \$F704 SW13 VECTOR 00099A FFF4 F70C A FDB \$F70C SW12 VECTOR 00101A FFF8 F7E4 A FDB \$F7E0 FIRQ F7E0 F7EC A FDB \$F7E0 FIRQ VECTOR 00101A FFF8 F7E0 F7EC A FDB \$F7E0 FIRQ VECTOR 00101A FFF8 F7E0 F7EC A FDB \$F7E0 FIRQ VECTOR 00101A FFF8 F7E0 F7EC A FDB \$F7E0 FIRQ VECTOR 00101A FFF8 F7E0 F7EC A FDB \$F7E0 FIRQ VECTOR 00101A FFF8 F7E0 F7EC A FDB \$F7E0 FIRQ VECTOR 00101A FFF8 F7E0 F7EC A FDB \$F7E0 FIRQ VECTOR 00101A FFF8 F7E0 F7EC A FDB \$F7E0 FIRQ VECTOR 00101A FFF8 F7E0 F7EC A FDB \$F7E0 FIRQ VECTOR 00101A FFF8 F7E0 F7EC A FDB \$F7E0 FIRQ VECTOR 00101A FFF8 F7E0 F7EC A FDB \$F7E0 FIRQ VECTOR 00101A FFF8 F7E0 F7EC A FDB \$F7E0 FIRQ VECTOR 00101A FFF8 F7E0 F7EC A FDB \$F7E0 FIRQ VECTOR | | | | Α | | \$F806 | PHYS | ADDR | \$00180 | 0-\$001FF | F REG | 3 | | 00081A FCAC 30 | | | | ۸ | | ¢ = Q ∩ /I | риус | ADDD | \$00100 | 0 \$00175 | E DEC | 2 | | 00082A FCAE BF | | | | А | | <b>\$</b> FOU4 | PH 13 | AUUK | \$00100 | 0-300176 | r KEG | 2 | | 00083A FCB1 30 | | | | Α | | \$F802 | PHYS | ADDR | \$00080 | 0-\$000FF | F REG | 1 | | 00085A FCB6 7E F037 A | 00083A FCB1 | 30 | | | DEX | · | _ | | • | | | | | * THE START ADDRESS FOR THE MMU MONITOR IS \$COO8. IT IS \$0008 | | | | | | | PHYS | ADDR | \$00000 | 0-\$0007F | F REG | 0 | | * THE START ADDRESS FOR THE MMU MONITOR IS \$COO8. IT IS \$00088 * PERMISSIBLE TO JUMP DIRECTLY TO THE MMU MONITOR FROM * THIS JUMP INSTRUCTION. HOWEVER, ASSISTO MUST BE IN PLACE BECAUSE THE INTERRUPT VECTORS IN THIS PROGRAM ARE BASED ON ASSISTO9. ***O0091** ***O0092** ****O0093** ***BOTH THE MMU MONITOR AND ASSISTO WILL WORK ONLY IN * TASK O** ***O0095** ***O0096A FFFO** ***O0097A FFFO** ***O0097A FFFO** ***O0099A FFF2** ***O0099A FFF4** ***FFO** ***O0099A FFF4** ***FFO** ***O0099A FFF4** ***FFO** ***O0100A FFF6** ***OFF** **OFF** ***OFF** **OFF** ***OFF** ***OFF | · · · · · | 7 E | F037 | | | \$F037 | | | | | | | | * PERMISSIBLE TO JUMP DIRECTLY TO THE MMU MONITOR FROM THIS JUMP INSTRUCTION. HOWEVER, ASSISTO9 MUST BE IN PLACE BECAUSE THE INTERRUPT VECTORS IN THIS PROGRAM ARE BASED ON ASSISTO9. ***O0092** ***O0093******************************** | | | | | | ADDDESS E | OD THE | MMII I | 40 N T T O D | 15 ¢C00 | ο ττ | τ ( | | * THIS JUMP INSTRUCTION. HOWEVER, ASSISTO9 MUST BE IN ** PLACE BECAUSE THE INTERRUPT VECTORS IN THIS PROGRAM ** PLACE BECAUSE THE INTERRUPT VECTORS IN THIS PROGRAM ** ARE BASED ON ASSISTO9. ** BOTH THE MMU MONITOR AND ASSISTO9 WILL WORK ONLY IN ** TASK O ** O0094 ** TASK O ** O0095 ** ORG \$FFFO ** ORG \$FFFO ** ORG \$FFFO ** OO099A FFFO ** O0099A FFF4 ** FDB \$F7D4 RESERVED VECTOR ** O0099A FFF4 ** FDB \$F7D6 SWI3 VECTOR ** O0100A FFF6 ** FTEO A FDB \$F7EO FIRQ VECTOR ** O1101A FFF8 ** FTEA A FDB \$F7E4 IRQ VECTOR ** O1101A FFF8 ** FTEA A FDB \$F7E8 SWI VECTOR ** O1103A FFFC ** O1104A FFFE ** FCOO A FDB \$F7EC NMI VECTOR ** O1105 ** TOTAL ERRORS O000000000 | | | | | | | | | | | | | | 00090 | | | | | | | | | | | | | | 00092 | | | | | | | | T VE | CTORS I | N THIS P | ROGRA | М | | * BOTH THE MMU MONITOR AND ASSISTO9 WILL WORK ONLY IN | | | | | | ON ASSIST | 09. | | | | | | | 00094 | | | | | | | D 44D | | | | | | | 00095 00096A FFF0 00097A FFF0 F7D4 A FDB \$F7D4 RESERVED VECTOR 00098A FFF2 F7D8 A FDB \$F7D8 SWI3 VECTOR 00100A FFF6 F7E0 A FDB \$F7E0 F1RQ VECTOR 00101A FFF8 F7E4 A FDB \$F7E4 F7E8 A F7E8 F7E4 F7E8 F7E8 F7E8 F7E8 F7E8 F7E8 F7E8 F7E8 | | | | ٠. | ROIH THE L | טונאטוא טואוטי | K AND A | 42212 | IU9 WIL | L WORK O | NLY 1 | Ŋ | | 00096A FFF0 0RG \$FFF0 00097A FFF0 F7D4 A FDB \$F7D4 RESERVED VECTOR 00098A FFF2 F7D8 A FDB \$F7D8 SWI3 VECTOR 00099A FFF4 F7DC A FDB \$F7DC SWI2 VECTOR 00100A FFF6 F7E0 A FDB \$F7E0 FIRQ VECTOR 00101A FFF8 F7E4 A FDB \$F7E8 SWI VECTOR 00102A FFFA F7EC A FDB \$F7EC NMI VECTOR 00103A FFFC F7EC A FDB \$FC00 00104A FFFE FCOO A FDB \$FC00 00105 END TOTAL ERRORS 0000000000 BND TOTAL ERRORS 0000000000 | | | | | | | | | | | | | | 00097A FFF0 | | | | | ORG | \$FFF0 | | | | | | | | 00098A FFF2 F7D8 A FDB \$F7D8 SWI3 VECTOR 00099A FFF4 F7DC A FDB \$F7DC SWI2 VECTOR 00100A FFF6 F7E0 A FDB \$F7E0 FIRQ VECTOR 00101A FFF8 F7E4 A FDB \$F7E4 IRQ VECTOR 00102A FFFA F7E8 A FDB \$F7E8 SWI VECTOR 00103A FFFC F7EC A FDB \$F7EC NMI VECTOR 00104A FFFE FC00 A FDB \$FC00 00105 TOTAL ERRORS 0000000000 | 00097A FFF0 | | F7D4 | Α | | • | RESEF | RVED | /ECTOR | | | | | 00100A FFF6 | | | | Α | | | SWI3 | VECTO | ) R | | | | | 00101A FFF8 | | | | | | | | | | | | | | 00102A FFFA F7E8 A FDB \$F7E8 SWÎ VECTOR 00103A FFFC F7EC A FDB \$F7EC NMI VECTOR 00104A FFFE FC00 A FDB \$FC00 00105 TOTAL ERRORS 0000000000 | | | | | | | | | | | | | | 00103A FFFC F7EC A FDB \$F7EC NMI VECTOR<br>00104A FFFE FC00 A FDB \$FC00<br>00105 END<br>TOTAL ERRORS 0000000000 | | | | | | | | | | | | | | 00104A FFFE FC00 A FDB \$FC00<br>00105 END<br>TOTAL ERRORS 0000000000 | | | | | | | | | | | | | | 00105 END<br>TOTAL ERRORS 0000000000 | | | | | | | mct1 | | ` | | | | | TOTAL ERRORS 0000000000 | | | | ., | | Ţ. J.J. | | | | | | | | TOTAL WARNINGS 0000000000 | TOTAL ERROR | | | | | | | | | | | | | | TOTAL WARNI | NGS C | 000000 | 0000 | | | | | | | | | | | | | | | | | | | | | | | ``` PAGE 001 CONST MC6809-MC6829 MMU MONITOR PROGRAM .SA:1 00001A C000 ORG $C000 MC6809-MC6829 MMU MONITOR PROGRAM 00002 TTL 00003 OPT ABS, LLE = 82, S, CRE 00004 00005 00006 MANIFEST CONSTANTS 00007 × 00008 REGISTER OFFSETS FROM STACK TOP 00009 00010 0000 A COFF EQU CONDITION CODES 00011 0001 4 © A AOFF EQU 1 00012 0002 A BOFF EOU 2 В Р 4 P 00013 0001 A DOFF D SAME AS A U EQU 1 DPR U 00014 0003 A DPOFF EQU 3 L 00015 0004 A XOFF EOU χ 9 0006 Н 00016 A YOFF EQU 6 8000 A UOFF U 4 00017 EQU 8 00018 000A A POFF EQU 10 РC 00019 CONDITION CODE BITS 00020 00021 00022 0800 A E EOU %10000000 ENTIRE FLAG %01000000 FIRO BIT 00023 0040 A F EQU 00024 0020 EQU %00100000 HALF CARRY A H 00025 0010 A I EQU %00010000 INTERRUPT MASK %00001000 NEGATIVE 00026 0008 A N EQU %00000100 ZERO 00027 0004 A Z EQU 00028 0002 Α ٧ %00000010 OVERFLOW EOU 00029 С %00000001 CARRY 0001 Α EOU ж 00030 × "NOT' CONDITION CODE BITS 00031 ·k 00032 00033 007F A NE EQU $FF-E 00034 00BF A NF EQU $FF-F $FF-H 00035 OODF A NH EQU 00036 00EF ANI EQU $FF-I 00037 00F7 A NN EQU $FF-N 00038 00FB A NZ EQU $FF-Z 00FD 00039 A NV EQU $FF-V 00040 00FE A NC $FF-C EQU 00041 * 00042 THE INTERRUPT VECTORS 00043 FFF0 00044 A NOVEC EQU $FFF0 RESERVED VECTOR A SWI3VC EQU SOFTWARE INTERRUPT 3 00045 FFF2 $FFF2 SOFTWARE INTERRUPT 2 00046 FFF4 SWI2VC EOU $FFF4 Α 00047 FFF6 A FIRQVC EQU $FFF6 FAST INTERRUPT 00048 FFF8 A IRQVEC EQU $FFF8 EXTERNAL INTERRUPT SOFTWARE INTERRUPT (SYS CALL) 00049 FFFA A SWIVEC EQU $FFFA 00050 FFFC Α NMIVEC EQU $FFFC NON-MASKABLE INTERRUPT 00051 FFFE A RESVEC EQU $FFFE PROCESSOR RESTART VECTOR 00052 CHARACTER CONSTANTS 00053 00054 00055 0000 A EOS EQU $00 END OF STRING BELL (@G) 00056 0007 A BEEP EQU $07 8000 A BS BACKSPACE (©H) 00057 EQU $08 00058 0009 A TAB EQU $09 TAB (©I) ``` | PAG | ìΕ | 002 | CONST | .SA:1 | | Ī | 4C6809 | 9-MC6829 MML | U MONITOR PROGRAM | |-----|------------|-----|-------|--------------|---|----------------|----------------|----------------------------------------|--------------------------------------------| | 000 | )59 | | | 000A | | LF | EQU | \$0A | LINE FEED (©J) | | 000 | | | | 000C | Α | FF | EQU | \$0C | FORM FEED (©L) | | 000 | | | | 0000 | | CR | EQU | \$OD | CARRIAGE RETURN (@M) | | 000 | | | | 001B | A | ESC | EQU | \$1B | ESCAPE (@[) | | 000 | | | | 0020 | | BLANK | EQU | \$20 | ASCII BLANK | | 000 | | | | 007F | Α | RUBOUT | EQU | \$7F | RUBOUT (DEL) | | 000 | | | | | | * | cvc | CALL NAMES | | | 000 | | | | | | * | 313 | CALL MAMES | | | 000 | | | | 0000 | Α | GETC | EQU | 0 | GET NEXT CHARACTER FROM STANDARD | | 000 | | | | 0001 | | PUTC | EQU | ĭ | PUT CHARACTER ON STANDARD OUTPUT | | 000 | 70 | | | | | * | • | | | | 000 | | | | | | * | END | OF CONSTAN | TS | | 000 | | | | | | * | | | | | 000 | | | | | | * | F 0.11 | ************************************** | 00 050167506 | | 000 | | | | | | * | EQUI | AIES FUR 68 | 29 REGISTERS | | 000 | | | | F800 | Δ | MMU | EQU | \$F800 | START OF MMU REGISTERS | | 000 | | | | F840 | | MMUO | EQU | MMU+\$40 | KEY VALUE FOR MMUO | | 000 | | | | F847 | | MMU7 | EQU | MMU+\$47 | KEY VALUE FOR MMU7 | | 000 | 79 | | | F848 | | SBIT | EQU | MMU+\$48 | SYSTEM/USER FLAG (BIT 0) | | 000 | 080 | | | F849 | Α | FUSE | EQU | MMU+\$49 | COUNT-DOWN FUSE | | 000 | | | | F84A | | ACCESS | | MMU+\$4A | ACCESS KEY | | 000 | | | | F84B | Α | OPERAT | EQU | MMU+\$4B | OPERATE KEY | | 000 | | | | 0000 | | *<br>DC175 | E 0.11 | ¢000 | DACE CITE | | 000 | | | | 0800<br>0020 | | PSIZE<br>NTASK | E Q U<br>E Q U | \$800<br>32 | PAGE SIZE<br>NUMBER OF TASKS IN SYSTEM | | 000 | | | | 0020 | | NPAGE | EQU | 32 | NUMBER OF PAGES PER TASK | | 000 | | | | 0400 | | MAXPAG | | \$400 | MAXIMUM NUMBER OF PAGES IN PHYSI | | 000 | | | | 0020 | | MAXTAS | | 32 | MAXIMUM NUMBER OF TASKS IN SYSTE | | 000 | | | | 0200 | Α | FAULT | EQU | \$200 | PAGE FAULT PAGE (FIRST PAGE OF N | | 000 | 090 | | | E008 | Α | CONSOL | EQU | \$E008 | EXORCISOR ACIA | | 000 | | | | D7A0 | | STACKP | | \$D7A0 | CONVENIENT STACK START | | 000 | | | | D7B0 | | SPTAB | EQU | \$D7B0 | ADJOINS BOTTOM OF STACK | | 000 | | | | D7AF | Α | CURTAS | EQU | \$D7AF | CURRENTLY EXAMINED TASK | | 000 | | | | | | * | MEM | ODV MANAGEMI | ENT UNIT MONITOR | | 000 | | | | | | * | n L m | OKI MANAGEM | ENT UNIT MUNITUR | | 000 | | | | | | * | COM | MANDS ARE: | | | 000 | 98 | | | | | * | | | | | 000 | | | | | | * | T | | E/CHANGE CURRENT TASK NUMBER | | 001 | | | | | | * | D | | Y CPU AND MMU REGISTERS FOR CURRE | | 001 | | | | | | * | R | | Y REGISTERS | | | 102<br>103 | | | | | * | M<br>S | | E/CHANGE MEMORY<br>E/CHANGE STACKP POINTER | | | 103 | | | | | * | G | | CONTINUE TASK EXECUTION | | 001 | | | | | | * | + | ADD RAI | | | 001 | | | | | | * | - | | RAM PAGE | | 001 | | | | | | * | Z | | U REGISTERS TO FAULT | | 001 | | | | | | * | ? | COMMAN | D SUMMARY | | 001 | | | | | | * | | | | | | 110 | | | | | *<br>* | | | | | 001 | | | | 0004 | ٨ | FREE | EQU | 4 | ADDRESS OF FREE MMU REGISTER | | | 112 | | | 1000 | | FREEPG | | <b>\$</b> 1000 | ADDRESS IN MAP O OF FREE PAGE | | | 114 | | | 1000 | ^ | * | -40 | Ψ1000 | NOUNESS IN HALL OUT TREE FAGE | | | 115 | | | | | SYS | MACR | | | | | 116 | | | | | SWI | | | | | | | | | | | | | | | | ı | | | | | | | | | | | OO117 | PAGE | 003 | MMA | .SA:1 | | | MC6809 | -MC6829 MMI | U MONITOR PROGRAM | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|----------------------------|----------------|---------------|------------|--------|---------------------|---------------------------------------------------------------------------------------|----------------------------------------------------| | O0119A CO00 | | | | | | | | | | | 00124 00125 00126 00127A C008 10CE D7A0 | 00119<br>00120<br>00121<br>00122 | A COOO<br>A COO3<br>A COO6 | 8E<br>BF<br>20 | D7D0<br>03 C0 | A<br>OB | | LDX<br>STX<br>BRA | #\$C008<br>\$D7D0<br>INIT | ASSISTO9 SWI VECTOR LOCATION | | 00126 00127A COOB 10CE D7AO A INIT LDS #STACKP SETUP STACK FOR MONITOR 00128A COOF 10FF D7BO A 001299 0130A CO13 CE E008 A LDU #CONSOL 00131A CO16 17 0588 C5A1 LBSR INZACI INITIALIZE THE TERMINAL 00132 | 00124 | 4 6000 | 10 | 0469 64 | υ <b>4</b> | | | | | | O0128A COOF 10FF D7BO A STS SPTAB REWRITE TASK 0"S SAVED STACKP AD O0129 | 00126 | | | | | | INII | IALIZE UNLY | Y TASK U'S SAVED STACKP POINTER | | Onlight Onli | 00128<br>00129 | A COOF | 10FF | | | | | | | | O0134A CO1C 7F | 00131 | A CO13<br>A CO16 | CE<br>17 | | | * | | | INITIALIZE THE TERMINAL | | O0137A | 00133<br>00134<br>00135 | 4 CO1C | 7 F | | | * | | | | | O0139A C026 | 00136<br>00137 | A C022 | 86 | | | MAIN | LDA | #PROMPT | | | 00143A C030 30 8C 1C | 00139<br>00140<br>00141 | A CO26<br>A CO28<br>A CO2A | 84<br>17 | 0456 C4 | 83 | | SYS<br>ANDA<br>LBSR | GETC<br>#\$7F<br>PUTS | AND WAIT FOR INPUT<br>MASK PARITY<br>PRINT A BLANK | | O0146A C037 A1 | 00143<br>00144 | A C030<br>A C033 | 30<br>6D | 8C 1C<br>84 | Α | LOOP | LEAX<br>TST | <ctab,pcf< td=""><td>R TABLE OF VALID COMMANDS<br/>END OF TABLE TEST</td></ctab,pcf<> | R TABLE OF VALID COMMANDS<br>END OF TABLE TEST | | O0149A | 00146<br>00147 | A CO37<br>A CO39 | A1<br>27 | 84<br>04 C0 | A<br>3F | | CMPA<br>BEQ | ,X<br>L00P2 | MATCH COMMAND<br>FOUND IT | | 00151A C041 30 8D 3FBB | 00149 | A CO3D | 20 | F4 C0 | 33 | 1 00P2 | BRA | LOOP | | | 00153A C047 20 D6 C01F | 00151 | A C041 | 30 | 8D 3FBB | | | LEAX | O,PCR | | | O0156A C04B | | A CO47 | 20 | | | | | | 40 10 100 12112 | | O0157A | 00155<br>00156 | 4 CO4B | | 3F | A | HUH | | | UNRECOGNIZED COMMAND | | 00160 | 00157<br>00158 | | | DO CO | 1 F | * | BRA | MAIN | | | 00163A C050 | 00160 | | | | | * | CTAB | TABLE | OF COMMAND CHARACTERS | | 00165A C053 01B9 A FDB ADDPAG-OFFSET 00166A C055 44 A FCB D DISPLAY CURRENT TASK REGISTERS 00167A C056 0396 A FDB DISPLA-OFFSET 00168A C058 2D A FCB '- REMOVE PAGE FROM TASK 00169A C059 01E5 A FDB REMOVE-OFFSET 00170A C05B 54 A FCB 'T CHANGE CURRENT TASK 00171A C05C 020C A FDB TASK-OFFSET 00172A C05E 5A A FCB 'Z ZAP TASK REGISTERS 00173A C05F 037E A FDB ZAP-OFFSET | 00163 | A C050 | | 0205 | _ | CTAB | FDB | REGS-OFFS | | | 00166A C055 44 A FCB 'D DISPLAY CURRENT TASK REGISTERS 00167A C056 0396 A FDB DISPLA-OFFSET 00168A C058 2D A FCB '- REMOVE PAGE FROM TASK 00169A C059 01E5 A FDB REMOVE-OFFSET 00170A C05B 54 A FCB 'T CHANGE CURRENT TASK 00171A C05C 020C A FDB TASK-OFFSET 00172A C05E 5A A FCB 'Z ZAP TASK REGISTERS 00173A C05F 037E A FDB ZAP-OFFSET | | | | | _ | | | | | | 00168A C058 2D A FCB '- REMOVE PAGE FROM TASK 00169A C059 01E5 A FDB REMOVE-OFFSET 00170A C05B 54 A FCB 'T CHANGE CURRENT TASK 00171A C05C 020C A FDB TASK-OFFSET 00172A C05E 5A A FCB 'Z ZAP TASK REGISTERS 00173A C05F 037E A FDB ZAP-OFFSET | 00166 | A C055 | | | Α | | FCB | ' D | DISPLAY CURRENT TASK REGISTERS | | 00170A C05B 54 A FCB 'T CHANGE CURRENT TASK 00171A C05C 020C A FDB TASK-OFFSET 00172A C05E 5A A FCB 'Z ZAP TASK REGISTERS 00173A C05F 037E A FDB ZAP-OFFSET | 00168 | 4 CO58 | | 2 D | Α | | FCB | 1 _ | REMOVE PAGE FROM TASK | | 00172A CO5E 5A A FCB Z ZAP TASK REGISTERS<br>00173A CO5F 037E A FDB ZAP-OFFSET | 00170 | A C05B | | 54 | Α | | FCB | <b>'</b> T | CHANGE CURRENT TASK | | T T T T T T T T T T T T T T T T T T T | 00172 | 4 C05E | | 5 A | Α | | FCB | <b>'</b> Z | ZAP TASK REGISTERS | | | | | | | | | | | | ``` PAGE 004 MMA .SA:1 MC6809-MC6829 MMU MONITOR PROGRAM 00175A C062 0222 FDB MEMORY-OFFSET ' G 00176A C064 47 Α BEGIN/CONTINUE EXECUTION OF TASK FCB 00177A C065 035B Α FDB EXECUT-OFFSET 00178A C067 FCB EXAMINE/CHANGE STACKP POINTER 53 Α 00179A C068 175B STACKP-OFFSET Α FDB · $ 00180A C06A 24 Α FCB DISPLAY PAGE (256 BYTES) IN HEX HEXDUM-OFFSET 00181A C06B 032D Α FDR 00182A C06D 3F Α FCB ASKING FOR HELP 00183A C06E 002C Α FDB HELP-OFFSET 00184A C070 END OF TABLE Α FCB 0.0 00185 00186 HELP --- PRINT LEGAL COMMANDS SUMMARY 00187 00188A C071 30 8C 04 HELP LEAX <HELPIN, PCR 0420 C497 00189A C074 17 LBSR PSTRNG 00190A C077 39 RTS × 00191 00192 ж HELPINFO --- TEXT EMITTED FOR HELP COMMAND 00193 00194A C078 OD A HELPIN FCB CR, LF 00195A C07A 4 C FCC /LEGAL COMMANDS ARE:/ Α CR,LF 00196A C08D 0D FCB 00197A C08F DISPLAY/CHANGE CURRENT TASK: 54 Α FCC : T CR,LF 00198A COB1 0D Α FCB 00199A COB3 44 FCC DISPLAY MMU REGISTERS FOR CURRENT Α /D 00200A COEO OΒ Α FCB CR, LF Α 00201A COE2 4 D FCC : M EXAMINE/CHANGE MEMORY: 00202A COFE ΩD Α FCB CR,LF 00203A C100 52 Α FCC : R EXAMINE TASK'S REGISTERS: 00204A C11F 0 D FCB Α CR,LF 00205A C121 53 Α FCC : S EXAMINE/CHANGE STACKP POINTER: Α 00206A C145 OD FCB CR, LF 00207A C147 Α 24 FCC :$ DISPLAY A PAGE IN HEX: 00208A C163 Α 0D FCB CR, LF 00209A C165 FCC BEGIN/CONTINUE TASK: 47 Α :G CR,LF 00210A C17F αo Α FCB 00211A C181 2B Α FCC /+ ADD A PAGE/ Α CR,LF ٥n FCB 00212A C192 00213A C194 2 D Α FCC /- DELETE A PAGE/ 00214A C1A8 00 Α FCB CR,LF 00215A C1AA 5 A Α FCC /Z ZAP PAGES BACK TO DEFAULT/ 00216A C1CA 0 D Α FCB CR,LF 00217A C1CC 3F Α FCC /? THIS MESSAGE/ FCB 00218A C1DF 00 Α EOS 00219 50 A PHYMSG FCC 00220A C1E0 /PHYSICAL PAGE=/ 00221A C1EE 00 Α FCB E0S 00222A C1EF 20 LOGMSG FCC / LOGICAL PAGE=/ Α 00223A C1FD 00 E0S Α FCB 00224 00225 ADD PAGE XXX TO CURRENT TASK AT PAGE PP (A XXX 00226 00227 XXX = $000 TO MAXPAG 00228 PP = $00 TO NPAGE 00229 00230A C1FE 30 8C DF ADDPAG LEAX PHYMSG, PCR PROMPT FOR PHYSICAL PAGE# 0293 C497 00231A C201 17 LBSR PSTRNG 00232A C204 17 024E C455 LBSR GET3HX ASK FOR PAGE ``` ``` PAGE 005 MMA .SA:1 MC6809-MC6829 MMU MONITOR PROGRAM 00233A C207 25 20 C229 BCS ADDX 00234A C209 1083 0400 CMPD #MAXPAG Α 00235A C20D 24 C229 1 A BHS ADDX PAGE NUMBER OUT OF RANGE 00236A C20F 1F 02 Α TFR D,Y SAVE IT IN Y 00237 8C DB 00238A C211 30 LEAX LOGMSG, PCR PROMPT FOR LOGICAL PAGE# 00239A C214 17 0280 C497 LBSR PSTRNG 00240A C217 17 0227 C441 LBSR ASK FOR TASK PAGE GET2HX 00241A C21A 25 0D C229 BCS ADDX 00242A C21C 81 20 CMPA #NPAGE CHECK OUT OF RANGE PAGE 00243A C21E 24 C229 09 ADDX BHS 00244 * 00245 NOW PUT PHYSICAL PAGE NUMBER IN TASK'S MAP 00246 00247A C220 8D 25 C247 BSR WINDOW GET CURRENT TASK WINDOW F800 00248A C222 8E LDX #MMU Α 00249A C225 48 ASLA COMPUTE MMU OFFSET 00250A C226 10AF 86 STY PUT PAGE IN MMU A,X 00251A C229 39 ADDX RTS 00252 * 00253 REMOVE A PAGE FROM A TASK 00254 00255 THE LOGICAL PAGE NUMBER 00256 00257A C22A 30 8C C2 REMOVE LEAX LOGMSG, PCR ASK FOR LOGICAL PAGE # 00258A C22D 17 0267 C497 LBSR PSTRNG 00259A C230 17 020E C441 LBSR GET2HX 00260A C233 25 C246 QUIT IF NOT HEX RCS. RFMX 11 00261A C235 81 20 CMPA #NPAGE OR IF PAGE OUT OF RANGE 00262A C237 24 OD C246 BHS REMX 00263A C239 8 D 00 C247 BSR WINDOW F800 00264A C23B 8E LDX #MMU 00265A C23E 48 ASLA 00266A C23F 108E 0200 #FAULT LDY AN EMPTY PAGE 00267A C243 10AF 86 Α STY A,X 00268A C246 39 REMX RTS 00269 00270 WINDOW --- SET ACCESS KEY TO CURRENT TASK 00271 k 00272A C247 34 02 A WINDOW PSHS 00273A C249 B6 D7AF Α LDA CURTAS 00274A C24C B7 F84A Α STA ACCESS 00275A C24F 35 82 Α PULS A,PC 00276 00277 TASK --- DISPLAY/CHANGE CURRENT TASK BEING EXAM 00278 00279A C251 B6 D7AF A TASK LDA CURTAS PICKUP CURRENT TASK 00280A C254 17 025E C4B5 PUT2HX DISPLAY IT LBSR 00281A C257 17 PRINT A BLANK AND 0229 C483 LBSR PUTS 00282A C25A 17 01E4 C441 ASK FOR NEW TASK NUMBER LBSR GET2HX 00283A C25D 25 07 C266 BCS TASKX NON-HEX TASK# 00284A C25F 81 20 CMPA #NTASK 00285A C261 24 03 C266 BHS TASKX TASK OUT OF RANGE 00286A C263 B7 D7AF ADDRESS TASK GIVEN CURTAS STA 00287A C266 39 TASKX RTS 00288 00289 ж MEMORY --- EXAMINE/CHANGE MEMORY 00290 ``` ``` PAGE 006 MMA .SA:1 MC6809-MC6829 MMU MONITOR PROGRAM 00291A C267 17 01F8 C462 MEMORY LBSR GET START ADDRESS GFT4HX 00292A C26A 25 38 C2A4 MEMX BAD ADDRESS BCS 00293A C26C 1F MOVE POINTER TO X 01 TFR D,X 00294A C26E 17 021A C48B ML00P CŔLF START NEW LINE LBSR 00295A C271 1F 10 TFR X,D MOVE POINTER TO D AND 00296A C273 17 0255 C4CB PUT4HX LBSR PRINT CURRENT ADDRESS 00297A C276 17 020A C483 LBSR PUTS SEPARATE WITH A BLANK 00298A C279 F6 D7AF LDB CURTAS PICKUP CURRENT TASK# 00299A C27C 8D PICKUP THE BYTE FROM USER MAP FUBYTE 27 C2A5 BSR 00300A C27E 17 0234 C4B5 LBSR PUT2HX AND PRINT IT 01FF C483 ANOTHER SPACE 00301A C281 17 LBSR PUTS 00302A C284 17 01BA C441 LBSR GET2HX TRY TO GET NEW BYTE NON-HEX, MIGHT BE SPECIAL 00303A C287 25 06 C28F BCS MMOVE 00304A C289 8D 22 C2AD BSR SUBYTE PLACE BÝTE IN USER MAP 00305A C28B 30 01 LEAX UPDATE POINTER TO NEXT BYTE 1,X MLOOP 00306A C28D 20 DF C26E INCREMENTED ADDRESS BRA 00307A C28F 81 2E A MMOVE CMPA #AGAIN RE-EXAMINE SAME? 00308A C291 27 DB C26E MLOOP BEQ 00309 CMPA 00310A C293 81 ADVANCE TO NEXT? QD. #FWD Α C29B 00311A C295 26 04 BNE MEM2 00312A C297 30 01 LEAX ADD 1 TO X 1,X 00313A C299 20 D3 C26E BRA MLOOP 00314A C29B 81 5 E A MEM2 CMPA #BACK GO BACK ONE? 00315A C29D 26 04 BNE MEM3 C2A3 00316A C29F 30 1F LEAX -1,X SUBTRACT ONE FROM X MLOOP 00317A C2A1 20 CB C26E BRA 00318A C2A3 12 MEM3 NOP NONE OF THE ABOVE 00319A C2A4 39 MEMX RTS 00320 FUBYTE --- FETCH USER BYTE (SIMULATE LDA ,X OF 00321 * BYTE ADDRESS IS IN X, TASK TO USE IS IN RETURNS WITH BYTE IN A. OTHER REGS UNCH 00322 00323 00324 00325A C2A5 34 10 A FUBYTE PSHS Χ PLACE USER PAGE IN FREEPG 00326A C2A7 8D 0.0 C2B5 BŚR GETPAG LDA ,X X,PC 00327A C2A9 A6 84 Α PICKUP BYTE 00328A C2AB 35 90 Α PULS AND RETURN TO CALLER 00329 SUBYTE --- SET USER BYTE (SIMULATE STA ,X OF TA BYTE ADDRESS IS IN X, BYTE IN A, TASK T 00330 00331 * 00332 REGISTERS UNCHANGED ON EXIT 00333 00334A C2AD 34 10 A SUBYTE PSHS 00335A C2AF 8D C2B5 GETPAG PLACE USER PAGE IN FREEPG 04 BSR ,X X,PC SAVE IT IN RIGHT PLACE 00336A C2B1 A7 84 STA Α 00337A C2B3 35 90 Α PULS AND RETURN 00338 00339 GETPAG --- POINT TO USER BYTE 00340 00341 X HAS USER ADDRESS, B HAS TASK # 00342 * RETURNS WITH X POINTING TO BYTE IN OS MAP. D UNCHANGED, ACCESS KEY IS LEFT WITH T 00343 00344 TASK NUMBER IN B. 00345 A GETPAG PSHS 00346A C2B5 34 D,Y SAVE SOME REGISTERS 26 00347A C2B7 F7 F84A SETUP WINDOW TO TASK STB ACCESS Α 00348A C2BA 1F 10 Α TFR X,D MOVE POINTER INTO ACCUMULATOR ``` ``` PAGE 007 MMB .SA:1 MC6809-MC6829 MMU MONITOR PROGRAM 00349A C2BC 47 FIND PHYSICAL PAGE # ASRA 00350A C2BD 47 ASRA 00351A C2BE 84 3E ANDA #%00111110 MASK ALL BUT PAGE # 00352A C2C0 108E F800 00353A C2C4 10AE A6 Α LDY #MMU Α LDY PICKUP PAGE 00354A C2C7 7F F84A ACCESS NOW TALK TO OS MAP Α CLR 00355A C2CA 10BF F804 Α STY MMU+FREE "FREE OS PAGE 00356A C2CE 1F NOW POINT TO OFFSET 10 Α TFR X,D 00357A C2D0 84 07 Α ANDA #%111 MASK HIGH BITS OF ADDRESS 00358A C2D2 8E 1000 Α LDX #FREEPG POINT TO PAGE BEGIN 00359A C2D5 30 ADD OFFSET 8B Α LEAX D,X 00360A C2D7 35 D,Y,PC Α6 Α PULS RESTORE REGISTERS AND RETURN 00361 00362 REGS --- DISPLA TASK'S REGISTERS 00363 × 00364 EFHINZVC A-XX B-XX DPR-XX 00365 X-XXXX Y-XXXX U-XXXX P-XXXX 00366 S-XXXX 00367 00368A C2D9 45 A RSTRNG FCC /EFHINZVC/THE NAMES OF THE BITS 00369 00370A C2E1 20 FCC A-? B-? DPR-?/ A MSSTR ĆR,LF 00371A C2F0 0D FCB Α 00372A C2F2 58 /X-?? Y-?? U-?? P-??/ Α FCC 00373A C305 0D Α FCB CR,LF 00374A C307 Α 53 FCC /S-/ 00375A C309 00 Α FCB E0S 00376 00377 00378 FIRST, PRETTY PRINT THE CCR 00379 00380A C30A F6 D7AF A REGS LDB CURTAS 00381A C30D 17 0258 C568 LBSR GETUS GET TOP OF USER STACKP COFF,X 00382A C310 30 84 LEAX ADD IN CCR OFFSET 00383A C312 8D C2A5 FUBYTE PICKUP CONDITION CODES 91 BSR 00384A C314 STORE ON STACKP 34 02 Α PSHS Α 00385A C316 30 8C CO LEAX RSTRNG, PCR PICKUP STRING START 00386A C319 C6 LOOP COUNTER 08 #8 Α LDB , X + 00387A C31B A6 80 A REGS3 PICKUP APPROPRIATE CHARACTER LDA 00388A C31D 69 E4 ROL GET LEADING BIT Α 00389A C31F 25 02 C323 BCS REGS2 PRINT BIT NAME 00390A C321 86 2 E LDA BIT OFF CHARACTER Α PUTC 00391A C323 REGS2 SYS PRINT . OR CHARACTER 00392A C325 5A DECB LOOP ON ALL 8 BITS 00393A C326 26 F3 C31B BNE REGS3 00394A C328 32 DELETE TEMPORARY LEAS 61 Α 1,5 00395 00396A C32A F6 D7AF LDB CURTAS 00397A C32D 17 0238 C568 LBSR GETUS 00398A C330 30 LEAX AOFF, X POINT TO START OF REGISTERS 01 Α MSSTR, PCR GET FORMATTING STRING 00399A C332 31 8C AC LEAY Y+ #EOS 00400A C335 A6 A REGS6 PICKUP FORMAT CHAR Α0 1 DA IF AT END, WRAP UP WITH STACKP P 00401A C337 81 00 CMPA 00402A C339 27 C34D BE0 12 REGS4 00403A C33B 81 CMPA # ' ? INSERT HEX NUMBER? 3F 0.349 REGS5 00404A C33D 26 0 A BNE GET THE BYTE 00405A C33F 17 FF63 C2A5 LBSR FUBYTE 00406A C342 30 01 LEAX 1,X AND ADVANCE TO NEXT ``` ``` PAGE 008 MMB .SA:1 MC6809-MC6829 MMU MONITOR PROGRAM 00407A C344 17 00FA C441 LBSR GET2HX 00408A C347 20 C335 ЕC REGS6 GET NEXT CHAR BRA 00409A C349 REGS5 SYS PUTC JUST PRINT THE CHAR 0335 00410A C34B 20 E8 BRA REGS6 00411A C34D 17 0218 C568 REGS4 LBSR GETUS 00412A C350 1F 10 Α TFR X,D FINALLY, 00413A C352 17 0176 C4CB LBSR PUT4HX PRINT USER STACKP POINTER 00414A C355 39 RTS 00415 00416 * STACK --- EXAMINE CHANGE USER STACK POINTER 00417 D7AF A STACK 00418A C356 F6 LDB CURTAS GET CURRENT TASK NUMBER 00419A C359 17 020C C568 GETUS PICKUP SP IN X LBSR 00420A C35C 1F MOVE TO D 10 TFR X,D 00421A C35E 17 016A C4CB PÚT4HX LBSR 00422A C361 17 011F C483 LBSR PUTS 00FB C462 00423A C364 17 GET4HX LBSR ASK FOR NEW VALUE 00424A C367 25 80 C371 STACKX BCS 00425 00426 PUT NEW STACKP POINTER IN PLACE 00427 00428A C369 1F TFR MOVE TO PLACE PUTUS EXPECTS IT 01 Α D,X 00429A C36B F6 D7AF LDB CÚRTAS GET CURRENT TASK Α 0201 C572 00430A C36E 17 LBSR PUTUS REPLACE IT 00431A C371 39 STACKX RTS 00432 00433 HEXDUM --- DUMP A PAGE IN HEXADECIMAL 00434 OOCC C441 HEXDUM LBSR 00435A C372 17 GET2HX AS FOR PAGE NUMBER : 00436A C375 25 28 C39F BCS HEXX BAD PAGE ADDRESS , - S 00437A C377 6F E2 CLR INITIALIZE BYTE COUNT Α 00438A C379 5F ZERO LOW BYTE OF ADDRESS CLRB LBSR 00439A C37A 17 010E C48B HEX3 CRLF 00440A C37D 1F TFR D,X MOVE ADDRESS TO POINTER REG. 01 0149 C4CB 00441A C37F 17 PUT4HX PRINT CURRENT ADDRESS LBSR 00442A C382 17 00FE C483 HEX2 PUTS THEN A BLANK LBSR 00443A C385 F6 D7AF Α LDB CURTAS 00444A C388 17 FF1A C2A5 FUBYTE PICKUP THE BYTE LBSR 00445A C38B 30 01 A LEAX 1,X BUMP POINTER 00446A C38D 17 00B1 C441 LBSR GET2HX PRINT THE BYTE 00447A C390 6C E4 INC Α , S 00448A C392 A6 E4 Α LDA S 00449A C394 85 0F BITA #%1111 START NEW LINE WHEN COUNT MOD 16 00450A C396 26 EΑ C382 BNE HEX2 00451A C398 1F TFR 10 Α X,D \mathsf{TSTB} WHILE LOW BYTE != O KEEP PRINTIN 00452A C39A 5D 00453A C39B 26 DD C37A BNE HEX3 00454A C39D 32 61 LEAS 1,5 DROP TEMP HEXX 00455A C39F 39 RTS 00456 00457 EXECUT --- BEGIN/CONTINUE EXECUTION OF TASK 00458 00459A C3AO B6 A EXECUT LDA D7AF CURTAS 00460A C3A3 B7 F84B Α STA OPERAT SETUP FOR TASK SWITCH 019F C548 00461A C3A6 17 LBSR RETURN SIMULATE RTI 00462 00463 WHEN TASK QUITS, IT RETURNS HERE 00464 ``` ``` PAGE 009 MMB .SA:1 MC6809-MC6829 MMU MONITOR PROGRAM 00465A C3A9 7F F84B Α CIR OPERAT SWITCH BACK TO MONITOR 00466A C3AC B6 D7AF LDA CURTAS 008F C441 00467A C3AF 17 LBSR GET2HX SHOW WHICH TASK QUIT 00468A C3B2 30 8C 04 <XITMSG,PCR LEAX 00469A C3B5 17 00DF C497 LBSR PSTRNG 00470A C3B8 39 RTS TASK TERMINATED, RETURN TO MONIT 00471 20 00472A C3B9 A XITMSG FCC / STOPPED./ 00473A C3C2 00 FCB EOS Α 00474 * 00475 ZAP --- SET ALL REGISTERS FOR CURRENT TASK TO F 00476 00477A C3C3 B6 D7AF A ZAP LDA CURTAS CAN'T ZAP TASK 0 ! 00478A C3C6 27 C3DA 12 BEQ ZAPX 00479A C3C8 B7 F84A ACCESS BRING IT INTO THE WINDOW STA Α START OF REGS 00480A C3CB 8E F800 LDX #MMU 0200 00481A C3CE 108E LDY #FAULT PAGE FAULT PAGE Α 00482A C3D2 10AF 00483A C3D5 8C 81 A ZAP2 STY X++ F840 CMPX #MMU+NPAGE+NPAGE END OF MMU REGISTERS 00484A C3D8 26 F8 C3D2 BNE 7AP2 00485A C3DA 39 ZAPX RTS 00486 00487 Ж DISPLA --- DISPLAY MMU REGISTERS FOR CURRENT TA 00488 00489 00490A C3DB 17 OOAD C48B DISPLA LBSR START ON A NEW LINE CRLF 00491A C3DE 30 8C 2C LEAX <TASMSG, PCR 00B3 C497 00492A C3E1 17 LBSR PSTRNG PRINT TASK NUMBER 00493A C3E4 B6 D7AF LDA CURTAS 00494A C3E7 8D C441 PRINT TASK # 58 BSR GET2HX 00495A C3E9 17 009F C48B LBSR CRLF START NEW LINE 00496 00497A C3EC 8E F800 LDX #MMU POINT TO START OF REGS Α 00498A C3EF 34 A DISP2 10 PSHS Χ SAVE POINTER 00499 00500 FINALLY PRINT THE PAGE NUMBER 00501 00502A C3F1 17 FE53 C247 LBSR WINDOW 10 00503A C3F4 35 PULS RESTORE POINTER TO REGS. Α Χ 00504A C3F6 EC 81 LDD X++ PICKUP PAGE AND ADVANCE TO NEXT 00505A C3F8 17 00C7 C4C2 PRINT PAGE ADDRESS LBSR PUT3HX 00506A C3FB 17 0085 C483 PUTS LBSR 00507A C3FE 1F 10 TFR X,D CHECK IF TIME TO PRINT CR Α 00508A C400 C5 CR EVERY 4 REGISTERS (EACH 8 BYT 0.7 #%111 BITB Α 00509A C402 26 C407 03 BNE DISP5 00510A C404 17 0084 C48B LBSR CRLF 00511A C407 8C A DISP5 F840 CMPX #MMU+NPAGE+NPAGE CHECK IF AT END OF REGS 00512A C40A 26 E 3 C3EF BNE DISP2 00513A C40C 39 RTS 00514 00515A C40D 54 A TASMSG FCC /TASK # / 00516A C414 00 FCB EOS Α 00517 005F A PROMPT EQU 00518 PROMPT FOR INPUT .- RE-EXAMINE SAME BYTE GO TO NEXT BYTE 002F 00519 A AGAIN EOU CR 00520 000D A FWD EQU ' © 00521 005E A BACK EQU GO BACK ONE BYTE 00522 ``` ``` PAGE 010 I0 MC6809-MC6829 MMU MONITOR PROGRAM .SA:1 水 MONIO --- MONITOR CONSOLE I/O ROUTINES 00523 00524 00525 00526 MAPUP --- CONVERT a-z TO A-Z 火 00527 ж 00528 CHARACTER TO CONVERT IS IN A. ONLY CHARACTERS F 00529 ARE CHANGED 00530 00531A C415 81 61 A MAPUP CMPA #'a CHECK BOUNDS NOMAP 00532A C417 25 06 C41F BLO CHARACTER <A 00533A C419 81 CMPA # ' z 7 A Α NOMAP 00534A C41B 22 02 C41F BHI CHARACTER > Z #'a-'A PERFORM MAP DOWN 00535A C41D 80 20 Α SUBA 00536A C41F 39 NOMAP RTS 00537 00538 火 GETNYB --- GET NYBBLE IN A ж 00539 * 00540 TRY TO GET ONE HEX CHARACTER. IF 0-9 OR A-F ·k CONVERT TO BINARY. OTHERWISE RETURN CHARACTER 00541 00542 IN A WITH C-BIT SET. 00543 00544A C420 GETNYB SYS GETC GET ONE CHARACTER 00545A C422 8D C415 MAPUP F 1 BSR MAP TO UPPER CASE ONLY 00546A C424 34 02 Α PSHS SAVE IT IN CASE IT'S NOT HEX Α # 0 00547A C426 80 30 SUBA 00548A C428 2B C43D BMI NOTHEX WAS LESS THAN O 13 00549A C42A 81 CMPA #9 00550A C42C 2F 0 A C438 GOTIT IS BETWEEN 0-9 BLE # A- 9-1 00551A C42E 80 07 SUBA Α 00552A C430 81 09 #9 Α CMPA C43D NOTHEX 00553A C432 2F 09 WAS BETWEEN 9 AND A BLE 00554A C434 81 0F Α CMPA #$F 00555A C436 2E 05 C43D BGT NOTHEX WAS GREATER THAN F DON'T NEED SAVED CHAR 00556A C438 32 61 A GOTIT LEAS 1,5 00557A C43A 1C TURN OFF CARRY FΕ Α ANDCC #NC 00558A C43C 39 RTS SET CARRY 00559A C43D 1A A NOTHEX ORCC 01 # C 00560A C43F 35 82 PULS A,PC RETURN TYPED CHARACTER Α 00561 00562 * GET2HX --- GET ASCII CHARACTERS AND CONVERT TO BINARY * RESULT IS RETURNED IN A, NO OTHER REGISTERS ARE CHANG 00563 * IF A NON-HEX CHARACTER IS TYPED, THE C BIT IS SET 00564 * AND THE CHARACTER TYPED IS RETURNED IN A. OTHERWISE 00565 * THE C BIT IS CLEARED. 00566 00567 C420 GET2HX BSR GET HIGH NYBBLE 00568A C441 8D חת GETNYB 00569A C443 25 C454 GET22 0F BCS 00570A C445 48 MOVE IT TO THE HIGH NYBBLE ASLA 00571A C446 48 ASLA 00572A C447 48 ASLA 00573A C448 48 ASLA 00574A C449 34 02 PSHS SAVE IT C420 00575A C44B 8D BSR GETNYB GET LOW NYBBLE D3 00576A C44D 25 03 C452 BCS GET23 BAD SECOND NYBBLE 00577A C44F AA ΕO COMBINE HIGH AND LOW NYBBLES ORA ,S+ 00578A C451 39 RTS 00579A C452 32 61 A GET23 LEAS 1,5 DROP HIGH NYBBLE 00580A C454 39 GET22 RTS ``` ``` PAGE 011 I0 .SA:1 MC6809-MC6829 MMU MONITOR PROGRAM 00581 00582 * GET3HX --- GET ASCII CHARACTERS AND CONVERT TO 00583 * 00584 RESULT IS RETURNED IN D, NO OTHER REGISTERS ARE IF A NON-HEX CHARACTER IS TYPED, THE C-BIT IS S 00585 00586 AND THE CHARACTER TYPED IS RETURNED IN A. OTHE 00587 THE C-BIT IS CLEARED. 00588 00589A C455 8D С9 C420 GET3HX BSR GETNYB 00590A C457 25 15 C46E BCS GET42 00591A C459 1F 89 TFR A,B MOVE HIGH NYBBLE TO B 00592A C45B 8D C441 E 4 BSR GET2HX 00593A C45D 25 C46E ΩF BCS GET42 00594A C45F 1E 89 SWAP HIGH FOR LOW EXG A,B 00595A C461 39 GET32 RTS 00596 00597 GET4HX --- GET ASCII CHARACTERS AND CONVERT TO 00598 RESULT IS RETURNED IN D, NO OTHER REGISTERS ARE IF A NON-HEX CHARACTER IS TYPED, THE C-BIT IS S 00599 ж Ж 00600 火 00601 AND THE CHARACTER TYPED IS RETURNED IN A. OTHE 00602 THE C-BIT IS CLEARED. 00603 00604A C462 8D DD C441 GET4HX BSR GET2HX 00605A C464 25 08 C46E BCS GET42 00606A C466 1F 89 TFR Α A,B MOVE HIGH BYTE TO B 00607A C468 8D D7 C441 GET2HX BSR 00608A C46A 25 C46E 02 BCS GET42 00609A C46C 1E 89 EXG A,B SWAP HIGH FOR LOW Α 00610A C46E 39 GET42 RTS 00611 * GETRNG --- GET START AND END ADDRESSES 00612 00613 RETURN START IN X AND END+1 IN Y 00614 C-BIT SET IF A NON-HEX DIGIT WAS TYPED; 00615 F1 00616A C46F 8D C462 GETRNG BSR GET4HX 00617A C471 0F C482 GETRX 25 BCS BAD START ADDRESS 00618A C473 1F 01 TFR D,X 00619A C475 8D 00 C483 BSR PUTS ACKNOWLEDGE FIRST ADDRESS AS GOO 00620A C477 8D GET4HX E9 C462 BSR 00621A C479 25 07 C482 BCS GETRX BAD END ADDRESS 00622A C47B C3 0001 Α ADDD #1 BUMP END ADDRESS 00623A C47E 02 1 F Α TFR D, Y 00624A C480 1C FΕ Α ANDCC #NC CLEAR C-BIT TO SAY NO ERROR 00625A C482 39 GETRX RTS 00626 00627 * PUTS --- PRINT A BLANK ON THE CONSOLE 00628 00629 00630 *ALL REGISTERS UNCHANGED 00631 00632A C483 34 02 A PUTS PSHS 00633A C485 86 20 Α LDA #BLANK 00634A C487 SYS PUTC 00635A C489 35 A,PC RESTORE AND RETURN 82 PULS 00636 00637A C48B 34 02 A CRLF PSHS SAVE A 00638A C48D 86 #CR 0.0 LDA Α ``` ``` PAGE 012 I0 MC6809-MC6829 MMU MONITOR PROGRAM .SA:1 PUTC 00639A C48F SYS 00640A C491 86 0Α Α LDA #LF PUTC 00641A C493 SYS A,PC 00642A C495 35 82 PULS RESTORE AND RETURN Α 00643 00644 * PSTRNG --- PRINT STRING 00645 00646 * POINTER TO STRING START IS IN X, STRING 00647 * IS TERMINATED BY EOS CHARACTER * NO REGISTERS ARE CHANGED 00648 00649 A PSTRNG PSHS SAVE STUFF 00650A C497 34 12 A,X 00651A C499 A6 80 A PSTR2 LDA X+ PICKUP CHARACTER #E0S AT END OF STRING? 00652A C49B 81 00 CMPA Α PSTR9 00653A C49D 27 04 C4A3 BEQ YES, QUIT 00654A C49F PUTC PRINT IT SYS 00655A C4A1 20 F6 C499 BRA PSTR2 AND CONTINUE 00656A C4A3 35 A PSTR9 PULS 92 A,X,PC RESTORE AND RETURN 00657 00658 * PUTNYB --- PRINT LOWER NYBBLE OF A IN HEX 00659 02 00660A C4A5 34 A PUTNYB PSHS SAVE A 00661A C4A7 84 0F Α ANDA #$F CLEAR HIGH GARBAGE # 0 00662A C4A9 8B ADD ASCII OFFSET 30 Α ADDA # 9 00663A C4AB 81 CMPA CHECK IF >9 39 Α PUTNY2 00664A C4AD 23 02 C4B1 BLS NOW PRINT # A- 9-1 MOVE UP TO A-F 00665A C4AF 8B 07 ADDA Α PUTNY2 SYS PUTC 00666A C4B1 PULS 00667A C4B3 35 82 A,PC RESTORE AND RETURN 00668 00669 * PUT2HX --- PRINT A IN HEX ON TERMINAL 00670 * NUMBER TO BE PRINTED IS IN A, NO REGISTERS ARE CHANGE 00671 00672 00673A C4B5 34 02 A PUT2HX PSHS SAVE A FOR LOW NYBLLE 00674A C4B7 47 ASRA 00675A C4B8 47 ASRA 00676A C4B9 47 ASRA 00677A C4BA 47 ASRA 00678A C4BB 8D PUTNYB PRINT ONE HEX DIGIT E8 C4A5 BSR PICKUP VALUE AGAIN 00679A C4BD 35 02 PULS Α C4A5 00680A C4BF 8D E 4 BSR PUTNYB PRINT LOW NYBBLE 00681A C4C1 39 RETURN RTS 00682 00683 * PUT3HX --- PRINT D IN HEX ON TERMINAL 00684 * NUMBER TO BE PRINTED IS IN D, NO REGISTERS ARE CHANGE 00685 00686 C4A5 PUT3HX BSR 00687A C4C2 8D E1 PUTNYB PRINT HIGH NYBBLE FIRST 00688A C4C4 1E 89 EXG A,B NOW PRINT LOW NYBBLE C4B5 00689A C4C6 8D PUT2HX FD BSR 00690A C4C8 1E 89 EXG SWITCH BYTES BACK Α A,B 00691A C4CA 39 RTS 00692 00693 * PUT4HX --- PRINT D IN HEX ON TERMINAL 00694 00695 * NUMBER TO BE PRINTED IS IN D, NO OTHER REGISTERS * ARE CHANGED 00696 ``` ``` PAGE 013 IO .SA:1 MC6809-MC6829 MMU MONITOR PROGRAM 00697 00698A C4CB 8D E8 C4B5 PUT4HX BSR PUT2HX PRINT HIGH BYTE FIRST 00699A C4CD 1E 89 Α EXG A,B NOW PRINT LOW BYTE 00700A C4CF 8D E4 C4B5 PÚT2HX BSR 00701A C4D1 1E 89 EXG A,B SWITCH BYTES BACK 00702A C4D3 39 RTS 00703 00704 SWIH --- SOFTWARE INTERRUPT HANDLER 00705 00706 SWIH IS ENTERED VIA THE SWI INSTRUCTION AND IS FOR TRANSFERRING CONTROL TO A ROUTINE DETERM 00707 BYTE THAT FOLLOWS THE SWI OPCODE. THIS BYTE IS 00708 00709 INDEX INTO THE DISPATCH TABLE FOR STAND FUNCTIONS. THE RETURN ADDRESS OF THE CALLING 00710 00711 ADJUSTED BY SWIH BEFORE THE NAMED ROUTINE IS C 00712 CALLED ROUTINE IS ENTERED AS IF IT WERE DIREC 00713 FROM AN SWI INSTRUCTION (EXCEPT THAT THE MACHIN 00714 WILL NOT BE CORRECT). 00715 00716 NOTE: THIS ROUTINE CONVERTED FROM A NON-MMU SY 00717 00718A C4D4 8E D7B0 A SWIH LDX #SPTAB SAVE TASKS STACK POINTER 00719A C4D7 B6 F84B LDA OPERAT 00720A C4DA 48 ASLA 00721A C4DB 10EF 86 SAVE IT OFF STS 00722A C4DE 10FE D7B0 Α SPTAB PICKUP MONITOR'S STACK LDS 00723 * 00724 火 FETCH TASK'S PC 00725 00726A C4E2 F6 F84B LDB OPERAT GET TASK THAT INTERRUPTED 00727A C4E5 17 0080 C568 LBSR GETUS GET STACK POINTER POFF+1,X LOW BYTE OF PC 00728A C4E8 30 LEAX 0 B Α 00729A C4EA 17 FDB8 C2A5 LBSR FUBYTE 00730A C4ED 34 02 PSHS Α SAVE 00731A C4EF 30 1F LEAX -1,X BACKUP TO HIGH BYTE OF PC 00732A C4F1 17 FDB1 C2A5 LBSR FUBYTE 00733A C4F4 34 02 PC NOW ON STACK PSHS Α 00734A C4F6 35 PULS 10 RESTORE TO X 00735A C4F8 17 FDAA C2A5 LBSR FUBYTE GET SWI FUNCTION CODE 00736A C4FB 34 02 Α PSHS SAVE Α 00737A C4FD 30 01 Α LEAX BUMP USER PC 1,X 00738A C4FF 34 10 PSHS SAVE FOR REPLACEMENT X 00739A C501 8D 65 C568 BSR GETUS 00740A C503 30 0 A Α LEAX POFF, X POINT TO HIGH BYTE 00741A C505 35 02 PULS GET HIGH BYTE 00742A C507 FDA3 C2AD 17 LBSR SUBYTE REPLACE HIGH 00743A C50A 30 01 Α LEAX 1,X POINT TO LOW BYTE 00744A C50C 35 02 PULS GET LOW BYTE Δ 00745A C50E 17 FD9C C2AD LBSR SUBYTE REPLACE LOW 00746 00747 NOW DO THE REAL WORK 00748 00749A C511 35 02 PULS RESTORE FUNCTION CODE 00750A C513 81 03 CMPA #NCALLS THROW OUT BAD NUMBERS 00751A C515 24 31 C548 CALL OUT OF RANGE BHS RETURN <SWITAB, PCR GET TABLE START ADDRESS 00752A C517 30 8C 05 LEAX 00753A C51A 48 ASLA TABLE IS 2 BYTES/ENTRY PICKUP OFFSET FROM TABLE 00754A C51B EC 86 A LDD A,X ``` ``` PAGE 014 SWIH .SA:1 MC6809-MC6829 MMU MONITOR PROGRAM 00755A C51D 6E 8B Α D,X GO TO ROUTINE JMP 00756 * 00757 SWITAB --- TABLE OF SYSTEM CALL ADDRESSES 00758 00759A C51F 0006 A SWITAB FDB UGETC-SWITAB #0 USER GETC 00760A C521 0017 Α FDB UPUTC-SWITAB #1 USER PUTC 00761A C523 0028 FDB UQUIT-SWITAB #2 USER QUITS 00762 00763 0003 A NCALLS EQU NUMBER OF, ENTRIES IN THE TABLE 00764 00765 00766A C525 CE E008 A UGETC LDU #CONSOL GET CONSOLE ADDRESS C57D 00767A C528 8D RAWGTC 53 BSR 00768A C52A F6 F84B LDB OPERAT DESTINATION TASK# Α 00769A C52D 8D C568 GET USERS STACK POINTER 39 BSR GETUS 00770A C52F ADD OFFSET FOR A REGISTER 30 01 LEAX AOFF,X Α 00771A C531 17 FD79 C2AD LBSR SUBYTE WRITE CHARACTER INTO STACK 00772A C534 20 SWITCH BACK TO TASK 12 C548 RETURN BRA 00773A C536 CE E008 A UPUTC LDU #CONSOL 00774A C539 F6 F84B LDB OPERAT DESTINATION TASK# 00775A C53C 8D C568 2 A GETUS POINT TO STACK. BSR 00776A C53E 01 LEAX AOFF,X ADD A REG OFFSET 00777A C540 17 FD62 C2A5 FUBYTE FETCH THE CHARACTER LBSR 00778A C543 8D 40 C585 BSR RAWPTC PRINT IT 00779A C545 20 01 C548 BRA RETURN 00780A C547 39 UOUIT RETURN FROM MONITOR CALL TO STAR RTS 00781 00782 RETURN --- RETURN TO INTERRUPTED TASK * 00783 火 00784 THE INTERRUPTED TASK NUMBER IS IN THE OPERAT 00785 THE TASK WAS ZERO (I.E. THE MONITOR ITSELF) A IS EXECUTED. IF NOT, THEN THE STACK POINTER I TO WHAT IT WAS WHEN THE INTERRUPT OCCURRED AND * 00786 00787 00788 THAT TASK IS CAUSED BY WRITING TO THE 6 TO 00789 REGISTER. 00790 00791 00792A C548 B6 F84B A RETURN LDA OPERAT PICKUP INTERRUPTED TASK# 00793A C54B 27 C567 1 A BEQ SIMPLE WAS JUST THE MONITOR 00794A C54D 48 ASLA 00795A C54E 8E D780 Α LDX #SPTAB FIND OLD STACK POINTER SAVE MONITOR'S STACK POINTER 00796A C551 10FF D7B0 Α STS SPTAB 00797A C555 С6 01 #1 Α LDB SETUP FOR WRITE TO FUSE 00798A C557 1A 50 ORCC # I + F ENTER CRITICAL SECTION Α 00799A C559 10EE 86 Α LDS A,X PICKUP USER TASK STACK POINTER 00800A C55C F7 F849 Α STB FUSE START THE SWITCH 00801A C55F AND AWAY WE GO..... 3 R RTI 00802A C560 NOP 00803A C561 12 NOP 00804A C562 12 NOP 00805A C563 12 NOP 00806A C564 12 NOP 00807A C565 20 FΕ C565 BRA SOMETHING SERIOUSLY WRONG HERE 00808A C567 3B SIMPLE RTI JUST AN RTI FOR MONITOR 00809 00810 GETUS --- GET USERS STACK POINTER IN X (TASK# 00811 00812A C568 34 04 A GETUS PSHS В SAVE B ``` ``` MC6809-MC6829 MMU MONITOR PROGRAM PAGE 015 SWIH .SA:1 00813A C56A 58 ASLB 00814A C56B 8E D7B0 Α LDX #SPTAB POINT TO STACK SAVE AREA 00815A C56E AE 85 Α LDX В,Х PICKUP APPROPRIATE POINTER 00816A C570 35 84 RETURN WITH SP IN X Α PULS B,PC 00817 00818 PUTUS --- MAKE X THE STACK POINTER FOR TASK IN 00819 00820A C572 34 24 A PUTUS PSHS B,Y 00821A C574 58 ASLB 00822A C575 108E D7B0 LDY #SPTAB Α 00823A C579 AF Α STX B,Y PUT NEW POINTER IN PLACE А5 00824A C57B 35 Α4 B,Y,PC Α PULS 00825 00826 RAW ACIA I/O SUBROUTINES 00827 00828 0000 A ACIACR EQU 0 CONTROL REGISTER 00829 0001 A ACIADR EOU DATA REGISTER A .RDRF 00830 0001 %0000001 RECEIVER FULL FLAG EQU 00831 0002 A .TDRE %00000010 TRANSMITTER EMPTY FLAG EQU 00832 RAWGTC --- GET A CHARACTER FROM THE CONSOLE AND 00833 00834 00835 U CONTAINS THE ADDRESS OF THE ACIA CONTROL REGI 00836 CHARACTER IS RETURNED IN A, ALL OTHER REGISTERS 00837 GETC FALLS INTO PUTC IN ORDER TO ECHO THE CHARA 00838 A RAWGTC LDA ACIACR, U 00839A C57D A6 C4 #.RDRF 00840A C57F 85 01 WAIT FOR RECEIVER FULL BITA 00841A C581 27 FΑ C57D BEQ RAWGTC 41 00842A C583 A6 ACIADR, U PICKUP RECEIVED CHARACTER Α LDA 00843 00844 RAWPTC --- SEND THE CHARACTER IN A OUT 00845 * 00846 U CONTAINS THE ADDRESS OF THE ACIA CONTROL REGI 00847 ALL REGISTERS RETURN UNCHANGED. THERE IS SPECIAL TREATMENT OF LF FOR SLOW TERMI 00848 00849 00850 00851A C585 34 A RAWPTC PSHS 02 SAVE IT 00852A C587 A6 ACIACR, U C 4 A RPUTC2 LDA 00853A C589 85 02 WAIT FOR EMPTY ACIA Α BITA #.TDRE 00854A C58B 27 FΑ C587 RPUTC2 BEQ 00855A C58D 35 02 PULS PICKUP CHARACTER Α 00856A C58F 41 Α STA ACIADR, U AND SEND IT ON ITS WAY Α7 00857A C591 81 CMPA FUDGE FOR SLOW BANTAMS! 0 A Α #LF 00858A C593 27 01 C596 BEQ PRDLY 00859A C595 39 RTS 00860A C596 34 02 SAVE IT A PRDLY PSHS Α 00861A C598 4F CLRA C585 00862A C599 8D EΑ BSR RAWPTC C585 00863A C59B 8D E8 BSR RAWPTC C585 RAWPTC 00864A C59D 8D E6 BSR 00865A C59F 35 82 PULS A A,PC 00866 INZACI --- INITIALIZE AN ACIA 00867 00868 U CONTAINS THE ADDRESS OF THE ACIA CONTROL REGI 00869 00870 ``` ``` PAGE 016 RAWIO .SA:1 MC6809-MC6829 MMU MONITOR PROGRAM 00871A C5A1 34 02 A INZACI PSHS SAVE 00872A C5A3 86 03 #%0000011 MASTER RESET ACIA LDA Α 00873A C5A5 A7 C.4 Α STA ACIACR, U 00874A C5A7 86 15 Α #%00010101 8DATA,1STOP,DIVIDE BY 16 LDA 00875A C5A9 A7 C4 Α STA ACIACR, U INITIALIZE CONTROL REG 00876A C5AB 35 82 RESTORE AND RETURN Α PULS A,PC 00877 00878 RAWEMP --- CHECK IF A CHARACTER IS READY 00879 00880 U CONTAINS THE ADDRESS OF THE CONTROL REGISTER, IS TESTED TO SEE IF A CHARACTER HAS BEEN RECEIV 00881 00882 00883 RETURNS WITH A=O IF NO CHARACTER PRESENT, OTHER 00884 00885A C5AD A6 C4 A RAWEMP LDA ACIACR, U PICKUP STATUS BYTE 00886A C5AF 84 01 ANDA #.RDRF A CHARACTER PRESENT? 00887A C5B1 27 02 C5B5 NO QUIT WITH A=0 BEQ RAWEXT 00888A C5B3 86 01 I D A #1 00889A C5B5 39 RAWEXT RTS 00890 FND TOTAL ERRORS 00000--00000 TOTAL WARNINGS 00000--00000 0001 .RDRF 00830*00840 00886 0002 .TDRE 00831*00853 F84A ACCESS 00081*00274 00347 00354 00479 0000 ACIACR 00828*00839 00852 00873 00875 00885 0001 ACIADR 00829*00842 00856 C1FE ADDPAG 00165 00230* 00233 00235 00241 00243 00251* C229 ADDX 00307 00519* 002E AGAIN 00011*00398 00770 00776 0001 AOFF 005E BACK 00314 00521* 0007 BEEP 00056* 0020 BLANK 00063*00633 0002 B0FF 00012* 0008 BS 00057* 0001 C 00029*00040 00559 00010*00382 0000 COFF E008 CONSOL 00090*00130 00766 00773 00061*00194 00196 00198 00200 00202 00204 00206 00208 00210 00212 000D CR 00214 00216 00371 00373 00520 00638 C48B CRLF 00136 00294 00439 00490 00495 00510 00637* CO4F CTAB 00143 00162* D7AF CURTAS 00093*00133 00273 00279 00286 00298 00380 00396 00418 00429 00443 00459 00466 00477 00493 C3EF DISP2 00498*00512 C407 DISP5 00509 00511* C3DB DISPLA 00167 00490* 0001 DOFF 0003 DPOFF 00013* 00014* 0080 E 00022*00033 0000 E0S 00055*00218 00221 00223 00375 00401 00473 00516 00652 001B ESC 00062* C3AO EXECUT 00177 00459* 0040 F 00023*00034 00798 ``` ``` PAGE 017 RAWIO .SA:1 MC6809-MC6829 MMU MONITOR PROGRAM 0200 FAULT 00089*00266.00481 000C FF 00060* FFF6 FIRQVC 00047* 0004 FREE 00112*00355 1000 FREEPG 00113*00358 C2A5 FUBYTE 00299 00325*00383 00405 00444 00729 00732 00735 00777 F849 FUSE 00080*00800 000D FWD 00310 00520* C454 GET22 00569 00580* C452 GET23 00576 00579* C441 GET2HX 00240 00259 00282 00302 00407 00435 00446 00467 00494 00568*00592 00604 00607 00595* C461 GET32 C455 GET3HX 00232 00589* C46E GET42 00590 00593 00605 00608 00610* C462 GET4HX 00291 00423 00604*00616 00620 0000 GETC 00068*00139 00544 C420 GETNYB 00544*00568 00575 00589 C2B5 GETPAG 00326 00335 00346* C46F GETRNG 00616* C482 GETRX 00617 00621 00625* C568 GETUS 00381 00397 00411 00419 00727 00739 00769 00775 00812* C438 GOTIT 00550 00556* 0020 H 00024*00035 CO71 HELP 00183 00188* CO78 HELPIN 00188 00194* C382 HEX2 00442*00450 00439*00453 C37A HEX3 C372 HEXDUM 00181 00435* C39F HEXX 00436 00455* CO49 HUH 00145 00155* 00025*00036 00798 0010 I COOB INIT 00122 00127* C5A1 INZACI 00131 00871* FFF8 IRQVEC 00048* 000A LF 00059*00194 00196 00198 00200 00202 00204 00206 00208 00210 00212 00214 00216 00371 00373 00640 00857 C1EF LOGMSG 00222*00238 00257 C033 L00P 00144*00149 CO3F LOOP2 00147 00150* CO1F MAIN 00136*00153 00157 C415 MAPUP 00142 00531*00545 0400 MAXPAG 00087*00234 0020 MAXTAS 00088* C29B MEM2 00311 00314* C2A3 MEM3 00315 00318* C267 MEMORY 00175 00291* C2A4 MEMX 00292 00319* C26E MLOOP 00294*00306 00308 00313 00317 C28F MMOVE 00303 00307* 00076*00077 00078 00079 00080 00081 00082 00248 00264 00352 00355 F800 MMU 00480 00483 00497 00511 F840 MMU0 00077* F847 MMU7 00078* 00370*00399 C2E1 MSSTR 0008 N 00026*00037 OOFE NC 00040*00557 00624 0003 NCALLS 00750 00763* ``` ``` PAGE 018 RAWIO .SA:1 MC6809-MC6829 MMU MONITOR PROGRAM 007F NE 00033* OOBF NF 00034* OODF NH 00035* OOEF NI 00036* FFFC NMIVEC 00050* 00F7 NN 00037* 00532 00534 00536* C41F NOMAP C43D NOTHEX 00548 00553 00555 00559* FFFO NOVEC 00044* 0020 NPAGE 00086*00242 00261 00483 00483 00511 00511 0020 NTASK 00085*00284 OOFD NV 00039* OOFB NZ 00038* CO45 OFFSET 00152*00163 00165 00167 00169 00171 00173 00175 00177 00179 00181 00183 F84B OPERAT 00082*00134 00460 00465 00719 00726 00768 00774 00792 C1EO PHYMSG 00220*00230 00018*00728 00740 000A POFF C596 PRDLY 00858 00860* 005F PROMPT 00137 00518* 0800 PSIZE 00084* C499 PSTR2 00651*00655 C4A3 PSTR9 00653 00656* C497 PSTRNG 00189 00231 00239 00258 00469 00492 00650* C4B5 PUT2HX 00280 00300 00673*00689 00698 00700 C4C2 PUT3HX 00505 00687* C4CB PUT4HX 00296 00413 00421 00441 00698* 00069*00138 00156 00391 00409 00634 00639 00641 00654 00666 0001 PUTC C4B1 PUTNY2 00664 00666* C4A5 PUTNYB 00660*00678 00680 00687 C483 PUTS 00141 00281 00297 00301 00422 00442 00506 00619 00632* 00430 00820* C572 PUTUS C5AD RAWEMP 00885* C5B5 RAWEXT 00887 00889* C57D RAWGTC 00767 00839*00841 C585 RAWPTC 00778 00851*00862 00863 00864 C30A REGS 00163 00380* C323 REGS2 00389 00391* C31B REGS3 00387*00393 00402 00411* C34D REGS4 00404 00409* C349 REGS5 C335 REGS6 00400*00408 00410 C22A REMOVE 00169 00257* C246 REMX 00260 00262 00268* FFFE RESVEC 00051* C548 RETURN 00461 00751 00772 00779 00792* C587 RPUTC2 00852*00854 C2D9 RSTRNG 00368*00385 007F RUBOUT 00064* 00079* F848 SBIT C567 SIMPLE 00793 00808* 00092*00128 00718 00722 00795 00796 00814 00822 D7BO SPTAB C356 STACK 00418* D7A0 STACKP 00091*00127 00179 C371 STACKX 00424 00431* 00120* COOO START C2AD SUBYTE 00304 00334*00742 00745 00771 FFF4 SWI2VC 00046* ``` ``` PAGE 019 RAWIO .SA:1 MC6809-MC6829 MMU MONITOR PROGRAM FFF2 SWI3VC 00045* C4D4 SWIH 00123 ( 00123 00718* C51F SWITAB 00752 00759*00759 00760 00761 FFFA SWIVEC 00049* 0009 TAB 00058* C251 TASK 00171 00279* C266 TASKX 00283 00285 00287* C40D TASMSG 00491 00515* C525 UGETC 00759 00766* 0008 U0FF 00017* C536 UPUTC C547 UQUIT 00760 00773* 00761 00780* 0002 V 00028*00039 C247 WINDOW 00247 00263 00272*00502 C3B9 XITMSG 00468 00472* 0004 X0FF 00015* 0006 YOFF 00016* 0004 Z 00027*00038 C3C3 ZAP C3D2 ZAP2 00173 00477* 00482*00484 00478 00485* C3DA ZAPX ``` Motorola reserves the right to make changes to any products herein to improve reliability, function or design. Motorola does not assume any liability arising out of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights nor the rights of others. MOTOROLA Semiconductor Products Inc.