Semiconductor Products Sector Application Note **AN2187** # Emulating the HC08AZ32 Using the HC908AZ60A By Tracy McHenry Systems Engineering East Kilbride, Scotland ### 1 Introduction The purpose of this document is to help customers to use the HC908AZ60**A** (0.5 $\mu$ device) to emulate the HC08AZ32 (0.65 $\mu$ device). It highlights the differences between the two devices and provides a checklist to help with the development of compatible code. The main difference between the two devices is that HC908AZ60A is made from a new NVM technology and contains 60k of Flash and 1k of EEPROM, whereas the HC08AZ32 contains 32k of ROM and 512 bytes of EEPROM. There are other minor differences between the devices and these are discussed in this application note. The user should consider all differences when developing code that is to be used on both devices. # 2 Differences between the HC08AZ32 and the HC908AZ60A This section describes the differences between the HC08AZ32 and the HC908AZ60A. Each affected module is listed along with a summary of the changes. Freescale™ semiconductor ## 2.1 ROM versus FLASH On the HC08AZ32 device, code is stored in static, factory masked Read Only Memory (ROM) whereas on the HC908AZ60A, code is stored in non-volatile electrically erasable and programmable memory constructed from split-gate flash technology (Flash EEPROM). There is no difference when reading from either ROM or Flash memories however it should be noted that the HC908AZ60A has 60k of Flash whereas the HC08AZ32 has only 32k of ROM. The user is advised to consult the latest HC908AZ60A specification for details on programming the Flash module. ### 2.2 EEPROM This section will concentrate on the operation of the HC908AZ60A EEPROM module, which is made from a new NVM technology. HC908AZ60A EEPROM read operations remain the same as the HC08AZ32, however, program and erase operations are a super-set of the current HC08AZ32 algorithm. Also, the HC908AZ60A has two 512 byte EEPROM modules whereas the HC08AZ32 has one 512 byte EEPROM module. Each of the HC908AZ60A EEPROM modules contains 2 new registers that must be set up correctly before any attempt is made to program or erase. The new registers are required to provide the EEPROM with a constant timebase of 35µs from the user's oscillator frequency. It is important to spend time gaining familiarity with the new HC908AZ60A EEPROM as it is essential that the EEPROM module is set up correctly before any program or erase operations are called. Failure to do so could cause premature wear out of the EEPROM or could result in improper programming/erasing of the EEPROM. The basic programming and erase operations for the EEPROM on the HC08AZ32 and the EEPROM on the HC908AZ60A are the same. Also, bit polarity is the same with the programmed state being a logic 0 and the erased state a logic 1. The user is advised to consult the latest HC908AZ60A specification for details of program and erase algorithms. The HC908AZ60A EEPROM requires a constant timebase source for program and erase operations. The clock source that is required to drive the EEDIV clock divider input must first be selected using bit-7 in the Config-2 register at address \$FE09. Secondly, the divide ratio from this source has to be set up for each 512 byte EEPROM module by programming an 11-bit time base pre-scalar into the divider registers, EExDIVH and EExDIVL (where x is 1 or 2 depending on which EEPROM module is selected). These registers must be programmed with a proper value before starting any EEPROM erase or programming steps. The function of the divider is to provide a constant clock source with a period of $35\mu s$ (within $\pm 2\mu s$ ) to the internal timer and related EEPROM circuits for proper program or erase operations. The recommended frequency range of the reference clock is 250 KHz to 16 MHz. The EEDIV value is calculated by the following formula: EEDIV= INT[Reference Frequency(Hz) x 35 x $10^{-6}$ + 0.5] The result is rounded down to the nearest integer value. For example, if the Reference Frequency is 4.9152MHz, the EEDIV value in the above formula will be 172. To examine the time base output of the divider, the Reference Frequency is divided by the calculated EEDIV value (172), which equals to 28.577KHz in frequency or $34.99\mu s$ in period. The user must exercise caution when setting up the divide ratio - EExDIVH and EExDIVL are volatile registers. They have duplicate non-volatile registers, EExDIVHNVR and EExDIVLNVR whose contents are loaded into EExDIVH and EExDIVL upon reset. However, the user should remember to correctly set up the EExDIVH and EExDIVL registers **before** attempting to program the EExDIVHNVR and EExDIVLNVR non-volatile registers. In order to develop code compatible with the ROM and the Flash device, the software should first detect whether the device is a HC908AZ60A or a HC08AZ32. Figure 1 in section 3 shows a method for performing the device detection. If a HC908AZ60A is detected, then the user can perform one of the following two options in order to set up the EExDIVH/L registers. # Freescale Semiconductor, Inc. # Option 1: - 1. Write the required divider value into EExDIVH and EExDIVL. - Call the EEPROM programming routine and program EExDIVHNVR and EExDIVLNVR with the divider value that the user would like downloaded into EExDIVH and EExDIVL every time the device is reset. # Option 2: - In the user's initialisation routine that is called every time the device is reset and before any EEPROM program or erase operations are attempted, write the required divider value into EExDIVH and EExDIVL. - Ignore the non-volatile EExDIVHNVR and EExDIVLNVR registers. After a reset, the initialisation routine will be executed and the required divider value will be written into EExDIVH and EExDIVL. This will overwrite the default value of \$FF that was downloaded upon reset from EExDIVHNVR and EExDIVLNVR. ### **NOTE:** The EExDIVH and EExDIVL registers are shown below and it should also be noted that Bit-7, EEDIVSECD, of EExDIVH (and EExDIVHNVR) controls EEPROM security. If this bit is programmed to 0 after system reset the security feature is permanently enabled and the divider value in the EEDIV registers cannot be changed. | EE1DIVL | Bit-7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------|---------| | \$FE1B | EE1DIV7 | EE1DIV6 | EE1DIV5 | EE1DIV4 | EE1DIV3 | EE1DIV2 | EE1DIV1 | EE1DIV0 | Reset: EE1DIVLNVR EE1DIVLNVR EE1DIVLNVR EE1DIVLNVR EE1DIVLNVR EE1DIVLNVR EE1DIVLNVR | EE2DIVH | Bit-7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|------------|---|---|---|---|------------|------------|------------| | \$FF7A | EEDIVSECD | | | | | EE2DIV10 | EE2DIV9 | EE2DIV8 | | Reset: | EE2DIVHNVR | Х | Х | Х | Х | EE2DIVHNVR | EE2DIVHNVR | EE2DIVHNVR | | EE2DIVL | Bit-7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------|---------| | \$FF7B | EE2DIV7 | EE2DIV6 | EE2DIV5 | EE2DIV4 | EE2DIV3 | EE2DIV2 | EE2DIV1 | EE2DIV0 | Reset: EE2DIVLNVR EE2DIVLNVR EE2DIVLNVR EE2DIVLNVR EE2DIVLNVR EE2DIVLNVR EE2DIVLNVR EE2DIVLNVR The HC908AZ60A EEPROM also contains a new feature selected via an AUTO bit in the EEPROM control registers (EE1CR at address \$FE1D for EEPROM module 1 and EE2CR at address \$FF7D for EEPROM module 2). Setting bit-1 of these registers (which is an unused bit in the HC08AZ32 EECR) enables the AUTO function. The AUTO function enables significantly faster programming/erasing of the EEPROM by allowing the logic of the MCU to automatically use the optimum programming or erasing time for the EEPROM. Using the AUTO function means that the user does not need to wait for the normal minimum specified programming or erasing time. After setting the EEPGM bit as normal the user just has to poll that bit again, waiting for the MCU to clear it indicating that programming or erasing is complete. However, this feature is not available on the HC08AZ32, therefore, to keep code compatible with the HC08AZ32, the user is advised *not* to enable it. Finally, the HC908AZ60A has a special feature that designates the 16 bytes of addresses from \$08F0 to \$08FF in EEPROM-1 and the 16 bytes of addresses from \$06F0 to \$06FF in EEPROM-2 to be permanently secured. This security option is enabled by programming the EEPRTCT bit in the EEPROM Non-Volatile Register (EE1NVR, address \$FE1C and EE2NVR, address \$FF7C) to a logic 0. Once the EEPRTCT bit is programmed to 0 for the first time programming and erasing of secured locations \$08F0 to \$08FF of EEPROM-1 (or \$06F0 to \$06FF if EEPROM-2 is selected) is permanently disabled. Secured locations \$08F0 to \$08FF (or \$06F0 to \$06FF if EEPROM-2 is selected) can, # ication Note however, be read as normal. Programming and erasing of EENVR is permanently disabled and bulk and block erase operations are disabled for the unprotected locations (\$0800-\$08EF and \$0900-\$09FF for EEPROM-1 and \$0600-\$06EF and \$0700 to \$07FF for EEPROM-2). Single byte program and erase operations are still available for locations \$0800-\$08EF for EEPROM-1 (\$0600-\$06EF for EEPROM-2) and \$0900-\$09FF for EEPROM-1 (\$0700-\$07FF for EEPROM-2) for all bytes that are not protected by the EEPROM Block Protect, EEPBx, bits in EExNVR. Freescale Semiconductor, Inc. **NOTE:** Once armed, the protect option is permanently enabled. Consequently, all functions in the EExNVR will remain in the state they were in immediately before the security was enabled. # 2.3 Mask Options The HC08AZ32 uses mask option registers (MORA and MORB) to set up various options. The contents of MORA and MORB are selected by the user at ROM submission. Alternatively, the HC908AZ60A uses configuration registers (Config-1 and Config-2) that can be programmed by the user to select their required options. The configuration registers are write-once registers. Out of reset the configuration registers will read their default values. Once these registers have been written to, further writes will have no effect until a reset occurs. Owing to the differences between these registers (address and content), if code is to be developed that can be used on both devices then it is essential to detect whether the device is a HC908AZ60A or a HC08AZ32. Figure 1 in section 3 shows a method for completing this task. The code should be developed such that if a HC908AZ60A is detected, Config-1 and Config-2 are programmed with the required values. Also, Config-2 should only accessed when the device is a HC908AZ60A and that MORB should only be read when the device is a HC08AZ32. Finally, although MORA and Config-1 are located at the same address (\$001F) it is still important to know which device is present when reading that location as the polarity of several bits is different. # 2.3.1 Mask Option Register A versus Config-1 Register MORA and Config-1 registers are located at address \$001F however the polarity of several bits in these registers is different and are listed below. | MORA | Bit-7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------|----------------------|--------|---------|---------|-------|-------|------|------|--| | \$001F | LVISTOP | ROMSEC | LVIRSTD | LVIPWRD | SSREC | COPRS | STOP | COPD | | | Docoti | Lineffected By Decet | | | | | | | | | Reset: Unaffected By Reset | Config-1 | Bit-7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---------|---|--------|--------|-------|------|------|------| | \$001F | LVISTOP | R | LVIRST | LVIPWR | SSREC | COPL | STOP | COPD | | Reset: | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | Bit-2 on the HC08AZ32 is defined as a COP Rate Select (COPRS) bit to determine the timeout period of the COP and when selected as a '1' enables a long COP timeout period of 262128 cycles. Conversely, this bit is defined as a COP Long Timeout (COPL) bit on the HC908AZ60A and when selected as a '1' enables a short COP timeout period of 8176 cycles. Bit-4 on the HC08AZ32 is defined as the LVI Power Disable (LVIPWRD) bit and when selected as a '1' disables the LVI module power. However, this bit is defined as a LVI Power Enable (LVIPWR) bit on the HC908AZ60A and when set to a '1' enables the LVI module power. Bit-5 on the HC08AZ32 is defined as a LVI Reset Disable (LVIRSTD) bit and when selected as a '1' disables LVI module resets. Again, on the HC908AZ60A this bit is defined as a LVI reset enable (LVIRST) bit and when set to a '1' enables the reset signal from the LVI module. Bit 6 on the HC08AZ32 is defined as a ROM security bit (ROMSEC). Setting this bit enables the ROM security feature preventing access to the ROM contents. # Freescale Semiconductor, Inc. # 2.3.2 Mask Option Register B versus Config-2 Register MORB, a HC08AZ32 register, is located at address \$003F and contains only one active bit. The HC908AZ60A has a Config-2 register instead which is located at address \$FE09 and has several bits that are important to code development, in particular when writing to the EEPROM. The following bit descriptions refer to Config-2 (address \$FE09) of the HC908AZ60A. ## Bit-0 — AZxx This bit is used to configure the device as a 'AZ' device and should be set to a '1' by the user. ### Bit-3 — AT60A This is a device indicator read-only bit which identifies the device as new A-suffix silicon. If this bit is a '1' then it is HC908AZ60A silicon. This bit should only be used to distinguish between the $0.65\mu$ flash HC908AZ60 and the $0.5\mu$ flash HC908AZ60A. ### Bit-4 — MSCAND This bit is used to disable the MSCAN module. When set to a '1' the MSCAN module is disabled. ### Bit-7 — EEDIVCLK This is the EEPROM Timebase Divider Clock Select bit, which selects the reference clock source for the EEPROM timebase divider. Selected as a '1' means that the CPU bus clock (possibly the PLL) drives the EEPROM time base divider. A '0' selects CGMXCLK instead. # 2.4 Analogue to Digital Converter The user is required to select 15-channels versus 8-channels at ROM submission for the HC08AZ32, however, the user should note that the HC908AZ60A is always configured with a 15-channel analog to digital converter. ### **CAUTION:** The user should note that for devices configured with a 15 channel ADC, the pins used for ADC channels 12 and 14 also share their functions with timer clock inputs as well as general purpose I/O. Therefore, do not use channels 14 or 12 if using TACLK or TBCLK pins as the clock inputs for the 16-bit timers. # 2.5 Timer Interface Module A TIMA on the HC08AZ32 is a 4-channel timer whereas the HC908AZ60A's TIMA module is a 6-channel timer. The additional vectors for the HC908AZ60A are located at \$FFCC – \$FFCF which is ROM area on the HC08AZ32. For code compatibility these extra timer channels should not be used although the user should be aware of their existence. # 3 Differences Guide The flowchart shown in **Figure 1** illustrates a possible method for determining whether a device is a HC908AZ60A or a HC08AZ32. Figure 2 highlights the main code changes to run it on an HC908AZ60A. # cation Note Freescale Semiconductor, Inc. Figure 1: Method to detect a HC908AZ60A or a HC08AZ32 Figure 2: Main changes required to code to run it on a HC908AZ60A # 4 Conclusion All of the differences discussed above should be taken into account when developing code that can be used on both the HC908AZ60A and the HC08AZ32. In particular, it is important to gain familiarity with the polarity differences of several bits in the HC08AZ32 MORA register versus the HC908AZ60A Config-1 register. This will ensure that the various options are set up correctly regardless of what device is present (either the ROM HC08AZ32 or the Flash HC908AZ60A). Also, the key differences between the EEPROM on the HC08AZ32 and the EEPROM on the HC908AZ60A should be understood. Regarding the EEPROM on the HC908AZ60A, care should be taken when setting up the EExDIVH, EExDIVL, EExDIVHNVR and EExDIVLNVR registers to ensure that setting bit-7, EExDIVSECD, does not permanently enable the EEDIV security feature. This is essential if the EExDIV register values require to be changed. It is recommended that the required divider value is written into the EExDIV registers by writing to EExDIVL first, then EExDIVH, taking care over the value written to bit-7, EExDIVSECD of EExDIVH. Additionally, it is important to note that the EExDIVH and EExDIVL registers **must** be written with the required divider value before attempting to program or erase the EEPROM (including the no-volatile registers) to prevent the EEPROM from being severely damaged. Finally, the user is advised to read the relevant chapters of the latest HC08AZ32 and HC908AZ60A specifications to ensure all differences have been fully captured. # Freescale Semiconductor, Inc. #### How to Reach Us: #### Home Page: www.freescale.com #### E-mail: support@freescale.com ### **USA/Europe or Locations Not Listed:** Freescale Semiconductor Technical Information Center, CH370 1300 N. Alma School Road Chandler, Arizona 85224 +1-800-521-6274 or +1-480-768-2130 support@freescale.com #### Europe, Middle East, and Africa: Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) support@freescale.com #### Japan: Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064 Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com ### Asia/Pacific: Freescale Semiconductor Hong Kong Ltd. Technical Information Center 2 Dai King Street Tai Po Industrial Estate Tai Po, N.T., Hong Kong +800 2666 8080 support.asia@freescale.com #### For Literature Requests Only: Freescale Semiconductor Literature Distribution Center P.O. Box 5405 Denver, Colorado 80217 1-800-441-2447 or 303-675-2140 Fax: 303-675-2150 LDCForFreescaleSemiconductor@hibbertgroup.com Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document. Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters which may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the part.