Setup Hardware Clock (RTC) Module on a Raspberry Pi: Difference between revisions
Ingrate one (talk | contribs) m (Ingrate one moved page Saving time with Hardware Clock to Setup Hardware Clock (RTC) Module on a Raspberry Pi: The title should reflect the purpose of this page for adding an RTC module on a Raspberry Pi.) |
Ingrate one (talk | contribs) (adding how to for another chipset and add testing hardware bind section.) |
||
Line 1: | Line 1: | ||
= | = Hardware Prerequisites= | ||
Read the documentation on Installing coin battery and mounting it on the correct GPIO pins for your version of Raspberry Pi board. | |||
Example of Raspberry Pi RTC Modules with documentation: | |||
* [https://wiki.dfrobot.com/Raspberry_Pi_RTC_Module_SKU__DFR0386#target_0 DFROBOT - Raspberry Pi RTC Module SKU DFR0386] | |||
* [https://learn.adafruit.com/adding-a-real-time-clock-to-raspberry-pi/wiring-the-rtc Adafruit RTC Modules] | |||
* [http://www.piface.org.uk/assets/piface_clock/PiFaceClockguide.pdf PiFace Real Time Clock] | |||
= Install Software = | = Install Software = | ||
Add the modules from the kernel | Add the modules from the kernel. The documentation should give you required modules paired with chipset mcp7941x, ds1307 or etc. | ||
== /etc/modules == | == /etc/modules|/etc/modules-load.d/i2c.conf == | ||
Add these modules so they're loaded on boot. You can modprobe each one individually if you don't want to reboot. | Add these modules so they're loaded on boot. You can modprobe each one individually if you don't want to reboot. | ||
'''mcp7941x''' | |||
{{Cat|/etc/modules|i2c_dev | {{Cat|/etc/modules|i2c_dev | ||
i2c_bcm2708 | i2c_bcm2708 | ||
i2c:mcp7941x | i2c:mcp7941x | ||
}} | |||
'''ds1307''' | |||
{{Cat|/etc/modules-load.d/i2c.conf|i2c_dev | |||
i2c_bcm2708 | |||
rtc-ds1307 | |||
}} | }} | ||
== /media/mmcblk0p1/config.txt == | == /media/mmcblk0p1/config.txt == | ||
You will need to mount this as read-write | You will need to mount this as read-write in diskless mode | ||
{{cmd|mount -o remount,rw /media/mmcblk0p1}} | {{cmd|mount -o remount,rw /media/mmcblk0p1}} | ||
Line 31: | Line 43: | ||
== Binding the hardware clock device == | == Binding the hardware clock device == | ||
Read the documentation for the mounted RTC module to get an I2C address for hardware binding. | |||
You will want to make sure the device is created when hwclock starts, if it isn't already created. To the bottom of {{Path|/etc/conf.d/hwclock}} add this: | You will want to make sure the device is created when hwclock starts, if it isn't already created. To the bottom of {{Path|/etc/conf.d/hwclock}} add this: | ||
'''mcp7941x''' | |||
{{Cat|/etc/conf.d/hwclock|... | {{Cat|/etc/conf.d/hwclock|... | ||
start_pre() { | start_pre() { | ||
Line 48: | Line 62: | ||
}} | }} | ||
to {{Path|/media/mmcblk0p1/config.txt}} | '''ds1307''' | ||
{{Cat|/etc/conf.d/hwclock|... | |||
start_pre() { | |||
einfo "Creating RTC device"; | |||
echo ds1307 0x68 > /sys/bus/i2c/devices/i2c-1/new_device | |||
} | |||
}} | |||
In diskless mode save to {{Path|/media/mmcblk0p1/config.txt}}. | |||
In system disk mode save to {{Path|/boot/usercfg.txt}}. | |||
=== Testing hardware bind === | |||
Before test hardware bind, reboot or run line echo … from {{Path|/etc/conf.d/hwclock}} example | |||
{{cmd|echo ds1307 0x68 > /sys/bus/i2c/devices/i2c-1/new_device }} | |||
Display hardware clock | |||
{{cmd|hwclock }} | |||
Output should display time | |||
<pre> hwclock: Wed Mar 12 17:41:09 2025 0.000000 seconds </pre> | |||
Or error similar below | |||
<pre> hwclock: ioctl 0x80247009 failed: Invalid argument </pre> | |||
meaning hardware bind is successful. | |||
Write system time to RTC module | |||
{{cmd|hwclock -w }} | |||
Run hwclock again to check the time. | |||
== Starting hwclock on boot == | == Starting hwclock on boot == | ||
The hwclock service needs to be started for the hardware clock device to actually do anything. Check if hwclock has been started by running this command: | The hwclock service needs to be started for the hardware clock device to actually do anything. Check if hwclock has been started by running this command: | ||
{{cmd|rc-status {{!}} grep hwclock}} | {{cmd|rc-status {{!}} grep hwclock }} | ||
If it outputs | If it outputs |
Latest revision as of 15:36, 12 March 2025
Hardware Prerequisites
Read the documentation on Installing coin battery and mounting it on the correct GPIO pins for your version of Raspberry Pi board.
Example of Raspberry Pi RTC Modules with documentation:
Install Software
Add the modules from the kernel. The documentation should give you required modules paired with chipset mcp7941x, ds1307 or etc.
/etc/modules|/etc/modules-load.d/i2c.conf
Add these modules so they're loaded on boot. You can modprobe each one individually if you don't want to reboot.
mcp7941x
Contents of /etc/modules
ds1307
Contents of /etc/modules-load.d/i2c.conf
/media/mmcblk0p1/config.txt
You will need to mount this as read-write in diskless mode
mount -o remount,rw /media/mmcblk0p1
Add these two parameters to the bottom
Contents of /media/mmcblk0p1/config.txt
mount -o remount,ro /media/mmcblk0p1
Then you will need to reboot.
Binding the hardware clock device
Read the documentation for the mounted RTC module to get an I2C address for hardware binding. You will want to make sure the device is created when hwclock starts, if it isn't already created. To the bottom of /etc/conf.d/hwclock add this:
mcp7941x
Contents of /etc/conf.d/hwclock
For the time being this is necessary but in the future when issue 1032 you should be able to just add
Contents of /media/mmcblk0p1/config.txt
ds1307
Contents of /etc/conf.d/hwclock
In diskless mode save to /media/mmcblk0p1/config.txt.
In system disk mode save to /boot/usercfg.txt.
Testing hardware bind
Before test hardware bind, reboot or run line echo … from /etc/conf.d/hwclock example
echo ds1307 0x68 > /sys/bus/i2c/devices/i2c-1/new_device
Display hardware clock
hwclock
Output should display time
hwclock: Wed Mar 12 17:41:09 2025 0.000000 seconds
Or error similar below
hwclock: ioctl 0x80247009 failed: Invalid argument
meaning hardware bind is successful.
Write system time to RTC module
hwclock -w
Run hwclock again to check the time.
Starting hwclock on boot
The hwclock service needs to be started for the hardware clock device to actually do anything. Check if hwclock has been started by running this command:
rc-status | grep hwclock
If it outputs
hwclock [ started ]
hwclock has already started. Otherwise start it manually and add it to the default init.d runlevel, so that it starts at boot time:
rc-service hwclock start
rc-update add hwclock default
If you are running Alpine Linux in the diskless mode (non-persistent root filesystem), save the configuration by:
lbu commit -d