### **CMOS Dual-Port RAM** #### **SAE 81C80 A** #### **CMOSIC** #### **Features** - Processor interface with address and data bus plus signals ALE, WR, RD - 8051-, 8096-compatible timing - Memory capacity 504 bytes - All functions fully static (excl. oscillator watchdog) - Standby operation - On-chip oscillator with separate clock output - Eight scheduling registers - Three loadable timers for processor monitoring or applicable as longterm timers - Monitoring of internal oscillator (hardware watchdog) - Three outputs for interrupt triggering (can be set on the bus) - Fully asynchronous operation of two processors possible - Data retention down to 1 V - P-LCC-44 (SMD) package - Extended temperature range from 40 through 110 °C - CMOS technology | Туре | Ordering Code | Package | |-------------|---------------|------------------| | SAE 81C80 A | Q67100-H8706 | P-LCC-44-1 (SMD) | The SAE 81C80 A dual-port RAM (DPR) is a CMOS memory IC with a capacity of 504 bytes (**figure 1**). A very notable feature of this DPR is that it can be used by two microcontrollers (MCs) simultaneously and fully asynchronously. Each microcontroller uses the DPR like a normal static RAM. Thus, when comparing the circuit development of this DPR with that of standard memory, no extra effort is required. Access collisions are excluded, which is the pre-requisite for fast communication between the two MCs. The SAE 81C80 A DPR is ideally suited for multi-processor/multi-controller applications like master/slave configurations or controls where one controller aquires measured data and a second one controls the actuators (e.g. in motors, etc.). (**See figures 2 and 3**). ## **Pin Configuration** (top view) # **Pin Definitions and Functions** | Pin No. | Symbol | Function | |----------------------------------------------|--------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>8<br>9<br>10<br>11<br>12<br>13<br>14 | AD10<br>AD11<br>AD12<br>AD13<br>AD14<br>AD15<br>AD16<br>AD17 | Data and address bus port 1 | | 06 | A18 | Address 8 port 1 | | 37<br>36<br>35<br>34<br>33<br>32<br>31<br>30 | AD20<br>AD21<br>AD22<br>AD23<br>AD24<br>AD25<br>AD26<br>AD27 | Data and address bus port 2 | | 38 | A28 | Address 8 port 1 | | 15<br>29 | ALE1<br>ALE2 | Address latch enable port 1 Address latch enable port 2 These signals are for separating data and addresses on the bus. The address is stored on the falling edge of the signal. | | 5<br>39 | RD1<br>RD2 | Read signal port 1 (active low) Read signal port 2 (active low) | | 4<br>40 | WR1<br>WR2 | Write signal port 1 (active low) Write signal port 2 (active low) | | 3 2 | CS1<br>CS1 | Chip select port 1 Chip select port 1 (active low) | | 41<br>42 | CS2<br>CS2 | Chip select port 2 Chip select port 2 (active low) The chip-select inputs select a port when the two associated inputs are on active level. | | Pin No. | Symbol | Function | |----------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 27 | RES | Reset input Resets the IC to a defined initial state when RES is low. At the same time the outputs WD1, WD2, WD3 are switched low for the duration of the reset pulse. The oscillator continues to operate. | | 28 | PD | Power down Disables all other inputs and the oscillator when PD is low. | | 44<br>1 | $V_{ m SS}$ $V_{ m DD}$ | Negative supply voltage Positive supply voltage | | 43 | N.C. | Not connected | | 19 | XTAL1 | Pin for crystal (must remain open for external clock supply). | | 20 | XTAL2 | Pin for crystal or applying external clock | | 21 | CLKQ | Clock output | | 22 | WDO | Oscillator watchdog (open-drain output) High indicates that the oscillator is working. | | 16<br>17<br>18 | WD1<br>WD2<br>WD3 | Open-drain outputs of three timers | | 26 | $V_{\rm SS}$ | No function (must be connected) | | 23<br>24<br>25 | Int1<br>Int2<br>Int3 | Open-drain outputs Outputs that can be controlled via the port for triggering an interrupt on a processor for example. | Figure 1 Principle of the Dual-Port-RAM (DPR) Figure 2 Interfacing Master and Slave Processors by DPRs Figure 3 Dual-Port RAM used between Measured-Data Acquisition and the Actuators ### **Functional Description** #### **Dual-Port RAM** The SAE 81C80A is a 504-byte static RAM simultaneously accessible by two microcontrollers. The memory locations are selected via a multiplexed address/data bus and two chip-select inputs. The direction of data transfer is determined by the $\overline{\text{RD}}$ and $\overline{\text{WR}}$ inputs. There will be no undefined states when a memory location is concurrently accessed by two processors, even if they write simultaneously to the same memory location. Depending on the internal state of the access control and the actual physical sequence, the value one of the two ports will be stored. Also, if one memory location is read and written to at the same time, the data will not be mixed, i.e. either the original data or the new data are read out. ### **Chip-Select Inputs** The chip-select inputs affect signals $\overline{WR}$ and $\overline{RD}$ , but not the ALE input. Therefore, the ALE signal on the DPR (even if the DPR is not selected) must correspond to the specified values. To eliminate selection, it is sufficient if one of the two chip-select inputs becomes inactive when the falling edge of $\overline{WR}$ or $\overline{RD}$ appears. ### Reset The reset is necessary for setting the control units of the DPR to a defined initial state. It initializes the timer-mode registers with the values $0000XXX0_B$ (timers 1 and 2) and $00000XX0_B$ (timer 3). The $\overline{INT}$ outputs are set to 0. The reset input is a TTL input without Schmitt-trigger response. For this reason, neither an ALE nor a $\overline{\text{WR}}$ signal must be applied to the DPR if the voltage on the reset input is below $V_{\text{IH}}$ . The length of the Reset pulse must be greater than six clock (oscillator) cycles and the clock must be active. When the reset input is low the reset input is low, outputs $\overline{WD1}$ , $\overline{WD2}$ and $\overline{WD3}$ are set to low. After a reset these outputs are high. The scheduling registers are set to state 1 by reset. A reset is also necessary if the DPR is reactivated from power-down, while the contents of the RAM and oscillator remain unaffected. #### **Power-Down Mode** When the power-down mode (PD) is activated, all inputs (except PD and XTAL1, XTAL2) plus the oscillator are disabled. This means that any levels are possible on the remaining inputs. An active level on $\overline{PD}$ also produces an internal reset. Nevertheless, to ensure proper operation after deactivation of the power-down mode, an external reset should be made to bridge the time required by the <u>oscillator for buildup</u>. The <u>outputs of the ports go high-impedance, while outputs CLKO, WDO, WD1, WD2, WD3, INT1, INT2 and INT3 are set to low. The $\overline{PD}$ input shows a Schmitt-trigger response. This allows $V_{DD}$ to be evaluated directly, for example (see application circuit).</u> ### **Interrupt Outputs** The DPR has three interrupt outputs that can be set and reset directly by writing to an address (**see table 1**). The outputs are located in the same address range as the scheduling registers. However, only bits 2 and 3 are relevant for the interrupt outputs. At least one of bits 0 and 1 should be other than 1 to prevent the scheduling registers from being affected. The functions of the outputs are shown in the following table: | RES | Bit 3 | Bit 2 | Output | |-----|-------|-------|-----------| | 1 | 0 | 0 | no change | | 1 | 0 | 1 | 1 | | 1 | 1 | 0 | 0 | | 1 | 1 | 1 | undefined | | 0 | _ | _ | 0 | ### **Oscillator Watchdog** This part of the circuit is a fail-save mechanism for the oscillator. If the frequency of the clock is missing, the output switches to $\overline{\text{WDO}}$ low. The circuit works like an analog integrator. Below approx. 100 kHz, low pulses are produced on the output. The pulse width depends on the clock frequency. This part of the circuit should not be used at operating frequencies of les than 500 kHz. ### **Supply Voltage** To prevent any interference, the supply voltage of the DPR should be blocked as close as possible to the pins with a capacitor of approx. 100 nF (see application circuit). #### **Timers** The three timers are 24-bit counters with a clock frequency of $f_{\rm OSC}/6$ . Each of the counters can be set by writing to three specific RAM addresses. The value is then simultaneously stored in the RAM and a buffer register of the timer. When the low byte is written, all three bytes are parallely stored in the reload register. The value in the reload register is kept in all operating modes until the associated low byte is written again. The counters are down-counters. They can be started by setting bit 7 in the associated timer-mode register (TMR). Each counter can be configured by a TMR. The bits of the TMRs have the following function: Bit 0: This bit provides overwrite protection for the reload register. **Use:** After writing to the reload registers and starting of the timer – by writing to the associated protection bit – the adjacent RAM area can be used without affecting the reload register (reset state = 0). Bit 4: It serves for switching the polarity of the output signal (reset state = 0). **Bit 4 = 0**; idle state 1, active 0 **Bit 4 = 1**; idle state 0, active 1 Bit 5: This bit switches the operating mode (reset state = 0). **Bit 5 = 0** single-shot, i.e. when the counter is started, the output signal becomes active. After reaching zero, the output signal is reset. The timer has to be restarted to trigger another count cycle. The values from the reload register are then loaded into the counter. **Bit 5 = 1** auto reload, i.e. when the counter is started, the value of the reload register is loaded into it. When zero is reached, the counter issues a pulse ( $\approx 4~\mu s$ at 12 MHz), automatically reloads the original value and the entire operation starts again. In this way a frequency can be set with a resolution of 24 bits. Because of the pulse width of eight timer clock pulses, however, the shortest period is limited to nine timer clock pulses ( $t_{osx} \times 6$ ). If a new start pulse appears in the count cycle (even without "STOP"), no pulse is issued and the counter is reloaded. Bit 6: In the reload mode the timer can be halted by setting this bit and resetting bit 5. (In a new start the contents of the counter are lost and that of the reload registers remain unaffected). Bit 7: Setting this bit starts the counter. ### Only for the registers of timers 1 and 2 Bit 1-3: These are used together with bit 0 for switching the watchdog mode ON and OFF. ### Only for the register of timer 3 Bit 1-2: Reserved (should always be 0 for correct operation). Bit 3: Switches **all three timers** to test mode, i.e. only the upper twelve bits are used to generate the output signal (reset state = 0). ### **Watchdog Mode** For timers 1 and 2 a special mode was implemented which can be used to monitor the two processors. In this mode there is a control register (CR) for each timer (**see table 1** for addresses). The watchdog mode is set by loading the TMR with the value 101X1111<sub>B</sub>, the polarity of the output signal being freely selectable with bit 4. This mode works similarly to the auto-reload mode, but neither the reload register nor the TMR can be altered. In the watchdog mode, the timer can only be restarted (and the output pulse suppressed) if the values $055_{\mbox{H}}$ and $0AA_{\mbox{H}}$ are successively written into the control register. The time between these two write operations is random, but the sequence must be completed before the timer has run down, i.e. the output pulse is generated. No value may be written into either the TMR or CR between the two write operations, otherwise the sequence has to be started again. To reset the timer to the normal mode, first the value $055_{\rm H}$ has to be written into the CR, then the value $010X0000_{\rm B}$ into the TMR, and finally the value $0AA_{\rm H}$ into the CR. Here, too, if any other value is written into either of the two registers during the sequence, the entire operation has to be started again. The time between the accesses is random. The timer operation in watchdog mode is illustrated in the appendix in an 8051 example program. **Note:** The relevant bits for changing the timer state to watchdog mode are bit 0 - bit 3; the shown pattern is the only one, which makes sense for this mode. Figure 4 Bit Assignment of Timer-Mode Registers for Timer 1 and 2 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |-------------------------|-------------------------------------------|-------------------------------------------------------|----------------------------------------------|------------------------------------------------------|------------------------------------------------------|------------------------------------------------------|-----------------------------------------------------------| | Software<br>start (= 1) | Timerstop<br>(= 1) for<br>auto-<br>reload | Mode<br>(auto-<br>reload = 1,<br>single-<br>shot = 0) | Polarity of<br>output<br>pulse<br>(High = 0) | Only for<br>watchdog<br>mode<br>(normal<br>mode = 0) | Only for<br>watchdog<br>mode<br>(normal<br>mode = 0) | Only for<br>watchdog<br>mode<br>(normal<br>mode = 0) | Protection (= 1) against over- writing of reload register | Figure 5 Bit Assignment of Timer-Mode Registers for Timer 3 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |-------------------------|-------------------------------------------|-------------------------------------------------------|----------------------------------------------|-------------------|----------------------------------|----------------------------------|-----------------------------------------------------------| | Software<br>start (= 1) | Timerstop<br>(= 1) for<br>auto-<br>reload | Mode<br>(auto-<br>reload = 1,<br>single-<br>shot = 0) | Polarity of<br>output<br>pulse<br>(High = 0) | switches timer to | Reserved<br>(normal<br>mode = 0) | Reserved<br>(normal<br>mode = 0) | Protection (= 1) against over- writing of reload register | #### **Access Collisions** With a RAM which can be written to or read simultaneously by two controllers, different kinds of access collision are possible: - 1. Simultaneous read access to the same memory location from both ports; - 2. One port reads the same memory location which the other port writes to concurrently; - 3. Concurrent write access to the same memory location from both ports; - 4. Read access to a logically linked data block by one port, while the other port modifies the same data block. The SAE 81C80A dual-port RAM avoids the first three types of access collision by hardware. The fourth problem can be solved by user software. The standard solution for the access collisions described above would be as follows: **before** accessing the memory area, an additional memory location must be established by setting an access flag (semaphore). This would necessitate three memory operations: - First access: read the flag and check whether the data area is free. - Second access: write the flag with the data for reservation. - Third access: read the flag and make sure that your own reservation has not been overwritten by the other port. Only after this sequence would a microcontroller be privileged for access and could write or read to the data area without the risk of contention. With the SAE 81C80A dual-port RAM this access routine is simplified using scheduling registers. ### **Scheduling Registers** **Note:** The assignment of a memory area to a scheduling register is defined by the user software of both controllers With the scheduling registers synchronization can be done with only one access because the reservation is performed during reading. The other port cannot overwrite it. This means that a scheduling register is written by reading, unless it was occupied. The description above shows that these registers are no ordinary RAM locations. They are formed by a finite state machine (FSM), which can assume the following four states (see figure 6): - State 1: port 1 was the previous owner and the register is free. - State 2: port 1 occupies the register. - State 3: port 2 was the previous owner and the register is free. - State 4: port 2 occupies the register. The state of a register can be read out from the particular address, but causes also a change in the state of the FSM (arrows in **figure 6**). Reading produces 2-bit information: - Bit 0 is the owner bit. It is set when the reading port is or was the owner of a register. - Bit 1 is the occupied bit. It is set when a register has been reserved by a port. - Bit 2 through 7 are always 0. Reserving is done by reading a register and enabling by writing to it XXXXXX11<sub>B</sub> (pay attention to the interrupt outputs of bits 2 and 3!). Thus a correct protocol using the scheduling registers takes the following form: - 1. Read the scheduling register. - 2. Check whether the occupied bit is set and the owner bit is not set (i.e. the other port has reserved). If so, go back to 1, otherwise continue. - 3. Process the data area. - 4. Enable the scheduling register by writing 03<sub>H</sub> to the address of the register - 5. End In cases where accessing of a data area requires prior reading of or writing to this data area by the second processor, a separate evaluation of the occupied bit and owner bit can be done in step 2: - 2a. Owner bit self? If so, continue to 2c, otherwise to 2b. - 2b. Occupied bit self? If so, continue to 2c, otherwise to 3. - 2c. Enable the scheduling register by writing 03<sub>H</sub> to the address of the register (continue with 1). ### The following applies only to the scheduling registers: Usually, in the case of a concurrent access by both processors, writing has priority over reading. However, a simultaneous read or write access from the two ports means that port 1 has priority over port 2. The addresses of the scheduling registers are listed in table 1. The assignment of scheduling registers to specific data areas is made by the user. The software (of both controllers) should be configured so that, prior to accessing a logically related data area, the associated scheduling register is accessed first (according to the above sequence). So the assignment of the various dual-port RAM address spaces to scheduling registers will depend solely on the structure of the user software. Figure 6 Diagram Showing the Various States of the Scheduling Registers Only the two least significant bits of the data are shown (in converted commas). ### Notes: - 1. The owner bit indicates the last owner of a register. - 2. Only if the port is owner of the register will writing change the state. - 3. The reset state is state 1. - 4. The FSM is symmetrical. Therefore, the two processors can use the same program. Table 1 Address Assignment of DPR Registers | Register | Address | Register | Address | |---------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------| | Scheduling register 1 Scheduling register 2 Scheduling register 3 | 1F8 <sub>H</sub><br>1F9 <sub>H</sub><br>1FA <sub>H</sub> | High-byte timer 2 Medium-byte timer 2 Low-byte timer 2 | 1E7 <sub>H</sub><br>1E6 <sub>H</sub><br>1E5 <sub>H</sub> | | Scheduling register 4 Scheduling register 5 Scheduling register 6 Scheduling register 7 Scheduling register 8 | 1FB <sub>H</sub><br>1FC <sub>H</sub><br>1FD <sub>H</sub><br>1FE <sub>H</sub><br>1FF <sub>H</sub> | High-byte timer 3 Medium-byte timer 3 Low-byte timer 3 | 1EB <sub>H</sub><br>1EA <sub>H</sub><br>1E9 <sub>H</sub> | | Timer-mode register 1 Timer-mode register 2 Timer-mode register 3 | 1E0 <sub>H</sub><br>1E4 <sub>H</sub><br>1E8 <sub>H</sub> | Control-register timer 1<br>Control-register timer 2 | 1EC <sub>H</sub><br>1ED <sub>H</sub> | | High-byte timer 1 Medium-byte timer 1 Low-byte timer 1 | 1E3 <sub>H</sub><br>1E2 <sub>H</sub><br>1E1 <sub>H</sub> | Interrupt output 1 Interrupt output 1 Interrupt output 1 | 1F8 <sub>H</sub><br>1F9 <sub>H</sub><br>1FA <sub>H</sub> | Figure 7 Memory Map # **Block Diagram** # **Absolute Maximum Ratings** $T_{\rm A}$ = –40 to 110 °C; all voltages referred to $V_{\rm SS}$ | Parameter | Symbol | | es | Unit | | |------------------------------|-----------|-------|------|--------------------|----| | | | min. | typ. | max. | | | Storage temperature | $T_{stg}$ | - 50 | _ | 125 | °C | | Total power dissipation | $P_{tot}$ | _ | _ | 500 | mW | | Power dissipation per output | $P_{Q}$ | _ | _ | 50 | mW | | Input voltage | $V_1$ | - 0.5 | _ | $V_{\rm DD}$ + 0.5 | V | | Supply voltage | $V_{DD}$ | - 0.5 | _ | 6 | V | # **Operating Range** | Supply voltage | $V_{DD}$ | 4.5 | 5 | 5.5 | V | |-----------------------------------------|----------|------|---|-----|-----| | Supply current (w/o loading of outputs) | $I_{DD}$ | _ | _ | 20 | mA | | Operating frequency | $f_{S}$ | _ | _ | 12 | MHz | | Ambient temperature | $T_{A}$ | - 40 | _ | 110 | °C | | Standby current | $I_{DD}$ | _ | _ | 1 | μΑ | | Data-retention voltage | $V_{DH}$ | 1 | _ | _ | V | ## **DC Characteristics** $T_{\rm A}$ = 25 °C; all voltages referred to $V_{\rm SS}$ | Parameter | Symbol | Limit | Values | Unit | Test | | |-----------------------------------------------|----------------|------------------|----------|------|--------------------------------|--| | | | min. | max. | | Condition | | | All Input Signals Excep | t XTAL2 and Pl | <u> </u> | | | | | | H-input voltage | $V_{IH}$ | 2.2 | $V_{DD}$ | V | _ | | | L-input voltage | $V_{IL}$ | 0 | 0.8 | V | _ | | | Input capacitance | $C_{L}$ | _ | 10 | pF | _ | | | Input current | $I_{l}$ | ١ | 1 | μΑ | _ | | | XTAL2 (as external clo | ck input) | | | | | | | H-input voltage | $V_{IH}$ | 3.5 | $V_{DD}$ | V | _ | | | L-input voltage | $V_{IL}^{II}$ | 0 | 0.5 | V | _ | | | Input capacitance | | _ | 10 | pF | _ | | | PD (Schmitt-trigger cha | racteristics) | | | | 1 | | | H-input voltage | $V_{IH}$ | $V_{\rm DD}$ – 1 | $V_{DD}$ | V | _ | | | L-input voltage | $\mid V_{IL}$ | 0 | 1.0 | V | _ | | | Input capacitance | $C_{I}$ | _ | 10 | pF | _ | | | Output Signals AD10-1 | 7, AD20-27 | | | | | | | H-output voltage | $V_{QH}$ | 2.4 | $V_{DD}$ | V | $I_{\rm O} = 0.5 {\rm m}$ | | | L-output voltage | $V_{QL}$ | _ | 0.4 | V | $I_{\rm Q}^{\rm q}$ = 1.6 m/s | | | Output Signals WD1, W (open drain, weak pull- | | | | | | | | L-output voltage | $V_{QL}$ | _ | 0.4 | V | $I_{\rm Q}$ = 1.6 m/s | | | Output Signal Clock-Oเ | ıt | | | | • | | | H-output voltage | $V_{QH}$ | 2.4 | _ | V | $I_{\rm Q}$ = 0.5 m/ | | | L-output voltage | $V_{QL}$ | _ | 0.4 | V | $I_{\rm O}^{\alpha}$ = 1.6 m/s | | | Load capacitance | $C_{L}^{qL}$ | _ | 80 | pF | | | ## **AC Characteristics** The AC characteristics apply throughout the operating range $T_{\rm A}$ = 25 °C. | Parameter | Symbol | Limit | Unit | | |--------------------------------------------------|-------------------|-------------------------|-------------------------|----| | | | min. | max. | | | Read cycle time | $t_{CYR}$ | 300 + t <sub>LHLL</sub> | _ | ns | | Write cycle time | $t_{CYW}$ | 440 + t <sub>LHLL</sub> | _ | ns | | ALE pulse width | t <sub>LHLL</sub> | 40 | _ | ns | | Address setup to ALE low | t <sub>AVLL</sub> | 30 | _ | ns | | Address hold after ALE low | $t_{LLAX}$ | 40 | _ | ns | | RD pulse width | $t_{RLRH}$ | 120 | _ | ns | | WR pulse width | t <sub>WLWH</sub> | 120 | _ | ns | | ALE low to RD or WR active | $t_{LLWL}$ | 30 | _ | ns | | Data hold after RD high | $t_{RHDX}$ | 0 | 30 | ns | | ALE low to valid data out | $t_{LLDV}$ | _ | 290 | ns | | RD low to data valid (only scheduling registers) | $t_{RLDV}$ | _ | 2 t <sub>OSC</sub> + 20 | ns | | Valid data in after WR low | $t_{DVWL}$ | _ | 30 | ns | | WR low to ALE high | $t_{WLLH}$ | 150 | _ | ns | | Data setup before WR high | $t_{\sf QVWH}$ | 30 | _ | ns | | Data hold after WR high | $t_{WHQX}$ | 30 | _ | ns | | Delay RD low to both chip select active | $t_{RLCH}$ | _ | 20 | ns | | Delay WR low to both chip select active | $t_{WLCH}$ | _ | 20 | ns | | Set-up of chip select to RD *) | $t_{CLRL}$ | 0 | _ | ns | | Set-up of chip select to WR *) | $t_{CLWL}$ | 0 | _ | ns | <sup>\*)</sup> For deselection # AC Characteristics (cont'd) The AC characteristics apply throughout the operating range $T_{\rm A}$ = 25 °C. | Parameter | Symbol | Limit Values | | Unit | |--------------------------------------|-------------------|---------------------|---------------------|------| | | | min. | max. | | | Active pulse length of timer outputs | $t_{ACT}$ | 48 t <sub>OSC</sub> | 48 t <sub>OSC</sub> | ns | | Oscillator period | $t_{\rm OSC}$ | 83 | _ | ns | | High time | t <sub>OSCH</sub> | 35 | _ | ns | | Low time | $t_{ m SCL}$ | 35 | _ | ns | **Pulse Diagram 1** # Pulse Diagram 2 # **Note to Chip Select Timing:** The shown timing is not necessary, if the device is always activated or deactivated. This means either of CS or $\overline{\text{CS}}$ or both may be constant "high" or "low". **Pulse Diagram 3** ### Example of Application Circuit 1) 1) Design proposal (non-obligatory) # **Appendix** # 8051 Program for Timer Operation in Watchdog Mode | HBYTE | EQU | 1E3 <sub>H</sub> | ; Address high byte reload register | |-------|-----|------------------|-------------------------------------| | TMR | EQU | 1E0 <sub>H</sub> | ; Address timer-mode register | | CR | EQU | 1EC <sub>H</sub> | ; Address control register | | REST1 | EQU | 055 <sub>H</sub> | ; 1st value to restart timer | | REST2 | EQU | 0AA <sub>H</sub> | ; 2nd value to restart timer | | WDOFF | EQU | 040 <sub>H</sub> | ; Value to switch off watchdog mode | # ; Load reload register | MOV | DPTR, #HBYTE | |------|--------------| | CLR | Α | | MOVX | @DPTR,A | | DEC | DPL | | MOV | A, #0FFH | | MOVX | @DPTR,A | | DEC | DPL | | MOVX | @DPTR,A | # ; Set watchdog mode and start timer | MOV | A, #0AFH | |------|----------| | DEC | DPL | | MOVX | @DPTR,A | ### ; Reset timer | MOV | DPTR, #KR | |------|-----------| | MOV | A, #REST1 | | MOVX | @DPTR,A | | MOV | A, #REST2 | | MOVX | @DPTR,A | ; Switch off watchdog mode and halt timer # 8051 Program for Timer Operation in Watchdog Mode (cont'd) | MOV | DPTR, #KR | |------|------------| | MOV | A, #REST1 | | MOVX | @DPTR,A | | MOV | A, #WDOFF | | MOV | DPTR, #TMR | | MOVX | @DPTR,A | | MOV | A, #REST2 | | MOV | DPTR, #KR | | MOVX | @DPTR,A | | | | ; END