

# **Chapter 8** Serial Communication Interface

# FIPSOC User's Manual



# **Serial Communication Interface**

## 1. Overview

The Field Programmable System On Chip (FIPSOC) constitutes a new concept in system integration. It provides the user with the possibility of integrating a microprocessor core along with programmable digital and analog cells within the same integrated circuit. This chip can be considered as a large granularity FPGA with a FPAA (Field Programmable Analog Array) and a built-in microprocessor core that does not only act as a general purpose processing element, but also configures the programmable cells and their interconnections. Therefore, there is a strong interaction between hardware and software as long as signal values and configuration data within the programmable cells are accessible from microprocessor programs.

This chapter describes the Serial Communication Block integrated on the FIPSOC system. It supports two serial communication interfaces: a 2-wire protocol and an SPI interface.

The 2-wire interface supports multi-devices serial data communication using two lines. The 2-wire subblock can be configured as either a master device or a slave device. The block is identify by an address which can be set via software.

The SPI interface is a synchronous interface which allows several devices to be interconnected. Two wires are required for data to obtain full duplex transfer communication. A third line is used for clocking purposes. The SPI subsystem supports different communication rates and can be configured to be both master or slave.

The Serial Communication Block would be programmed by the software. However, it also supports on-reset configuration (hardware configuration) in order to provide more flexibility to the FIPSOC boot procedure.

## 2. 2-Wire Serial Interface

Note: 2-wire serial interface is not available in device 8x12 of the FIPSOC family.

This bus interface supports serial data transmission using two lines between the devices connected to it. The two wires are used to one for data (serial data – SDA) and one for the clock signal (serial clock –SCL). Multiple devices can be connected to the bus and can operate as either a transmitter or receiver.

The transfer on the bus is initiated and controlled by a master device that generates the clock signal; the other devices, which send or receive data, are known as slaves. Each device hanging in the bus is recognized by an address. Any master-device must first identify the desired slave by sending its address through the 2-wire bus and configure it as either a transmitter or receiver (read or write operations, respectively).

The 2-wire interface is multi-master. That is, more than one device are capable of controlling the serial clock of the bus.

## 2.1. Bit Transfer

The transmission is controlled by the serial clock (SCL). The SCL line is used to control each data bit transferred. The data on the SDA line must be stable during the high level of the SCL line. Level of the SDA line can only change while the clock pulse on SCL is low. Data changed during SCL high periods will indicate a start or stop command (see figure 2.1).





• Bus free: Both SDA and SCL are bi-directional lines, connected to a positive supply via a pull-up resistor (see figure 2.2). When the bus is free, no transfer between any devices is in progress and both lines stay high. All SDA and SCL outputs of any devices connected to the bus must be opendrain (or open-collector) driven.





Fig. 2.2: Connection of devices to the 2-wire bus

- Start Condition: A high-to-low transition in SDA line with SCL high is a start condition (see figure 2.1). Only the master device may generate this situation. The bus is considered to be busy after a start condition. A start command always precedes any command in the bus.
- Stop Condition: A low-to-high transition in SDA while SCL is high is interpreted as a stop condition

(see figure 2.1). After the stop condition, the bus is considered to be free, and a high level must be set in both SDA and SCL lines.

• Acknowledgement: All address and data words are serially transmitted through the SDA line in 8-bit words, most significant bit first. Each byte transmitted is followed by an acknowledge bit set by the receiver. The receiver must pull-down the SDA line during the 9<sup>th</sup> clock cycle to acknowledge that it has received each word. During this cycle, the transmitter has to release the SDA line to receive the confirmation from the receiver.







Fig. 2.4: Data transfer on the 2-wire interface

## 2.2. Data Transfer

After a start condition, the master device must send a slave address. This first word has two purposes: firstly, it is used to identify the slave device in the bus; secondly, it is used to establish the transfer direction of the communication (that is, configure the slave device as receiver or transmitter). The first word is seven bits long (address field) followed by an eight bit (operation field) which is the R/W command select bit. A read operation is initiated if this bit is high; otherwise, a write operation is initiated (see figure 2.4).

The slave addressed must pull-down the ninth bit as mentioned before (see figure 2.3). If the master device do not detect a zero in the ninth clock cycle, no device has been addressed. The master must then re-try to start a communication or release the 2-wire bus. The first action would be done by sending a different address after a new start condition. The second one will be done by producing a stop condition. The number of bytes that can be transmitted between the start and the stop condition is unrestricted. Data transfer is always finished by an stop command (see figure 2.4). In other words, several start commands are allowed without releasing the bus. Various combinations of read/write format are possible in the same transmission session. These formats are described below (and shown in figure 2.5):

- Master transmitter: The master device transmits data to the slave receiver. The transfer direction is not changed, and the acknowledge bit is always set by the slave. This format is used in write operations.
- Master receiver: The master device reads data from the slave after the first byte transmitted. The transfer direction changes after the first byte (that is, the address word transmission has *master® slave* direction while any other word is *slave® master* transmitted). The acknowledge bit is always set by the receiver. Due to this fact only the first



acknowledge bit is set by the slave (receiver behavior)

• Combined format: It is used to change the direction of a transfer or change the slave selected without releasing the 2-wire bus. During a change of direction, the Start Condition and the Slave address are both repeated, but with the operation bit reversed

