Inter-IC Bus
IIC Programming Examples
68HC(9)12DG128 Rev 1.0
MOTOROLA
Inter-IC Bus
267
17-iicbus
IIC Programming Examples
Initialization
Sequence
Reset will put the IIC Bus Control Register to its default status. Before
the interface can be used to transfer serial data, an initialization
procedure must be carried out, as follows:
1.
Update the Frequency Divider Register (IBFD) and select the
required division ratio to obtain SCL frequency from system clock.
Update the IIC Bus Address Register (IBAD) to define its slave
address.
Set the IBEN bit of the IIC Bus Control Register (IBCR) to enable
the IIC interface system.
Modify the bits of the IIC Bus Control Register (IBCR) to select
Master/Slave mode, Transmit/Receive mode and interrupt enable
or not.
2.
3.
4.
Generation of
START
After completion of the initialization procedure, serial data can be
transmitted by selecting the 'master transmitter' mode. If the device is
connected to a multi-master bus system, the state of the IIC Bus Busy
bit (IBB) must be tested to check whether the serial bus is free.
If the bus is free (IBB=0), the start condition and the first byte (the slave
address) can be sent. The data written to the data register comprises the
slave calling address and the LSB set to indicate the direction of transfer
required from the slave.
The bus free time (i.e., the time between a STOP condition and the
following START condition) is built into the hardware that generates the
START cycle. Depending on the relative frequencies of the system clock
and the SCL period it may be necessary to wait until the IIC is busy after
writing the calling address to the IBDR before proceeding with the
following instructions. This is illustrated in the following example.
An example of a program which generates the START signal and
transmits the first byte of data (slave address) is shown below: