#### **Product Features** - Using external 32.768kHz quartz crystal - Supports I<sup>2</sup>C-Bus's high speed mode (400 kHz) - Includes time (Hour/Minute/Second) and calendar (Year/Month/Date/Day) counter functions (BCD code) - Programmable square wave output signal - Two Time-of-Day Alarms - Oscillator Stop Flag - Operating range: 1.8V to 5.5V **Ordering Information** | Part Number | Package | |-------------|---------------------------------| | IT7C4337WE | Lead free and Green 8-Pin SOIC | | IT7C4337UE | Lead free and Green 8-Pin MSOP | | IT7C4337ZEE | Lead free and Green 8-Pin TDFN | | IT7C4337TE | Lead free and Green 8-Pin TSSOP | ### **Product Description** The IT7C4337 serial real-time clock is a low-power clock/calendar with two programmable time-of-day alarms and a programmable square-wave output. Address and data are transferred serially via a 2-wire, bidirectional bus. The clock/calendar provides seconds, minutes, hours, day, date, month, and year information. The date at the end of the month is automatically adjusted for months with fewer than 31 days, including corrections for leap year. The clock operates in either the 24-hour or 12-hour format with AM/PM indicator. Table 1 shows the basic functions of IT7C4337. More details are shown in section: overview of functions. Table 1. Basic functions of IT7C4337 | Item | | Fu | nction | IT7C4337 | |------|---------------|-------------------|--------------------|----------------------------| | | | C | Crystal: 32.768kHz | V | | 1 | Oscillator | Source | External input | √ | | 1 | Oscillator | Oscillator enab | le/disable | √ | | | | Oscillator fail d | letect | √ | | | | Time dienley | 12-hour | √ | | 2 | Time | Time display | 24-hour | √ | | | | Century bit | | √ | | 3 | Alarm interru | Alarm interrupt | | √ 2 | | 4 | Programmab | le square wave ou | tput (Hz) | 1, 4.096k, 8.192k, 32.768k | ## **Pin Assignment** ## **Pin Description** | Pin no. | Pin | Туре | Description | |---------|----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | X1 | I | <b>Oscillator Circuit Input.</b> Together with X2, 32.768kHz crystal is connected between them. Or external clock input. | | 2 | X2 | О | <b>Oscillator Circuit Output.</b> Together with X1, 32.768kHz crystal is connected between them. When 32.768kHz external input, X2 must be float. | | 6 | SCL | I | <b>Serial Clock Input.</b> SCL is used to synchronize data movement on the I <sup>2</sup> C serial interface. | | 5 | SDA | I/O | <b>Serial Data Input/Output.</b> SDA is the input/output pin for the 2-wire serial interface. The SDA pin is open-drain output and requires an external pull-up resistor. | | 3 | ĪNTĀ | О | <b>Interrupt Output.</b> When enabled, INTA is asserted low when the time matches the values set in the alarm registers. This pin is an open-drain output and requires an external pull up resistor. | | 7 | SQW/INTB | О | <b>Square-Wave/Interrupt Output.</b> Programmable square-wave or interrupt output signal. It is an open-drain output and requires an external pull up resistor. | | 8 | VCC | P | Power. | | 4 | GND | P | Ground. | #### **Function Block** ## **Recommended Layout for Crystal** ## **Crystal Specifications** | Parameter Symbol | | Min | Тур | Max | Unit | |-------------------|---------------------------|-----|--------|-----|------| | Nominal Frequency | $f_{O}$ | ı | 32.768 | ı | kHz | | Series Resistance | ESR | - | = | 70 | kΩ | | Load Capacitance | C <sub>1</sub> (Optional) | 0 | - | 15 | pF | | Load Capacitance | C <sub>2</sub> (Optional) | 0 | = | 15 | pF | | Build-in Cap | $C_{X1}, C_{X2}$ | - | 12 | - | pF | The crystal, traces and crystal input pins should be isolated from RF generating signals. ## **Function Description** #### **Overview of Functions** #### **Clock function** CPU can read or write data including the year (last two digits), month, date, day, hour, minute, and second. Any (two-digit) year that is a multiple of 4 is treated as a leap year and calculated automatically as such until the year 2100. #### Alarm function This device has two alarm system (Alarm 1 and Alarm 2) that outputs interrupt signals from INTA or INTB to CPU when the date, day of the week, hour, minute or second correspond to the setting. Each of them may output interrupt signal separately at a specified time. The alarm is be selectable between on and off for matching alarm or repeating alarm. #### Programmable square wave output A square wave output enable bit controls square wave output at pin 7. Frequencies are selectable: 1, 4.096k, 8.192k, 32.768k Hz. #### **Interface with CPU** Data is read and written via the I<sup>2</sup>C bus interface using two signal lines: SCL (clock) and SDA (data). Since the output of the I/O pin SDA is open drain, a pull-up resistor should be used on the circuit board if the CPU output I/O is also open drain. The SCL's maximum clock frequency is 400 kHz, which supports the I<sup>2</sup>C bus's high-speed mode. #### Oscillator fail detect When oscillator fail, IT7C4337 OSF bit will be set. #### Oscillator enable/disable Oscillator and time count chain can be enabled or disabled at the same time by /ETIME bit. #### **Registers** Allocation of registers | Addr. | tion of registers | | | | Register o | lefinition | | | | |---------|--------------------------|-------------------|---------------|--------------|------------|------------|-----------|-----------|-----------| | (hex)*1 | Function | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | 00 | Seconds (00-59) | 0 | S40 | S20 | S10 | S8 | S4 | S2 | S1 | | 01 | Minutes (00-59) | 0 | M40 | M20 | M10 | M8 | M4 | M2 | M1 | | 02 | Hours (00-23 / 01-12) | 0 | 12, /24 | H20 or P, /A | H10 | Н8 | H4 | H2 | H1 | | 03 | Days of the week (01-07) | 0 | 0 | 0 | 0 | 0 | W4 | W2 | W1 | | 04 | Dates (01-31) | 0 | 0 | D20 | D10 | D8 | D4 | D2 | D1 | | 05 | Months (01-12) | Century | 0 | 0 | MO10 | MO8 | MO4 | MO2 | MO1 | | 06 | Years (00-99) | Y80 | Y40 | Y20 | Y10 | Y8 | Y4 | Y2 | Y1 | | 07 | Alarm 1: Seconds | A1M1*2 | S40 | S20 | S10 | S8 | S4 | S2 | S1 | | 08 | Alarm 1: Minutes | A1M2*2 | M40 | M20 | M10 | M8 | M4 | M2 | M1 | | 09 | Alarm 1: Hours | A1M3*2 | 12, /24 | H20 or P, /A | H10 | Н8 | H4 | Н2 | H1 | | 0A | Alarm 1: Day, Date | A1M4*2 | Day,<br>/Date | 0,<br>D20 | 0,<br>D10 | 0,<br>D8 | W4,<br>D4 | W2,<br>D2 | W1,<br>D1 | | 0B | Alarm 2: Minutes | A2M2*3 | M40 | M20 | M10 | M8 | M4 | M2 | M1 | | 0C | Alarm 2: Hours | A2M3*3 | 12, /24 | H20 or P, /A | H10 | Н8 | H4 | Н2 | H1 | | 0D | Alarm 2: Day, Date | A2M4*3 | Day,<br>/Date | 0,<br>D20 | 0,<br>D10 | 0,<br>D8 | W4,<br>D4 | W2,<br>D2 | W1,<br>D1 | | 0E | Control | /ETIME*4 | 0 | 0 | RS2*5 | RS1*5 | INTCN*6 | A2IE*7 | A1IE*7 | | 0F | Status | OSF <sup>*9</sup> | 0 | 0 | 0 | 0 | 0 | A2F*8 | A1F*8 | #### Caution points: - \*1. IT7C4337 uses 8 bits for address. For excess 0FH address, 4337 will not respond (no acknowledge signal was given). - \*2. Alarm 1 mask bits. Select alarm repeated rate when an alarm occurs. - \*3. Alarm 2 mask bits. Select alarm repeated rate when an alarm occurs. - \*4. Oscillator and time count chain enable/disable bit. - \*5. Square wave output frequency select. - \*6. Interrupt output pin select bit. - \*7. Alarm 1 and alarm 2 enable bits. - \*8. Alarm 1 and alarm 2 flag bits. - \*9. Oscillator stop flag. - \*10. All bits marked with "0" are read-only bits. Their value when read is always "0". #### Control and status register | Addr. (hex) | Description | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-------------|---------------------|-------------|----|--------|-----|--------|------------|------------------|------------------| | 0E | Control (default) | /ETIME<br>0 | 0 | 0<br>0 | RS2 | RS1 | INTCN<br>0 | A2IE<br>0 | A1IE<br>0 | | 0F | Status<br>(default) | OSF<br>1 | 0 | 0<br>0 | 0 | 0<br>0 | 0<br>0 | A2F<br>Undefined | A1F<br>Undefined | #### Oscillator related bits #### /ETIME Enable oscillator and time count chain bit. | /ETIME | Data | Description | | |--------------|------|------------------------------------------------|-----| | Read / Write | 0 | Enable oscillator and time count chain. Defau | ılt | | Read / Write | 1 | Disable oscillator and time count chain. | | #### OSF Oscillator Stop Flag. A logic 1 in this bit indicates that the oscillator either is stopped or was stopped for some period of time and may be used to judge the validity of the clock and calendar data. This bit is set to logic 1 anytime that the oscillator stops. The following are examples of conditions that can cause the OSF bit to be set: - 1) The first time power is applied. - 2) The voltage present on VCC is insufficient to support oscillation. - 3) The /ETIME bit is turned off. - 4) External influences on the crystal (e.g., noise, leakage, etc.). This bit remains at logic 1 until written to logic 0. #### Square wave frequency selection bits #### • RS2, RS1 Square wave Rate Select. These bits control the frequency of the square-wave output when the square wave has been enabled. | RS2, RS1 | Data | SQW output freq. (Hz) | |--------------|------|-----------------------| | | 00 | 1 | | Read / Write | 01 | 4.096k | | Read / Wille | 10 | 8.192k | | | 11 | 32.768k Default | #### **Interrupt related bits** #### **INTCN** Interrupt Output pin select bit. This bit controls the relationship between the two alarms and the interrupt output pins | memap | t Outp | are print serie | et off. This off controls the relationship between the two diarms and the interrupt output phis. | |-------|--------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | INTO | CN | Data | Description | | Read | d / | 1 | A match between the timekeeping registers and the alarm 1 registers activates the INTA pin (if the alarm 1 is enabled) and a match between the timekeeping registers and the alarm 2 registers activates the SQW/INTB pin (if the alarm 2 is enabled). | | Wri | te | 0 | A match between the timekeeping registers and either alarm 1 or alarm 2 registers activates the INTA pin (if the alarms are enabled). In this configuration, a square wave is output on the SQW/INTB pin. | #### A1IE Alarm 1 Interrupt Enable. | A1IE | Data | Description | | |--------|------|---------------------------------------------------------------------------|---------| | Read / | 0 | The A1F bit does not initiate the INTA signal. | Default | | Write | 1 | Permits the alarm 1 flag (A1F) bit in the status register to assert INTA. | | #### A1F Alarm 1 Flag. | A1F | Data | Description | |--------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Read / Write | 0 | The time do not match the alarm 1 registers. Default | | Read | 1 | Indicates that the time matched the alarm 1 registers. If the A1IE bit is also logic 1, the INTA pin goes low. A1F is cleared when written to logic 0. Attempting to write to logic 1 leaves the value unchanged. | #### A2IE Alarm 2 Interrupt Enable. | A2IE | Data | Description | |--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | Read / | 0 | The A2F bit does not initiate an interrupt signal. Default | | Write | 1 | Permits the alarm 2 flag (A2F) bit in the status register to assert $\overline{\text{INTA}}$ (when INTCN = 0) or to assert SQW/INTB (when INTCN = 1). | #### A2F Alarm 2 Flag. | A1F | Data | Description | | |-----------------|------|----------------------------------------------|---------| | Read /<br>Write | 0 | The time do not match the alarm 2 registers. | Default | | | | Indicates that the time matched the alarm 1 registers. This flag can be used to generate an interrupt on either $\overline{\text{INTA}}$ or $\overline{\text{SQW}}/\overline{\text{INTB}}$ depending on the status of the INTCN bit. If the INTCN = 0 and A2F = 1 | |------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Read | 1 | (and A2IE = 1), the $\overline{INTA}$ pin goes low. If the INTCN = 1 and A2F = 1 (and A2IE = 1), the | | | | SQW/INTB pin goes low. A2F is cleared when written to logic 0. Attempting to write to logic 1 leaves the value unchanged. | #### **Time Counter** Time digit display (in BCD code): - Second digits: Range from 00 to 59 and carried to minute digits when incremented from 59 to 00. - Minute digits: Range from 00 to 59 and carried to hour digits when incremented from 59 to 00. - Hour digits: See description on the /12, 24 bit. Carried to day and day-of-the-week digits when incremented from 11 p.m. to 12 a.m. or 23 to 00. | Addr. (hex) | Description | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-------------|-------------|----|-----------|-------------|-----------|-----------|-----------|-----------|------------| | 00 | Seconds | 0 | S40 | S20 | S10 | S8 | S4 | S2 | <b>S</b> 1 | | 00 | (default) | 0 | Undefined | 01 | Minutes | 0 | M40 | M20 | M10 | M8 | M4 | M2 | M1 | | 01 | (default) | 0 | Undefined | 02 | Hours | 0 | 12, /24 | H20 or P,/A | H10 | Н8 | H4 | H2 | H1 | | 02 | (default) | 0 | Undefined Note: Any registered imaginary time should be replaced with correct time, otherwise it will cause the clock counter malfunction. #### 12, /24 bit This bit is used to select between 12-hour clock system and 24-hour clock system. | 12, /24 | Data | Description | |--------------|------|----------------| | Read / Write | 0 | 24-hour system | | icau/ will | 1 | 12-hour system | This bit is used to select between 12-hour clock operation and 24-hour clock operation. | 12, /24 | Description | Hours register | | | | | | | | | |---------|------------------------|----------------|---------------|---------------|---------------|--|--|--|--|--| | | | 24-hour clock | 12-hour clock | 24-hour clock | 12-hour clock | | | | | | | | | 00 | 52 ( AM 12 ) | 12 | 72 ( PM 12) | | | | | | | 0 | 24 hazzationa diamlara | 01 | 41 ( AM 01 ) | 13 | 61 ( PM 01 ) | | | | | | | 0 | 24-hour time display | 02 | 42 ( AM 02 ) | 14 | 62 ( PM 02 ) | | | | | | | | | 03 | 43 ( AM 03 ) | 15 | 63 ( PM 03 ) | | | | | | | | | 04 | 44 ( AM 04 ) | 16 | 64 ( PM 04 ) | | | | | | | | | 05 | 45 ( AM 05 ) | 17 | 65 ( PM 05 ) | | | | | | | | | 06 | 46 ( AM 06 ) | 18 | 66 ( PM 06 ) | | | | | | | | | 07 | 47 ( AM 07 ) | 19 | 67 ( PM 07 ) | | | | | | | 1 | 10.1 | 08 | 48 ( AM 08 ) | 20 | 68 ( PM 08 ) | | | | | | | 1 | 12-hour time display | 09 | 49 ( AM 09 ) | 21 | 69 ( PM 09 ) | | | | | | | | | 10 | 50 ( AM 10 ) | 22 | 70 ( PM 10 ) | | | | | | | | | 11 | 51 ( AM 11 ) | 23 | 71 (PM 11) | | | | | | <sup>\*</sup> Be sure to select between 12-hour and 24-hour clock operation before writing the time data. 10 #### Days of the week Counter The day counter is a divide-by-7 counter that counts from 01 to 07 and up 07 before starting again from 01. Values that correspond to the day of week are user defined but must be sequential (i.e., if 1 equals Sunday, then 2 equals Monday, and so on). Illogical time and date entries result in undefined operation. | Addr. (hex) | Description | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-------------|------------------|----|----|----|----|----|-----------|-----------|-----------| | 03 | Days of the week | 0 | 0 | 0 | 0 | 0 | W4 | W2 | W1 | | 03 | (default) | 0 | 0 | 0 | 0 | 0 | Undefined | Undefined | Undefined | #### Calendar Counter The data format is BCD format. Day digits: Range from 1 to 31 (for January, March, May, July, August, October and December). Range from 1 to 30 (for April, June, September and November). Range from 1 to 29 (for February in leap years). Range from 1 to 28 (for February in ordinary years). Carried to month digits when cycled to 1. Month digits: Range from 1 to 12 and carried to year digits when cycled to 1. Year digits: Range from 00 to 99 and 00, 04, 08, ..., 92 and 96 are counted as leap years. | Addr. (hex) | Description | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-------------|-------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | 04 | Dates | 0 | 0 | D20 | D10 | D8 | D4 | D2 | D1 | | 01 | (default) | 0 | 0 | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | | 05 | Months | Century*1 | 0 | 0 | M10 | M8 | M4 | M2 | M1 | | 03 | (default) | Undefined | 0 | 0 | Undefined | Undefined | Undefined | Undefined | Undefined | | 06 | Years | Y80 | Y40 | Y20 | Y10 | Y8 | Y4 | Y2 | Y1 | | 30 | (default) | Undefined <sup>\*1:</sup> The century bit is toggled when the years register overflows from 99 to 00. #### **Alarm Register** #### Alarm 1, Alarm 2 Register | Addr. | Description | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-------|----------------------|-----------|-----------|-------------|-----------|-----------|-----------|-----------|-----------| | 07 | Alarm 1: Seconds | A1M1*1 | S40 | S20 | S10 | S8 | S4 | S2 | S1 | | 07 | (default) | Undefined | 08 | Alarm 1: Minutes | A1M2*1 | M40 | M20 | M10 | M8 | M4 | M2 | M1 | | 08 | (default) | Undefined | 09 | Alarm 1: Hours | A1M3*1 | 12, /24 | H20 or P,/A | H10 | Н8 | H4 | H2 | H1 | | 0) | (default) | Undefined | | Alarm 1: Day, Date | A1M4*1 | Day, | 0, | 0, | 0, | W4, | W2, | W1, | | 0A | Alailli 1. Day, Date | A11V14 | /Date*1 | D20 | D10 | D8 | D4 | D2 | D1 | | | (default) | Undefined | 0B | Alarm 2: Minutes | A2M2*2 | M40 | M20 | M10 | M8 | M4 | M2 | M1 | | ОВ | (default) | Undefined | 0C | Alarm 2: Hours | A2M3*2 | 12, /24 | H20 or P,/A | H10 | Н8 | H4 | H2 | H1 | | 00 | (default) | Undefined | | Alama 2. Day Data | A2M4*2 | Day, | 0, | 0, | 0, | W4, | W2, | W1, | | 0D | Alarm 2: Day, Date | AZIVI4 | /Date*2 | D20 | D10 | D8 | D4 | D2 | D1 | | | (default) | Undefined <sup>\*1</sup> Note: Alarm mask bit, using to select Alarm 1 alarm rate. <sup>\*2</sup> Note: Alarm mask bit, using to select Alarm 2 alarm rate. #### **Alarm Function** #### Related register | Addr. | Function | | | | Register | definition | | | | |-------|--------------------|--------|---------------|-----------------|-----------|------------|-----------|-----------|-----------| | (hex) | Function | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | 00 | Seconds | 0 | S40 | S20 | S10 | S8 | S4 | S2 | S1 | | 01 | Minutes | 0 | M40 | M20 | M10 | M8 | M4 | M2 | M1 | | 02 | Hours | 0 | 12, /24 | H20 or<br>A, /P | H10 | Н8 | H4 | H2 | H1 | | 03 | Days of the week | 0 | 0 | 0 | 0 | 0 | W4 | W2 | W1 | | 04 | Dates | 0 | 0 | D20 | D10 | D8 | D4 | D2 | D1 | | 07 | Alarm 1: Seconds | A1M1 | S40 | S20 | S10 | S8 | S4 | S2 | S1 | | 08 | Alarm 1: Minutes | A1M2 | M40 | M20 | M10 | M8 | M4 | M2 | M1 | | 09 | Alarm 1: Hours | A1M3 | 12, /24 | H20 or A, /P | H10 | Н8 | H4 | H2 | H1 | | 0A | Alarm 1: Day, Date | A1M4 | Day,<br>/Date | 0,<br>D20 | 0,<br>D10 | 0,<br>D8 | W4,<br>D4 | W2,<br>D2 | W1,<br>D1 | | 0B | Alarm 2: Minutes | A2M2 | M40 | M20 | M10 | M8 | M4 | M2 | M1 | | 0C | Alarm 2: Hours | A2M3 | 12, /24 | H20 or A, /P | H10 | Н8 | H4 | H2 | H1 | | 0D | Alarm 2: Day, Date | A2M4 | Day,<br>/Date | 0,<br>D20 | 0,<br>D10 | 0,<br>D8 | W4,<br>D4 | W2,<br>D2 | W1,<br>D1 | | 0E | Control | /ETIME | 0 | 0 | RS2 | RS1 | INTCN | A2IE | A1IE | | 0F | Status | OSF | 0 | 0 | 0 | 0 | 0 | A2F | A1F | Note: Alarm function does not support different hour system adopted in time and alarm register. The IT7C4337 contains two time-of-day/date alarms. The alarms can be programmed (by the INTCN bit of the control register) to operate in two different modes - each alarm can drive its own separate interrupt output or both alarms can drive a common interrupt output. Bit 7 of each of the time-of-day/date alarm registers are mask bits. When all of the mask bits for each alarm are logic 0, an alarm only occurs when the values in the timekeeping registers 00h ~ 04h match the values stored in the time-of-day/date alarm registers. The alarms can also be programmed to repeat every second, minute, hour, day, or date. Table 2 and Table 3 shows the possible settings. The Day, /Date bits (bit 6 of the alarm day/date registers) control whether the alarm value stored in bits 0 ~ 5 of that register reflects the day of the week or the date of the month. If the bit is written to logic 0, the alarm is the result of a match with date of the month. If the bit is written to logic 1, the alarm is the result of a match with day of the week. When the IT7C4337 register values match alarm register settings, the corresponding alarm flag (A1F or A2F) bit is set to logic 1. If the corresponding alarm interrupt enable (A1IE or A2IE) is also set to logic 1, the alarm condition activates one of the interrupt output (INTA or SQW/INTB) signals. The match is tested on the once-per-second update of the time and date registers. Table 1. Alarm 1 Mask Bits | Day, | Ala | ırm 1 regis | ster mask l | oits | Alarm rate | | | | |-------|------|-------------|-------------|------|----------------------------------------------------|--|--|--| | /Date | A1M4 | A1M3 | A1M2 | A1M1 | Alamirac | | | | | × | 1 | 1 | 1 | 1 | Alarm once per second | | | | | × | 1 | 1 | 1 | 0 | Alarm when seconds match | | | | | × | 1 | 1 | 0 | 0 | Alarm when minutes and seconds match | | | | | × | 1 | 0 | 0 | 0 | Alarm when hours, minutes, and seconds match | | | | | 0 | 0 | 0 | 0 | 0 | Alarm when date, hours, minutes, and seconds match | | | | | 1 | 0 | 0 | 0 | 0 | Alarm when day, hours, minutes, and seconds match | | | | | | | Others | | | Ignored. | | | | Table 2. Alarm 2 Mask Bits | Day, | Alarm 2 | register m | nask bits | Alarm rate | | | | | |-------|---------|------------|-----------|----------------------------------------------------|--|--|--|--| | /Date | A2M4 | A2M3 | A2M2 | Alamirac | | | | | | × | 1 | 1 | 1 | Alarm once per minute (00 seconds of every minute) | | | | | | × | 1 | 1 | 0 | Alarm when minutes match | | | | | | × | 1 | 0 | 0 | Alarm when hours, minutes | | | | | | 0 | 0 | 0 | 0 | Alarm when date, hours, and minutes match | | | | | | 1 | 0 | 0 | 0 | Alarm when day, hours, and minutes match | | | | | | | Others | | | Ignored. | | | | | #### I<sup>2</sup>C Bus Interface #### Overview of I<sup>2</sup>C-BUS The I<sup>2</sup>C bus supports bi-directional communications via two signal lines: the SDA (data) line and SCL (clock) line. A combination of these two signals is used to transmit and receive communication start/stop signals, data signals, acknowledge signals, and so on. Both the SCL and SDA signals are held at high level whenever communications are not being performed. The starting and stopping of communications is controlled at the rising edge or falling edge of SDA while SCL is at high level. During data transfers, data changes that occur on the SDA line are performed while the SCL line is at low level, and on the receiving side the data is captured while the SCL line is at high level. In either case, the data is transferred via the SCL line at a rate of one bit per clock pulse. The I<sup>2</sup>C bus device does not include a chip select pin such as is found in ordinary logic devices. Instead of using a chip select pin, slave addresses are allocated to each device and the receiving device responds to communications only when its slave address matches the slave address in the received data. #### **System Configuration** All ports connected to the I<sup>2</sup>C bus must be either open drain or open collector ports in order to enable AND connections to multiple devices. SCL and SDA are both connected to the VDD line via a pull-up resistance. Consequently, SCL and SDA are both held at high level when the bus is released (when communication is not being performed). Fig 1. System configuration # Starting and Stopping I<sup>2</sup>C Bus Communications Fig 2. Starting and stopping on I<sup>2</sup>C bus #### 1) START condition, repeated START condition, and STOP condition - a) START condition - SDA level changes from high to low while SCL is at high level - b) STOP condition - SDA level changes from low to high while SCL is at high level - c) Repeated START condition (RESTART condition) In some cases, the START condition occurs between a previous START condition and the next STOP condition, in which case the second START condition is distinguished as a RESTART condition. Since the required status is the same as for the START condition, the SDA level changes from high to low while SCL is at high level. #### 2) Data Transfers and Acknowledge Responses during I<sup>2</sup>C-BUS Communication #### a) Data transfers Data transfers are performed in 8-bit (1 byte) units once the START condition has occurred. There is no limit on the amount (bytes) of data that are transferred between the START condition and STOP condition. The address auto increment function operates during both write and read operations. Updating of data on the transmitter (transmitting side)'s SDA line is performed while the SCL line is at low level. The receiver (receiving side) captures data while the SCL line is at high level. <sup>\*</sup>Note with caution that if the SDA data is changed while the SCL line is at high level, it will be treated as a START, RESTART, or STOP condition. #### b) Data acknowledge response (ACK signal) When transferring data, the receiver generates a confirmation response (ACK signal, low active) each time an 8-bit data segment is received. If there is no ACK signal from the receiver, it indicates that normal communication has not been established. (This does not include instances where the master device intentionally does not generate an ACK signal.) Immediately after the falling edge of the clock pulse corresponding to the 8th bit of data on the SCL line, the transmitter releases the SDA line and the receiver sets the SDA line to low (= acknowledge) level. After transmitting the ACK signal, if the Master remains the receiver for transfer of the next byte, the SDA is released at the falling edge of the clock corresponding to the 9th bit of data on the SCL line. Data transfer resumes when the Master becomes the transmitter. When the Master is the receiver, if the Master does not send an ACK signal in response to the last byte sent from the slave, that indicates to the transmitter that data transfer has ended. At that point, the transmitter continues to release the SDA and awaits a STOP condition from the Master. #### **Slave Address** The I<sup>2</sup>C bus device does not include a chip select pin such as is found in ordinary logic devices. Instead of using a chip select pin, slave addresses are allocated to each device. All communications begin with transmitting the [START condition] + [slave address (+ $R\overline{/W}$ specification)]. The receiving device responds to this communication only when the specified slave address it has received matches its own slave address. Slave addresses have a fixed length of 7 bits. See table for the details. An $R/\overline{W}$ bit is added to each 7-bit slave address during 8-bit transfers. | Operation | Transfer data | | | | R/W bit | | | | | |-----------|---------------|-------|-------|-------|---------|-------|-------|-------|-------------| | Operation | Transfer data | bit 7 | bit 6 | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 | | Read | D1 h | 1 | 1 | 0 | 1 | n | 0 | 0 | 1 (= Read) | | Write | D0 h | 1 | 1 | U | 1 | U | U | 0 | 0 (= Write) | #### I<sup>2</sup>C Bus's Basic Transfer Format | S | Start indication P | Stop indication A | RTC Acknowledge | |----|--------------------|-------------------|--------------------| | Sr | Restart indication | A | Master Acknowledge | #### 1) Write via I<sup>2</sup>C bus | S | | ı<br>Sla<br>I | i | ddres | i | bits) | ı | write | Α | ' | | A | ddr. | sett | ing | 1 | 1 | Α | bit<br>7 | bit<br>6 | bit<br>5 | bit<br>4 | bit<br>3 | bit 2 | bit<br>1 | bit<br>0 | Α | Р | |-------|------------------------------------------------------------------------------------|---------------|------------|-------|--------|-------|-------------|-------|---|-----|------|---|------|------|-----|---|---|---|----------|----------|----------|----------|----------|-------|----------|----------|---|-----| | Start | 1<br>Slov | 1 | 0<br>dross | 1 | 0 | 0 | 0<br>notion | 0 | A | Add | 2000 | | | | | | | A | \\/ris | to da | <u> </u> | | | | | | A | Sto | | | Start Slave address + write specification A C K Specifies the write start address. | | | | C<br>K | | | ıa | | | | K | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 18 #### Read via I<sup>2</sup>C bus #### Standard read | | S | ' | Sla | ve ad | dres | s (7 b | oits) | | mita | Α | | l | , | Addr | . setti | ng | | ' | A | | | | | | | | | | | |----------|-------|------|-------|-------|------|--------|--------|-------|------------|-------------|-----|----------------|-----|------|---------|-------|-----|-----|-------------|-----|---|-----|-----|-----|-----|-----|-----|----|---| | | | 1 | 1 | 0 | 1 | 0 | 0 | 0 | write<br>0 | | | | | | | | | | | | | | | | | | | | | | • | Start | Slav | ve ad | dress | + Wr | ite sp | ecific | ation | | A<br>C<br>K | | ress<br>cifies | the | read | start | addre | SS. | | A<br>C<br>K | • | | | | | | | | | | | | | | Sla | ve ad | dres | s (7 t | oits) | | | Α | bit A | bit | | bit | bit | bit | bit | bit | bit | /A | P | | | Sr | | _ | | | ا م ا | 0 | | Read | ^ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | l | | <b>\</b> | Sr | 1 | 1 | 0 | 1 | 0 | U | 0 | ı | | | | | | | | | | | | | | | | | | | | | #### Simplified read | s | | Slav | ve ad | Idres | s (7 | bits) | | | Α | bit Α | bit /A | L | |-------|-----|-------|-------|--------|-------|---------|--------|-----------|-------------|------|--------|---------------------------------|------|----------------|-------|-----|-----|-------------|-----|-------|-------|-----|--------|---------------------|-----|-----|-----------------------|----| | | 1 | 1 | 0 | 1 | 0 | 0 | 0 | Read<br>1 | ^ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ^ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | <i>I</i> /A | l | | Start | Sla | ve ad | dress | s + re | ead s | pecific | cation | 1 | A<br>C<br>K | by t | he int | [<br>ead fr<br>ternal<br>auto i | addr | ie ad<br>ess r | dress | | | A<br>C<br>K | | addre | regis | | ıto in | 2)<br>creme<br>data | | | N<br>O<br>A<br>C<br>K | St | #### Note: - The above steps are an example of transfers of one or two bytes only. There is no limit to the number of bytes transferred during actual communications. - 49H, 4AH are used as test mode address. Customer should not use the addresses. ## **Maximum Ratings** | -65°Cto +150°C | |-----------------------------| | 40°Cto +85°C | | | | 0.3V to $(V_{\infty}+0.3V)$ | | -0.3V to +6.5V | | 0.3V to $(V_{cc}+0.3V)$ | | 320mW (depend on package) | | | #### Note: Stresses greater than those listed under MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability. ## **Recommended Operating Conditions** | Part No. | Symbol | Descri | ption | Min | Type | Max | Unit | |----------|------------------|-----------------------|----------|-------------|------|----------------------|---------------| | | $V_{CC}$ | Power voltage | | 1.8 | - | 5.5 | | | | V <sub>OSC</sub> | Oscillator voltage | | 1.7 | - | 5.5 | V | | IT7C4337 | X7 | T (1: 1 1 1 | SCL, SDA | $0.7V_{CC}$ | - | V <sub>CC</sub> +0.3 | V | | | $V_{IH}$ | Input high level | - | - | 5.5 | | | | | $V_{\rm IL}$ | Input low level | | -0.3 | - | $0.3V_{CC}$ | | | | $T_A$ | Operating temperature | | -40 | - | 85 | $\mathcal{C}$ | #### **DC** Electrical Characteristics Unless otherwise specified, $V_{CC} = 1.8 \sim 5.5 \text{V}$ , $T_A = -40 \text{ } \text{C}$ to +85 C | Sym. | Item | Pin | Condition | Min | Typ | Max | Unit | |-----------|--------------------------|-------------------|-----------------|-------------|------|--------------|------| | $V_{CC}$ | Supply voltage | V <sub>CC</sub> | | 1.8 | 1 | 5.5 | V | | Vosc | Oscillator voltage | V <sub>CC</sub> | | 1.7 | - | 5.5 | V | | | Active supply current | V <sub>CC</sub> | Note 1, 5 | - | - | 150 | ۸ | | $I_{CC}$ | Standby current | V <sub>CC</sub> | Note 2, 3, 5 | - | 0.5 | 0.8 | μA | | 1CC | Timekeeping current | V <sub>CC</sub> | Note 2, 4, 5 | - | 350 | 600 | nA | | | Data retention current | V <sub>CC</sub> | Note 2, 6 | - | - | 150 | шА | | $V_{IL1}$ | Low-level input voltage | SCL | | -0.3 | - | $0.3V_{CC}$ | V | | $V_{IH1}$ | High-level input voltage | SCL | | $0.7V_{CC}$ | - | $V_{CC}+0.3$ | | | $V_{IL2}$ | Low-level input voltage | X1 | | - | 0.53 | - | V | | $V_{IH2}$ | High-level input voltage | X1 | | - | 0.53 | - | V | | $I_{OL}$ | Low-level output current | SDA, /INTA, /INTB | $V_{OL} = 0.4V$ | - | - | 3 | mA | | $I_{IL}$ | Input leakage current | SCL | | - | - | 1 | μΑ | | $I_{OZ}$ | Output current when OFF | SDA, /INTA, /INTB | | - | 1 | 1 | μΑ | - 1. SCL clocking at max frequency = 400kHz, $V_{IL} = 0.0V$ , $V_{IH} = VCC$ . 2. Specified with 2-wire bus inactive, $V_{IL} = 0.0V$ , $V_{IH} = VCC$ . - 3. SQW enabled. - 4. Specified with the SQW function disabled by setting INTCN = 1. - 5. Using recommended crystal on X1 and X2. - 6. Crystal oscillator is disabled. #### **AC Electrical Characteristics** | Sym | Description | Value | Unit | |-------------|-------------------------------------------|-----------------------|------| | $V_{HM}$ | Rising and falling threshold voltage high | $0.8~\mathrm{V_{CC}}$ | V | | $V_{ m HL}$ | Rising and falling threshold voltage low | $0.2~\mathrm{V_{CC}}$ | V | #### Over the operating range | Symbol | Item | Min. | Тур. | Max. | Unit | |----------------------|--------------------------------------------------|------|------|------|------| | $f_{SCL}$ | SCL clock frequency | | | 400 | kHz | | t <sub>SU;STA</sub> | START condition set-up time | 0.6 | | | μs | | t <sub>HD;STA</sub> | START condition hold time | 0.6 | | | μs | | t <sub>SU;DAT</sub> | Data set-up time (RTC read/write) | 200 | | | ns | | t <sub>HD;DAT1</sub> | Data hold time (RTC write) | 35 | | | ns | | t <sub>HD;DAT2</sub> | Data hold time (RTC read) | 0 | | | μs | | t <sub>SU;STO</sub> | STOP condition setup time | 0.6 | | | μs | | t <sub>BUF</sub> | Bus idle time between a START and STOP condition | 1.3 | | | μs | | $t_{LOW}$ | When SCL = "L" | 1.3 | | | μs | | t <sub>HIGH</sub> | When SCL = "H" | 0.6 | | | μs | | t <sub>r</sub> | Rise time for SCL and SDA | | | 0.3 | μs | | $t_{\rm f}$ | Fall time for SCL and SDA | | | 0.3 | μs | | t <sub>SP</sub> * | Allowable spike time on bus | | | 50 | ns | | C <sub>B</sub> | Capacitance load for each bus line | | | 400 | pF | <sup>\*</sup> Note: only reference for design #### **Mechanical Information** #### WE (Lead free and Green SOIC-8) NOTE: All dimensions in inches (in parentheses in millimeters). #### **UE(Lead free and Green MSOP-8)** #### NOTE: 1. All dimensions in inches and (millimeters). **ZEE** (Lead free and Green 8-Pin TDFN) #### TE (Lead free and Green 8-Pin TSSOP) - 1. Controlling dimentions in millimeters. - Ref: JEDEC MO-153F/AA 26