# **Application Note**



# AR49-M49M, AR49-M25S Series 25-Bit Optical Single-Turn with 24-Bit **Energy-Harvesting Multi-Turn Absolute Encoder Modules**





### Overview

The Broadcom® AR49 series of optical absolute encoder modules offers up to 25-bit single-turn (ST) position information and 24-bit multi-turn (MT) counts, hence a combined 49-bit high resolution output. The ST block of the encoder consists of a patterned disk, a light source, and photosensitive elements to translate the mechanical motion into an electrical signal. It is designed with a selection of serial communication protocols, with a dedicated electronic circuit designed for a robust signal communication.

These encoders offer many intelligent features such as a built-in temperature sensor, user-programmable resolution, zero reset, system alarm, and more. They come with a recommended high-temperature range of -40°C to 115°C. One of the key advantages is the multi-turn tracking that employs a proprietary energy-harvesting (EH) technology by harvesting the magnetic energy while the patterned disk with magnet rotates. The counter ASIC harvests the energy generated by the EH sensor for processing rotational count and generating counting logics to the nonvolatile memory, which updates and stores the counting.

The entire operation of energy generation, counting, and storage processing is completed within limited energy and a short duration; hence, the kit encoder is suited for both lowspeed and high-speed measurements.

## **Applications**

- AC/DC servo motor feedback
- Medical and laboratory equipment
- Robotics
- Factory automation

**CAUTION!** This product is not specifically designed or manufactured for use in any specific devices. Customers are solely responsible for determining the suitability of the product for its intended application and solely liable for all loss, damage, expense, or liability in connection with such use. Contact Broadcom for further inquiry.

# **Mounting Requirement and Guideline**

The AR49 encoder module is designed with two options of centering method.

For guiding with the outer diameter (OD) or the inner diameter (ID) of the encoder module, the recommended motor mounting dimensions are shown in Figure 1.

Figure 1: Motor Mounting Dimension with 6-mm Shaft Size

#### **Guide Outer Diameter**



Figure 2: Assembly Guidelines for Mounting Requirement with OD Guiding



NOTE: Applicable for both ST and MT options.

Figure 3: Assembly Guidelines for Mounting Requirement with ID Guiding



Figure 4: Recommended Shield Cover Dimensions



To eliminate or minimize the influence of the external magnetic field interference on encoder operation, use of shielding is mandatory for the AR49-M49M multi-turn options.

Recommended shield cover material: Mild steel SPCC-SD, thickness 0.8 mm (minimum).

Finishing: Ni plating 8 μm to 12 μm thick, with Cu under coating 2 μm to 4 μm.

Figure 5: Shield Cover Reference Design with Inner Diameter Guided Mounting



**NOTES:** Unless otherwise specified:

- 1. Fold radius = 0.5 mm.
- 2. Parts to be burr free.
- 3. This is a partially dimensioned drawing. For non-tolerance features, the following tolerance applies:



Critical dimensions.



Figure 6: Shield Cover Reference Design with Outer Diameter Guided Mounting



NOTES: Unless otherwise specified:

- 1. Fold radius = 0.5 mm.
- 2. Parts to be burr free.
- 3. This is a partially dimensioned drawing. For non-tolerance features, the following tolerance applies:



Critical dimensions.



VIEW-C

# **Encoder Memory Area**

The AR49 supports 8 kb of user register area. The memory data is kept in a nonvolatile memory. The available register pages and banks are accessible by the user and unlocked.

There are additional register pages reserved for system areas that are protected against accidental writing during operation. The memory data is kept in nonvolatile memories.

Table 1: AR49 Encoder Memory Overview

| For S    | PI/RS485 | For I    | BiSS-C  |                                                                           |
|----------|----------|----------|---------|---------------------------------------------------------------------------|
| Page     | Address  | Bank     | Address | Content                                                                   |
|          | 0x00     |          | 0x00    |                                                                           |
| 0 to 4   | ::       | 0 to 9   | ::      | Nonvolatile Memory (External EEPROM) – User                               |
|          | 0x7E     |          | 0x3F    |                                                                           |
|          | 0x00     |          | 0x00    |                                                                           |
| 5        | ::       | 10 to 11 | ::      | Nonvolatile Memory (Internal – Accuracy, Sub-grating Correction, IEC LUT) |
|          | 0x7E     |          | 0x3F    |                                                                           |
|          | 0x00     |          | 0x00    |                                                                           |
| 6        | ::       | 12 to 13 | ::      | Nonvolatile Memory (Internal – Accuracy, Once-Around Correction, OAC LUT) |
|          | 0x7E     |          | 0x3F    |                                                                           |
|          | 0x00     |          | 0x00    |                                                                           |
| 7        | ::       | 14 to 15 | ::      | Nonvolatile Memory (Internal) – System-User Area                          |
|          | 0x7E     |          | 0x3F    |                                                                           |
|          | 0x00     |          | 0x00    |                                                                           |
| 8        | ::       | 16 to 17 | ::      | Nonvolatile Memory (Internal) – System-Factory Area                       |
|          | 0x7E     |          | 0x3F    |                                                                           |
|          | 0x00     |          | 0x00    |                                                                           |
| 9 to 10  | ::       | 18 to 21 | ::      | Fixed Volatile Memory (Registers)                                         |
|          | 0x7E     |          | 0x3F    |                                                                           |
|          | 0x00     |          | 0x00    |                                                                           |
| 11 to 13 | ::       | 22 to 27 | ::      | Nonvolatile Memory (External EEPROM) – User                               |
|          | 0x7E     |          | 0x3F    |                                                                           |

### SPI/RS485 Memory

- A total of 8 pages with 127 addresses each are allocated for user access.
- The active page numbers are specified in address 0x7F. Page change is done by writing to address 0x7F. The default page after power-on is Page 0.
- Once the page value is changed, allow a time delay of 18 ms.
- Typical EEPROM read time is 200 µs minimum.
- Typical EEPROM write time is 6 ms minimum.
- Page 9 and 10 are volatile memory addresses reserved for encoder system use.

### **BiSS-C Memory**

- A total of 16 banks with 64 addresses each are allocated for user access.
- The active page numbers are specified in address 0x40.
- Bank change is done by writing to address 0x40.
- Banks 18 to 21 are volatile memory addresses reserved for encoder system use.

AR49-Series-AN101 Broadcom

# **System Memory for Encoder Configuration**

Table 2: Encoder Memory Map for Calibration and Special Commands

|       | BiSS-C |       | Standar | d SSI/SF | PI/RS485 |                     |                  | AR49                 | Registers a         | and Comma             | nds                   |                          |                          |
|-------|--------|-------|---------|----------|----------|---------------------|------------------|----------------------|---------------------|-----------------------|-----------------------|--------------------------|--------------------------|
| Bank  | Add    | ress  | Page    | Add      | ress     |                     |                  |                      | Bi                  | t                     |                       |                          |                          |
| [dec] | [dec]  | [hex] | [dec]   | [dec]    | [hex]    | 7                   | 6                | 5                    | 4                   | 3                     | 2                     | 1                        | 0                        |
|       | 0      | 00    |         | 0        | 00       |                     |                  | Ur                   | nlock Registe       | r Write (ABh          | )                     |                          |                          |
|       | 1      | 01    |         | 1        | 01       |                     |                  |                      | Memory Prog         | gram (C0h)            |                       |                          |                          |
|       | 2      | 02    |         | 2        | 02       |                     |                  |                      |                     |                       | Alarm<br>Clear        | ST Offset                | MT Offset                |
|       | 3      | 03    |         | 3        | 03       |                     |                  | Factory Re           | eserved (USE        | R Prohibited          | d Access)             |                          |                          |
|       | 4      | 04    |         | 4        | 04       |                     |                  |                      |                     |                       |                       | AutoCal_<br>NoAcc_<br>En | AutoCal_<br>Full_En      |
|       | 5      | 05    |         | 5        | 05       |                     | IEC_<br>Cal_En   | Acc_Cal_<br>RST      | Acc_<br>Cal2_En     | Acc_<br>Cal1_En       | MPhase_<br>En         | MLS_<br>Vpp_Cal_<br>En   | Inc_Cal_<br>En           |
|       | 6      | 06    |         | 6        | 06       |                     |                  |                      | MT_Sync_<br>En      | CMA_<br>CCW_En        | CMA_<br>CW_En         | FeRAM_<br>Clear          | CM_Test_<br>En           |
|       | 8      | 08    |         | 8        | 08       |                     |                  |                      |                     |                       | Vwc_<br>Mon_En        | CMA_<br>Clear_ EN        | XC_<br>Comp_<br>Clear_En |
|       | 9      | 09    |         | 9        | 09       |                     | 1                | ŀ                    | EHMT Regist         | ter Byte 0x7          |                       |                          |                          |
|       | 10     | 0A    |         | 10       | 0A       | EHMT_<br>Test_ Mode |                  |                      |                     |                       |                       |                          |                          |
| 18    | 11     | 0B    | 9       | 11       | 0B       |                     |                  | Н                    | ard Reset Re        | egister (A7h)         |                       |                          |                          |
|       | 13     | 0D    |         | 13       | 0D       |                     |                  |                      | EHMT Paran          | neter [15:8]          |                       |                          |                          |
|       | 14     | 0E    |         | 14       | 0E       |                     |                  |                      | EHMT Para           | meter [7:0]           |                       |                          |                          |
|       | 15     | 0F    |         | 15       | 0F       |                     |                  |                      | EHMT CI             | MD[7:0]               |                       |                          |                          |
|       | 34     | 0x22  |         | 34       | 0x22     |                     | Reserved         |                      | TempErr             | Memory<br>Err         | Config<br>Code Err    | STErr                    | MLSErr                   |
|       | 35     | 0x23  |         | 35       | 0x23     |                     | Rese             | erved                |                     | Reserved              | Reserved              | LisErr<br>(IncErr)       | LedErr                   |
|       | 40     | 28    |         | 40       | 28       |                     |                  |                      |                     |                       |                       | AutoCal_<br>Error        | Auto_<br>Cal_<br>Done    |
|       | 41     | 29    |         | 41       | 29       | Acc_Cal_<br>Err     | Acc_Cal_<br>Done | MPhase_<br>Error     | MPhase_<br>Done     | MLS_<br>Vpp_<br>Error | MLS_<br>Vpp_<br>Done  | Inc_Cal_<br>Error        | INC_Cal_<br>Done         |
|       | 42     | 2A    |         | 42       | 2A       | EEPROM_<br>Err      |                  |                      |                     |                       | CM_<br>Test_<br>Done  |                          |                          |
|       | 43     | 2B    |         | 43       | 2B       |                     | CMA_<br>Busy     | CMA_<br>CCW_<br>Done | CMA_<br>CW_<br>Done | EHMT_<br>Error        | EHMT_<br>XC_<br>Alarm | CMA_<br>Error            |                          |

### NOTE:

- The memory program command is needed for the system area memory to be effective upon power cycle; applicable for changes to internal memory pages 5 to 8 (banks 10 to 17).
- Perform the memory program command for changes to any of the affected banks before moving to other nonvolatile memory banks.
- Changes will be lost after a power cycle without a memory program command.

#### **Change Memory Page/Bank**

- 1. Write the required page value in hex into Address 0x7F. For example, Data 09h (Go to Page 9) for RS485/SPI.
- 2. Write the required bank value in hex into Address 0x40. For example, Data 12h (Go to Bank 18) for BiSS-C.

#### **Unlock Register Write**

- 1. Go to Page 9, 0x09 (BiSS-C Bank 18, 0x12).
- 2. Write address 0x00: Data ABh (unlock Level 1).

#### **Memory Programming**

- 1. Go to Page 9, 0x09 (BiSS-C Bank 18, 0x12).
- 2. Write address 0x01: Data C0h (page programming).
- 3. Wait at least 320 ms.
- 4. Power cycle the encoder.

#### **EHMT Counter Soft Reset**

- 1. Unlock Register Write.
- 2. Go to Page 9, 0x09 (BiSS-C Bank 18, 0x12).
- 3. Write address 0x0F: Data 0Fh.

Table 3: Encoder Memory Map for MT Related Data

|       | Standard |       |       | BiSS-C |       |                                 | En | ergy-Ha | arvesting | Multi-T   | urn (EHI  | MT) |   |
|-------|----------|-------|-------|--------|-------|---------------------------------|----|---------|-----------|-----------|-----------|-----|---|
| Page  | Add      | ress  | Bank  | Add    | dress |                                 |    |         | E         | Bit       |           |     |   |
| [dec] | [dec]    | [hex] | [dec] | [dec]  | [hex] | 7                               | 6  | 5       | 4         | 3         | 2         | 1   | 0 |
|       | 57       | 39    |       | 57     | 39    |                                 |    | Е       | HMT Ret   | urned D   | ata       | 1   |   |
|       | 62       | 3E    | 18    | 62     | 3E    | EHMT CMA Offset Value [15:8]    |    |         |           |           |           |     |   |
|       | 63       | 3F    |       | 63     | 3F    | EHMT CMA Offset Value [7:0]     |    |         |           |           |           |     |   |
|       | 64       | 40    |       | 0      | 00    | EHMT_XC_ERR_Compensation [15:8] |    |         |           |           |           |     |   |
|       | 65       | 41    |       | 1      | 01    |                                 | Е  | HMT_X   | C_ERR_    | Compen    | sation [7 | :0] |   |
| 9     | 66       | 42    |       | 2      | 02    |                                 |    |         | 1N4T A1 A | DMAD      | utoo      |     |   |
|       | 67       | 43    | 19    | 3      | 03    |                                 |    | ЕГ      | HMT_ALA   | ARIVI Z D | ytes      |     |   |
|       | 68       | 44    | 19    | 4      | 04    | FUNT OL 4 O D 4                 |    |         |           |           |           |     |   |
|       | 69       | 45    |       | 5      | 05    | EHMT Status 2 Bytes             |    |         |           |           |           |     |   |
|       | 70       | 46    |       | 6      | 06    | EHMT_VWC_DATA 2 Bytes           |    |         |           |           |           |     |   |
|       | 71       | 47    |       | 7      | 07    | ETHINT_VWC_DATA 2 Bytes         |    |         |           |           |           |     |   |

**Table 4: EHMT Status and Alarm Registers** 