| Data transferred (n bytes + Ack)                                                 |                  |         |        |         |             |         |          |                               |        |   |
|----------------------------------------------------------------------------------|------------------|---------|--------|---------|-------------|---------|----------|-------------------------------|--------|---|
|                                                                                  |                  |         |        |         |             |         |          |                               |        |   |
| S                                                                                | Slave address    | RW      | Α      | E       | Data        | А       | D        | ata                           | A/Ā    | Р |
| Master-transmitter addresses a slave receiver. Transfer direction is not changed |                  |         |        |         |             |         |          |                               |        |   |
| Data transferred (n bytes + Ack)                                                 |                  |         |        |         |             |         |          |                               |        |   |
|                                                                                  |                  | 1       |        |         |             |         |          |                               |        |   |
| S                                                                                | Slave address    | RW      | A      | E       | Data        | А       | D        | ata                           | Ā      | Р |
| (read)                                                                           |                  |         |        |         |             |         |          |                               |        |   |
|                                                                                  | A master         | reads a | slave  | inmedia | tely after  | the fi  | rst byte |                               |        |   |
|                                                                                  |                  |         |        |         |             |         |          |                               |        |   |
|                                                                                  |                  |         |        |         | - Direction | n and A | Ack. 🥿   |                               |        |   |
|                                                                                  |                  |         | transf |         | depends     | on RW   | / bits   | <ul> <li>Data trai</li> </ul> |        |   |
|                                                                                  |                  | (1 b    | ytes + | ACK)    |             |         |          | (n bytes                      | + ACK) |   |
|                                                                                  |                  |         |        |         |             |         |          |                               |        |   |
| S                                                                                | Slave address RW | A Da    | ta A   | AVA Sr  | Slave add   | lress   | RW A     | Data                          | A/Ā    | Р |
| Combined format                                                                  |                  |         |        |         |             |         |          |                               |        |   |
|                                                                                  |                  |         |        |         |             |         |          |                               |        |   |



## 2.3. Arbitration

Special situations will appear when more than one device try to initiate a data transfer at the same time or devices with different speed responses are connected to the bus. The first situation, called multi-master conflict, requires an arbitration procedure; the second one, requires a clock signal synchronization method.

• Multi-master arbitration

If two or more masters try to put information onto the bus, the first device to produce a 'one' when the other produces a 'zero' will lose the arbitration. Note that bits transferred by the devices until that moment are equal in both transmissions, so no corrupted information is sent.

## Semiconductor Design Solutions



Fig. 2.6: Arbitration procedure on the 2-wire interface

In other words, re-starting is not needed after the multi-master conflict is arbitrated. If a master that loses the arbitration can also behave as a slave, it is possible that the master device would like to establish a communication with it. In this case, the losing master must change to its slave receiver mode in order to acknowledge the addressing call from the winning master.

Clock Synchronization

Master devices generate the serial clock signal in the SCL line. Since the 2-wire lines are pull-up lines, any devices in the bus can alter the SCL signal by obliging a low level in the line. Slow slave-devices may use this characteristic to hold the low period of the serial clock, leaving the master device in a high wait-state. When all the devices release the SCL line, the low-to-high transition will occur and the master device will continue its function (see figure 2.7).

Different slow operations can be handled thank to this bus specification (pull-up resistor), such as interrupt requesting on microcontrollers, data and acknowledgement preparations, long-time needed to store information and so on.



Fig. 2.7: Clock synchronization procedure on the 2-wire interface

## 3. SPI Serial Interface

This bus interface is a synchronous interface which allows several devices to be interconnected. Separate wires are needed for data and clock. Two wires are required for data to obtain full duplex transfer communication. A third line is used for clocking purposes.

The transfer on the bus is controlled by the master device that generates the clock signal. A fourth signal



is used to recognize any device connected to the bus (slave select signal).

The transmission between the master device and the slave device selected is realized using two unidirectional lines. A read operation is always accompanied with a write operation (talk about receiver and transmitter devices has no sense in this interface).

## **3.1.** Signal Description

The four basic SPI signals are MISO, MOSI, SCK and SS. They can be described as follows (as shown in figure 3.1):

- Master in, Slave out (MISO): this signal is configured as an input in a master device and as an output in a slave device. It is one of the two lines that transfers serial data in one direction. When multiple slave devices are connected to the SPI bus, this output must be placed in the high-impedance state if the slave is not selected.
- Master out, Slave in (MOSI): The MOSI line is configured as an output in a master device and as an input in a slave device. It is one of the two lines that transfer data in one direction.
- Serial Clock (SCK): The serial clock is used to synchronize data movement both in and out of the device through its MISO and MOSI lines. The master device generates this signal, so it is configured as an output in a master device and as an input in a slave device.
- Slave Select (SS): The slave select input line is used to select a slave device. It is active with low level, and it must stay low during the transmission. The SS line on the master must be tied high.

The most significant bit is first sent in both MISO and MOSI lines.



## 3.2. Bit Transfer

Data transmission is controlled by the SCK signal. For each cycle sent through the SCK line, bits from the master device (using the MOSI line) and bits from the slave (through the MISO line) are simultaneously generated. When the master device transmit data, the slave device responds by sending data to the master. This implies full duplex communication with both data out and data in synchronized with the same serial clock. A read operation is realized by sending a word through the MOSI line (that is, generating the clock signal in the SCK line).

### 3.3. Data Transfer

