ADUC834 Analog Devices, ADUC834 Datasheet - Page 47

no-image

ADUC834

Manufacturer Part Number
ADUC834
Description
Precision Analog Microcontroller: 1MIPS 8052 MCU + 62kB Flash + 16/24-Bit ADC + 12-Bit DAC
Manufacturer
Analog Devices
Datasheet

Specifications of ADUC834

Mcu Core
8052
Mcu Speed (mips)
1
Sram (bytes)
2304Bytes
Gpio Pins
34
Adc # Channels
4
Other
PWM

Available stocks

Company
Part Number
Manufacturer
Quantity
Price
Part Number:
ADUC834
Manufacturer:
ADI
Quantity:
4 000
Part Number:
ADUC834BS
Manufacturer:
TKS
Quantity:
15 200
Part Number:
ADUC834BS
Manufacturer:
ADI
Quantity:
455
Part Number:
ADUC834BS
Manufacturer:
AD
Quantity:
20 000
Part Number:
ADUC834BSZ
Manufacturer:
TOSHIBA
Quantity:
1 200
Part Number:
ADUC834BSZ
Manufacturer:
Analog Devices Inc
Quantity:
10 000
Part Number:
ADUC834BSZ
Manufacturer:
ADI/亚德诺
Quantity:
20 000
The main features of the MicroConverter I
Software Master Mode
The ADuC834 can be used as a I
the I
the data bit by bit, which is referred to as a software master. Master
mode is enabled by setting the I2CM bit in the I2CCON register.
To transmit data on the SDATA line, MDE must be set to enable
the output driver on the SDATA pin. If MDE is set then the
SDATA pin will be pulled high or low depending on whether the
MDO bit is set or cleared. MCO controls the SCLOCK pin and
is always configured as an output in Master mode. In Master
mode, the SCLOCK pin will be pulled high or low depending
on the whether MCO is set or cleared.
To receive data, MDE must be cleared to disable the output
driver on SDATA. Software must provide the clocks by toggling
the MCO bit and read SDATA pin via the MDI bit. If MDE is
cleared, MDI can be used to read the SDATA pin. The value of
the SDATA pin is latched into MDI on a rising edge of SCLOCK.
MDI is set if the SDATA pin was high on the last rising edge of
SCLOCK. MDI is clear if the SDATA pin was low on the last
rising edge of SCLOCK.
Software must control MDO, MCO, and MDE appropriately to
generate the START condition, slave address, acknowledge bits,
data bytes, and STOP conditions appropriately. These functions
are provided in Application Note uC001.
Hardware Slave Mode
After reset, the ADuC834 defaults to hardware slave mode. The
I
Slave mode is enabled by clearing the I2CM bit in I2CCON.
The ADuC834 has a full hardware slave. In slave mode, the I
address is stored in the I2CADD register. Data received or to be
transmitted is stored in the I2CDAT register.
REV. A
2
C interface is enabled by clearing the SPE bit in SPICON.
Only two bus lines are required; a serial data line (SDATA)
and a serial clock line (SCLOCK).
An I
Because each slave device has a unique 7-bit address then
single master/slave relationships can exist at all times even in
a multislave environment (Figure 35).
On-chip filtering rejects <50 ns spikes on the SDATA and
the SCLOCK lines to preserve data integrity.
2
C peripheral in master mode and writing software to output
2
C master can communicate with multiple slave devices.
Figure 35. Typical I
MASTER
I
2
C
DV
DD
2
C master device by configuring
2
C System
SLAVE #1
SLAVE #2
I
I
2
2
2
C
C
C interface are:
2
C
–47–
Once enabled in I
START condition. If the ADuC834 detects a valid start condition,
followed by a valid address, and by the R/W bit, the I2CI inter-
rupt bit will get automatically set by hardware.
The I
has preconfigured the I
as well as the global interrupt bit EA in the IE SFR, i.e.,
On the ADuC834 an auto clear of the I2CI bit is implemented
so this bit is cleared automatically on a read or write access to
the I2CDAT SFR.
A, I2CDAT
If for any reason the user tries to clear the interrupt more than
once, i.e., access the data SFR more than once per interrupt,
then the I
be reset using the I2CRS bit.
The user can choose to poll the I2CI bit or enable the interrupt.
In the case of the interrupt, the PC counter will vector to 003BH
at the end of each complete byte. For the first byte when the
user gets to the I2CI ISR, the 7-bit address and the R/W bit will
appear in the I2CDAT SFR.
The I2CTX bit contains the R/W bit sent from the master. If
I2CTX is set then the master would like to receive a byte. Hence
the slave will transmit data by writing to the I2CDAT register.
If I2CTX is cleared, the master would like to transmit a byte.
Hence the slave will receive a serial byte. The software can
interrogate the state of I2CTX to determine whether it should
write to or read from I2CDAT.
Once the ADuC834 has received a valid address, hardware will
hold SCLOCK low until the I2CI bit is cleared by the software.
This allows the master to wait for the slave to be ready before
transmitting the clocks for the next byte.
The I2CI interrupt bit will be set every time a complete data
byte is received or transmitted provided it is followed by a valid
ACK. If the byte is followed by a NACK, an interrupt is NOT
generated. The ADuC834 will continue to issue interrupts for
each complete data byte transferred until a STOP condition is
received or the interface is reset.
When a STOP condition is received, the interface will reset to a
state where it is waiting to be addressed (idle). Similarly, if the
interface receives a NACK at the end of a sequence, it also
returns to the default idle state. The I2CRS bit can be used to
reset the I
face back to the default idle state.
It should be noted that there is no way (in hardware) to distin-
guish between an interrupt generated by a received START +
valid address and an interrupt generated by a received data byte.
User software must be used to distinguish between these interrupts.
; Enabling I2C Interrupts for the ADuC834
MOV
SETB EA
MOV
2
C peripheral will only generate a core interrupt if the user
IEIP2,#01h
2
2
C controller will halt. The interface will then have to
C interface. This bit can be used to force the inter-
I2CDAT, A
; I2CI auto-cleared
2
C slave mode, the slave controller waits for a
2
C interrupt enable bit in the IEIP2 SFR
; enable I2C interrupt
; I2CI auto-cleared MOV
ADuC834

Related parts for ADUC834