1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/drivers/include/ds3234.h
Joakim Nohlgård a6f430b4b5 drivers/ds3234: Minimal driver for DS3234 extremely accurate RTC
This driver currently only supports the SPI connected DS3234, and only
for initializing 1 Hz square wave output on the SQW pin, nothing else.
2019-02-19 11:57:40 +01:00

70 lines
1.5 KiB
C

/*
* Copyright 2018 SKF AB
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @defgroup drivers_ds3234 DS3234 Extremely Accurate SPI RTC
* @brief Driver for Maxim DS3234 Extremely Accurate SPI Bus RTC with
* Integrated Crystal and SRAM
* @{
*
* @file
* @brief DS3234 device driver
*
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
*/
#ifndef DS3234_H
#define DS3234_H
#include <periph/gpio.h>
#include <periph/spi.h>
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief Parameters for the DS3234 device driver
*/
typedef struct {
spi_t spi; /**< SPI bus the sensor is connected to */
spi_clk_t clk; /**< SPI bus clock speed */
gpio_t cs; /**< CS pin GPIO handle */
} ds3234_params_t;
/**
* @brief Return codes for the DS3234 device driver
*/
enum ds3234_return_codes {
DS3234_OK = 0,
DS3234_NO_DEV = 1,
DS3234_NO_SPI = 2
};
/**
* @brief Initialize the DS3234 RTC as a PPS device
*
* This will enable square wave output on the SQW pin at 1 Hz
*
* @param params DS3234 circuit parameters
*
* @return DS3234_OK on success
* @return DS3234_NO_SPI if cannot initiate SPI
* @return DS3234_NO_DEV if the device is not found on the bus
*/
int ds3234_pps_init(const ds3234_params_t *params);
#ifdef __cplusplus
}
#endif
#endif /* DS3234_H */
/** @} */