Name

CYGPKG_DEVICES_WALLCLOCK_DALLAS_DS1390 — eCos Support for the Dallas DS1390 Serial Real-Time Clock

Description

This package CYGPKG_DEVICES_WALLCLOCK_DALLAS_DS1390 provides a device driver for the wallclock device in the Dallas DS1390 Serial Real-Time Clock chips. The driver can also be used with any other chips that provide the same interface to the clock hardware.

The package will usually be loaded into the configuration automatically whenever selecting a target which contains a compatible chip. By default it will provide the standard eCos wallclock device, although another implementation such as software emulation may be selected if desired. The only other configuration options related to this package allow users to change the compiler flags. If the application does not actually use the wallclock device, directly or indirectly, then the code should get removed automatically at link-time to ensure that the application does not suffer any unnecessary overheads.

Functionality

This wallclock device driver package implements the standard functionality required by the generic wallclock support CYGPKG_IO_WALLCLOCK. The functionality is not normally accessed directly. Instead it is used by the C library time package to implement standard calls such as time and gmtime. The eCos C library also provides a non-standard function cyg_libc_time_settime for changing the current wallclock setting. In addition RedBoot provides a date command which interacts with the wallclock device.

Porting

The DS1390 driver uses the SPI driver API defined by the package CYGPKG_IO_SPI. A suitable SPI device driver must be available for the target. The platform HAL must provide a cyg_spi_device structure cyg_spi_wallclock_ds1390. The platform HAL should initialize this structure and any associated SPI driver specific struture with the correct phase, polarity and chip select parameters for this device.

In addition the DS1390 device driver package CYGPKG_DEVICES_WALLCLOCK_DALLAS_DS1390 should be included in the CDL target entry so that it gets loaded automatically whenever eCos is configured for that target.

Extra API Calls

In addition to the standard wallclock API calls, this driver exports a number of additional functions to permit direct access to additional features of the device. A header, cyg/io/wallclock/ds1390.h is available to define this API.

cyg_uint8 cyg_ds1390_read_reg( int addr )
Read and return a single 8-bit register from the DS1390, addr should be in the range 0x00 to 0x0F.
void cyg_ds1390_write_reg( int addr, int val )
Write a single 8-bit register to the DS1390, addr should be in the range 0x00 to 0x0F and val in the range 0x00 to 0xFF.
void cyg_ds1390_set_control( cyg_uint8 val )
Write the DS1390 control register with the content of val.
cyg_uint8 cyg_ds1390_get_control( void )
Read and return the value of the DS1390 control register.
void cyg_ds1390_set_status( cyg_uint8 val )
Write the DS1390 status register with the content of val.
cyg_uint8 cyg_ds1390_get_status( void )
Read and return the value of the DS1390 control register.
void cyg_ds1390_set_charger( cyg_uint8 val )
Write the DS1390 trickle-charge register with the content of val.
cyg_uint8 cyg_ds1390_get_charger( void )
Read and return the value of the DS1390 trickle-charge register.
int cyg_wallclock_set_alarm( cyg_uint32 secs )
Set the DS1390 alarm to trigger when the wallclock time matches the value of secs. The DS1390 alarm will match only up to days of the month, so the alarm cannot be set more than one month in the future. This function only initializes the DS1390 to generate the alarm interrupt; it is the responsibility of the caller to attach an ISR to the appropriate vector and unmask it in the interrupt controller.