-
Notifications
You must be signed in to change notification settings - Fork 110
/
Copy pathDS1302.h
188 lines (168 loc) · 5.05 KB
/
DS1302.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
// Interface for the DS1302 timekeeping chip.
//
// Copyright (c) 2009, Matt Sparks
// All rights reserved.
//
// Distributed under the 2-clause BSD license.
#ifndef DS1302_H_
#define DS1302_H_
#include <stdint.h>
// Class representing a particular time and date.
class Time {
public:
enum Day {
kSunday = 1,
kMonday = 2,
kTuesday = 3,
kWednesday = 4,
kThursday = 5,
kFriday = 6,
kSaturday = 7
};
// Creates a Time object with a given time.
//
// Args:
// yr: year. Range: {2000, ..., 2099}.
// mon: month. Range: {1, ..., 12}.
// date: date (of the month). Range: {1, ..., 31}.
// hr: hour. Range: {0, ..., 23}.
// min: minutes. Range: {0, ..., 59}.
// sec: seconds. Range: {0, ..., 59}.
// day: day of the week. Sunday is 1. Range: {1, ..., 7}.
Time(uint16_t yr, uint8_t mon, uint8_t date,
uint8_t hr, uint8_t min, uint8_t sec,
Day day);
uint8_t sec;
uint8_t min;
uint8_t hr;
uint8_t date;
uint8_t mon;
Day day;
uint16_t yr;
};
// An interface to the Dallas Semiconductor DS1302 Real Time Clock (RTC) chip.
//
// Accessing and setting individual components of the time are not supported in
// this interface as doing so can lead to errors if the time changes as it is
// being read or modified. Instead, using DS1302::time() guarantees safe reads
// and writes using the DS1302's burst mode feature.
class DS1302 {
public:
// Size of the DS1302's RAM storage, in bytes.
static const int kRamSize = 31;
// Prepares to interface with the chip on the given I/O pins.
//
// Args:
// ce_pin: CE pin number
// io_pin: IO pin number
// sclk_pin: SCLK pin number
DS1302(uint8_t ce_pin, uint8_t io_pin, uint8_t sclk_pin);
// Enables or disables write protection on the chip.
//
// While write protection is enabled, all attempts to write to the chip (e.g.,
// setting the time) will have no effect.
//
// The DS1302 datasheet does not define the initial state of write protection,
// so this method should be called at least once when initializing a device
// for the first time.
//
// Args:
// enable: true to enable write protection.
void writeProtect(bool enable);
// Sets or clears Clock Halt flag on the chip.
//
// Enabling the Clock Halt flag disables the DS1302's clock oscillator and
// places it into a low-power standby mode. While in this mode, the time does
// not progress. The time can still be read from the chip while it is halted,
// however.
//
// The DS1302 datasheet does not define the initial state of the Clock Halt
// flag, so this method should be called at least once when initializing a
// device for the first time.
//
// Args:
// value: true to set halt flag, false to clear.
void halt(bool value);
// Returns the current time and date in a Time object.
//
// Returns:
// Current time as Time object.
Time time();
// Sets the time and date to the instant specified in a given Time object.
//
// The time will not be set if write protection is enabled on the
// chip. Setting the time with this function has no effect on the Clock Halt
// flag.
//
// Args:
// t: Time instant.
void time(Time t);
// Writes a byte to RAM.
//
// The DS1302 has 31 bytes (kRamSize) of static RAM that can store arbitrary
// data as long as the device has power.
//
// Writes to invalid addresses have no effect.
//
// Args:
// address: RAM address in [0, kRamSize).
// value: Byte to write to the RAM address.
void writeRam(uint8_t address, uint8_t value);
// Reads a byte from RAM.
//
// Reads of invalid addresses return 0.
//
// Args:
// address: RAM address in [0, kRamSize).
//
// Returns:
// Byte from RAM or 0 if the address is invalid.
uint8_t readRam(uint8_t address);
// Writes 'len' bytes into RAM from '*data', starting at RAM address 0.
//
// Args:
// data: Input data.
// len: Number of bytes of '*data' to read. Must be <= kRamSize.
void writeRamBulk(const uint8_t* data, int len);
// Reads 'len' bytes from RAM into '*data', starting at RAM address 0.
//
// Args:
// data: Output data.
// len: Number of bytes of RAM to read. Must be <= kRamSize.
void readRamBulk(uint8_t* data, int len);
// Reads register byte value.
//
// Args:
// reg: register number
//
// Returns:
// register value
uint8_t readRegister(uint8_t reg);
// Writes byte into register.
//
// Args:
// reg: register number
// value: byte to write
void writeRegister(uint8_t reg, uint8_t value);
private:
uint8_t ce_pin_;
uint8_t io_pin_;
uint8_t sclk_pin_;
// Shifts out a value to the IO pin.
//
// Side effects: sets io_pin_ as OUTPUT.
//
// Args:
// value: byte to shift out
// readAfter: whether this will be followed by a read; if so, it
// will leave io_pin_ as INPUT.
void writeOut(uint8_t value, bool readAfter = false);
// Reads in a byte from the IO pin.
//
// Side effects: sets io_pin_ to INPUT.
//
// Returns:
// byte read in
uint8_t readIn();
};
#endif // DS1302_H_