The SR12 with serial peripheral interface is used to output absolute position data in serial format using only three wires: a Slave Select input, Clock input, and Data output. The SR12 functions as a slave device and requires a master device to supply the Slave Select and Clock inputs.

While power is applied, the SR12 is continuously reading and storing its position. Position information is updated about once per millisecond when not transmitting. In this state, the master device has the Slave Select high, Clock low, and the SR12 has the Data output in a high impedance state.

To retrieve position data from the SR12 the master lowers the Slave Select input and then waits 100  $\mu$ sec. This interrupts the normal processing of the SR12. The SR12 enables the Data output and prepares to transmit the most recent position data. During the time the SR12 is transmitting data it is not updating its position. After the master waits 100  $\mu$ sec, it generates the Clock input at any rate between 1KHz and 50KHz. For each clock pulse the SR12 outputs 1 bit of data for a total of 16 bits. Data is available on the output 10  $\mu$ sec after each rising clock edge. After the falling edge of the 16th clock pulse, the SR12 holds the 16th bit on the Data output line for 50  $\mu$ sec and then puts the Data output in a high impedance state. The master can return the Slave Select to high at anytime after the initial 100  $\mu$ sec wait period, and it must be returned to a high state before initiating another data transfer. The master must wait the full 50  $\mu$ sec after the last data bit before initiating another data transfer, however it should wait at least another 1 millisecond so the SR12 can update the position information.



## Notes

- 1. D8 is the most significant bit of position data and D0 is the least significant bit.
- 2. For an 8-bit SR12 (SR12-256...) D8 is zero. For a 7-bit SR12 (SR12-128) D8 and D7 are zero.
- 3. To indicate an error condition, all bits are set to zero.
- 4. Nomimal voltage levels: High 5vdc; Low 0vdc
- 5. Clock pulses beyond the 16th are ignored.
- 6. Clock pulses should not be generated during the 100 µsec wait period after Slave Select is set low.