The whole SPI system (master device, bus and slave device) works like a system consisting of two shift registers interconnected. The byte transmitted from the master shift register is replaced by the byte received from the slave. On the other side, the byte received from the master in the slave shift register replaces the previous word, which is sent to the master device via the MISO line (see figure 3.1).

The SPI devices are double buffered on read, but not on write. Thus, if a write is performed during data transfer stored data will be erased, and both transmitted and received data would be corrupted. In order to save the data received, every eight cycles of the SCK the shift register is copied to the buffer register.

## 3.4. Serial Clock Control

Byte exchange takes place during eight cycles of SCK. After any exchange operation, the stored data is transferred to the buffer register.

A byte transmission is begun when the master device writes on the shift register. This operation starts an internal counter which generates eight cycles in the SCK line.

Four possible timing relationships may be chosen for the transmission depending on the synchronization edge and level of the clock. Both master and slave devices must operate with the same synchronization for a right transmission. A bit transfer is made by placing data on the MOSI and MISO lines a half-cycle before the active clock edge (internal strobe in figure 3.2).



Fig. 3.2: Synchronization Clock Timing Diagram



## 4. Serial Comm. Interface Block SFR

## Note: 2-wire serial interface is not available in device 8x12 of the FIPSOC family.

The Serial Communication Interface Block of the FIPSOC is controlled using registers located in the SFR map. These registers have different usage depending on the boot register configuration (described further in this section).

Their values after reset depends on the levels set in a few in-out pads of the FIPSOC chip (on-reset configuration).

The registers used to control the Serial Communication block are described below:

| Comi al | Comm  | Desister | On Deast  | a aufi aunati an | ١ |
|---------|-------|----------|-----------|------------------|---|
| senai   | Comm. | Register | (On-Kesei | configuration    | , |

| Address | Name     | Bit        | Description                                                                          |                                |  |  |
|---------|----------|------------|--------------------------------------------------------------------------------------|--------------------------------|--|--|
| \$9C    | SCMREG   |            | Serial Communication Register<br>(2-wire / SPI)                                      |                                |  |  |
|         | SCMREG.7 | CCF.       | Communication complete flag. If 1 data is transferred; if 0, transfer is in progress |                                |  |  |
|         |          |            | 2-wire Register                                                                      | SPI register                   |  |  |
|         | SCMREG.6 | MASTER     | 2MST                                                                                 | SPMT                           |  |  |
|         | SCMREG.5 | SDRC / CK1 | SDRC (1=send,<br>0=receive)                                                          | CK1 (TX frec. select bit 1)    |  |  |
|         | SCMREG.4 | СКО        | (1=100KHz,<br>0=1MHz)                                                                | CK0 (TX frec. select bit 0)    |  |  |
|         | SCMREG.3 | ID / MODF  | ID (this bit is set,<br>if the device is<br>addressed)                               | MODF<br>(multimaster<br>fault) |  |  |
|         | SCMREG.2 | ERR/WCOL   | ERR (set if error during TX)                                                         | WCOL (write collision)         |  |  |
|         | SCMREG.1 | CMD/CPOL   | CMD (1 if cmd.<br>in progress)                                                       | CPOL (clock polarity)          |  |  |
|         | SCMREG.0 | BUSY/CPHA  | BBUSY (set if bus busy)                                                              | CPHA (clock phase)             |  |  |

Data Direction Port Register (On-Reset configuration)

| Address | Name  | Bit | Description                                                                                                                                                                 |
|---------|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| \$9E    | DDGPR |     | Data Direction General Purpose<br>Port Register. For each bit of this<br>register, if 1, the corresponding pin<br>is an input; if 0, the corresponding<br>pin is an output. |

Serial Comm. Buffer Register (hXX, after Reset)

| Address | Name   | Bit | Description                                                                                                                                                                                                      |
|---------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| \$9F    | SCMBUF |     | Communication buffer. The<br>register is used for both transmit<br>and receive data through both I2C<br>or SPI bus. Transmit data is<br>written to this location and receive<br>data is read from this location. |

Boot Control Register (On-reset configuration)

| Address | Name   | Bit    | Description                                                                                                                                                            |
|---------|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| \$9D    | SBCR   |        | Boot Control                                                                                                                                                           |
|         | SBCR.7 | SCEN   | Serial Communication Enable. If 1,<br>serial communication system (I2C<br>and SPI protocols) is enabled.                                                               |
|         | SBCR.6 | SCSL   | Serial Communication Select. If 1,<br>serial communication system is<br>configured as I2C; if 0, , serial<br>communication system is configured<br>as SPI.             |
|         | SBCR.5 | MASTER | Boot master.                                                                                                                                                           |
|         | SBCR.4 | SCIE   | Serial Communication Interrupt<br>Enable. If 1, enables the<br>communication interrupt                                                                                 |
|         | SBCR.3 | GOE    | Global Output Enable. If 0, it<br>disables every output of every DMC<br>and places all the IO pads in input<br>state.                                                  |
|         | SBCR.2 | OD     | Open Drain. If OD = 0, the general<br>purpose port outputs are normal<br>CMOS outputs; if 1, the general<br>purpose port outputs act as open<br>drain outputs          |
|         | SBCR.1 | IREN   | Internal ROM Enable. If 1, the<br>internal ROM is mapped at locations<br>\$0000-\$001F of the program<br>memory. If 0, external memory is<br>used for those locations. |
|         | SBCR.0 | Baud   | SCI boot baud rate. This bit selects<br>the initial baud rate of the SCI port<br>when booting from it                                                                  |

## **5.** Global Configuration

Note: 2-wire serial interface is not available in device 8x12 of the FIPSOC family.

The serial Communication Interface Block consist of four main blocks which control the protocol between the external serial device and the FIPSOC chip. These blocks are:

- 2-wire interface block, which generate all the signals needed to the full implementation of the protocol. The block is controlled by three registers mapped through locations of the SFR map of the 8051. It also includes a flag in a status SFR (\$C4, ISR) which would interrupt the mP8051, if enabled.
- SPI interface block, which generate the signals needed in a SPI bus protocol. The block is configured and controlled by two registers mapped in the SFR memory area.
- Control block: The block sets the communication interface and is used by the boot program to obtain the configuration after reset (on-reset configuration).
- On reset configuration circuitry, which decodes external information set on the pads to configure the communication interface that would be used on boot.



Figure 5.1 schematically shows the Serial Communication Interface Block.



Fig. 5.1: Serial Communication Interface Block

Four Special Function Registers locations are used to access to any of the seven internal registers of the block. These registers can be grouped according to their accessing address on the SFR map, as described below:

- a) Serial Comm. Status Register SCMREG (**\$9C**):
  - ✓ 2-wire register: It is used by the 8051 to control the protocol communication. The bits of this register are for both configuring and status purposes. The register is mapped to the SFR area if the 2-wire interface is selected
  - ✓ SPI registers: It is used by the 8051 to control and receive information from the SPI block. The register can be accessed only if the SPI interface is chosen.
