# Adafruit DS3231 Precision RTC Breakout

## Overview

![](https://cdn-learn.adafruit.com/assets/assets/000/103/727/medium800/components_DS3231_top.jpg?1628094646)

The datasheet for the DS3231 explains that this part is an "Extremely Accurate I²C-Integrated RTC/TCXO/Crystal". And, hey, it does exactly what it says on the tin! ±2ppm accuracy from 0°C to +40°C. This means ±1 minute/year.

This Real Time Clock (RTC) is the most precise you can get in a small, low power package.

![](https://cdn-learn.adafruit.com/assets/assets/000/103/728/medium800/components_DS3231_back.jpg?1628094672)

[We've had a breakout board version of this RTC for a while](https://www.adafruit.com/product/3013). We want to make it even easier for folks to use, so [now it also comes with STEMMA QT connectors](https://www.adafruit.com/product/5188) for plug-and-play simplicity. Be sure you buy the correct version you wish to use.

![](https://cdn-learn.adafruit.com/assets/assets/000/030/360/medium800/components_3013_quarter_ORIG.jpg?1454534810)

Most RTC's use an external 32kHz timing crystal that is used to keep time with low current draw. And that's all well and good, but those crystals have slight drift, particularly when the temperature changes (the temperature changes the oscillation frequency very very very slightly but it does add up!) This RTC is in a beefy package because the crystal is _inside_ the chip! And right next to the integrated crystal is a temperature sensor. That sensor compensates for the frequency changes by adding or removing clock ticks so that the timekeeping stays on schedule

![](https://cdn-learn.adafruit.com/assets/assets/000/030/357/medium800/components_3013_iso_ORIG.jpg?1454534769)

This is the finest RTC you can get, and now we have it in a compact, breadboard-friendly breakout. With a coin cell plugged into the back, you can get years of precision timekeeping, even when main power is lost. Great for datalogging and clocks, or anything where you need to really know the time.

To make life easier so you can focus on your important work, we've taken the sensor and put it onto a breakout PCB along with support circuitry to let you use it with 3.3V (Feather/Raspberry Pi) or 5V (Arduino/ Metro328) logic levels. Additionally, since it speaks I2C you can easily connect it up with two wires (plus power and ground!).&nbsp; We've even included&nbsp;[SparkFun qwiic](https://www.sparkfun.com/qwiic)&nbsp;compatible**&nbsp;[STEMMA QT](https://learn.adafruit.com/introducing-adafruit-stemma-qt)**&nbsp;connectors for the I2C bus so&nbsp; **you don't even need to solder!** &nbsp;[**QT Cable is not included** , but we have a variety in the shop](https://www.adafruit.com/?q=stemma+qt+cable&sort=BestMatch).&nbsp;Just wire up to your favorite micro and you can use our [CircuitPython](https://github.com/adafruit/Adafruit_CircuitPython_DS3231)/Python or&nbsp;[Arduino drivers](https://github.com/adafruit/RTClib)&nbsp;to easily interface with the DS3231.

![](https://cdn-learn.adafruit.com/assets/assets/000/103/726/medium800/components_DS3231_STEMMA_side.jpg?1628094628)

Comes as a fully assembled and tested breakout plus a small piece of header. You can solder header in to plug it into a breadboard, or solder wires directly.

A coin cell is required to use the battery-backup capabilities! We don't include one by default, to make shipping easier for those abroad, [but we do stock them so pick one up or use any CR1220 you have handy.](https://www.adafruit.com/products/380)

Info: 

![](https://cdn-learn.adafruit.com/assets/assets/000/030/359/medium800/components_3013_kit_ORIG.jpg?1454534798)

# Adafruit DS3231 Precision RTC Breakout

## Pinouts

![](https://cdn-learn.adafruit.com/assets/assets/000/103/729/medium800/components_DS3231_top.jpg?1628094735)

![](https://cdn-learn.adafruit.com/assets/assets/000/030/348/medium800/components_3013_top_ORIG.jpg?1454531982)

## Power Pins:

- **Vin** - this is the power pin. Since the RTC can be powered from 2.3V to 5.5V power, you do not need a regulator or level shifter for 3.3V or 5V logic/power. To power the board, give it the same power as the logic level of your microcontroller - e.g. for a 5V micro like Arduino, use 5V
- **GND** - common ground for power and logic

## I2C Logic pins:

- **SCL** - I2C clock pin, connect to your microcontrollers I2C clock line. This pin has a 10K pullup resistor to Vin
- **SDA** - I2C data pin, connect to your microcontrollers I2C data line. This pin has a 10K pullup resistor to Vin
- [**STEMMA QT**](https://learn.adafruit.com/introducing-adafruit-stemma-qt) **- On the STEMMA QT version only!** These connectors allow you to connect to development boards with **STEMMA QT** connectors, or to other things, with[various associated accessories](https://www.adafruit.com/?q=JST%20SH%204).

## Other Pins:

- **BAT** - this is the same connection as the positive pad of the battery. You can use this if you want to power something else from the coin cell, or provide battery backup from a different separate batery. VBat can be between 2.3V and 5.5V and the DS3231 will switch over when main Vin power is lost
- **32K** - 32KHz oscillator output. Open drain, you need to attach a pullup to read this signal from a microcontroller pin
- **SQW** - optional square wave or interrupt output. Open drain, you need to attach a pullup to read this signal from a microcontroller pin
- **RST** - This one is a little different than most RST pins, rather than being just an input, it is designed to be used to reset an external device or indicate when main power is lost. Open drain, but has an internal 50K pullup. The pullup keeps this pin voltage high as long as Vin is present. When Vin drops and the chip switches to battery backup, the pin goes low.
- **ON LED** - The ON LED will glow on the black STEMMA QT version when power is present. There is an unmarked jumper on the back connected completing the circuit. You can cut the jumper to prevent the LED from turning on if you wish (and resolder to restore the functionality).

# Adafruit DS3231 Precision RTC Breakout

## Assembly

![](https://cdn-learn.adafruit.com/assets/assets/000/030/349/medium800/components_3013_kit_ORIG.jpg?1454532001)

## Prepare the header strip:

Cut the strip to length if necessary. It will be easier to solder if you insert it into a breadboard - **long pins down**

![components_header.jpg](https://cdn-learn.adafruit.com/assets/assets/000/030/340/medium640/components_header.jpg?1454531663)

## Add the breakout board:

Place the breakout board over the pins so that the short pins poke through the breakout pads

![components_place.jpg](https://cdn-learn.adafruit.com/assets/assets/000/030/341/medium640/components_place.jpg?1454531684)

## And Solder!

Be sure to solder all pins for reliable electrical contact.  
  
_(For tips on soldering, be sure to check out our_ [_Guide to Excellent Soldering_](http://learn.adafruit.com/adafruit-guide-excellent-soldering)_)._

![components_solder1.jpg](https://cdn-learn.adafruit.com/assets/assets/000/030/342/medium640/components_solder1.jpg?1454531706)

![components_solder2.jpg](https://cdn-learn.adafruit.com/assets/assets/000/030/343/medium640/components_solder2.jpg?1454531710)

![components_solder3.jpg](https://cdn-learn.adafruit.com/assets/assets/000/030/344/medium640/components_solder3.jpg?1454531713)

You're done! Check your solder joints visually and continue onto the next steps

![components_done.jpg](https://cdn-learn.adafruit.com/assets/assets/000/030/345/medium640/components_done.jpg?1454531721)

Don't forget that the Real Time Clock requires a battery backup. A CR1220 size battery goes in the back, make sure the + symbol on the battery is visible when you insert!

![components_insertbatt.jpg](https://cdn-learn.adafruit.com/assets/assets/000/030/346/medium640/components_insertbatt.jpg?1454531733)

![components_batteryin.jpg](https://cdn-learn.adafruit.com/assets/assets/000/030/347/medium640/components_batteryin.jpg?1454531784)

# Adafruit DS3231 Precision RTC Breakout

## Arduino Usage

You can easily wire this breakout to any microcontroller, we'll be using an Arduino. For another kind of microcontroller, just make sure it has I2C, then port the code - its pretty simple stuff!

- Connect **Vin (red wire)** to the power supply, 3-5V is fine. Use the same voltage that the microcontroller logic is based off of. For most Arduinos, that is 5V
- Connect **GND (black wire)** to common power/data ground
- Connect the **SCL (yellow wire)** pin to the I2C clock **SCL** pin on your Arduino. On an UNO & '328 based Arduino, this is also known as **A5** , on a Mega it is also known as **digital 21** and on a Leonardo/Micro, **digital 3**
- Connect the **SDA (blue wire)** pin to the I2C data **SDA** pin on your Arduino. On an UNO & '328 based Arduino, this is also known as **A4** , on a Mega it is also known as **digital 20** and on a Leonardo/Micro, **digital 2**

![components_DS3231_QT_Arduino_STEMMA_bb.jpg](https://cdn-learn.adafruit.com/assets/assets/000/103/730/medium640/components_DS3231_QT_Arduino_STEMMA_bb.jpg?1628099891)

![components_DS3231_QT_Arduino_breadboard_bb.jpg](https://cdn-learn.adafruit.com/assets/assets/000/103/731/medium640/components_DS3231_QT_Arduino_breadboard_bb.jpg?1628099911)

![components_DS3231_original_Arduino_bb.jpg](https://cdn-learn.adafruit.com/assets/assets/000/103/732/medium640/components_DS3231_original_Arduino_bb.jpg?1628099926)

The DS3231 has a default **I2C address of 0x68** and cannot be changed

# Download RTCLib

For the RTC library, we'll be using a fork of JeeLab's excellent RTC library [RTClib](http://github.com/adafruit/RTClib) - a library for getting and setting time from an RTC (originally written by JeeLab, our version is slightly different so please **only use ours** to make sure its compatible!)

To begin reading data, you will need to download Adafruit's RTCLib from the Arduino library manager.

Open up the Arduino library manager:

![](https://cdn-learn.adafruit.com/assets/assets/000/084/220/medium800/components_library_manager_menu.png?1573775505)

Search for&nbsp;the&nbsp; **RTCLib&nbsp;** library and install the one by Adafruit

![](https://cdn-learn.adafruit.com/assets/assets/000/084/221/medium800/components_rtclib.png?1573775593)

We also have a great tutorial on Arduino library installation at:  
[http://learn.adafruit.com/adafruit-all-about-arduino-libraries-install-use](http://learn.adafruit.com/adafruit-all-about-arduino-libraries-install-use "Link: http://learn.adafruit.com/adafruit-all-about-arduino-libraries-install-use")

# First RTC Test

The first thing we'll demonstrate is a test sketch that will read the time from the RTC once per second. We'll also show what happens if you remove the battery and replace it since that causes the RTC to halt. So to start, remove the battery from the holder while the Arduino is not powered or plugged into USB. Wait 3 seconds and then replace the battery. This resets the RTC chip.

![](https://cdn-learn.adafruit.com/assets/assets/000/030/352/medium800/components_insertbatt.jpg?1454532796)

# Load Demo

Open up **File-\>Examples-\>RTClib**** -\>ds3231** and upload to your Arduino wired up to the RTC

![](https://cdn-learn.adafruit.com/assets/assets/000/030/351/medium800/components_ds3231.png?1454532789)

Upload to your Arduino and check the serial console @ 57600 baud (this is a change from the photos). After a few seconds, you'll see the report that the Arduino noticed this is the first time the DS3231 has been powered up, and will set the time based on the Arduino sketch.

![](https://cdn-learn.adafruit.com/assets/assets/000/030/353/medium800/components_lostpower.png?1454533306)

Unplug your Arduino plus RTC for a few seconds (or minutes, or hours, or weeks) and plug back in.

Next time you run it you won't get the same "RTC lost power" message, instead it will come immediately and let you know the correct time!

![](https://cdn-learn.adafruit.com/assets/assets/000/030/354/medium800/components_reset.png?1454533526)

From now on, you wont have to ever set the time again: the battery will last 5 or more years.

## Reading the Time

Now that the RTC is merrily ticking away, we'll want to query it for the time. Lets look at the sketch again to see how this is done.

```
void loop () {
    DateTime now = rtc.now();
    
    Serial.print(now.year(), DEC);
    Serial.print('/');
    Serial.print(now.month(), DEC);
    Serial.print('/');
    Serial.print(now.day(), DEC);
    Serial.print(" (");
    Serial.print(daysOfTheWeek[now.dayOfTheWeek()]);
    Serial.print(") ");
    Serial.print(now.hour(), DEC);
    Serial.print(':');
    Serial.print(now.minute(), DEC);
    Serial.print(':');
    Serial.print(now.second(), DEC);
    Serial.println();
```

There's pretty much only one way to get the time using the RTClib, which is to call **now()**, a function that returns a DateTime object that describes the year, month, day, hour, minute and second when you called **now()**.

There are some RTC libraries that instead have you call something like **RTC.year()** and **RTC.hour()** to get the current year and hour. However, there's one problem where if you happen to ask for the minute right at **3:14:59** just before the next minute rolls over, and then the second right after the minute rolls over (so at **3:15:00** ) you'll see the time as **3:14:00** which is a minute off. If you did it the other way around you could get **3:15:59** - so one minute off in the other direction.

Because this is not an especially unlikely occurrence - particularly if you're querying the time pretty often - we take a 'snapshot' of the time from the RTC all at once and then we can pull it apart into **day()** or **second()** as seen above. Its a tiny bit more effort but we think its worth it to avoid mistakes!

We can also get a 'timestamp' out of the DateTime object by calling **unixtime** which counts the number of seconds (not counting leapseconds) since midnight, January 1st 1970

```
    Serial.print(" since midnight 1/1/1970 = ");
    Serial.print(now.unixtime());
    Serial.print("s = ");
    Serial.print(now.unixtime() / 86400L);
    Serial.println("d");
```

Since there are 60\*60\*24 = 86400 seconds in a day, we can easily count days since then as well. This might be useful when you want to keep track of how much time has passed since the last query, making some math a lot easier (like checking if its been 5 minutes later, just see if **unixtime()** has increased by 300, you dont have to worry about hour changes).

# Adafruit DS3231 Precision RTC Breakout

## CircuitPython

It's easy to use the DS3231 RTC with CircuitPython too!&nbsp; There's a handy [Adafruit CircuitPython DS3231 module](https://github.com/adafruit/Adafruit_CircuitPython_DS3231) you can load on a board and get started setting and reading the time with Python code!

## CircuitPython Wiring

First wire up the DS3231 to your board as shown on the previous Arduino page.&nbsp; The DS3231 uses a simple I2C connection with:

- **Vin (red wire)** connected to your board's **3.3V** or **5V** output.
- **GND (black wire)** connected to your board's **ground**.
- **SCL (yellow wire)** connected to your board's **I2C SCL** / clock line.
- **SDA (blue wire)** connected to your board's **I2C SDA** / data line.

![components_DS3231_QT_Feather_STEMMA_bb.jpg](https://cdn-learn.adafruit.com/assets/assets/000/103/734/medium640/components_DS3231_QT_Feather_STEMMA_bb.jpg?1628100521)

![components_DS3231_QT_Feather_breadboard_bb.jpg](https://cdn-learn.adafruit.com/assets/assets/000/103/735/medium640/components_DS3231_QT_Feather_breadboard_bb.jpg?1628100551)

![components_DS3231_original_Feather_bb.jpg](https://cdn-learn.adafruit.com/assets/assets/000/103/736/medium640/components_DS3231_original_Feather_bb.jpg?1628100567)

## CircuitPython Library Installation

You'll also need to install the&nbsp;[Adafruit CircuitPython DS3231](https://github.com/adafruit/Adafruit_CircuitPython_DS3231)&nbsp;library on your CircuitPython board.&nbsp;&nbsp; **Remember this module is for Adafruit CircuitPython firmware and not MicroPython.org firmware!**

First make sure you are running the&nbsp;[latest version of Adafruit CircuitPython](https://github.com/adafruit/circuitpython/releases)&nbsp;for your board.

Next you'll need to install the necessary libraries&nbsp;to use the hardware--carefully follow the steps to find and install these libraries from&nbsp;[Adafruit's CircuitPython library bundle](https://github.com/adafruit/Adafruit_CircuitPython_Bundle).&nbsp; For example the Circuit Playground Express guide has&nbsp;[a great page on how to install the library bundle](https://learn.adafruit.com/adafruit-circuit-playground-express/circuitpython-libraries)&nbsp;for both express and non-express boards.

Remember for non-express boards like the Trinket M0, Gemma M0, and Feather/Metro M0 basic you'll need to manually install the necessary libraries from the bundle:

- **adafruit\_ds3231.mpy**
- **adafruit\_bus\_device**
- **adafruit\_register**

Before continuing make sure your board's lib folder or root filesystem has the&nbsp; **adafruit\_ds3231.mpy, adafruit\_bus\_device,** and **adafruit\_register** files and folders **&nbsp;** copied over.

## CircuitPython Usage

Next&nbsp;[connect to the board's serial REPL&nbsp;](../../../../micropython-basics-how-to-load-micropython-on-a-board/serial-terminal)so you are at the CircuitPython&nbsp; **\>\>\>** &nbsp;prompt.

Then import the necessary&nbsp; **board** module to initialize the I2C bus:

```python
import board
i2c = board.I2C()
```

Note on some boards like the ESP8266 that don't have a hardware I2C interface you might need to instead import and use the bitbangio module, like:

```
import board
import bitbangio
i2c = bitbangio.I2C(board.SCL, board.SDA)
```

Now import the DS3231 module and create an instance of the DS3231 class using the I2C interface created above:

```
      import adafruit_ds3231
ds3231 = adafruit_ds3231.DS3231(i2c)
    
```

![](https://cdn-learn.adafruit.com/assets/assets/000/047/893/medium800/components_Screen_Shot_2017-11-02_at_5.37.19_PM.png?1509669458)

At this point you're read to read and even set the time of the clock.&nbsp; You just need to interact with the **datetime** property of the DS3231 instance.&nbsp; For example to read it you can run:

```
ds3231.datetime
```

![](https://cdn-learn.adafruit.com/assets/assets/000/047/891/medium800/components_Screen_Shot_2017-11-02_at_5.29.15_PM.png?1509668971)

Notice the time is returned as a special [Python time structure](https://docs.python.org/3/library/time.html#time.struct_time).&nbsp; This is from the time module in Python and it has properties like:

- **tm\_year** - The year of the timestamp
- **tm\_mon** - The month of the timestamp
- **tm\_mday** - The day of the month of the timestamp
- **tm\_hour** - The hour of the timestamp
- **tm\_min** - The minute of the timestamp
- **tm\_sec** - The second of the timestamp
- **tm\_wday** - The day of the week (0 = Monday, 6 = Sunday)
- **tm\_yday** - The day within the year (1-366)
- **tm\_isdst** - 0 if not in daylight savings, 1 if in savings, and -1 if unknown

Also notice if the time hasn't been set it defaults to a value of January 1st, 2000 (wow Y2K retro!).

You can write to the **datetime** property to set the time of the clock, for example to set it to January 1st, 2017, at midnight local time you could run:

```
import time
ds3231.datetime = time.struct_time((2017, 1, 1, 0, 0, 0, 6, 1, -1))
```

![](https://cdn-learn.adafruit.com/assets/assets/000/047/892/medium800/components_Screen_Shot_2017-11-02_at_5.36.53_PM.png?1509669429)

Notice the parameters to the **struct\_time** initializer, you must pass in a tuple of all the values listed above.

Now if you read the **datetime** property you'll see the clock is running from the set time.&nbsp; For example if you want to read and print out just the year, month, day, hour, minute, and second you could run:

```
current = ds3231.datetime
print('The current time is: {}/{}/{} {:02}:{:02}:{:02}'.format(current.tm_mon, current.tm_mday, current.tm_year, current.tm_hour, current.tm_min, current.tm_sec))
```

![](https://cdn-learn.adafruit.com/assets/assets/000/047/894/medium800/components_Screen_Shot_2017-11-02_at_5.42.28_PM.png?1509669766)

That's all there is to using the DS3231 with CircuitPython!&nbsp; Simply import the DS3231 module, create an instance of the class, and interact with its **datetime** property to set and get the time!

Here's a complete example program you can save as **main.py** on your board and see the time and date printed every second to the REPL:

https://github.com/adafruit/Adafruit_CircuitPython_DS3231/blob/main/examples/ds3231_simpletest.py

# Adafruit DS3231 Precision RTC Breakout

## Python Docs

# Adafruit DS3231 Precision RTC Breakout

## Downloads

## Datasheets

- [Analog Devices (formerly Maxim) product page for the DS3231 with datasheets](https://www.maximintegrated.com/en/products/digital/real-time-clocks/DS3231.html)
- [3D models on GitHub](https://github.com/adafruit/Adafruit_CAD_Parts/tree/main/5188%20DS3231%20RTC)
- [EagleCAD PCB files on GitHub](https://github.com/adafruit/Adafruit-DS3231-Precision-RTC-Breakout-PCB)
- [Fritzing object for DS3231 STEMMA QT&nbsp;](https://github.com/adafruit/Fritzing-Library/blob/master/parts/Adafruit%20DS3231%20STEMMA%20QT.fzpz)
- [Fritzing object for DS3231 Breakout](https://github.com/adafruit/Fritzing-Library/blob/master/parts/Adaruit%20DS3231.fzpz)

# Schematic and Fab Print for STEMMA QT Version
![](https://cdn-learn.adafruit.com/assets/assets/000/103/737/medium800/components_DS3231_QT_sch.png?1628101000)

![](https://cdn-learn.adafruit.com/assets/assets/000/103/738/medium800/components_DS3231_QT_Fab_Print.png?1628101010)

# 3D Model
![](https://cdn-learn.adafruit.com/assets/assets/000/122/206/medium800/components_5188_DS3231_RTC.jpg?1688004165)

# Schematic and Fab Print for Original Version
![](https://cdn-learn.adafruit.com/assets/assets/000/030/355/medium800/components_schem.png?1454534089)

![](https://cdn-learn.adafruit.com/assets/assets/000/030/356/medium800/components_print.png?1454534114)


## Featured Products

### Adafruit DS3231 Precision RTC Breakout

[Adafruit DS3231 Precision RTC Breakout](https://www.adafruit.com/product/3013)
The datasheet for the **DS3231** explains that this part is an "Extremely Accurate I²C-Integrated RTC/TCXO/Crystal". And, hey, it does exactly what it says on the tin! This **Real Time Clock (RTC)** is the most precise you can get in a small, low power...

In Stock
[Buy Now](https://www.adafruit.com/product/3013)
[Related Guides to the Product](https://learn.adafruit.com/products/3013/guides)
### CR1220 12mm Diameter - 3V Lithium Coin Cell Battery

[CR1220 12mm Diameter - 3V Lithium Coin Cell Battery](https://www.adafruit.com/product/380)
These are the highest quality & capacity batteries, the same as shipped with the iCufflinks,&nbsp;iNecklace, Datalogging and GPS Shields, GPS HAT, etc. One battery per order (you'll want one battery per cufflink or pendant.)  
  
Brand may vary but all battery brands are verified...

In Stock
[Buy Now](https://www.adafruit.com/product/380)
[Related Guides to the Product](https://learn.adafruit.com/products/380/guides)
### Adafruit DS3231 Precision RTC - STEMMA QT

[Adafruit DS3231 Precision RTC - STEMMA QT](https://www.adafruit.com/product/5188)
&nbsp;

The datasheet for the **DS3231** explains that this part is an "Extremely Accurate I²C-Integrated RTC/TCXO/Crystal". And, hey, it does exactly what it says on the tin! This **Real Time Clock (RTC)** is the most precise you can get in a...

In Stock
[Buy Now](https://www.adafruit.com/product/5188)
[Related Guides to the Product](https://learn.adafruit.com/products/5188/guides)

## Related Guides

- [Digital Clock with CircuitPython](https://learn.adafruit.com/digital-clock-with-circuitpython.md)
- [Mindfulness Clock OF DOOM](https://learn.adafruit.com/mindfulness-clock-of-doom.md)
- [Metro Minimalist Clock](https://learn.adafruit.com/metro-minimalist-clock.md)
- [Adding a Real Time Clock to Raspberry Pi](https://learn.adafruit.com/adding-a-real-time-clock-to-raspberry-pi.md)
- [Plotting Offline Data - JSONL to CSV files, filters and graphs](https://learn.adafruit.com/plotting-offline-data-jsonl-to-csv-files-filters-and-graphs.md)
- [MacroPad 2FA TOTP Authentication Friend](https://learn.adafruit.com/macropad-2fa-totp-authentication-friend.md)
- [Prop-Maker Feather Talking Adabot Clock](https://learn.adafruit.com/prop-maker-feather-talking-adabot-clock.md)
- [I2C Addresses and Troublesome Chips](https://learn.adafruit.com/i2c-addresses.md)
- [No-Code, No-Solder Monitoring For Perfect Bread](https://learn.adafruit.com/no-code-no-solder-temperature-monitoring-with-wippersnapper-offline.md)
- [QT Py CH32V203 eInk / ePaper Daily Calendar and Clock](https://learn.adafruit.com/ch32v203-eink-epaper-calendar-and-clock.md)
- [Adding a Real Time Clock to BeagleBone Black](https://learn.adafruit.com/adding-a-real-time-clock-to-beaglebone-black.md)
- [Adafruit TE MS8607 PHT Sensor](https://learn.adafruit.com/adafruit-te-ms8607-pht-sensor.md)
- [Adafruit Trinkey QT2040](https://learn.adafruit.com/adafruit-trinkey-qt2040.md)
- [Adafruit Infrared IR Remote Receiver](https://learn.adafruit.com/adafruit-infrared-ir-remote-receiver.md)
- [Adafruit QT Py ESP32-C3 WiFi Dev Board](https://learn.adafruit.com/adafruit-qt-py-esp32-c3-wifi-dev-board.md)
