參數(shù)資料
型號(hào): S87C751-1A28
廠商: NXP SEMICONDUCTORS
元件分類: 微控制器/微處理器
英文描述: 8-bit Microcontroller with 2/4/8K Bytes In-System Programmable Flash
中文描述: 8-BIT, OTPROM, 12 MHz, MICROCONTROLLER, PQCC28
封裝: PLASTIC, MO-047AB, SOT-261-3, LCC-28
文件頁(yè)數(shù): 13/24頁(yè)
文件大小: 211K
代理商: S87C751-1A28
Philips Semiconductors
Product specification
83C751/87C751
80C51 8-bit microcontroller family
2K/64 OTP/ROM, I
2
C, low pin count
1998 May 01
13
I
2
C Serial Interface
The I
2
C bus uses two wires (SDA and SCL) to transfer information
between devices connected to the bus. The main features of the bus
are:
Bidirectional data transfer between masters and slaves
Serial addressing of slaves (no added wiring)
Acknowledgment after each transferred byte
Multimaster bus
Arbitration between simultaneously transmitting masters without
corruption of serial data on bus
The 82B715 extends communication distance to 100 feet (30M).
A large family of I
2
C compatible ICs is available. See the I
2
C section
of this manual for more details on the bus and available ICs.
The 83C751 I
2
C subsystem includes hardware to simplify the
software required to drive the I
2
C bus. The hardware is a single bit
interface which in addition to including the necessary arbitration and
framing error checks, includes clock stretching and a bus timeout
timer. The interface is synchronized to software either through polled
loops or interrupts. Refer to the application note AN422, in
Section 4, entitled “Using the 8XC751 Microcontroller as an I
2
C Bus
Master” for additional discussion of the 83C751 I
2
C interface and
sample driver routines.
Six time spans are important in I
2
C operation and are insured by
timer I:
The MINIMUM HIGH time for SCL when this device is the master.
The MINIMUM LOW time for SCL when this device is a master.
This is not very important for a single-bit hardware interface like
this one, because the SCL low time is stretched until the software
responds to the I
2
C flags. The software response time normally
meets or exceeds the MIN LO time. In cases where the software
responds within MIN HI + MIN LO) time, timer I will ensure that
the minimum time is met.
The MINIMUM SCL HIGH TO SDA HIGH time in a stop condition.
The MINIMUM SDA HIGH TO SDA LOW time between I
2
C stop
and start conditions (4.7
μ
s, see spec.).
The MINIMUM SDA LOW TO SCL LOW time in a start condition.
The MAXIMUM SCL CHANGE time while an I
2
C frame is in
progress. A frame is in progress between a start condition and the
following stop condition. This time span serves to detect a lack of
software response on this 8XC751 as well as external I
2
C
problems. SCL “stuck low” indicates a faulty master or slave. SCL
“stuck high” may mean a faulty device, or that noise induced onto
the I
2
C bus caused all masters to withdraw from I
2
C arbitration.
The first five of these times are 4.7
μ
s (see I
2
C specification) and are
covered by the low order three bits of timer I. Timer I is clocked by
the 8XC751 oscillator, which can vary in frequency from 0.5 to
16MHz. Timer I can be preloaded with one of four values to optimize
timing for different oscillator frequencies. At lower frequencies,
software response time is increased and will degrade maximum
performance of the I
2
C bus. See special function register I2CFG
description for prescale values (CT0, CT1).
The MAXIMUM SCL CHANGE time is important, but its exact span
is not critical. The complete 10 bits of timer I are used to count out
the maximum time. When I
2
C operation is enabled, this counter is
cleared by transitions on the SCL pin. The timer does not run
between I
2
C frames (i.e., whenever reset or stop occurred more
recently than the last start). When this counter is running, it will carry
out after 1020 to 1023 machine cycles have elapsed since a change
on SCL. A carry out causes a hardware reset of the 83C751 I
2
C
interface and generates an interrupt if the timer I interrupt is
enabled. In cases where the bus hangup is due to a lack of software
response by this 83C751, the reset releases SCL and allows I
2
C
operation among other devices to continue.
I
2
C Interrupts
If I
2
C interrupts are enabled (EA and EI2 are both set to 1), an I
2
C
interrupt will occur whenever the ATN flag is set by a start, stop,
arbitration loss, or data ready condition (refer to the description of
ATN following). In practice, it is not efficient to operate the I
2
C
interface in this fashion because the I
2
C interrupt service routine
would somehow have to distinguish between hundreds of possible
conditions. Also, since I
2
C can operate at a fairly high rate, the
software may execute faster if the code simply waits for the I
2
C
interface.
Typically, the I
2
C interrupt should only be used to indicate a start
condition at an idle slave device, or a stop condition at an idle master
device (if it is waiting to use the I
2
C bus). This is accomplished by
enabling the I
2
C interrupt only during the aforementioned conditions.
I
2
C Register I2CON
7
6
5
4
3
2
1
0
Read
RDAT
ATN
DRDY
ARL
STR
STP
MASTER
Write
CXA
IDLE
CDR
CARL
CSTR
CSTP
XSTR
XSTP
Reading I2CON
RDAT
The data from SDA is captured into “Receive DATa”
whenever a rising edge occurs on SCL. RDAT is also
available (with seven low-order zeros) in the I2DAT
register. The difference between reading it here and there
is that reading I2DAT clears DRDY, allowing the I
2
C to
proceed on to another bit. Typically, the first seven bits of a
received byte are read from I2DAT, while the 8th is read
here. Then I2DAT can be written to send the Ack bit and
clear DRDY.
“ATteNtion” is 1 when one or more of DRDY, ARL, STR, or
STP is 1. Thus, ATN comprises a single bit that can be
tested to release the I
2
C service routine from a “wait loop.”
“Data ReaDY” (and thus ATN) is set when a rising edge
occurs on SCL, except at idle slave. DRDY is cleared by
writing CDR = 1, or by writing or reading the I2DAT
register. The following low period on SCL is stretched until
the program responds by clearing DRDY.
ATN
DRDY
相關(guān)PDF資料
PDF描述
S87C751-1DB 8-bit Microcontroller with 2/4/8K Bytes In-System Programmable Flash
S87C751-1N24 8-bit Microcontroller with 2/4/8K Bytes In-System Programmable Flash
S87C751-2A28 8-bit Microcontroller with 2/4/8K Bytes In-System Programmable Flash
S87C751-2N24 8-bit Microcontroller with 2/4/8K Bytes In-System Programmable Flash
S87C751-4A28 8-bit Microcontroller with 2/4/8K Bytes In-System Programmable Flash
相關(guān)代理商/技術(shù)參數(shù)
參數(shù)描述
S87C751-1DB 制造商:PHILIPS 制造商全稱:NXP Semiconductors 功能描述:80C51 8-bit microcontroller family 2K/64 OTP/ROM, I2C, low pin count
S87C751-1N24 制造商:PHILIPS 制造商全稱:NXP Semiconductors 功能描述:80C51 8-bit microcontroller family 2K/64 OTP/ROM, I2C, low pin count
S87C751-2A28 制造商:PHILIPS 制造商全稱:NXP Semiconductors 功能描述:80C51 8-bit microcontroller family 2K/64 OTP/ROM, I2C, low pin count
S87C751-2N24 制造商:PHILIPS 制造商全稱:NXP Semiconductors 功能描述:80C51 8-bit microcontroller family 2K/64 OTP/ROM, I2C, low pin count
S87C7514A28 制造商:PHILIPS 功能描述:New