- b) Serial Comm. Buffer Register SCMBUF (**\$9F**):
  - ✓ 2-wire buffer: It is used for the data exchange and it can be accessed only if the 2-wire is enabled and the communication is in progress (that is, the bus is not free)
  - ✓ 2-wire address register: It is used to identify the 2-wire block device in the bus. It can be accessed only when the block is enabled and the bus is free.
  - ✓ SPI buffer register: It is used for data exchange between the serial communication block and the 8051. It is visible when SPI interface is selected
- c) Serial Comm. boot-control Register SBCR (**\$9D**):

It has two functions: firstly, it selects and enable the desired communication interface protocol; secondly, it contains on-reset information used by the boot program to configure the boot mode of the FIPSOC chip.

d) Data Direction General Port Reg. DDGPR (\$9E):

This register configures the general purpose port as an input or an output. If either the 2-wire or the SPI interface is enabled, the direction bits of the serial communication pads used will be ignored. All the register are configured on-reset. That means that some external pads have a special function when the reset input is active. The on-reset configuration is later described in section 8. Figure 5.2 shows the registers organization.



Fig. 5.2: Serial Registers Organization

## 5.1. (SBCR) Serial Communication Boot-Control Register

This register is accessed through position **\$9D** of the SFR memory area.

| SCEN  | SCSL | BMST | SCIE | GOE | ODS | IREN | BAUD |
|-------|------|------|------|-----|-----|------|------|
| *     | *    | *    | 0    | 0   | *   | *    | *    |
| * 1:4 |      |      |      |     |     |      |      |

\* bit configured on-reset

SCEN (Serial Communication Enable bit).

If SCEN is set, the serial communication block is enabled. If so, the corresponding bits of the general purpose port change their function. These bit are different depending on the interface protocol selected. If SCEN = 0, the serial communication interface block is disabled and the general purpose port will be full controlled by the **SFR \$9E** (DDGPR) and **\$90** (P1 of the 8051 core). See figure 5.3.

SCIS (Serial Communication Interface Selection).

When SCEN=1, if this bit is set the 2-wire interface is selected; otherwise, the SPI block will be enabled. When the 2.wire interface block is chosen, the two most significant bits of the general purpose port (bits GPP.7 and GGP.6) will change its function to provide the two lines of the 2-wire protocol (SCL and SDA, respectively) as shown in figure 5.4.





Fig. 5.3: General Purpose Port, if Serial Comm. Block disabled

Otherwise, if SCIS = 0, the SPI block is selected, and the most significant nibble of the general purpose port will change its function to communication purpose (as shown in Figure 5.5). SCK, MOSI, MISO and SSN lines are located in bits 7 through 4 of the general purpose port, respectively. Note that SSN is always an input, SCK is always bi-directional. MOSI and MISO lines directions depends on the operating mode selected in the SPI interface block.



Fig. 5.4: General Purpose Port, if 2-wire block enabled

The driving configuration of the general purpose port can be selected from either open drain or CMOS levels driven by setting or clearing bit 2 of the Serial Boot-Control Register (see below). Only the two most significant bits of the general purpose port is open drain driven (no selection is allowed) when the 2-wire interface block is selected (and the Serial Communication block is enabled too).





BMST (Boot Master Selection)

This flag is used by the on chip boot program to configure the FIPSOC chip on reset and it has no effect in any of the blocks of the Serial Comm. Block. Its value is set when the reset signal is active. If BMST=1, master device configuration program is required during the boot process; if this flag is cleared, the boot program is called to execute the slave device routine.

SCIE (Serial Communication Interrupt Enable)

When this bit is set, the serial block would cause an interrupt through the PLHW1 interrupt source of channel 0 of the External Interrupt Controller Block (see EIC Block Document for further information). If SCIE=0, no interrupt signal will be generated, and a low level will be set in the wire.