|       | BiSS-C |       |       | Standard | d     |                  |              | Energ           | y-Harvesti      | ng Multi-Turr       | (EHMT)              |                    |             |
|-------|--------|-------|-------|----------|-------|------------------|--------------|-----------------|-----------------|---------------------|---------------------|--------------------|-------------|
| Bank  | Add    | ress  | Page  | Add      | ress  |                  |              |                 |                 | Bit                 |                     |                    |             |
| [dec] | [dec]  | [hex] | [dec] | [dec]    | [hex] | 7                | 6            | 5               | 4               | 3                   | 2                   | 1                  | 0           |
|       | 02     | 0x02  |       | 66       | 0X42  |                  |              |                 |                 |                     |                     | MemErr             | MagLO       |
|       | 03     | 0x03  |       | 67       | 0x43  | VWC<br>Quality   | XC_<br>Error | CMA_<br>Timeout | VWC_<br>Timeout | Speed_<br>VWC       | Speed_<br>CMA       | Speed_<br>MT       | MT Error    |
| 19    | 04     | 0x04  | 9     | 68       | 0x44  | Alarm<br>Trigger |              |                 | DUT<br>Ready    |                     |                     |                    |             |
|       | 05     | 0x05  |       | 69       | 0x45  |                  |              | Reserved        | Reserved        | VWC Result<br>Ready | CMA<br>CCW<br>Ready | CMA<br>CW<br>Ready | MT<br>Ready |

# **Register Bit for Counting Direction Selection**

**Table 5: Encoder Counting Direction** 

| Page      | Address |     | Bit                   |     |   |   |   |   |   |               |  |  |
|-----------|---------|-----|-----------------------|-----|---|---|---|---|---|---------------|--|--|
| [Decimal] | [hex]   | 7   | 6                     | 5   | 4 | 3 | 2 | 1 | 0 | Default Value |  |  |
| 7         | 20      | N/A | Counting<br>Direction | N/A |   |   |   |   |   | 8'h40h        |  |  |

With the default setting (bit 6 = 0), position data is counting up when rotating in a counter-clockwise direction, as viewed from the top of the encoder.

Figure 7: Default Counting Direction



View from the top



### **Position Zero Reset**

The encoder zero reset data can be accessed by reading the addresses in Table 6.

Table 6: User Zero-Reset Registers

| Page  |       | RS485<br>dress | Bank  | BiSS-C | Address |                 | Bit         |  |       |          |  | Default |     |     |
|-------|-------|----------------|-------|--------|---------|-----------------|-------------|--|-------|----------|--|---------|-----|-----|
| [dec] | [dec] | [dec]          | [dec] | [hex]  | [hex]   | 7 6 5 4 3 2 1 0 |             |  |       |          |  |         |     |     |
|       | 16    | 10             |       | 16     | 10      |                 |             |  | MT_ZF | R[23:16] |  |         |     | 00h |
|       | 17    | 11             |       | 17     | 11      |                 | MT_ZR[15:8] |  |       |          |  |         | 00h |     |
| 7     | 18    | 12             | 14    | 18     | 12      |                 |             |  | MT_Z  | :R[7:0]  |  |         |     | 00h |
| /     | 19    | 13             | 14    | 19     | 13      | ST_ZR[24:17]    |             |  |       |          |  |         | 00h |     |
|       | 20    | 14             |       | 20     | 14      | ST_ZR[16:9]     |             |  |       |          |  |         | 00h |     |
|       | 21    | 15             |       | 21     | 15      | ST_ZR[8:1]      |             |  |       |          |  | 00h     |     |     |

### **Auto Zero-Reset (Single-Turn Position)**

When the codewheel/hub is stationary, execute the ST Reset command so that the single-turn position output value will be reset to the zero value.

- 1. Option 1 with memory bit setting:
  - a. Unlock Register Write.
  - b. Write Page 9/Bank 18, Address 0x02[1] = 1b.
- 2. Option 2 with the dedicated zero reset commands for the RS485, SPI or BiSS-C protocols.

## **Auto Zero-Reset (Multi-Turn Counter Output)**

- 1. Option 1 with memory bit setting:
  - a. Unlock Register Write.
  - b. Write to Page 9/Bank 18, Address 0x02[0] = 1b.
- 2. Option 2 with the dedicated multi-turn zero reset commands for the RS485, SPI or BiSS-C protocols.

The multi-turn value will be reset to the zero value when this command is completed.

# Multi-Turn and Single-Turn Absolute Resolution Setting

Select the configuration for the absolute position output by updating the Page 7/Bank 14 Address 0x16, see Table 7 and Table 8.

- 1. Unlock Register Write.
- 2. Write in the new settings at Page 7/Bank 14, read back to ensure the setting is written successfully.
- 3. Program memory.

Table 7: Multi-Turn and Single-Turn Bits Setting Description for SPI/SSI/BiSS-C Protocols

| Page (SPI/SSI) | Bank<br>(BiSS-C) | Address | Bits | Name             | Settings | SPI/SSI<br>25-Bit Output |
|----------------|------------------|---------|------|------------------|----------|--------------------------|
|                |                  |         | 7    | Reserved         | Х        | N/A                      |
|                |                  |         |      |                  | 000      | 0                        |
|                |                  |         |      |                  | 001      | 12                       |
|                |                  |         |      |                  | 010      | 14                       |
|                |                  |         | 6.4  | MT. Coloct [O:0] | 011      | 16                       |
|                | 0x0E             | 0x16    | 6:4  | MT_Select [2:0]  | 100      | 18                       |
|                |                  |         |      |                  | 101      | 20                       |
|                |                  |         |      |                  | 110      | 22                       |
|                |                  |         |      |                  | 111      | 24                       |
|                |                  |         |      |                  | 0000     | 15                       |
| 0x07           |                  |         |      |                  | 0001     | 16                       |
|                |                  |         |      |                  | 0010     | 17                       |
|                |                  |         |      |                  | 0011     | 18                       |
|                |                  |         |      |                  | 0100     | 19                       |
|                |                  |         | 2.0  | CT Colort [2:0]  | 0101     | 20                       |
|                |                  |         | 3:0  | ST_Select [3:0]  | 0110     | 21                       |
|                |                  |         |      |                  | 0111     | 22                       |
|                |                  |         |      |                  | 1000     | 23                       |
|                |                  |         |      |                  | 1001     | 24                       |
|                |                  |         |      |                  | 101x     | 25                       |
|                |                  |         |      |                  | 11xx     | 25                       |

NOTE: For ST only option, the MT selection is defaulted to binary 000.

Table 8: Multi-Turn and Single-Turn Bits Setting Description for RS485 Protocols

| Page | Address | Bits | Name            | Settings | RS485 24 Bits ST Output | RS485 25 Bits ST Output |
|------|---------|------|-----------------|----------|-------------------------|-------------------------|
|      |         | 7    | Reserved        | х        | N/A                     | N/A                     |
|      |         |      |                 | 000      | 0                       | 0                       |
|      |         |      |                 | 001      | 12                      | 12                      |
|      |         |      |                 | 010      | 14                      | 14                      |
|      |         | C. 1 | MT Calact [0:0] | 011      | 16                      | 16                      |
|      |         | 6:4  | MT_Select [2:0] | 100      | 18                      |                         |
|      |         |      |                 | 101      | 20                      | NI/A                    |
|      |         |      |                 | 110      | 22                      | N/A                     |
|      |         |      |                 | 111      | 24                      |                         |
| 0x07 | 0x16    |      |                 | 0000     | 17                      | 15                      |
| UXU7 | UXIO    |      |                 | 0001     | 18                      | 16                      |
|      |         |      |                 | 0010     | 19                      | 17                      |
|      |         |      |                 | 0011     | 20                      | 18                      |
|      |         |      |                 | 0100     | 21                      | 19                      |
|      |         | 3:0  | ST_Select [3:0] | 0101     | 22                      | 20                      |
|      |         |      |                 | 0110     | 23                      | 21                      |
|      |         |      |                 | 0111     | 24                      | 22                      |
|      |         |      |                 | 1000     |                         | 23                      |
|      |         |      |                 | 1001     | N/A                     | 24                      |
|      |         |      |                 | 1010     |                         | 25                      |

# **Encoder Error and Warning Setting**

To enable the Error or Warning bits in the ALMC field, set the respective bit to 1, disable 0.

Table 9: Error and Warning Bits Configuration Addresses

