Details of Time Data Bits - DS3231
Now let's look at how the data is stored inside each register of the DS3231. The structure is almost the same as the DS1307 with slight changes.
| REGISTER | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | 
|---|---|---|---|---|---|---|---|---|
| Seconds | 0 | Tens digit of seconds | Ones digit of seconds | |||||
| Minutes | 0 | Tens digit of minutes | Ones digit of minutes | |||||
| Hours | 0 | Select 12/24 format | PM/AM Flag in 12 hour format or Part of Tens in 24 hour format | Tens digit of hours | Ones digit of hours | |||
| Day | 0 | 0 | 0 | 0 | 0 | Day value (1-7) | ||
| Date | 0 | 0 | Tens digit of date | Ones digit of date | ||||
| Month | Century | 0 | 0 | Tens digit of month | Ones digit of month | |||
| Year | Tens digit of year | Ones digit of year | ||||||
Seconds: Range 00-59
The bits 0-3 represent the ones digit part of the seconds. The bits 4-6 represent the tens digit part of the seconds.
⚡ Note: Unlike the DS1307, the DS3231 does NOT have a Clock Halt (CH) bit in the seconds register.
If you want to represent seconds 30, the BCD format will be: 0011 0000. So, we will put 011 in bits 4-6 (tens digit) and 0000 in bits 0-3 (ones digit).
Bit:     7 6 5 4 3 2 1 0
Value:   0 0 1 1 0 0 0 0
         │ └─┬─┘ └──┬──┘
         │   3      0
         Always 0
Bit 7 is always 0 in the DS3231.
Minutes: Range 00-59
The bits 0-3 represent the ones digit part of the minutes. The bits 4-6 represent the tens digit part of the minutes.
If you want to represent minutes 45, the BCD format will be: 0100 0101. So, we will put 100 in bits 4-6 (tens digit) and 0101 in bits 0-3 (ones digit).
Bit:     7 6 5 4 3 2 1 0
Value:   0 1 0 0 0 1 0 1
         │ └─┬─┘ └──┬──┘
         │   4      5
         Always 0
Bit 7 is always 0.
Hours: Range 1-12 + AM/PM (12-hour mode) or 00-23 (24-hour mode)
In 12-hour mode:
- Bit 6 = 1 (selects 12-hour format)
- Bit 5 = AM/PM bit (0=AM, 1=PM)
- Bit 4 = tens digit of hour (0 or 1)
- Bits 3-0 = ones digit of hour
In 24-hour mode:
- Bit 6 = 0 (selects 24-hour format)
- Bits 5-4 = tens digit of hour
- Bits 3-0 = ones digit of hour
⚡ Note: The hours value must be re-entered whenever the 12/24-hour mode bit is changed.
If you want to represent 2 PM in 12-hour mode, the format will be: 0110 0010. So bit 6=1 (12-hour), bit 5=1 (PM), bit 4=0 (tens digit), bits 3-0 will be 0010 (ones digit).
Bit:     7 6 5 4 3 2 1 0
Value:   0 1 1 0 0 0 1 0
         │ │ │ │ └──┬──┘
         │ │ │ │    2
         │ │ │ tens digit
         │ │ PM bit
         │ 12-hour format
         Always 0
If you want to represent 14:00 in 24-hour mode, the format will be: 0001 0100. So bit 6=0 (24-hour), bits 5-4 will be 01 (tens digit), bits 3-0 will be 0100 (ones digit).
Bit:     7 6 5 4 3 2 1 0
Value:   0 0 0 1 0 1 0 0
         │ │ └┬┘ └──┬──┘
         │ │  1     4
         │ 24-hour format
         Always 0
Day: Range 01-07 (1=Sunday, 2=Monday, etc.)
The bits 0-2 represent the day value. Bits 3-7 are always 0.
If you want to represent Tuesday (day 3), the format will be: 0000 0011.
Bit:     7 6 5 4 3 2 1 0
Value:   0 0 0 0 0 0 1 1
         └───┬───┘ └─┬─┘
         Always 0     3
Date: Range 01-31 (day of month)
The bits 0-3 represent the ones digit part of the date. The bits 4-5 represent the tens digit part of the date.
If you want to represent date 25, the BCD format will be: 0010 0101. So, we will put 10 in bits 4-5 (tens digit) and 0101 in bits 0-3 (ones digit).
Bit:     7 6 5 4 3 2 1 0
Value:   0 0 1 0 0 1 0 1
         └┬┘ └┬┘ └──┬──┘
          0   2     5
         Always 0
Bits 6-7 are always 0.
Month: Range 01-12
Key DS3231 Feature: Bit 7 is the Century bit (meaning is ambiguous).
The bits 0-3 represent the ones digit part of the month. Bit 4 represents the tens digit part of the month.
If you want to represent month 12 (December), the BCD format will be: 0001 0010. So, we will put 1 in bit 4 (tens digit) and 0010 in bits 0-3 (ones digit). Bit 7 (century bit) depends on your driver's interpretation - it could be 0 or 1.
Bit:     7 6 5 4 3 2 1 0
Value:   1 0 0 1 0 0 1 0
         │ └┬┘ │ └──┬──┘
         │  0  1    2
         Century bit (interpretation varies)
Bits 5-6 are always 0.
DS3231 Century Bit
The DS3231 has a century bit in the Month register (bit 7), but the datasheet does not clearly define what this bit means. Here's what we know for certain:
⚡ From the DS3231 datasheet: "The century bit (bit 7 of the month register) is toggled when the years register overflows from 99 to 00."
What this means:
- The bit automatically flips when the year goes from 99 → 00 (i.e., when year goes from 2099 to 2100, assuming current century interpretation)
- It's a flag that indicates a century transition has occurred
- However, the datasheet does NOT specify what 0 vs 1 represents
You can search "ds3231 century bit" to see the numerous forum discussions and GitHub issues discussing about this confusion and the resulting portability problems between different libraries.
The Problem: The century bit does not actually identify which century you're in - it just toggles on transitions. Different implementations interpret it differently:
- Some assume: 0 = 20th century (1900s), 1 = 21st century (2000s)
- Others assume: 0 = 21st century (2000s), 1 = 22nd century (2100s).
Practical Impact:
- Different systems may interpret the same century bit value differently
- Applications need to decide how to interpret this bit based on their use case
- Many libraries simply ignore the century bit and assume all dates are in the 2000s
Year: Range 00-99 (represents the year within the century)
The bits 0-3 represent the ones digit part of the year. The bits 4-7 represent the tens digit part of the year.
If you want to represent year 23 (2023), the BCD format will be: 0010 0011. So, we will put 0010 in bits 4-7 (tens digit) and 0011 in bits 0-3 (ones digit).
Bit:     7 6 5 4 3 2 1 0
Value:   0 0 1 0 0 0 1 1
         └──┬──┘ └──┬──┘
            2      3