The interrupt is produced either if a word is successfully transmitted or if any error is produced in any step of the transmission. Table 5.1 shows the interrupt sources:

| SCIE | SCIS       | Interrupt sources |
|------|------------|-------------------|
| 0    | Х          | Doesn't interrupt |
| 1    | 0 (SPI)    | CCF + MODF + WCOL |
| 1    | 1 (2-wire) | CCF + ERR         |

 Table 5.1: SFR Locations of the breakpoints

GOE (Global Output Enable)

If GOE is cleared, all the outputs of the cells and all the pad cells of the Programmable Logic core will be disabled. That is, none of any of the cells will drive its outputs. This signal is routed to the whole FPGA to disable every single DMC output before chip configuration. The flag can be set either from software of from hardware. By default this bit is 0.



This bit affects the driving configuration of the general purpose port. If this bit is cleared, the general purpose port electrical characteristics will be normal CMOS inputs/outputs. If this bit is set, the general purpose block will be open drain driven.

If the 2-wire interface block is selected, no selection is possible in the two most significant bits of the port, since the 2-wire bus requires an open drain driving pads.

#### IREN (Internal ROM Enable)

If IREN is set, locations \$0000 through \$001F will be mapped in the internal read only memory. Otherwise, the mP8051 will fetch the instructions from an external memory. This bit is set on reset by hardware and it can be modified via software during the program execution.

#### BAUD (SCI Baud Rate)

This flag is used by the on chip boot program to configure the serial interface routine if the FIPSOC is set to the serial interface boot mode, so this flag has no effect in any other block. Its value is set when the reset signal is active. If BAUD=1 and the SCI boot mode is set, the boot program is called to configure the serial port of the 8051 to work at 3205,1 baud if a typical 16 MHz crystal is used (fosc/4992); otherwise, if BAUD=0, fosc/1536 will be used (10416,6 bauds)

## 5.2. (SCMREG) Serial Communication Status Register

Depending on bit SCIS of the SBCR register (**SFR \$9D**), the internal circuitry will select the 2-wire register or the SPI register. If SCIS is set, operations realized in location \$9C of the SFR map will affect to the 2-wire register; otherwise, the SPI register will be accessed.

#### 2-wire Register

This register is accessed through position **\$9C** of the SFR memory area if SCIS of the SBCR is set.

| CCF | 2MST | SDRC | CK0 | ID | ERR | CMD | BUSY |
|-----|------|------|-----|----|-----|-----|------|
| 1   | 1    | 1    | *   | 1  | 1   | 0   | 0    |

\* bit configured on-reset

#### CCF (Communication Complete flag)

This bit is set by hardware when a word transmission is completed. If CCF flag is 0, the block is transmitting (or receiving) or is ready to transmit (or receive).

The CCF flag is set by the internal state machine after nine cycles of the serial clock line. Clearing the CCF bit is accomplished by reading the 2-wire register with the CCF set.

When the 2-wire bus is free, the CCF flag is set

#### 2MST (2-wire Master)

The master flag indicates if the device controls or is suitable to control the 2-wire bus. By default, that is when the bus is free, this bit is set and the block would send a start command in order to get the bus control.

The 2-wire master bit is cleared if one of the following situations happens:

- ✓ A start condition is detected in the bus and no command operation has been executed
- ✓ The device loses arbitration during the arbitration procedure

The 2MST flag will change to high again if a stop condition is detected on the bus (so the bus is left free).

Note that this flag has different meaning than the boot master (BMST) bit of the SBCR register. The 2MST represents the status of the 2-wire interface block, while the BMST bit in SBCR does not show any state of any subblock of the serial communication block.

#### SDRC (Send-Receive mode operation)

This bit indicates if the master or the slave device works in the transmit or the receive mode. If this bit is set, the device is set to be a transmitter; otherwise, the device will be a receiver device.

| MST | SDRC | Operating mode     |
|-----|------|--------------------|
| 0   | 0    | Receiver-Slave     |
| 0   | 1    | Transmitter-Slave  |
| 1   | 0    | Receive-Master     |
| 1   | 1    | Transmitter-Master |

#### Table 5.2: Operating modes of the 2-wire interface block

The 2-wire interface block is configured as mastertransmitter device when the bus is free. In this waiting state any device in the bus (including itself) can send a start command and, therefor, behaves as a master. After the device gets the bus arbitration, it must address an slave device by transmitting the word command.

If the 2-wire interface detects a non-owner start condition in the bus, it will automatically changes its waiting state mode (master-transmitter) to the slave-receiver mode to allows the master device to



address it. This process is shown in the flow graph of figure 5.6.

After the first byte transmission (called the command word), the 2-wire interface block will change to one of the two receiver or transmitter mode to operate during the rest of the communication (see table 5.4)



Fig. 5.6: Start-up 2-wire interface process

#### CK0 (Serial Clock frequency Configuration)

The frequency of the serial clock signal may be configured (as shows in table 5.3). The serial clock frequency is compatible to other 2-wire interfaces when CK0=1. This bit configure the 2-wire interface block clock (as depicted from Figure 5.7).

| CK0 | Frequency  | Frequency for<br>fosc=16 MHz |
|-----|------------|------------------------------|
| 0   | fosc / 16  | 1 MHz                        |
| 1   | fosc / 160 | 100 KHz                      |

 Table 5.3: 2-wire serial clock frequencies