| Page | Address [hex]           | 7                        | 6 | 5     | 4       | 3        | 2                | 1 | 0   | Default Value |  |  |
|------|-------------------------|--------------------------|---|-------|---------|----------|------------------|---|-----|---------------|--|--|
|      | 30 Alarm Enable [31:24] |                          |   |       |         |          |                  |   | 1Fh |               |  |  |
|      | 31                      |                          |   | Ala   | FFh     |          |                  |   |     |               |  |  |
|      | 32                      |                          |   | Al    | arm En  | able [15 | :8]              |   |     | 1Bh           |  |  |
| 7    | 33                      |                          |   | Α     | larm Er | able [7: | 0]               |   |     | 0Fh           |  |  |
| ,    | 34                      |                          |   | Alarm | Latch E | nable [  | able [31:24] 1Fh |   |     |               |  |  |
|      | 35                      |                          |   |       |         |          |                  |   |     |               |  |  |
|      | 36                      |                          |   | Alarn | 0Bh     |          |                  |   |     |               |  |  |
|      | 37                      | Alarm Latch Enable [7:0] |   |       |         |          |                  |   |     | 0Eh           |  |  |

Table 10: AR49 Alarm Bits Assignment

|      | Alarm Bits |       |               |              |                 |              |              |  |
|------|------------|-------|---------------|--------------|-----------------|--------------|--------------|--|
| 31   | 30         | 29    | 28            | 27           | 26              | 25           | 24           |  |
|      | Reserved   | •     | MT Sync Error | Reserved     | MT Protocol Err | Rese         | erved        |  |
| 23   | 22         | 21    | 20            | 19           | 18              | 17           | 16           |  |
| Rese | erved      | XCErr | Reserved      | EHMT Counter | EHMT Counter    | EHMT Counter | EHMT Counter |  |
|      |            |       |               | Err[9:3]     | Err[2]          | Err[1]       | Err[0]       |  |
| 15   | 14         | 13    | 12            | 11           | 10              | 9            | 8            |  |
|      | Reserved   |       | TempErr       | Memory       | Reserved        | STErr        | MLSErr       |  |
|      |            |       |               | Err          |                 |              | (McodeErr)   |  |
| 7    | 6          | 5     | 4             | 3            | 2               | 1            | 0            |  |
|      |            | Res   | served        |              |                 | LisErr       | LEDErr       |  |
|      |            |       |               |              |                 | (IncErr)     |              |  |

# **SPI4 Error or Warning Readout and Descriptions**

For SPI4 protocol option, send the operation command (OC) 0x9Ch to perform error or warning bits readout. To perform segregation between Error or Warning bits, see the AR49 alarm bits settings in Table 10. Enable the Error or Warning bits in the operation command (OC) 0x9Ch by setting the respective bit to 1. Conversely, setting a bit to 0 will disable the particular bit.

Table 11: SPI4 Protocol Error and Warning Bits Masking Assignment

| Page | Address [hex]                | 7                        | 6 | 5    | 4         | 3        | 2       | 1 | 0 | Default Value |
|------|------------------------------|--------------------------|---|------|-----------|----------|---------|---|---|---------------|
|      | 28 SPI4 Warning Mask [31:24] |                          |   |      |           |          |         |   |   | 00h           |
|      | 29                           |                          |   | SPI4 | Warning   | Mask     | [23:16] |   |   | 10h           |
|      | 2A                           |                          |   | SPI4 | Warnin    | g Mask   | [15:8]  |   |   | 10h           |
| 7    | 2B                           |                          |   | SPI4 | l Warnir  | g Mask   | [7:0]   |   |   | 03h           |
| ,    | 2C                           |                          |   | SPI  | 4 Error I | Лask [3  | 1:24]   |   |   | 1Fh           |
|      | 2D                           |                          |   | SPI  | 4 Error I | /lask [2 | 3:16]   |   |   | EFh           |
|      | 2E                           |                          |   | SPI  | 0Bh       |          |         |   |   |               |
|      | 2F                           | 2F SPI4 Error Mask [7:0] |   |      |           |          |         |   |   | 0Ch           |

# **Encoder Alarm Definition**

The following table shows the encoder alarm bits and their definition across all protocol options.

Table 12: AR49-M49M and AR49-M25S General Encoder Alarms and Definition Table

| Alarms            | Alarms Definition                                                                                    | Check Frequency          |
|-------------------|------------------------------------------------------------------------------------------------------|--------------------------|
| TempErr           | Temperature Error.                                                                                   | Every 90 ms              |
|                   | To indicate the temperature exceeds the maximum preset limit.                                        |                          |
|                   | 1: Temperature above preset limit.                                                                   |                          |
|                   | 0: Temperature below preset limit.                                                                   |                          |
| Memory            | MEM Error (Memory Error).                                                                            | Upon power-up and memory |
| Err               | To indicate if loading of internal and external EEPROM contents upon encoder power up is successful. | read                     |
|                   | ■ 1: Failure to access EEPROM memory data/or there is a checksum error in the memory.                |                          |
|                   | 0: Normal operation, no EEPROM memory access error                                                   |                          |
| STErr             | Single-turn Counting Error.                                                                          | Per ADC sample           |
|                   | To check the integrity of ST position.                                                               |                          |
|                   | <ul><li>1: Error in Absolute (MLS) code or MLSErr flag has triggered.</li></ul>                      |                          |
|                   | 0: Normal operation, no error in single-turn position.                                               |                          |
| MLSErr (McodeErr) | To detect error in MLS code generation.                                                              | Per ADC sample           |
|                   | ■ 1: MLS code error.                                                                                 |                          |
|                   | O: MLS code good.                                                                                    |                          |
| LisErr            | Lissajous (Incremental) Error.                                                                       | Per ADC sample           |
| (IncErr)          | A measure of integrity of ADC Sin & Cos signals by means of Lissajous specifications.                |                          |
|                   | ■ 1: Lissajous out of specification.                                                                 |                          |
|                   | 0: Lissajous within specification.                                                                   |                          |
| LEDErr            | LED Error.                                                                                           | Continuous detect        |
|                   | To indicate if LED current is out of operating range.                                                |                          |
|                   | <ul><li>1: LED out of operating range.</li></ul>                                                     |                          |
|                   | 0: LED within operating range.                                                                       |                          |

Table 13: AR49-M49M Encoder Multi-Turn Alarms and Definition Table

| Alarms            | Alarms Definition                                                           | Check Frequency         |
|-------------------|-----------------------------------------------------------------------------|-------------------------|
| MT Sync Error     | EHMT Sync Error.                                                            | Upon MT synchronization |
|                   | To detect wrong MT counting during MT counter synchronization.              |                         |
|                   | ■ 1: Error in multi-turn synchronization.                                   |                         |
|                   | 0: No error in multi-turn synchronization.                                  |                         |
| MT Protocol Error | To detect an MT encoder protocol error – energy harvesting (Wiegand).       | Per MT encoder polling  |
|                   | ■ 1: MT encoder protocol error.                                             |                         |
|                   | 0: No MT encoder protocol error.                                            |                         |
| XCErr             | To indicate an MT encoder miscount by comparing the EHMT counter vs. the MT | Each time ST rolls over |
|                   | software counter.                                                           |                         |
|                   | <ul><li>1: EHMT: Miscount or XCERR value overflow.</li></ul>                |                         |
|                   | ■ 0: No MT miscount.                                                        |                         |

Table 13: AR49-M49M Encoder Multi-Turn Alarms and Definition Table (Continued)

| Alarms                | Alarms Definition                                                                                                                             | Check Frequency        |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| EHMT Counter Err[9:3] | MT Counter Error.                                                                                                                             | Per MT encoder polling |
|                       | To detect error receive from EHMT counter.                                                                                                    |                        |
|                       | ■ 1: EHMT Counter Error Bits [9:3] triggers.                                                                                                  |                        |
|                       | 0: No EHMT counter errors.                                                                                                                    |                        |
| EHMT Counter Err[2]   | MT Counter Error.                                                                                                                             | Per MT encoder polling |
|                       | To detect Error receive from EHMT counter.                                                                                                    |                        |
|                       | ■ 1: EHMT Counter Error Bit[2] triggers.                                                                                                      |                        |
|                       | 0: No EHMT Counter Errors                                                                                                                     |                        |
| EHMT Counter Err[1]   | MT Counter Error.                                                                                                                             | Per MT encoder polling |
|                       | To detect error receive from EHMT counter.                                                                                                    |                        |
|                       | ■ 1: EHMT Counter Error Bit[1] triggers.                                                                                                      |                        |
|                       | 0: No EHMT counter errors.                                                                                                                    |                        |
| EHMT Counter Err[0]   | MT Error.                                                                                                                                     | Per MT encoder polling |
|                       | To detect error on reading MT Hardware counter value or I <sup>2</sup> C communication error.                                                 |                        |
|                       | <ul><li>1: Error in MT position reading, the EHMT Counter Error Bit[0] triggers.</li><li>0: No error in MT position reading.</li></ul>        |                        |
| MT Counter Error      | MT Counter Error.                                                                                                                             | Per MT encoder polling |
|                       | To detect Error bit received from the EHMT Counter Error register.                                                                            |                        |
|                       | ■ 1: Any of the EHMT Counter Err[9:1] bit triggers.                                                                                           |                        |
|                       | 0: No EHMT counter error.                                                                                                                     |                        |
| MT Error              | MT Error for BiSS-C and RS485 Protocols.                                                                                                      | Per MT encoder polling |
|                       | To detect error on reading MT hardware counter value or I <sup>2</sup> C communication error. Same as the EHMT Counter Error Bit[0] triggers. |                        |

Table 14: AR49-M49M EHMT Counter Error Register Definition

| EHMT Counter Error Bit | Name             | EHMT Counter Error[9:0] Description                                          |
|------------------------|------------------|------------------------------------------------------------------------------|
| 0                      | MT Error         | Error occurs on reading hardware multi-turn value or I <sup>2</sup> C stuck. |
| 1                      | Speed_MT         | Motor exceeds 15000RPM for MT synchronization.                               |
| 2                      | Speed_CMA        | Motor exceeds 200RPM for CMA calibration.                                    |
| 3                      | Speed_VWC        | Motor exceeds speed limit for VWC monitoring.                                |
| 4                      | VWC_Timeout      | Less than 700 VWC pulses detected within 90 seconds.                         |
| 5                      | CMA_Timeout      | VWC pulses not detected within 10 seconds.                                   |
| 6                      | Counter XC_Error | Continuous miscount for 5 revolutions.                                       |
| 7                      | VWC Quality      | VWC voltage less than 4.0V.                                                  |
| 8                      | MT_MagLO         | MT Counter ASIC detects no or low magnetic field.                            |
| 9                      | MT_MemErr        | FeRAM related error.                                                         |

### **Alarm Clear:**

- 1. Option 1 with memory bit setting
  - a. Unlock Register Write.
  - b. Write to Page 9/Bank 18, Address 0x02[2] = 1b.
- 2. Option 2 with Alarm Clear Command of the respective RS485, SPI, or BiSS-C protocols.

# **Temperature Sensor**

For the setting of temperature values and alarms, the configuration is as listed in Table 15. The temperature upper limit is defaulted to 0x7D, which is 125°C, referenced to the ambient temperature as measured by the AR49 encoder ASIC. The encoder temperature readout bit, which is an example of the data as 2's complement, is listed in Table 17.

Table 15: SSI/SPI/RS485 Temperature Sensor Setting

| S     | SI/SPI/RS4 | 85    |     |                                              |       |             |               |           |   |  |     |  |  |
|-------|------------|-------|-----|----------------------------------------------|-------|-------------|---------------|-----------|---|--|-----|--|--|
| Page  | Add        | ress  | Bit |                                              |       |             |               |           |   |  |     |  |  |
| [dec] | [dec]      | [hex] | 7   | 7 6 5 4 3 2 1 0                              |       |             |               |           |   |  |     |  |  |
|       | 2          | 02    |     | 1                                            | Tempe | rature Uppe | er Limit Offs | set [7:0] | 1 |  | 00h |  |  |
| 7     | 3          | 03    |     |                                              | 7     | Temperature | e Offset [7:0 | 0]        |   |  | 00h |  |  |
| ,     | 4          | 04    |     | Temperature Upper Limit [7:0]                |       |             |               |           |   |  |     |  |  |
|       | 5          | 05    |     | Temperature Output Data (Read only register) |       |             |               |           |   |  |     |  |  |

Table 16: BiSS-C Temperature Sensor Setting

|       | BiSS-C |             |   |                 |            |             |               |                |   |  |         |  |  |
|-------|--------|-------------|---|-----------------|------------|-------------|---------------|----------------|---|--|---------|--|--|
| Bank  | Addı   | Address Bit |   |                 |            |             |               |                |   |  | Default |  |  |
| [dec] | [dec]  | [hex]       | 7 | 7 6 5 4 3 2 1 0 |            |             |               |                |   |  |         |  |  |
|       | 2      | 02          |   |                 | Tempe      | rature Uppe | er Limit Offs | set [7:0]      |   |  | 00h     |  |  |
| 14    | 3      | 03          |   |                 | T          | emperature  | Offset [7:0   | 0]             |   |  | 00h     |  |  |
| 14    | 4      | 04          |   |                 | Ten        | perature U  | pper Limit    | [7:0]          |   |  | 7Dh     |  |  |
|       | 5      | 05          |   |                 | Temperatur | e Output Da | ata (Read c   | only register) | ) |  | _       |  |  |
|       | 117    | 75          |   |                 | Temperatur | e Output Da | ata (Read c   | only register) | ) |  | _       |  |  |
| _     | 73     | 49          |   |                 |            |             |               | Temp.<br>Alarm |   |  | 0       |  |  |

Table 17 is an example based on an initial alarm (Page 7/Bank 14, Address 0x04) setting of 125°C. The temperature offset can be a positive or negative value.

**Table 17: Temperature Sensor Offset Setting Example** 

|      | Temperature<br>Sensor Offset<br>Register | 0x02                                       | 0x03                        | 0x04                             | 0x05                        | Remark                                     | s                |
|------|------------------------------------------|--------------------------------------------|-----------------------------|----------------------------------|-----------------------------|--------------------------------------------|------------------|
| Case | Offset Value<br>(Decimal)                | Temperature<br>Upper Limit<br>Offset (hex) | Temperature<br>Offset (hex) | Temperature<br>Upper Limit (hex) | Temperature<br>Output (Dec) | Raw Temperature<br>without Offset<br>(Dec) | Alarm<br>Trigger |
|      |                                          |                                            |                             |                                  | 124                         | 124                                        | No               |
| 1    | 0                                        | 0                                          | 0                           | 7D                               | 125                         | 125                                        | Yes              |
|      |                                          |                                            |                             |                                  | 126                         | 126                                        | Yes              |
|      |                                          |                                            |                             |                                  | 124                         | 114                                        | No               |
| 2    | 10                                       | 0A                                         | 0A                          | 7D                               | 125                         | 115                                        | Yes              |
|      |                                          |                                            |                             |                                  | 126                         | 116                                        | Yes              |

Table 17: Temperature Sensor Offset Setting Example (Continued)

|      | Temperature<br>Sensor Offset<br>Register | Sensor Offset                              |                             | set                              |                             |     | 0x05             | Remarks |  |  |  |
|------|------------------------------------------|--------------------------------------------|-----------------------------|----------------------------------|-----------------------------|-----|------------------|---------|--|--|--|
| Case | Offset Value<br>(Decimal)                | Temperature<br>Upper Limit<br>Offset (hex) | Temperature<br>Offset (hex) | Temperature<br>Upper Limit (hex) | Temperature<br>Output (Dec) |     | Alarm<br>Trigger |         |  |  |  |
|      |                                          |                                            |                             |                                  | 124                         | 125 | No               |         |  |  |  |
| 3    | -1                                       | 0                                          | FF                          | 7D+01                            | 125                         | 126 | Yes              |         |  |  |  |
|      |                                          |                                            |                             |                                  | 126                         | 127 | Yes              |         |  |  |  |
|      |                                          |                                            |                             |                                  | 124                         | 134 | No               |         |  |  |  |
| 4    | -10                                      | 0                                          | F6                          | 7D+0A                            | 125                         | 135 | Yes              |         |  |  |  |
|      |                                          |                                            |                             |                                  | 126                         | 136 | Yes              |         |  |  |  |

#### NOTE:

- Case 1: No offset scenario.
- Case 2: If the temperature offset (Address 0x03) is a positive value, the temperature upper limit offset (Address 0x02) is also set to the same value.
- Case 3: If the temperature offset (Address 0x03) is a negative value, the absolute value of this value must be added to the default temperature upper limit (Address 0x04).
- Case 4: Another negative offset value example.
- The register addresses are at SPI/RS485 Page 7 or BiSS-C Bank14.

**Table 18: Temperature Sensor Data** 

| Temperature | TEMP[7:0] |
|-------------|-----------|
| -64         | 1100 0000 |
| -50         | 1100 1110 |
| -20         | 1110 1100 |
| -1          | 1111 1111 |
| 0           | 0000 0000 |
| 1           | 0000 0001 |
| 10          | 0000 1010 |
| 25          | 0001 1001 |
| 50          | 0011 0010 |
| 85          | 0101 0101 |
| 127         | 0111 1111 |
| 159         | 1001 1111 |
| 191         | 1011 1111 |

#### NOTE:

- The minimum support range for temperature output is -64°C.
- The negative values are from -1°C to -64°C only.
- The maximum positive value is 191°C.
- The temperature readout is found by accessing memory register at Page 7 Address 0x05 (see Table 15).
- For BiSS-C, the temperature readout is found by accessing the memory register at Address 0x75 (see Table 16).
- When reading using RS485-24-Bit format Command ID4 as per Table 39, the temperature data (TEMP) is available as the DF<sub>7</sub>.

# **Encoder Calibration**

The Broadcom encoder employs an intelligent calibration method by performing an auto signal optimization once the encoder is mounted within assembly tolerances. This eliminates the hassle of mechanically adjusting the encoder position to a very tight gap and mechanical center.

Figure 8: Encoder Signal Optimization and Accuracy Calibration Flow



Upon completion of the encoder assembly to the motor, perform the calibration process as follows:

- 1. Connect the AR49-M49-E01 programming and calibration kit to a computer via USB connection.
- 2. Connect encoder cable-end to encoder.
- 3. Follow the required steps to complete the ST and MT calibrations.
- 4. Update any user-specific configurations after calibration is completed.
- 5. The encoder is ready to use.

### NOTE:

- If the calibration continues to fail after consecutive trials, confirm the encoder codewheel and module installation again by referring to the codewheel and encoder mounting requirements and guidelines.
- Clear the ST and MT offset registers to all zeros before starting the ST and MT calibration process.

Figure 9: Example of the AR49-M49-E01 Calibration Kit and Its User Interface Software



The Programming/Calibration Kit with a USB PC Interface Cable and an Encoder Connecting Cable

The Programming/Calibration GUI Software

# **ST Angular Position Accuracy Correction**

Figure 10: Accuracy Correction with Reference Encoder Using the AR25-AC25 Calibration Station



Figure 11: Example of the Position Accuracy Error Before and After Correction



## ST Calibration of the AR49-M49M/M25S Encoders

## ST Auto-Calibration without Accuracy Correction

The position accuracy correction table will not be updated. The other signals' calibration after assembly will be performed. It is recommended to perform this calibration option unless the spindle motor (to drive the AR49 + motor assembly) can fulfill the low-speed ripple requirements for accuracy correction.

- 1. Unlock memory (Write Page 9/Bank 18, Address 0x00 = ABh).
- 2. Spin the spindle motor in a clockwise (CW) direction at a fixed constant speed. It is recommended to be within 60 rpm to 1000 rpm. Wait for the motor speed to be stable before starting the next step.
- 3. Write Page 9/Bank 18, Address 0x04[1] = 1b1.
- 4. Loop reading calibration status at Address 0x28.
- 5. If Address 0x28[1:0] = 00b, the calibration is in progress. Otherwise, if the value is 01b, the calibration is done; or if the value is 1xb, there is a calibration error and the calibration is not successful.
- 6. Clear the calibration register, Address 0x04 = 00h. If unsuccessful, repeat Steps 3 to 5 (repeat up to 10 times).
- 7. Check the assembly of the codewheel and encoder for any abnormality if calibration is not successful.

Figure 12: Flowchart for Full Auto-Calibration Process without Accuracy Correction



## Full ST Auto-Calibration with Accuracy Correction Enabled

Figure 13: Flowchart for Full Auto-Calibration Process



### Calibrate in Clockwise (CW) Direction