Therefor, the CK0 bit affects, not only to the period of the serial clock SCL, but also modified the time responses and SDA transitions times (see figure 5.8). Due to this fact, bit CK0 affects to both master and slave modes (frequency and transition times, respectively).



Fig. 5.7: Start-up 2-wire interface process



ID (Device address identification)

When the ID flag bit is set (and, of course, the serial communication block is enabled and the 2-wire block is selected), the block responds to the bus stimuli. Otherwise, if the ID=0, the 2-wire interface block enter to its idle mode, waiting to a new start command (as depicted from figure 5.6).

When the block is in the waiting mode (bus free) both SDA and SCL line are released (and no action will be produced or received).

The ID flag behaves as follows:

- ✓ Bus free: by default, any device hanging in the 2-wire bus can be addressed. Due to this fact, the 2-wire block must be "listening" during the first word, if it is enabled. In other words, the 2wire block is addressed at least during the first word transmission.
- After the first byte: After the exchange of the command word, the block will keeps the ID flag bit set if it is configured as master or the master device has addressed it.

If the block configured as a slave is not addressed, the ID flag will be cleared by hardware. Both lines will be left in high impedance and entered in the standby mode..

✓ *Start and stop conditions*: Either the start or the stop commands restart the communication between the 2-wire master and the "sleeping" device. Any of this command will take out the 2-wire block from its standby mode and will change the ID flag to 1.

Table 5.4 describes the flag configuration for any of the steps depicted from figure 5.6



| Stop                                          | 2-wire Register flags |      |    |  |
|-----------------------------------------------|-----------------------|------|----|--|
| Step                                          | 2MST                  | SDRC | ID |  |
| Bus free (waiting mode)                       | 1                     | 1    | 1  |  |
| Master device (during 1 <sup>st</sup> byte)   | 1                     | 1    | 1  |  |
| Slave device<br>(during 1 <sup>st</sup> byte) | 0                     | 0    | 1  |  |
| Non-addressed slave<br>(standby mode)         | 0                     | 0    | 0  |  |
| Addressed<br>Transmitter-slave                | 0                     | 1    | 1  |  |
| Addressed receiver-slave                      | 0                     | 0    | 1  |  |
| Transmitter master                            | 1                     | 1    | 1  |  |
| Receiver master                               | 1                     | 0    | 1  |  |

Table 5.4: 2-wire block mode configuration

ERR (2-wire transfer error)

The flag error indicates if a non-successful transmission is produced. If ERR = 1, an error has occurred; Otherwise, there is not any problem in the transmission up to the current step.

The ERR flag represents different error situations depending on when they are produced:

| Error                             | 2-wire Register flags |      |    |     |
|-----------------------------------|-----------------------|------|----|-----|
| Error                             | CCF                   | 2MST | ID | ERR |
| Device has not been<br>addressed  | 0                     | 0    | 0  | 1   |
| Non acknowledge bit has been sent | 0                     | -    | 1  | 1   |
| An error has been produced        | 0                     | 1    | 1  | 1   |
| Master loses arbitration          | 1                     | 1    | 1  | 1   |

#### Table 5.5: Error situations

CMD (2-wire command bit)

This bit is set while start and stop commands required by the mP8051 are in progress. The CMD flag is used to:

- ✓ *Action*: send both start and stop commands to the bus
- ✓ *Status*: show if a sent command is finished.

Actually, the command execution steps are as follows (see BUSY flag description too):

- ✓ By default, the CMD flag is cleared,
- ✓ Producing a start condition in the bus to start a transmission (if the bus is free) is accomplished

by writing in the 2-wire register with both CMD and BUSY bits set.

- ✓ Producing a stop condition in the bus to stop a transmission and leave the bus free is accomplished by writing in the 2-wire register with CMD=1 and BUSY=0
- ✓ The CMD flag bit will keep its value set to one during the execution of the command. After this, it will be cleared by hardware.
- ✓ If a start command has been executed, the BUSY flag will keep set and the 2-wire block will pull down the SCL and the SDA lines.
- ✓ If a stop command is already executed, the BUSY flag will be cleared and both lines will be released high.

Note that a command is executed by writing in the 2-wire register. CK0 bit will be overwritten during this access.

#### BUSY (Bus busy status flag)

This bit, accessed with the CMD bit, is used in write to send the start and stop commands to the 2-wire bus, and is used in read access to control the bus status.

If BUSY=1, the bus is not free; otherwise, bus is free. When BUSY=0, if the bus is occupied the buffer register is accessed; the device address register is accessed, otherwise.

#### SPI Register

This register is accessed through position **\$9C** of the SFR memory area if SCIS of the SBCR is cleared.

| CCF | SPMT | CK1 | CK0 | MODF | WCOL | CPOL | СРНА |
|-----|------|-----|-----|------|------|------|------|
| 1   | *    | *   | *   | Х    | Х    | *    | *    |
| ala |      |     |     |      |      |      |      |

\* bit configured on-reset

CCF (Communication Complete flag)

This bit is set by hardware upon completion of data transfer between the block and the external device. If CCF flag is 0, the block is transmitting (or receiving) or is ready to transmit (or receive).

The CCF flag is set by the internal state machine after eight cycles of the serial clock line. Clearing the CCF bit is accomplished by reading the SPI register with the CCF set.

#### SPMT (SPI Master)

The master flag indicates if the device controls or is suitable to control the SPI bus. On reset, the flag is configured. If this flag is set, the SCK line is controlled by the SPI block and the corresponding bit of the general purpose port is configured as an output. If not, the serial clock must be obtained



from the external line, so the SCK bit of the general purpose port is configured as an input.

If the SPMT = 0, the slave SPI block is selected by pulling down the SSN input. This input (bit 4 of the general purpose port) can be permanently tied down (if the block is going to behave always as an slave device) or selected by the SPI master device.

If the SPMT is set and any device selects the block a mode fault will occur.

Note that this flag has different meaning than the boot master (BMST) bit of the SBCR register. The SPMT bit configures the master or slave mode, while the BMST bit in SBCR is only used during the boot sequence.

CK1, CK0 (SPI Clock Rate Selects)

These two rate bits select one of the four baud rates to be used as SCK if the SPI interface block is a master; however, they have no effect in the slave mode. See Table 5.6.

| CK1,CK0 | Frequency | Frequency for<br>fosc=16 MHz |
|---------|-----------|------------------------------|
| 00      | fosc / 8  | 2 MHz.                       |
| 01      | fosc / 16 | 1 MHz.                       |
| 10      | fosc / 32 | 500 KHz.                     |
| 11      | fosc / 64 | 250 KHz.                     |

Table 5.6: SPI serial clock frequencies

MODF (Mode Fault flag error)

The mode fault flag indicates that there may have been a multi-master conflict for SPI bus control. The MODFflag is normally cleared, and is set only when the master device has its SSN line pulled low. Any write to the buffer register is ignored while this flag is set. Clearing the MODF bit is accomplished by reading the SPI register with MODF set followed by a clearing write to this bit in the SPI register

WCOL (write collision flag error)

The WCOL bit is set when an attempt is made to write to the CMbuffer register while data transfer is taking place. A transfer is said to begin and end when:

- ✓ CPHA is zero: A transfer is said to begin when SSN goes low and the transfer ends when SSN goes high after eight clock cycles on SCK.
- ✓ CPHA is one: A transfer is said to begin the first time SCK becomes active while SSN is low and the transfer ends when the SPIF flag gets set after eight cycles of SCK. Clearing the WCOL flag is accomplished by reading the SPI register

(with WCOL set) followed by a write access to the SPI register to clear the bit.

#### CPOL (Clock Polarity)

When the clock polarity bit is cleared and data is not being transferred, a steady state low value is produced at the SCK pin of the master device. Conversely, if this bit is set, the SCK pin will idle high. This bit is also used in conjunction with the clock phase control bit to produce the desired clock-data relationship between master and slave (see figure 3.2).

#### CPHA (Clock Phase)

The clock phase bit, in conjunction with the CPOL bit, controls the clock-data relationship between master and slave. The CPHA bit selects one of the two fundamentally different clocking protocols. When CPHA=0, the shift clock is the OR of SCK with SSN. When CPHA=1, the SSN pin may be though of as a simple output enable control (refer to figure 3.2)

## 5.3. (SCMBUF) Serial Communication Buffer Register

The Serial Communication Buffer Register (SFR \$9F, CMBUF) is used to transmit and receive data on the serial bus. Only a write to this register will initiate transmission or reception of another byte, and this will only occur in the master device. A completion of transmitting a byte of data is signaled by the CCF flag bit in both master and slave modes.

Depending on bit SCIS of the SBCR register (**SFR \$9D**), the internal circuitry will select the 2-wire block or the SPI one. If SCIS is set, operations realized in location \$9F of the SFR map will affect to the 2-wire buffer or the device address register; otherwise, the SPI buffer register will be accessed.

#### 2-wire buffer Register

This register is accessed through position **\$9F** of the SFR memory area if SCIS of the SBCR is set and the 2-wire bus is occupied. Transmission is initiated when master writes in this register. Received data can be read from the buffer register after the CCF flag is set.

#### 2-wire Device Address Register

This register is accessed through position **\$9F** of the SFR memory area if SCIS of the SBCR is set and the 2-wire bus is free. This register is configured on reset and is used to identify the block in the 2-wire bus. Device address may be configured by software by writing the desired address in it.



Note that the device address configuration is only available if bus is free; that is, if a transmission is in progress between any device hanging on the bus, the 2-wire address of the block cannot be configured.

#### SPI buffer Register

This register is accessed through position **\$9F** of the SFR memory area if SCIS of the SBCR is cleared. Transmission is initiated when master writes in this register. Received data can be read from the buffer register after the CCF flag is set.

## 5.4. (DDGPR) Data Direction Register

This registers sets the data direction of the general purpose port. In conjunction with SFR \$90 (P1) data is sent or received to/from the external system.

The most significant nibble is used for communication purpose as mentioned. If the Serial Communication block is enabled, the corresponding bits of the DDPGR register will be ignored, and those pins will be internally configured (see figures 5.3 to 5.5).

If a bit of the DDGPR is set, the direction of the corresponding bit of the general purpose port will be configured as input. Otherwise, the output data direction will be selected.



## 6. SPI Communication Process

This section will be described with flow graphs how the SPI block of the Serial Communication Block would be programmed for each step: initialize, data transmission and flags interpretation.

## 6.1. Initialize



## 6.2. Flags Interpretation



### 6.3. Data Transmission