- 1. Unlock memory (Write Page 9/Bank 18, Address 0x00 = ABh).
- 2. Spin the spindle motor in a CW direction at a fixed constant speed within 60 rpm to 3000 rpm (it is recommend to select the least ripple speed, not to exceed 5000 rpm). Wait for the motor speed to be stable before starting the next step.
- 3. Write Page 9/Bank 18, Address 0x04[0] = 1b.
- 4. Loop reading calibration status at Address 0x28.
- 5. If Address 0x28[1:0] = 00b, the calibration is in progress. Otherwise, if the value is 01b, the calibration is done; or if the value is 1xb, there is a calibration error and it is not successful.
- 6. Clear the calibration register, Address 0x04 = 00h. If unsuccessful, repeat Steps 3 to 5 (repeat up to 10 times).
- 7. Check the assembly of the codewheel and encoder for any abnormality if calibration is not successful.

**CAUTION!** Only calibrate the encoder with the full auto-calibration mode with accuracy correction when the assembled AR49 encoder is being driven by a highly stable servo motor; for example, controlled to the speed of 1000 rpm ± 0.2%, or better.

**CAUTION!** The ST offset register has to be cleared to all zeros before this calibration process that involves generating the accuracy correction look-up table (LUT).

### **ST Position Code Monotony Measurement**

The AR49 encoder has a built-in function to measure and monitor the code monotony of the ST position data. This step is not mandatory but provides a way to verify that the position output after calibration is normal without any sudden shift in position data. The code monotony value is measured as a 23-bit ST step at every 10-ns interval. The readout value is in 2's complement.

- 1. Unlock memory (Write Page 9/Bank 18, Address 0x00 = ABh).
- 2. Enable the code monotony measurement by writing Page 9/Bank 18, Address 0x06 = 01h.
- 3. Spin the spindle motor in a CW direction for >3 revolutions at a low speed, for example, 2 rpm to 60 rpm.
- 4. Read Page 9, Address 0x4F to 0x52 for the measured data. For BiSS-C, read Bank 19, Address 0x0F to 0x12.
- 5. End the code monotony measurement by writing Page 9/Bank 18, Address 0x06 = 00h.
- 6. Stop the motor. Repeat Steps 2 to 5 in a counter-clockwise (CCW) direction.

Figure 14: Code Monotony Self-Test Flowchart



**Table 19: Code Monotony Measurement Registers** 

| RS485         | Add   | ress  | BiSS-C        | Add   | ress               | Bit |   |   |   |           |        |   |            |
|---------------|-------|-------|---------------|-------|--------------------|-----|---|---|---|-----------|--------|---|------------|
| Page<br>[dec] | [dec] | [hex] | Bank<br>[dec] | [dec] | [hex]              | 7   | 6 | 5 | 4 | 3         | 2      | 1 | 0          |
|               | 6     | 06    | 18            | 6     | 06                 |     |   |   |   |           |        |   | CM_Test_En |
|               | 79    | 4F    |               | 15    | 15 0F CM_Max[15:0] |     |   |   |   |           |        |   |            |
| 9             | 80    | 50    | 10            | 16    | 10                 |     |   |   | C | ivi_iviax | [13.0] |   |            |
|               | 81    | 51    | 19            | 17    | 11                 |     |   |   | _ | NA Minl   | 15:01  |   |            |
|               | 82    | 52    |               | 18    | 12                 |     |   |   |   |           |        |   |            |

## Multi-Turn Calibration of the AR49-M49M Encoders

### **MT Calibration**

For the MT option of the AR49-M49M encoders, it is compulsory to perform the MT calibration procedures after the encoder has been assembled. For the optimum results, the shield should also be assembled during this process.

Figure 15: AR49-M49M Encoder MT Calibration Flow



### **Pre-Set the MT Memory Settings**

- 1. Motor condition: Static.
  - a. Unlock Register Write.
  - b. Write Address 0x7F to Data 09h (go to Page 9) or for BiSS-C: Write Address 0x40 to Data 12h (go to Bank 18).
  - c. Write Address 0x00 to Data ABh (unlock level 1).
- 2. Trigger MT counter soft reset.
  - a. Write Address 0x0F to Data 0Fh (trigger MT counter soft reset command). Wait 20 ms.
- 3. Set default MT configuration.
  - a. Write Address 0x0A to Data 80h (MT counter test mode, Bit 7 set to High).

Table 20: MT Calibration Command and Related Registers