## 7. 2-wire Communication Process

## Note: 2-wire serial interface is not available in device 8x12 of the FIPSOC family.

In this section will be described how the 2-wire block of the Serial Communication Block would be programmed for each step: initialize, data transmission, flag interpretation. A flow graph of the 2-wire communication process is also provided.

## 7.1. Initialize



## 7.2. Data Transmission





Address Detection





Send/Receive Word



Stop command



7.3. Flow Graph for the Communication Process



## 7.4. Flags Interpretation

Depending on the step of the communication, the flags bit would be interpreted as follows (see flow graph diagram):

1. Initiate

| 2-wire Register | Interpretation |  |
|-----------------|----------------|--|
| xxxx xxx0       | Bus free       |  |
| xxxx xxx1       | Bus busy       |  |

2. Start Command

| 2-wire Register | Interpretation                                                                                           |
|-----------------|----------------------------------------------------------------------------------------------------------|
| x00x xx01       | Bus busy. Arbitration lost.                                                                              |
| x1xx xx11       | Start condition executing.                                                                               |
| x1xx xx01       | Start command executed.                                                                                  |
| xxxx x100       | If BUSY is cleared after start<br>command is executed, a<br>device in the bus has sent a<br>stop command |



#### 3. Command word status

| 2-wire Register | Interpretation                                                   |
|-----------------|------------------------------------------------------------------|
| 011x 1001       | command is being sent                                            |
| 000x 1101       | Arbitration lost.                                                |
|                 | Changed to slave mode                                            |
| 000x 0101       | Slave device not addressed                                       |
|                 | (only in slave device)                                           |
| 11xx 1101       | Acknowledge error.                                               |
|                 | No device addressed                                              |
| 11xx 1001       | Command successfully<br>transmitted and a device is<br>addressed |

#### 4. Transmission status

| 2-wire Register | Interpretation               |
|-----------------|------------------------------|
| 0x1x 1001       | TX/RX in progress            |
| 0x01 1101       | TX error ('false zero' sent) |
|                 | (only in transmitter)        |
| 1xxx 1001       | Transmission completed       |
| 1xxx 1101       | Acknowledge bit error        |

#### 5. Stop Command

| 2-wire Register | Interpretation            |
|-----------------|---------------------------|
| x1xx xx10       | Stop condition executing. |
| x1xx xx00       | Stop command executed.    |

## 8. On-Reset Configuration

The FIPSOC chip has been designed to auto-boot after reset. In order to bring more flexibility to the boot process, different boot modes and configurations are supported.

The information needed in the boot sequence is obtained from the external system through the input/output cells. The values set in some of the pads are captured in the reset condition and stored in the Serial Communication Block Registers. The program boot later uses these values and configures the rest of the chip.

The boot modes supported are:

- 2-wire boot sequence: the Serial Communication Block is configured as a 2-wire device. Both address device and master/slave configuration can be on-reset set
- SPI boot sequence: the Serial Comm. Block is configured as an SPI device. Master/Slave configuration can be on-reset set.

## Semiconductor Design Solutions

- SCI boot sequence: the Serial Communication is disabled and the 8051 serial interface is used. Two clock rates can be selected on-reset.
- External Parallel Memory: The internal memory is deselected. The program instructions are fetched from an external memory using ports 0 and 2 of the 8051.

The pads used to load the defaults values of the registers and the boot mode are:

• *BT1, BT0*: These two inputs are used to select the boot mode, as depicted from Table 8.1

| BT1 | BT0 | Boot mode             |
|-----|-----|-----------------------|
| 0   | 0   | 2-wire boot mode.     |
| 0   | 1   | SPI boot mode.        |
| 1   | 0   | SCI boot mode.        |
| 1   | 1   | External Memory mode. |

 Table 8.1: Boot modes supported

• *AD[15:8]*: The addresses port is sampled in a high to low transition of the reset signal to configure the default values of the Serial Communication Block Registers. The direction of this port is set as input only if the reset signal is active; otherwise, the port has output direction.

#### **Registers** Configuration

Tables 8.2, 8.3 and 8.4 list the correspondence between the pads of the chip and the bits on the Serial Communication Block registers.

| SBCR | Value on reset    |  |
|------|-------------------|--|
| SCEN | not (BT1)         |  |
| SCSL | not (BT0)         |  |
| BMST | AD[15]            |  |
| SCIE | 0                 |  |
| GOE  | 0                 |  |
| ODS  | AD[10]            |  |
| IREN | not (BT1 and BT0) |  |
| BAUD | AD[8]             |  |

Table 8.2: SBCR register



| SCMREG |      | Value on reset |        |
|--------|------|----------------|--------|
| 2wire  | SPI  | 2 wire         | SPI    |
| CCF    | CCF  | 1              | 1      |
| 2MST   | SPMT | 1              | AD[15] |
| SDRC   | CK1  | 1              | AD[12] |
| CK0    | CK0  | AD[0]          | AD[11] |
| ID     | MODF | 1              | х      |
| ERR    | WCOL | 1              | х      |
| CMD    | CPOL | 0              | AD[14] |
| BUSY   | CPHA | 0              | AD[13] |

Table 8.3: SCMREG Register

| Register     | Value on reset |
|--------------|----------------|
| BUFREG       | AD             |
| ADDRESS[6:0] | AD[14:8]       |

Table 8.4: BUFREG and 2 wire ADDRESS Register