| Stan  | dard SS<br>RS485 |       | ı     | BiSS-C |       | Key AR49 Registers/Commands          |                         |                      |                     |                          |                          |                 |                       |  |  |
|-------|------------------|-------|-------|--------|-------|--------------------------------------|-------------------------|----------------------|---------------------|--------------------------|--------------------------|-----------------|-----------------------|--|--|
| Page  | Add              | ress  | Bank  | Add    | ress  |                                      |                         |                      | В                   | it                       |                          |                 |                       |  |  |
| [dec] | [dec]            | [hex] | [dec] | [dec]  | [hex] | 7                                    | 6                       | 5                    | 4                   | 3                        | 2                        | 1               | 0                     |  |  |
|       | 6                | 06    |       | 6      | 06    |                                      |                         |                      |                     | CMA_<br>CCW_En           | CMA_<br>CW_En            | FeRAM_<br>Clear |                       |  |  |
|       | 08               | 08    |       | 08     | 08    |                                      |                         |                      |                     |                          | VWC_<br>Trigger          |                 | XC_<br>Comp_<br>Clear |  |  |
|       | 10               | 0A    |       | 10     | 0A    | MT_Test_<br>Mode                     |                         |                      |                     |                          |                          |                 |                       |  |  |
|       | 15               | 0F    |       | 15     | 0F    |                                      | MT Counter Command[7:0] |                      |                     |                          |                          |                 |                       |  |  |
|       | 43               | 2B    | 18    | 43     | 2B    | MT_<br>Protocol_<br>Error            | CMA_<br>Busy            | CMA_<br>CCW_<br>Done | CMA_<br>CW_<br>Done | MT_<br>Counter_<br>Error | MT_<br>Counter_<br>Alarm | CMA_<br>Error   | MT_<br>Sync_<br>Error |  |  |
|       | 48               | 30    |       | 48     | 30    |                                      |                         |                      | 1                   | MT[38:32]                | 1                        | 1               |                       |  |  |
|       | 49               | 31    |       | 49     | 31    |                                      |                         |                      | MT[3                |                          |                          |                 |                       |  |  |
|       | 50               | 32    |       | 50     | 32    |                                      |                         |                      | MT[2                | 3:16]                    |                          |                 |                       |  |  |
| 9     | 51               | 33    |       | 51     | 33    |                                      |                         |                      | MT[                 | 15:8]                    |                          |                 |                       |  |  |
|       | 52               | 34    |       | 52     | 34    |                                      |                         |                      | MT[                 | 7:0]                     |                          |                 |                       |  |  |
|       | 62               | 3E    |       | 62     | 3E    |                                      |                         |                      | CMA_Of              | fset[15:8]               |                          |                 |                       |  |  |
|       | 63               | 3F    |       | 63     | 3F    |                                      |                         |                      | CMA_O               | ffset[7:0]               |                          |                 |                       |  |  |
|       | 66               | 42    |       | 2      | 02    |                                      |                         |                      |                     |                          |                          | MT_<br>MemErr   | MT_<br>MagLO          |  |  |
|       | 67               | 43    |       | 3      | 03    | VWC<br>Quality                       | XC_<br>Error            | CMA_<br>Timeout      | VWC_<br>Timeout     | Speed_<br>VWC            | Speed_<br>CMA            | Speed_<br>MT    | MT Error              |  |  |
|       | 68               | 44    | 19    | 4      | 04    | Alarm<br>Trigger                     |                         |                      | DUT<br>Ready        |                          |                          |                 |                       |  |  |
|       | 69               | 45    |       | 5      | 05    |                                      |                         | Reserved             | Reserved            | VWC<br>Result<br>Ready   | CMA<br>CCW<br>Ready      | CMA CW<br>Ready | MT<br>Ready           |  |  |
|       | 70               | 46    |       | 6      | 06    | EH Pulse VWC data; Average – 4 Sigma |                         |                      |                     |                          |                          |                 |                       |  |  |
|       | 71               | 47    |       | 7      | 07    |                                      |                         | EH                   | Pulse VW0           | C data – M               | ean                      |                 |                       |  |  |

## First FeRAM and Alarm Clear

- 1. Motor condition: Static.
- 2. Unlock Register Write.
- 3. Trigger MT counter soft reset.
- 4. Set default MT configuration.
- 5. FeRAM clear.
  - a. Write Address 0x06 to Data 02h (FeRAM clear command, Bit 1 set to High).
- 6. Read back 39 bits of the FeRAM MT value.
  - a. Read back 39 bits value from Page 9/Bank 18 Address 0x30 to 0x34,
  - b. Confirm its value is 0 ± 1 revolution.

## Codewheel Zero to Magnet Zero Alignment (CMA) Calibration

- 1. Motor condition: Spin 100 rpm in the CW direction.
- 2. Unlock Register Write.
- 3. Trigger MT counter soft reset.
- 4. Set default MT configuration.
- 5. CMA clock wise calibration.
  - a. Write Address 0x06 to Data 04h.
  - b. Wait for at least 1.2 seconds (2 revolutions at the speed of 100 rpm).
  - c. Read Address 0x2B. Expected data return 10h.
- 6. Motor condition: Spin 100 rpm in the CCW direction.
- 7. CMA counter clockwise calibration.
  - a. Write Address 0x06 to Data 0Ch.
  - b. Wait for at least 1.2 seconds (2 revolutions at the speed of 100 rpm).
  - c. Read Address 0x2B. Expected data return 30h.
- 8. CMA completed. AR49 will automatically program the CMA value into the memory.
- 9. Power cycle and read back the AR49 CMA value and confirm it has been set.
  - a. Read Address 0x3E and 0x3F. Expected data returned not equal to 00h.

Figure 16: CMA Calibration Direction Definition



Clockwise direction when looking toward the encoder shaft-end

Table 21: CMA Calibration Command and Related Registers

| Stan  | Standard SSI/SPI/<br>RS485 BiSS-0 |       |       |       |       | Key AR49 Registers/Commands |              |                      |                     |                          |                          |               |                       |  |
|-------|-----------------------------------|-------|-------|-------|-------|-----------------------------|--------------|----------------------|---------------------|--------------------------|--------------------------|---------------|-----------------------|--|
| Page  | Add                               | ress  |       | Bank  |       |                             | Bit          |                      |                     |                          |                          |               |                       |  |
| [dec] | [dec]                             | [hex] | [dec] | [dec] | [hex] | 7                           | 6            | 5                    | 4                   | 3                        | 2                        | 1             | 0                     |  |
|       | 6                                 | 06    | 18    | 6     | 06    |                             |              |                      |                     | CMA_<br>CCW_En           | CMA_<br>CW_En            |               |                       |  |
|       | 10                                | 0A    |       | 10    | 0A    | MT_ Test_<br>Mode           |              |                      |                     |                          |                          |               |                       |  |
| 9     | 43                                | 2B    |       | 43    | 2B    | MT_<br>Protocol_<br>Error   | CMA_<br>Busy | CMA_<br>CCW_<br>Done | CMA_<br>CW_<br>Done | MT_<br>Counter_<br>Error | MT_<br>Counter_<br>Alarm | CMA_<br>Error | MT_<br>Sync_<br>Error |  |
|       | 62                                | 3E    |       | 62    | 3E    | CMA_Offset [15:8]           |              |                      |                     |                          |                          |               |                       |  |
|       | 63                                | 3F    |       | 63    | 3F    | CMA_Offset [7:0]            |              |                      |                     |                          |                          |               |                       |  |

### **Second FeRAM Clear**

- 1. Motor condition: Move 1 revolution, and then stop at AR49 ST position ~90 degrees.
- 2. Unlock Register Write.
- 3. Trigger MT counter soft reset.
- 4. Set default MT configuration.
- 5. FeRAM clear.
  - a. Write Address 0x06 to Data 02h (FeRAM clear command, Bit-1 set to High).
- 6. Read back 39 bits of FeRAM MT value.
  - a. Read back 39 bits value from Page 9/Bank 18 Address 0x30 to 0x34.
  - b. Confirm that its value is  $0 \pm 1$  revolution.

Table 22: EHMT Cross-Check Error Compensation and Related Registers

| Stan  | dard SS<br>RS485 | I/SPI/ |       | BiSS-C | :     |                             |              | Key A           | R49 Regis       | ters/Com            | mands              |               |                       |
|-------|------------------|--------|-------|--------|-------|-----------------------------|--------------|-----------------|-----------------|---------------------|--------------------|---------------|-----------------------|
| Page  | Add              | ress   | Bank  | Add    | Iress |                             |              |                 | В               | it                  |                    |               |                       |
| [dec] | [dec]            | [hex]  | [dec] | [dec]  | [hex] | 7                           | 7 6 5 4      |                 |                 | 3                   | 2                  | 1             | 0                     |
|       | 08               | 08     |       | 08     | 08    |                             |              |                 |                 |                     |                    |               | XC_<br>Comp_<br>Clear |
|       | 34               | 22     | 18    | 34     | 22    | Reserved Temp_ N            |              |                 |                 | Mem_<br>Err         | Config<br>Code Err | STErr         | MLS_<br>Err           |
|       | 35               | 23     |       | 35     | 23    | Reserved                    |              |                 |                 |                     |                    | Lis_Err       | LED_<br>Err           |
|       | 64               | 40     |       | 0      | 00    |                             |              | EHMT_X          | C_ERR_C         | ompensat            | tion [15:8]        |               |                       |
| 9     | 65               | 41     |       | 1      | 01    |                             |              | EHMT_           | XC_ERR_0        | Compensa            | tion [7:0]         |               |                       |
|       | 66               | 42     |       | 2      | 02    |                             |              | Rese            | erved           |                     |                    | MT_<br>MemErr | MT_<br>MagLO          |
|       | 67               | 43     | 19    | 3      | 03    | VWC<br>Quality              | XC_<br>Error | CMA_<br>Timeout | VWC_<br>Timeout | Speed_<br>VWC       | Speed_<br>CMA      | Speed_<br>MT  | MT Error              |
|       | 68               | 44     |       | 4      | 04    | Alarm Reserved DUT Ready Re |              |                 |                 |                     | Rese               | erved         |                       |
|       | 69               | 45     |       | 5      | 05    | Reserved VWC Result         |              |                 |                 | CMA<br>CCW<br>Ready | CMACW<br>Ready     | MT<br>Ready   |                       |

## **Alarm and Compensation Register Clear**

- 1. Motor condition: Static.
- 2. Unlock Register Write.
- 3. Execute XC ERR compensation clear command as follows:
  - a. Write Address 0x08 to Data 01h (XC compensation clear command)
- 4. Alarm clear.
  - a. Write Address 0x02 to Data 04h (alarm clear command).
  - b. Delay 100 ms.
- 5. Read back AR49 XC\_ERR compensation value and confirm it has been cleared.
  - a. Read Address 0x40 and 0x 41. Expected data return 00h.
- 6. Read Back AR49 and MT counter alarm status.
  - a. Read Address 0x42 and 0x43. Expected data return 0000h.
  - b. Read Address 0x44 and 0x45. Expected data return 1001h.
  - c. Read Address 0x22 and 0x23. Expected data return 0000.

## **EH Pulse Voltage Monitoring**

The AR49 has a built-in function to measure and monitor the EH pulse voltage level (VWC). Measurement must be conducted with the final encoder assembly inclusive of the external shield cover.

- 1. Unlock Register Write.
- 2. Set the default MT configuration.
- 3. Enable VWC monitoring self-check by writing Page 9/Bank 18 Address 0x08 = 04h.
- 4. Spin the spindle motor in the clockwise (CW) direction for >350 rotations at 3000 rpm.
- 5. Loop reading calibration status Page 9, Address 0x45 (BiSS-C Bank19, Address 0x05).
  - a. If Bit[3] = 1b, the measurement is done.
- 6. End VWC monitoring self-check by writing Page 9/Bank 18, Address 0x08 = 00h.
- 7. Read Page 9, Address 0x46 to 0x47 (BiSS-C Bank19, Address 0x06 and 0x07) for the measured data.
- 8. Stop the motor. Repeat Steps 2 to 6 in the counter-clockwise (CCW) direction.
- 9. Clear the default MT configuration.

**Table 23: EH Pulse Monitoring Measurement Registers** 

| S     | PI/RS48 | 5     |       | BiSS-C |       | Description       |                        |                                                                           |   | В            | Bit                    |                      |   |             |
|-------|---------|-------|-------|--------|-------|-------------------|------------------------|---------------------------------------------------------------------------|---|--------------|------------------------|----------------------|---|-------------|
| Page  | Add     | ress  | Bank  | Add    | ress  |                   |                        |                                                                           |   |              |                        |                      |   |             |
| [dec] | [dec]   | [hex] | [dec] | [dec]  | [hex] |                   | 7                      | 6                                                                         | 5 | 4            | 3                      | 2                    | 1 | 0           |
|       | 8       | 08    | 18    | 8      | 08    | Command           |                        |                                                                           |   |              |                        | Vwc_<br>Mon_<br>Trig |   |             |
|       | 68      | 44    |       | 4      | 04    | Status            | Alarm<br>Trigger       |                                                                           |   | DUT<br>Ready |                        |                      |   |             |
| 9     | 69      | 45    | 19    | 5      | 05    | (Read Only)       |                        |                                                                           |   |              | VWC<br>Result<br>Ready |                      |   | MT<br>Ready |
|       | 70      | 46    |       | 6      | 06    | MT Counter<br>VWC |                        | EH Pulse VWC data, Average – 4 Sigma<br>(Target value: 53 to 100 decimal) |   |              |                        |                      |   |             |
|       | 71      | 47    |       | 7      | 07    | (Read Only)       | FU Dulas VMC data Maan |                                                                           |   |              |                        |                      |   |             |

**Table 24: EH Pulse Monitoring Target Specifications** 

| Parameters  | Conditions                              | Min. | Тур. | Max. | Unit |
|-------------|-----------------------------------------|------|------|------|------|
| (Mean – 4σ) | Potation around 2000 revolutions/minute | 5.3  | _    | 10   | V    |
| Mean        | Rotation speed 3000 revolutions/minute  | 5.6  | _    | 10   | V    |

Figure 17: VWC Monitoring Self Test Flowchart



# **General Specification of SPI 4-Wire Serial Communication**

# **Overview of the 4-Wire Serial Peripheral Interface (SPI4)**

Table 25: General Specification of SPI4 Serial Communication

| Item                        | Specification                         | Note                                                          |
|-----------------------------|---------------------------------------|---------------------------------------------------------------|
| Transmission type           | Serial Peripheral Interface (SPI)     |                                                               |
| Communication type          | Single-ended                          |                                                               |
| Synchronization type        | Synchronous                           |                                                               |
| Communication Baud rate     | Up to 10.0 Mb/s                       |                                                               |
| Frame Length                | Number of bits depending on operation |                                                               |
| Transmission Error Checking | 6 bits CRC                            | $G(X) = X^6 + X^1 + 1$                                        |
|                             | 16 bits CRC                           | $G(X) = X^{16} + X^{15} + X^{12} + X^7 + X^6 + X^4 + X^3 + 1$ |

An SPI4 serial communication is established between the encoder (client) and the host (for example, a servo driver) in a single-ended transmission format. The encoder will carry out specific operations based on the command requests made by the host.

Figure 18: General Transmission Frames Format for SPI-4 Wires



#### NOTE:

- When NCS = 1, MISO = high-Z (to support multi-encoder bus mode).
- During the first 8 clocks, MISO always echoes the operation command received on the MOSI line (to support the multi-encoder bus mode).
- SPI Mode 0 and SPI Mode 3.are implemented.

**Table 26: SPI4 Timing Specifications** 

| Symbol          | Description                      | Min. | Тур. | Max. | Unit |
|-----------------|----------------------------------|------|------|------|------|
| t <sub>C1</sub> | Permissible Clock Cycle Time     | 100  | _    | _    | ns   |
| t <sub>L1</sub> | Clock Signal Low Level Duration  | 50   | _    | _    | ns   |
| t <sub>L2</sub> | Clock Signal High Level Duration | 50   | _    | _    | ns   |
| t <sub>S1</sub> | Setup Time:                      | 50   | _    | _    | ns   |
|                 | NCS lo before SCLK Low→High      |      |      |      |      |
| t <sub>H1</sub> | Hold Time:                       | 80   | _    | _    | ns   |
|                 | NCS lo after SCLK Low→High       |      |      |      |      |

**Table 26: SPI4 Timing Specifications (Continued)** 

| Symbol          | Description                            | Min. | Тур. | Max. | Unit |
|-----------------|----------------------------------------|------|------|------|------|
| t <sub>W1</sub> | Wait Time:                             | 200  | _    | _    | ns   |
|                 | Between NCS Low→High and NCS High→Low  |      |      |      |      |
| t <sub>H2</sub> | Hold Time:                             | 20   | _    | _    | ns   |
|                 | MOSI Stable after SCLK Low→High        |      |      |      |      |
| t <sub>S2</sub> | Setup Time:                            | 15   | _    | _    | ns   |
|                 | MOSI Stable before SCLK Low→ High      |      |      |      |      |
| t <sub>P1</sub> | Propagation Delay:                     | _    | 51   | _    | ns   |
|                 | MISO Stable after SCLK High→Low        |      |      |      |      |
| t <sub>P2</sub> | Propagation Delay:                     | _    | 10   | 35   | ns   |
|                 | MISO High Impedance after NCS Low→High |      |      |      |      |

# **SPI4 Cyclic Redundancy Check Setting (CRC)**

Table 27: SPI4 CRC Settings

|      | Address |   |   |   |      | Bit     |                   |   |                 |               |                                   |
|------|---------|---|---|---|------|---------|-------------------|---|-----------------|---------------|-----------------------------------|
| Page | [hex]   | 7 | 6 | 5 | 4    | 3       | 2                 | 1 | 0               | Default Value | Description                       |
| 7    | 25      |   |   |   |      |         |                   |   | SPI4_Ext_<br>EN | 00h           | 6bits CRC: "0"<br>16bits CRC: "1" |
| /    | 26      |   |   |   | SPI4 | 00h     | CRC Initial Value |   |                 |               |                                   |
|      | 27      |   |   |   | SPI  | 4 CRC [ | 7:0]              |   |                 | 00h           | CRC midal value                   |

# **Encoder Read Out Frame Sets Format and Timing**

Figure 19: Register Read Operation Diagram



When NCS is low, the communication line is activated and the data is sampled on the rising edge of SCK.

The MISO state turns to high impedance mode (hi-Z) when NCS is high. The transmission works over specific operation command (OC).

**Table 28: SPI4 Operation Commands** 

| Operation       |                |       |           | CLK Bits                         |                 |   |     |       |                |       |       |              |               |                |                |           |                |                 |            |
|-----------------|----------------|-------|-----------|----------------------------------|-----------------|---|-----|-------|----------------|-------|-------|--------------|---------------|----------------|----------------|-----------|----------------|-----------------|------------|
| Command<br>(OC) | Description    | Ports | Byte<br>1 |                                  |                 |   |     | Byte  | 2              |       |       | Byte<br>3    | Byte<br>4     | Byte<br>5      | Byte<br>6      | Byte<br>7 | Byte<br>8      | Byte<br>9       | Byte<br>10 |
|                 | Activate       | MOSI  | В0        | 1                                | 0               | 0 | 0   | 0     | 0              | RA0   | PA0   |              |               |                |                |           |                |                 |            |
| 0xB0            | (1 encoder)    | MISO  | В0        | 0                                | 0               | 1 | 0   | 0     | 0              | 0     | 0     |              |               |                |                |           |                |                 |            |
| UXDU            | Activate       | MOSI  | В0        | 1                                | 0               | 0 | 0   | RA0   | PA0            | RA1   | PA1   |              |               |                |                |           |                |                 |            |
|                 | (2 encoder)    | MISO  | В0        | 0                                | 0               | 0 | 0   | 1     | 0              | 0     | 0     |              |               |                |                |           |                |                 |            |
|                 |                | MOSI  | A6        |                                  |                 |   |     |       |                |       |       |              |               |                |                |           |                |                 |            |
| 0xA6            | Position Read  | MISO  | A6        | Position Data + nError + nWarnin |                 |   |     | _     | CRC/Poence + 0 |       | ing + | -            |               |                |                |           |                |                 |            |
| 0x81            | Register Read  | MOSI  | 81        |                                  | ADDRESS(ADDR) 0 |   |     |       |                |       | 00h   |              |               |                |                |           |                |                 |            |
| UXOI            | (Continuous)   | MISO  | 81        | 81 ADDRESS(ADDR)                 |                 |   |     |       |                |       |       | 00h          | DATA1         | DATA2          |                |           |                |                 |            |
| 0xCF            | Register Write | MOSI  | CF        | ADDRESS(ADDR)                    |                 |   |     |       | DATA1          | DATA2 |       |              |               |                |                |           |                |                 |            |
| UXCF            | (Continuous)   | MISO  | CF        | ADDRESS(ADDR)                    |                 |   |     |       |                |       |       | DATA1        | DATA2         |                |                |           |                |                 |            |
|                 |                | MOSI  | 9C        |                                  |                 |   |     |       |                |       |       |              |               |                |                |           |                |                 |            |
| 0x9C            | Read Status    | MISO  | 9C        |                                  | 00h             |   |     |       |                |       |       | ERR<br>[7:0] | ERR<br>[15:8] | ERR<br>[23:16] | ERR<br>[31:24] |           | WARN<br>[15:8] | WARN<br>[23:16] |            |
| 0xD9            | Write          | MOSI  | D9        |                                  |                 |   | С   | OMMA  | ND             |       |       |              |               |                |                |           |                |                 |            |
| 0XD9            | Command        | MISO  | D9        |                                  |                 |   | С   | OMMA  | ND             |       |       |              |               |                |                |           |                |                 |            |
| 0x97            | Register Read  | MOSI  | 97        |                                  |                 | Α | NDD | RESS( | ADDF           | ₹)    |       |              |               |                |                |           |                |                 |            |
| 0.007           | (Single)       | MISO  | 97        |                                  |                 | Α | NDD | RESS( | ADDF           | R)    |       |              |               |                |                |           |                |                 |            |
| 0xAD            | Register       | MOSI  | AD        |                                  |                 |   |     |       |                |       |       |              |               |                |                |           |                |                 |            |
| UXAD            | Status/Data    | MISO  | AD        |                                  |                 |   |     | STATU | JS             |       |       | DATA         |               |                |                |           |                |                 |            |
| 0xD2            | Register Write | MOSI  | D2        | 2 ADDRESS(ADDR)                  |                 |   |     |       |                |       |       | DATA         |               |                |                |           |                |                 |            |
| UNDZ            | (Single)       | MISO  | D2        |                                  |                 | Α | NDD | RESS( | ADDF           | R)    |       | DATA         |               |                |                |           |                |                 |            |

### **Memory Read Command**

Use operation command (OC) 81h (continuous read on the current page of memory register) to read data from any register address in the ASIC chip. See Table 28 for the data streams sent on MOSI with OC 81h followed by the address of the first register to be read and a delay of 00h. These three bytes will reflect on the MISO line before sending out the register address's (ADDR) data (DATA1). As long as the CLK continues to be sent, consecutive register address's (ADDR+1) data (DATA2) is transmitted and so forth. This procedure continues until the clock ends.

Use operation command (OC) 97h followed by ADh to perform a single read data from any register address in the ASIC chip.

Figure 20: Memory Read Command with OC = 81h



### **Memory Write Command**

Use operation command (OC) CFh (continuous write on the current page of internal memory register) to write data into any register address in the ASIC chip. See Table 28 for the data streams sent on MOSI with OC = CFh followed by the address of the first register to be written and the data. With each data byte, the address of the register to be written is register address (ADDR+1). Data successfully received will be transmitted on MISO line.

Use operation command (OC) D2h followed by ADh to perform a single write data into any register address in the ASIC chip and retrieve back the written data.

WARNING! Do not perform a continuous write on an external EEPROM.

Figure 21: Memory Write Command with OC = CFh



#### Memory Read Status Command (Single – Status Description)

The following table describes the operation command (OC) ADh STATUS (STAT).

**Table 29: Status Bits Descriptions** 

| Bit | Name        | Description                                       |  |  |  |
|-----|-------------|---------------------------------------------------|--|--|--|
| 7   | Error/SC_EN | Invalid operation command/Specific command enable |  |  |  |
| 6:3 | _           | Reserved                                          |  |  |  |
| 2   | Fail        | Data request failed                               |  |  |  |
| 1   | Busy        | Encoder busy                                      |  |  |  |
| 0   | Valid       | Data valid                                        |  |  |  |

**NOTE:** If the last OC received is D9h, STATUS Bit 7 = 1'b1 and the data value reflects the operation status.

## **SPI4 Operation Command**

Use operation command (OC) D9h followed by the code shown in Table 30 to perform special tasks. Once the command is received, perform ADh to read back the status of the operation. The data value FFh indicates an error. The data value 00h indicates the task is completed. The data value Code indicates the task is in progress. In the case of an overwritten operation, for example, 0x97h register read, perform the command operation 0x00h(NOP) to put the operation status back to buffer for 0xADh.

Table 30: SPI4 Specific Operation Command

| Code | Name                  | Description                                                      |
|------|-----------------------|------------------------------------------------------------------|
| 0x00 | <nop_ok></nop_ok>     | <return-code: last="" operation="" succeeded="">.</return-code:> |
| 0x10 | REBOOT                | Equivalent to power-on.                                          |
| 0x18 | MT_RESYNC             | Resynchronize with the external MT device.                       |
| 0x19 | MT_RESET              | Clear FeRAM value.                                               |
| 0x20 | SCLEAR                | Clear the System Alarm registers.                                |
| 0x80 | MTST_PRESET           | Set current position as MT = 0, ST = 0.                          |
| 0x81 | MT_PRESET             | Set current position as MT = 0.                                  |
| 0xB4 | AUTO_CAL_ALL1         | Automatic calibrate analog + digital.                            |
| 0xB5 | AUTO_CAL_ALL2         | Automatic calibrate analog + digital + accuracy.                 |
| 0xFF | <nop_fail></nop_fail> | <return-code: failed="" last="" operation="">.</return-code:>    |

#### **SPI4 Position Read**

Use operation command (OC) A6h to read the absolute position data from the ASIC chip. For nError (nE), nWarning (nW), CRC selections, refer to the CRC setting in Table 27. Position the latch at the first rising clock. nError and nWarning trigger 0 if any of the error triggered. Sequence counter (Seq Cnt) is the position read counter. For every consecutive position read request received by the encoder, the sequence counter value is increased by 1 (Seq Cnt = Seq Cnt + 1), until 63 counts are reached. The counter then rolls over to become 0 and restarts the counting. Single-turn bits (ST-bit) and multi-turn bits (MT-bit) are continuous bits with no zero bit patching. See the encoder resolution bits selection in Table 7.

Figure 22: SPI4 Position Read Command



Table 31: Single-Turn Only Position Read

| Operation<br>Command (OC) | Description         | Ports | 1 Byte | <st-bit></st-bit> | 2 [ | Bits | 6 Bits       | 2 Bytes   |
|---------------------------|---------------------|-------|--------|-------------------|-----|------|--------------|-----------|
|                           | Position Read       | MOSI  | A6(8b) |                   |     |      |              |           |
| 0xA6(MT_OFF)              | > format = Basic    | MISO  | A6(8b) | ST Pos            | nΕ  | nW   | CRC (6b)     |           |
|                           | > format = Extended | MISO  | A6(8b) | ST Pos            | nΕ  | nW   | Seq Cnt (6b) | CRC (16b) |

Table 32: Multi-Turn + Single-Turn Position Read

| Operation<br>Command (OC) | Description         | Ports | 1 Byte | <mt-bit></mt-bit> | <st-bit></st-bit> | 2 E | Bits | 6 Bits       | 2 Bytes   |
|---------------------------|---------------------|-------|--------|-------------------|-------------------|-----|------|--------------|-----------|
|                           | Position Read       | MOSI  | A6(8b) |                   |                   |     |      |              |           |
| 0xA6                      | > format = Basic    | MISO  | A6(8b) | MT Pos            | ST Pos            | nΕ  | nW   | CRC (6b)     |           |
|                           | > format = Extended | MISO  | A6(8b) | MT Pos            | ST Pos            | nΕ  | nW   | Seq Cnt (6b) | CRC (16b) |

#### **Encoder Activation in a Chained or Bus Mode**

Use operation command (OC) B0h to activate encoders in a chained-type connection. Register data access (RAx) bit is enabled to access memory register in the encoder. Position data access (PAx) bit is enabled to access position data in the encoder.

**NOTE:** 1 = Enable; 0 = Disable.

**Table 33: Encoder Activation** 

| ос   | Description               | Ports | 0      | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10  | 11  | 12  | 13  | 14  | 15  |
|------|---------------------------|-------|--------|---|---|---|---|---|---|---|---|---|-----|-----|-----|-----|-----|-----|
|      | Activate (1 appeder)      | MOSI  | OSI B0 |   |   |   |   |   |   |   | 1 | 0 | 0   | 0   | 0   | 0   | RA0 | PA0 |
|      | 0xB0 Activate (1 encoder) | MISO  |        |   |   | В | 0 |   |   |   | 0 | 0 | 1   | 0   | 0   | 0   | 0   | 0   |
| UXBU |                           | MOSI  | В0     |   |   |   |   |   | 1 | 0 | 0 | 0 | RA0 | PA0 | RA1 | PA1 |     |     |
|      | Activate (2 encoders)     |       | B0     |   |   |   |   |   |   |   | 0 | 0 | 0   | 0   | 1   | 0   | 0   | 0   |

Figure 23: Chained or Bus Type Connection for Multi-Encoder



A Chain Type Connection for Multi-Encoder



A Bus Type Connection for Multi-Encoder

**Table 34: Encoder Data Output Arrangement** 

|                           |                     |       | Enco                                               | der 1  |         |                 |                 |              | Encoder 2 |         |    |                 |              |  |  |
|---------------------------|---------------------|-------|----------------------------------------------------|--------|---------|-----------------|-----------------|--------------|-----------|---------|----|-----------------|--------------|--|--|
| Operation<br>Command (OC) | Description         | Ports | Ports 1 Byte <s-bit> 2 Bits 6 Bits 2 Bytes</s-bit> |        | 2 Bytes | <s-bit></s-bit> | 2 Bits          |              | 6 Bits    | 2 Bytes |    |                 |              |  |  |
|                           | Position Read       | MOSI  | A6(8b)                                             |        |         |                 |                 |              |           |         |    |                 |              |  |  |
| 0xA6(MT OFF)              | > format = Basic    | MISO  | A6(8b)                                             | ST Pos | nΕ      | nW              | CRC (6b)        |              | ST Pos    | nΕ      | nW | CRC (6b)        |              |  |  |
| ` _ /                     | > format = Extended | MISO  | A6(8b)                                             | ST Pos | nE      | nW              | Seq Cnt<br>(6b) | CRC<br>(16b) | ST Pos    | nΕ      | nW | Seq Cnt<br>(6b) | CRC<br>(16b) |  |  |

# **General Specification of RS485 Serial Communication**

#### Overview of RS485 Communication

A one-to-one half-duplex serial communication is established between the client encoder and the host (for example, a servo driver). The communication is in a differential transmission format. The encoder will carry out specific operations based on the command requests made by the host. An acknowledgment of the command request received by the encoder is necessary before the encoder executes the requested operation. The acknowledgment is conditional on the valid verification of the start bit, information data field, and stop bit. Failing this checking, the encoder will not acknowledge and execute the received command request.

Table 35: General Specification of RS485 Serial Communication

| Item                        | Specification                      | Note                                                      |
|-----------------------------|------------------------------------|-----------------------------------------------------------|
| Transmission Type           | Differential Transceiver           |                                                           |
| Communication Type          | Half duplex                        | Recommended transceiver: ISL8485E or Equivalent           |
| Transmission Code Type      | Binary, Non-Zero Return (NRZ) code |                                                           |
| Synchronization Type        | Asynchronous                       |                                                           |
| Communication Baud Rate     | 2.5 Mb/s, 5.0 Mb/s, and 10.0 Mb/s  |                                                           |
| Frame Length                | 10 bits/Frame                      |                                                           |
| Transmission Error Checking | 8 bits CRC                         | CRC equation G(X) = X <sup>8</sup> + 1<br>X = CRC0 ~ CRC7 |

Figure 24: General Transmission Frames Format on Half-Duplex Line



**Start of transmission frames set:** Upon detecting of the first logic of low state 0 on the transmission line after an idling state, and if the following 3 bits conform to the encoder address sync code, the encoder will acknowledge it as a valid request control field (RCF) and indicates the start of a transmission frame set. Otherwise, the encoder will continue to search for the next available logic of Low State 0.

**End of transmission frames set:** After the command frame is detected, if there is no start bit after the end bit of the last frame read, and no subsequent frame is detected, then the end of the transmission frame set is concluded.

**Idle state:** The Idle state indicates there is a space between each transmission frames set and subsequent transmission frames. At idling state, the logic of output in transmission line is kept to high state 1.

# **Encoder Readout Frame Sets Format and Timing**

Figure 25: Encoder Position Data Readout Frames Set







Figure 26: Encoder Memory Data Read and Write Frames Set







#### **Encoder Position Data Readout Frame Sets**

When the host issues a RCF frame request, the encoder will respond after 3.0 µs (typical) with encoder data frames set with the following contents:

- CF: Control field corresponds to the command frame issued by the host.
- SF: Status field.
- DF0~DF7: Encoder data field.
- CRC: Cyclic redundancy check (CRC) frame.

The encoder response data frame sets are dependent on the requested operation by the host (see Table 39).

#### **Memory Data Readout Frames Set**

Content of transmission frames:

- CF: Control field (same for both the host command and the encoder response).
- ADF: Address data field, indicates the memory location to read.
- EDF: Memory data field, contains the data read from memory.
- CRC: Cyclic redundancy check (CRC) checking.

#### **Memory Data Write Frames Set**

Content of transmission frames:

- CF: Control field (Same for both host command and encoder response).
- ADF: Address data field, indicate the memory location to write.
- EDF: Memory data field, contains the written data to memory.
- CRC: Cyclic redundancy check (CRC) checking.

#### **Details Description of Data Frames**

#### Control Field (CF)

Figure 27: Control Field Format



Contents of the CF frame:

- Start Bit: Indicates the start of a frame, always 0.
- Sync Code: Indicates a valid encoder address sync code has been issued, default is 010.
- Data ID: Combination of bits defining command instructions (see to Table 36 and Table 37).
- Parity Bit: Parity check bit for data ID (see Table 36).
- Stop Bit: Indicate the end of a frame, always 1.

# **RS485 Data ID and Client Encoder Operation Definition**

Table 36: Encoder Operation Command Code Definition and Parity Bit

| Encoder Operation                     | Data ID | Enco  | der Sync | Code  |     | Data I | D Bits |     | Parity | HEX |
|---------------------------------------|---------|-------|----------|-------|-----|--------|--------|-----|--------|-----|
| Encoder Operation                     | טמנמ וט | Bit 0 | Bit 1    | Bit 2 | CC0 | CC1    | CC2    | CC3 | CC4    | ПЕХ |
|                                       | 0       | 0     | 1        | 0     | 0   | 0      | 0      | 0   | 0      | 02  |
| 5                                     | 1       | 0     | 1        | 0     | 1   | 0      | 0      | 0   | 1      | 8A  |
| Position or Encoder Info Read Command | 2       | 0     | 1        | 0     | 0   | 1      | 0      | 0   | 1      | 92  |
| Command                               | 3       | 0     | 1        | 0     | 1   | 1      | 0      | 0   | 0      | 1A  |
|                                       | 4       | 0     | 1        | 0     | 0   | 0      | 1      | 0   | 1      | A2  |
| Memory Write Command                  | 6       | 0     | 1        | 0     | 0   | 1      | 1      | 0   | 0      | 32  |
| Alarm Clear Command                   | 7       | 0     | 1        | 0     | 1   | 1      | 1      | 0   | 1      | ВА  |
| Position Zero Reset Command           | 8       | 0     | 1        | 0     | 0   | 0      | 0      | 1   | 1      | C2  |
| Multi-Turn and Alarm Clear<br>Command | С       | 0     | 1        | 0     | 0   | 0      | 1      | 1   | 0      | 62  |
| Memory Read Command                   | D       | 0     | 1        | 0     | 1   | 0      | 1      | 1   | 1      | EA  |

### **Description of Encoder Operation**

Table 37: Description of RS485 Encoder Operation for the 24-Bit ST Format

| Operation                                          | Data ID       | Description of Operation                                                                   |
|----------------------------------------------------|---------------|--------------------------------------------------------------------------------------------|
| Position Read Command                              | 0, 1, 2, 3, 4 | Transmit Data ID code (Table 36) according to the list of data fields to the encoder.      |
| Memory Write Command                               | 6             | 8 bits of data to be written into a designated memory address of the user-accessible area. |
| Alarm Clear Command <sup>a</sup>                   | 7             | Consecutive 10x sending to perform alarm clear command.                                    |
| Position Zero Reset Command <sup>a</sup>           | 8             | Consecutive 10x sending to perform position zero reset command                             |
| Multi-turn and Alarm Clear<br>Command <sup>a</sup> | С             | Consecutive 10x sending to perform multi-turn and alarm clear command.                     |
| Memory Read Command                                | D             | 8 bits of data to be read from a designated memory address of the user-accessible area.    |

a. See Table 39 and Table 40 for the requirements of consecutive sending for the clear or reset commands.

#### Status Field (SF)

Figure 28: SF Frame Format



#### Content of SF frame:

- Start Bit: Indicates the start of a frame, always 0.
- Encoder Information: Defined as 0000.
- Encoder Error: Returns with state 1 if an encoder error is detected.
- Stop Bit: Indicates the end of a frame, always 1.

Table 38: Status Field Description of Error Flags

| Logic When Error Is Detected | Error Flag | Error Description                                  |
|------------------------------|------------|----------------------------------------------------|
| Francis Francis A            | EA0        | Encoder counting error.                            |
| Encoder Error Bit 1          | EA1        | Multi-turn counting error.                         |
| Communication Error Bit 1    | CA0        | Parity error detected in host request frames set.  |
| Communication Error Bit 1    | CA1        | End bit error detected in host request frames set. |

#### Data Field (DF<sub>n</sub>)

Figure 29: DF<sub>n</sub> Frame Format



#### Content of DF<sub>n</sub> frame:

- Start Bit: Indicates the start of frame, always 0.
- DF0~DF7: 8 bits data set with LSB first in sequence.
- End Bit: Indicate the end of frame, always 1.

# **Description of Data Frames with Respective Data ID**

The AR49 encoder supports variants of RS485 output formats depending on the single-turn and multi-turn resolutions requirements. See Table 43 for the RS485 format settings.

#### RS485 Data Frames Format for 24-Bit ST and 24-Bit MT Output

This is the default RS485 format, which can transmit up to 3 bytes (24-bit) of ST data and 3 bytes (24-bit) of MT data.

Table 39: RS485 Data Frames Content with Respective Data ID for up to 24-bit Multi-Turn

| ID | CF | SF  | DF0  | DF1  | DF2  | DF3  | DF4  | DF5  | DF6  | DF7  | CRC | Remark                                                      | Frame<br>Size |
|----|----|-----|------|------|------|------|------|------|------|------|-----|-------------------------------------------------------------|---------------|
| 0  | CF | SF  | ABS0 | ABS1 | ABS2 |      |      |      |      |      |     | Position Read Command                                       | 6             |
| 1  | CF | SF  | ABM0 | ABM1 | ABM2 |      |      |      |      |      |     | Position Read Command                                       | 6             |
| 2  | CF | SF  | ENID |      |      |      |      |      |      |      |     | Encoder Identification                                      | 4             |
| 3  | CF | SF  | ABS0 | ABS1 | ABS2 | ENID | ABM0 | ABM1 | ABM2 | ALMC |     | Position Read Command                                       | 11            |
| 4  | CF | SF  | ABS0 | ABS1 | ABS2 | ENID | ABM0 | ABM1 | ABM2 | TEMP |     | Position Read Command                                       | 11            |
| 6  | CF | ADF | EDF  |      |      |      |      |      |      |      |     | Memory or Register<br>Write Command                         | 4             |
| 7  | CF | SF  | ABS0 | ABS1 | ABS2 |      |      |      |      |      | Yes | Consecutive 10x to<br>Perform Alarm Clear<br>Command        | 6             |
| 8  | CF | SF  | ABS0 | ABS1 | ABS2 |      |      |      |      |      |     | Consecutive 10x to<br>Perform ST Zero Reset<br>Command      | 6             |
| С  | CF | SF  | ABS0 | ABS1 | ABS2 |      |      |      |      |      |     | Consecutive 10x to<br>Perform MT and Alarm<br>Clear Command | 6             |
| D  | CF | ADF | EDF  |      |      |      |      |      |      |      |     | Memory or Register<br>Read Command                          | 4             |

#### NOTE:

- **ABSn**: Single-turn counts. LSB of the single-turn counts is located in ABS0, and MSB of the counts data is located in ABS2. Combining ABS0~ABS2 will provide a maximum total of 24 bits single-turn data.
- **ABMn**: Multi-turn counts. LSB of the multi-turn counts is located in ABM0, and MSB of the counts data is located in ABM2. Combining ABM0~ABM2 will provide a maximum total of 24 bits multi-turn data.
- **ENID**: The encoder single-turn bits identification in 8-bit format. For example, 23-bit output is set to 17h, and 24-bit output is set to 18h.
- ALMC: The encoder alarm data in 8-bit format. See Table 42.
- **TEMP:** The encoder temperature readout data in 8-bit format. See Table 18.

#### RS485 Data Frames Format for 25-Bit ST and 16-Bit MT Output

This is the alternative RS485 format, which can transmit up to 4 bytes (32-bit) of ST data and 2 bytes (16-bit) of MT data.

Table 40: RS485 Data Frames Content with up to 16-bit Multi-Turn Resolution

| ID | CF | SF  | DF0  | DF1  | DF2  | DF3  | DF4  | DF5  | DF6  | DF7  | CRC | Remark                                                 | Frame<br>Size |
|----|----|-----|------|------|------|------|------|------|------|------|-----|--------------------------------------------------------|---------------|
| 2  | CF | SF  | ENID |      |      |      |      |      |      |      |     |                                                        | 4             |
| 3  | CF | SF  | ABS0 | ABS1 | ABS2 | ENID | ABS3 | ABM0 | ABM1 | ALMC |     | Position Read Command.                                 | 11            |
| 4  | CF | SF  | ABS0 | ABS1 | ABS2 | ABS3 |      |      |      |      |     | Position Read Command.                                 | 7             |
| 5  | CF | SF  | ABS0 | ABS1 | ABS2 | ABS3 | ABM0 | ABM1 |      |      |     |                                                        | 9             |
| 6  | CF | ADF | EDF  |      |      |      |      |      |      |      |     | Memory or Register Write Command.                      | 4             |
| 7  | CF | SF  | ABS0 | ABS1 | ABS2 |      |      |      |      |      | Yes | Consecutive 10x to<br>Perform Alarm Clear<br>Command.  | 6             |
| 8  | CF | SF  | ABS0 | ABS1 | ABS2 |      |      |      |      |      |     | Consecutive 10x to Perform ST Zero Reset Command.      | 6             |
| С  | CF | SF  | ABS0 | ABS1 | ABS2 |      |      |      |      |      |     | Consecutive 10x to Perform MT and Alarm Clear Command. | 6             |
| D  | CF | ADF | EDF  |      |      |      |      |      |      |      |     | Memory or Register Read Command.                       | 4             |

#### NOTE:

- **ABSn**: Single-turn counts. LSB of the single-turn counts is located in ABS0, and MSB of the counts data is located in ABS3. 7 bits LSB of STC0 are fixed to 0. Combining STC0~STC3 will provide a maximum total of 25 bits single-turn data. Combining ABS0~ABS3 will provide a maximum total of 25 bits single-turn data.
- ABMn: Multi-turn counts. LSB of the multi-turn counts is located in ABM0, and MSB of the counts data is located in ABM1. Combining ABM0~ABM1 will provide a maximum total of 16 bits multi-turn data.
- ALMC: Encoder alarm bits. See Table 42.
- **TEMP:** Encoder temperature readout bit.

#### Single-Turn Encoder Identification Setting

For the setting of the ENID value, the configuration is as listed in Table 41.

Table 41: ENID Setting

|       | RS485 |       |   |            |   | EN | lID |   |   |   | Default<br>[hex] |  |  |
|-------|-------|-------|---|------------|---|----|-----|---|---|---|------------------|--|--|
| Page  | Addr  | ess   |   | Bit        |   |    |     |   |   |   |                  |  |  |
| [dec] | [dec] | [hex] | 7 | 6          | 5 | 4  | 3   | 2 | 1 | 0 |                  |  |  |
| 7     | 1     | 01    |   | ENID [7:0] |   |    |     |   |   |   |                  |  |  |

The default value is set to 18h, referenced to the 24-bit single-turn resolution of the AR49 encoder ASIC.

#### **RS485 Encoder Alarm Definition**

Table 42: ALMC Alarm Bits Definitions

|                         |                  | ALMC Bit     |          |                     |                               |                                   |       |       |  |  |  |  |  |
|-------------------------|------------------|--------------|----------|---------------------|-------------------------------|-----------------------------------|-------|-------|--|--|--|--|--|
| Bit Value               | DF7-0            | DF7-1        | DF7-2    | DF7-3               | DF7-4                         | DF7-5                             | DF7-6 | DF7-7 |  |  |  |  |  |
| 0                       | No Error         | No Error     | No Error | No Error            | No Error                      | No Error                          |       |       |  |  |  |  |  |
| 1                       | MT Sync<br>Error | Memory Error | ST Error | MT Counter<br>Error | Lissajous /LED/<br>Temp Error | MT Error (EHMT<br>Counter Err[0]) | N/A   | N/A   |  |  |  |  |  |
| Encoder Error<br>Status | EA1              | N/A          | EA0      | EA1                 | N/A                           | EA1                               |       |       |  |  |  |  |  |

#### **Cyclic Redundancy Check Frame (CRC)**

Figure 30: CRC Frame Format



#### Content of CRC frame:

- Start Bit: Indicates the start of a frame, always 0.
- CRC0~CRC7: 8 bits CRC data set with LSB first in sequence. The CRC codes are generated per the equation of  $G(X) = X^8 + 1$  (X = CRC0 ~CRC7).
- End Bit: Indicates the end of a frame, always 1.

#### Address Data Frame (ADF)

Figure 31: ADF Frame Format



#### Content of ADF frame:

- Start Bit: Indicates the start of a frame, always 0.
- ADD0~ADD6: 7 bits memory address data set with LSB first in sequence.
- Busy: Memory access busy (MBSY) status flag.
- End Bit: Indicates the end of a frame, always 1.

#### **Memory Data Frame (EDF)**

Figure 32: EDF Frame Format



#### Content of EDF frame:

- Start Bit: Indicates the start of a frame, always 0.
- DN0~DN7: 8 bits memory data set with LSB first in sequence.
- End Bit: Indicates the end of a frame, always 1.

# **RS485 Encoder Configuration**

The RS485 protocol settings, which is user configurable is listed in Table 43.

Table 43: RS485 Encoder Setting

| Page<br>[decimal] | Address<br>[hex]     | Bits    | Parameter             | Function            | Value [binary]    | Setting                               | Default<br>Value<br>[binary] |
|-------------------|----------------------|---------|-----------------------|---------------------|-------------------|---------------------------------------|------------------------------|
|                   |                      | 7       | Parity                | Default Setting     | 0                 | 0                                     | 0                            |
|                   |                      | 6       | RS485 Data Format     | Maximum ST Position | 0                 | 24-Bit                                | 0                            |
|                   |                      | 0       | R3400 Data Fullilat   | Data                | 1                 | 25-Bit                                | U                            |
|                   | 5 Broadcast Mode Off |         | RS485 broadcast       | 0                   | Broadcast<br>Mode | 1                                     |                              |
|                   |                      |         |                       | mode                | 1                 | Single Device                         |                              |
|                   |                      |         |                       |                     | 00                | 2.5 Mb/s                              | 00                           |
| 7                 | 1D                   | [4:3]   | RS485 Baud Rate       | Default = 2.5 Mb/s  | 01                | 2.5 1010/5                            |                              |
| 1                 | ID                   | 9 [4.3] | N3463 Daud Nate       | Delault – 2.5 Mb/s  | 10                | 5.0 Mb/s                              |                              |
|                   |                      |         |                       |                     | 11                | 10 Mb/s                               |                              |
|                   |                      |         |                       |                     | 000               | 010<br>(Default for<br>single device) |                              |
|                   |                      |         |                       |                     | 001               |                                       |                              |
|                   |                      | [2:0]   | RS485 Encoder Address | Encoder Address     | 010               |                                       | 010                          |
|                   |                      | [2.0]   | (Sync Code)           | Efficuler Address   | 011               |                                       | 010                          |
|                   |                      |         |                       |                     | ::                |                                       |                              |
|                   |                      |         |                       |                     | 111               |                                       |                              |

#### NOTE:

- Updating the RS485 settings requires the host to also issue the subsequent commands with the same changes made. Else, the communication between the host and the client encoder might fail.
- The memory program command is needed for the system area memory to be effective upon power cycle applicable for changes to internal memory Pages 5 to 8.
- Perform the memory program command for changes to any of the affected banks before moving to other nonvolatile memory banks.
- Changes will be lost after a power cycle without a memory program command.

# **General Specification of Synchronous Serial Interface (SSI) Communication**

A one-to-one single-ended/full-duplex serial communication is established between the encoder (client) and the host (for example, a servo driver). The communication can be a single-ended or differential transmission format. Synchronous data transmission is the data transmitted by synchronizing the transmission at the receiving and sending ends using a common clock. Data transmitted is adaptive to the number of clocks and bandwidth.

**Table 44: SSI Protocol Specifications** 

| SSI Communication<br>Parameters | Symbol             | Conditions | Min. | Тур. | Max.   | Unit |
|---------------------------------|--------------------|------------|------|------|--------|------|
| Clock Frequency                 | f <sub>CLK</sub>   | _          | 100  | _    | 10,000 | kHz  |
| Clock Duty                      | DUT <sub>CLK</sub> | _          | _    | 50   | _      | %    |
| Monoflop Time                   | t <sub>m</sub>     | _          | _    | _    | 20     | μs   |
| Pause Time                      | t <sub>p</sub>     | _          | 21   | _    | _      | μs   |

Figure 33: SSI Data Field and Timing Diagram



For the SSI option, the encoder calibration and device configuration are achieved by communicating in SPI mode during calibration.

Table 45: Definition of SSI Encoder Alarm Output Bits

| SSI Error | SSI Error Status [7:0]   |      |                                   |                         |                                                       |                                     |                 |               |  |
|-----------|--------------------------|------|-----------------------------------|-------------------------|-------------------------------------------------------|-------------------------------------|-----------------|---------------|--|
| Option    | Bit7                     | Bit6 | Bit5                              | Bit4                    | Bit3                                                  | Bit2                                | Bit1            | Bit0          |  |
| ST Only   | N/A                      |      |                                   | ST Error  <br>MLS Error | Memory<br>Error                                       | N/A                                 |                 |               |  |
| MT        | N/A                      |      | MT Error<br>(EHMT Counter Err[0]) | N/A                     | MT Counter Error  <br>MT Protocol Error  <br>XC Error | ST Error  <br>MLS Error             | Memory<br>Error | MT Sync Error |  |
| SSI Warni | SSI Warning Status [7:0] |      |                                   |                         |                                                       |                                     |                 |               |  |
| ST or MT  | N/A                      |      |                                   |                         | Temp Error                                            | Lissajous<br>(Incremental)<br>Error | LED Error       |               |  |

## **SSI 2-Wire Full-Duplex Connection**

- 1. Provide the following encoder power supply: For the 5.0V supply,  $V_{CC}$  should be within the range of 4.5V ~ 5.5V.
- 2. For best noise immunity, use a twisted-pair shielded cable for connection to the servo driver.
- 3. To prevent undesirable signal reflection, terminate with a  $120\Omega$  resistor.
- 4. Terminate the shield wire to frame ground (FG) at both ends of the communication line.

Figure 34: Typical SSI Full-Duplex Connection



# **General Specification of BiSS-C Serial Communication**

**Table 46: General Specification of Serial Communication** 

| Interface          | Symbol     | Recommended Circuit                       |
|--------------------|------------|-------------------------------------------|
| Serial Clock       | MA or SCLK | Transmitter (P/N: ISL3295E) or equivalent |
| Serial Data Output | SLO or DAT | Receiver (P/N: ISL3283E) or equivalent    |

#### **BiSS-C Serial Interface**

Table 47: BiSS-C Timing Characteristics

| Parameter                   | Symbol                    | Condition                         | Min.                 | Тур.               | Max. | Unit | Notes |
|-----------------------------|---------------------------|-----------------------------------|----------------------|--------------------|------|------|-------|
| MA Frequency                | f <sub>MA</sub>           | _                                 | 0.08                 | _                  | 10   | MHz  |       |
| MA Duty                     | DUT <sub>CLK</sub>        | _                                 | _                    | 50                 | _    | %    |       |
| Duni                        | T <sub>busy</sub>         | f <sub>MA</sub> = 5 MHz to 10 MHz | _                    | 2/ f <sub>MA</sub> | _    |      | а     |
| Busy                        |                           | 100 kHz ≤ f <sub>MA</sub> ≤ 5 MHz | _                    | 1/ f <sub>MA</sub> | _    | μs   | u u   |
| Timeout                     | t <sub>BiSS-timeout</sub> |                                   | 1.5/ f <sub>MA</sub> |                    | 5    | μs   | а     |
| Frame to Frame              | _                         | _                                 | _                    | _                  | 1    | μs   |       |
| Encoder Initialization Time | _                         | _                                 | _                    | 500                | _    | ms   |       |

a. Refer to Figure 35 for timing description.

#### **BiSS-C Data Field**

| MTIOO.OI | CT[04.0] | E[0]     | M/a maina ar[O] | CDCIE.01 |
|----------|----------|----------|-----------------|----------|
| WH[23:0] | 51[24:0] | Error[u] | vvarning[u]     | CRC[5:0] |

Figure 35: BiSS-C Interface Timing Diagram



#### NOTE:

- CRC Polynomial = Invert of (X<sup>6</sup> + X<sup>1</sup> + X<sup>0</sup>).
- nErr bit is active low. (Combine all the error status and reflect in nErr bit.)
- nWar bit is active low. (Combine all the warning status and reflect in nWar bit.)
- Position data varies depending on single-turn and multi-turn resolution.

Table 48: BiSS-C Device Registers

| Category                  | Description                            | Direct BiSS-C Register (hex) | Default Value (hex) |
|---------------------------|----------------------------------------|------------------------------|---------------------|
|                           | BiSS EDS-Bank [7:0] <sup>a</sup>       | 41                           | 00h                 |
|                           | BiSS Profile ID [15:0]                 | 42                           | 62h                 |
|                           | BISS FIGIRE ID [15.0]                  | 43                           | 33h                 |
|                           |                                        | 44                           | 00h                 |
|                           | D:00 0 : 1 N                           | 45                           | 00h                 |
|                           | BiSS Serial Number [31:0] <sup>b</sup> | 46                           | 00h                 |
|                           |                                        | 47                           | 00h                 |
| BiSS-C Device Information |                                        | 78                           | 41h                 |
|                           |                                        | 79                           | 45h                 |
|                           | D:00 Davida - ID (47:0)                | 7A                           | 18h                 |
|                           | BiSS Device ID [47:0]                  | 7B                           | 19h                 |
|                           |                                        | 7C                           | 80h                 |
|                           |                                        | 7D                           | 00h                 |
|                           | BiSS Manufacturer ID [15:0]            | 7E                           | 41h                 |
|                           | DIGG Manufacturer ID [10.0]            | 7F                           | 4Fh                 |

a. No specific EDS Bank format is supported.

## **BiSS-C Client Register Description**

Table 49: Definition of BiSS-C Encoder Status Bits and Clear Command

| Address 7                                                                                                              | Address 72(48) – nErr, Error Status [7:0] |             |                                   |            |                                                       |                         |                   |               |
|------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-------------|-----------------------------------|------------|-------------------------------------------------------|-------------------------|-------------------|---------------|
| Option                                                                                                                 | Bit7                                      | Bit6        | Bit5                              | Bit4       | Bit3                                                  | Bit2                    | Bit1              | Bit0          |
| ST Only                                                                                                                |                                           |             | N/A                               |            | ,                                                     | ST Error  <br>MLS Error | Memory<br>Error   | N/A           |
| EHMT                                                                                                                   | MT N/A                                    |             | MT Error (EHMT<br>Counter Err[0]) | N/A        | MT Counter Error  <br>MT Protocol Error  <br>XC Error | ST Error  <br>MLS Error | Memory<br>Error   | MT Sync Error |
| Address 7                                                                                                              | 3(49) – nWa                               | ar, Warning | Status [7:0]                      |            |                                                       |                         |                   |               |
| N/A                                                                                                                    |                                           |             |                                   | Temp Error | Lissajous<br>(Incremental)<br>Error                   | LED Error               |                   |               |
| Address 74(4A) – Encoder Clear Command <sup>a</sup> ; Bit2 = Alarm Clear, Bit1 = ST Zero Offset, Bit0 = MT Zero Offset |                                           |             |                                   |            |                                                       |                         |                   |               |
|                                                                                                                        | N/A                                       |             |                                   |            | Alarm Clear                                           | ST Zero Offset          | MT Zero<br>Offset |               |

a. Write 1 to execute one time clear command. Only one command bit should be triggered for each time.

b. Only the two LSB bytes of the serial number data, in hex data are used, corresponding to the running serial numbers in the product label.

# **Trouble Shooting Guide**

| No. | Description                         | Causes                                                            | Counter Measure                                                                                                                                     |  |
|-----|-------------------------------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1   |                                     | Encoder power supply too low                                      | Check if Vcc versus ground potential is within 4.5V~5.5V,                                                                                           |  |
|     |                                     | Poor connectivity between encoder connector to customer connector | Check the encoder connector and customer connector connectivity.                                                                                    |  |
|     |                                     | Wrong wire connection assignment                                  | Check the connector wire connection assignment.                                                                                                     |  |
|     |                                     | Detector IC faulty/shorted                                        | Perform power cycle. If problem still exists, please consult factory.                                                                               |  |
|     | No output                           | Transceiver faulty/shorted                                        | Where applicable, ensure proper line terminating resistors are used.                                                                                |  |
|     |                                     | Wrong baud rate used for RS485                                    | Check if the host and encoder are communicating at the correct baud rate.                                                                           |  |
|     |                                     | Wrong bit lengths used for BiSS-C                                 | Ensure the host clock numbers are set accordingly to the encoder resolutions,                                                                       |  |
|     |                                     | communications                                                    | 2. Follow the BiSS-C multi-cycle requirements for register access,                                                                                  |  |
| 2   | Encoder high current                | LED faulty/shorted                                                | Check encoder PCBA to ensure no accidental damage to the LED,                                                                                       |  |
|     | consumption<br>(>200 mA at 25°C)    | Detector IC faulty/shorted                                        | Check the encoder connector and customer connector connectivity.                                                                                    |  |
|     |                                     | Transceiver faulty/shorted                                        |                                                                                                                                                     |  |
| 3   | XCErr triggered                     | Multi-turn block faulty                                           | Ensure proper shielding and no exposure to a strong magnetic field source. Clear the alarm and power cycle after the disturbance source is removed. |  |
| 4   | MemoryErr triggered                 | Memory block faulty                                               |                                                                                                                                                     |  |
| 5   | Multi-turn Counting Error triggered | Multi-turn block faulty                                           | Ensure the MT calibration is done correctly.                                                                                                        |  |
| 6   | LodErr triggorod                    | LED faulty                                                        |                                                                                                                                                     |  |
|     | LedErr triggered                    | Codewheel is blocked                                              | Ensure no contaminations on the codewheel surface.                                                                                                  |  |
| 7   |                                     | LED faulty                                                        |                                                                                                                                                     |  |
|     | LisErr triggered                    | Single-turn block faulty                                          |                                                                                                                                                     |  |
|     |                                     | Codewheel issue                                                   |                                                                                                                                                     |  |
| 8   |                                     | LED faulty                                                        | Clean the codewheel and perform a power cycle. If the                                                                                               |  |
|     | MLSErr triggered                    | Single-turn block faulty                                          | problem still exists, consult factory.                                                                                                              |  |
|     |                                     | Codewheel issue                                                   |                                                                                                                                                     |  |
| 9   | Single-turn Counting triggered      | Single-turn block faulty                                          |                                                                                                                                                     |  |
|     | Single-turn Counting inggered       | Codewheel issue                                                   |                                                                                                                                                     |  |

# **Cleaning of Codewheel and Encoder Module**

Figure 36: Photo Detector Surface Inspection and Cleaning







#### NOTE:

- (a) Inspect the photo-detector area to ensure that there is no dust or oil/grease contamination.
- (b) Only use the air blower with a soft Teflon needle to blow away any dust particles on the photo-detector area.
- (c) Do not use a cleaning cotton bud/swab for cleaning the photo-detector area. Scratches to the dice surface might damage the encoder ASIC.

**CAUTION!** Do not touch the LED pad area with any cleaning instrument.

#### Dos and Don'ts

#### Do

- 1. Ensure a clean environment during installation.
- 2. Ensure that the encoder power supply is within 5V ± 10%.
- 3. Provide adequate protection from dust and moisture when using in a harsh environment.
- 4. Ensure that the connector-cable assembly follows the pin configuration, in accordance with the product data sheet.
- 5. Observe all ESD precautions when installing or handling of the encoder.
- Ensure that the magnetic shield is designed in accordance with the recommendations in this application note.

#### Don't

- 1. Do not overload the transceiver by using the wrong termination resistor.
- 2. Do not hammer the codewheel hub into the motor shaft during installation.
- 3. Do not reverse the power source polarity.
- 4. Do not operate the encoder under extreme temperatures over an extended time.
- 5. Do not place the magnet-hub in direct contact with the EH sensor.
- 6. Do not place the encoder module in close proximity to a strong magnet.

# **Packing Information**

**Table 50: Encoder Packing Information** 

| Packing Unit             | Quantity                         |  |
|--------------------------|----------------------------------|--|
| Unit per tray            | Maximum: 16 pieces               |  |
| Unit per pizza box       | Maximum: 32 pieces               |  |
| Tray per pizza box       | Maximum: 2 trays for 1 pizza box |  |
| Pizza box per carton box | Maximum: 6 pizza boxes           |  |

Figure 37: Example of the Encoder Module and Codewheel Packing within a Packaging Tray



Figure 38: Packing Box and Carton Information



34 cm (L) x 28 cm (W) x 8 cm (H)





62 cm (L) x 34 cm (W) x 28 cm (H)

# **Accessories Information**

| No. | Part Number  | Description                                                                                                                                                                                                                                                                                                                                   |
|-----|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | AS20-C300    | 8-pin mating connector with 300-mm cable length, 100 pieces SPI.                                                                                                                                                                                                                                                                              |
| 2   | AR49-M49-E01 | Programming Kit (applicable for all protocol options).  Contents: 1 unit of MCU based programming kit, 1 unit of USB cable for PC interface, DUT cable, and the associated programming software.                                                                                                                                              |
| 3   | AR25-AC25    | Accuracy Calibration Station for AR25/AR49 Series Rotary Reflective Encoder.  Contents: Mechanical setup including servo motor control, high accuracy reference encoder, programming kits, associated cables assemblies (for PC interface, motor handler communication, DUT encoder connection), and the associated GUI programming software. |

# AR49-M49-E01 Programming and Calibration Kit

Broadcom offers a simple USB powered programming kit, together with a PC-based custom GUI program for users to perform the necessary calibration or to program in the desired encoder settings.

By connecting to the AR49-M49-E01 programming kit, users can communicate to the AR49 series encoders based on the communication protocol option of the DUT encoder.

Figure 39: AR49-M49-E01 Programming Kit with the Adapter Board Attached



**CAUTION!** The programming kit has exposed connector pins at both the top and bottom sides. Do not place the kit on top of a conductive surface.

Figure 40: AR49-M49-E01 Programming Kit Connection



The AR49 series encoder is connected to the AR49-M49-E01 Programming Kit via the dedicated adapter PCB. There are two 8-pin connectors on the adapter PCB for connection to the encoder depending on the protocol options. Only one of the connector should be connected one at a time, according to the protocol option.

Table 51: Pins Assignment on the AR49-M49-E01 Adapter PCB

| Pin No. | Connector1: SSI 2-Wire/BiSS-C/SPI 4-Wire | Connector 2: RS485 |
|---------|------------------------------------------|--------------------|
| 1       | SEL1                                     | NC                 |
| 2       | SEL0                                     | NC                 |
| 3       | DATA-/SLO-/SPI-DIN/MOSI                  | DATA-              |
| 4       | DATA+/SLO+/SPI-DO/MISO                   | DATA+              |
| 5       | SCLK-/MA-/SPI-CLK                        | NC                 |
| 6       | SCLK+/MA+/SPI-NCS                        | NC                 |
| 7       | 0V                                       | 0V                 |
| 8       | +5V                                      | +5V                |

#### NOTE:

- Only one of the connectors should be connected one at a time, according to the protocol option.
- Pin 1 at the adapter PCB is connected to Pin 8 of the AR49 encoder, other pins are also reversed accordingly.
- The SSI option is configured via the shared SPI pins and setting the correct logic level to the SEL0 pin. SPI is enabled when SEL0 = Hi, while SSI is enabled when SEL0 = Lo. SEL1 = Lo by default.
- For SSI option, the SPI-CLK and SPI-NCS lines require a strong driver current to overcome the built-in 120Ω terminating resistance of the SSI SCLK lines. The programming kit has a buffer circuit included for this purpose.

# AS20-C300 Cable Assembly

Figure 41: AS20-C300 Cable-Connector Assembly



#### NOTE:

- · Dimensions are in millimeters.
- The 300-mm cable assembly has the mating connectors, 1.0-mm Pitch JST 08-SR, at both ends of the termination.

# **AR25-AC25 Accuracy Calibration System**

The AR25-AC25 calibration system combines both the ST and MT signal calibration together with the position accuracy correction for the AR49 encoders.

The Once Around Correction (OAC) and Interpolation Error Correction (IEC) are performed on the AR49 encoder module. This is to reduce contributing factors such as motor shaft radial run-out, encoder codewheel to hub eccentricity, and mismatch in dimension tolerance between the hub's inner diameter to motor shaft. The AR49 OAC and IEC features compensate the mounting assembly and signal interpolation errors electronically.

This Accuracy Calibration Station is developed as a reference tool to enable customers to perform accuracy calibration on the AR49 encoder to the required optimum accuracy performance.

Figure 43 shows the graphical user interface of the programming software. The test list is defined by using a customizable test script file.

Figure 42: Overview of the Calibration System



Figure 43: User Interface of the Calibration Software in Ready Mode



| Copyright © 2025 Broadcom. All Rights Reserved. The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries. For more information, go to <a href="https://www.broadcom.com">www.broadcom.com</a> . All trademarks, trade names, service marks, and logos referenced herein belong to their respective companies.                                                                                                                                                                         |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Broadcom reserves the right to make changes without further notice to any products or data herein to improve reliability, function, or design. Information furnished by Broadcom is believed to be accurate and reliable. However, Broadcom does not assume any liability arising out of the application or use of this information, nor 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. |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>№</b> BROADCOM°                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| - DICADCOII                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |