feat: add i2c rx8025t demo
This commit is contained in:
parent
57bf0e54f8
commit
691ff86905
76
demo/i2c/rx8025t/main.c
Normal file
76
demo/i2c/rx8025t/main.c
Normal file
@ -0,0 +1,76 @@
|
||||
// Copyright 2021 IOsetting <iosetting(at)outlook.com>
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
/***
|
||||
* Demo: RX8025T I2C RTC/TCXO
|
||||
* Board: STC8H3K32
|
||||
*
|
||||
* P32 -> SCL
|
||||
* P33 -> SDA
|
||||
* GND -> GND
|
||||
* 3.3V -> VCC
|
||||
*/
|
||||
|
||||
#include "fw_hal.h"
|
||||
#include "rx8025t.h"
|
||||
|
||||
#define BUFF_SIZE 16
|
||||
|
||||
__XDATA uint8_t time[BUFF_SIZE];
|
||||
|
||||
void I2C_Init(void)
|
||||
{
|
||||
// Master mode
|
||||
I2C_SetWorkMode(I2C_WorkMode_Master);
|
||||
/**
|
||||
* I2C clock = FOSC / 2 / (__prescaler__ * 2 + 4)
|
||||
*/
|
||||
I2C_SetClockPrescaler(0x3F);
|
||||
// Switch alternative port
|
||||
I2C_SetPort(I2C_AlterPort_P32_P33);
|
||||
// Start I2C
|
||||
I2C_SetEnabled(HAL_State_ON);
|
||||
}
|
||||
|
||||
void GPIO_Init(void)
|
||||
{
|
||||
// SDA
|
||||
GPIO_P3_SetMode(GPIO_Pin_3, GPIO_Mode_InOut_QBD);
|
||||
// SCL
|
||||
GPIO_P3_SetMode(GPIO_Pin_2, GPIO_Mode_Output_PP);
|
||||
}
|
||||
|
||||
int main(void)
|
||||
{
|
||||
uint8_t i;
|
||||
SYS_SetClock();
|
||||
// UART1 configuration: baud 115200 with Timer2, 1T mode, no interrupt
|
||||
UART1_Config8bitUart(UART1_BaudSource_Timer2, HAL_State_ON, 115200);
|
||||
|
||||
GPIO_Init();
|
||||
I2C_Init();
|
||||
RX8025T_Init();
|
||||
|
||||
while(1)
|
||||
{
|
||||
RX8025T_GetTime(time);
|
||||
for (i = 0; i < BUFF_SIZE; i++)
|
||||
{
|
||||
UART1_TxHex(time[i]);
|
||||
UART1_TxChar('-');
|
||||
}
|
||||
UART1_TxString("\r\n");
|
||||
SYS_Delay(1000);
|
||||
}
|
||||
}
|
48
demo/i2c/rx8025t/rx8025t.c
Executable file
48
demo/i2c/rx8025t/rx8025t.c
Executable file
@ -0,0 +1,48 @@
|
||||
// Copyright 2021 IOsetting <iosetting(at)outlook.com>
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
#include "rx8025t.h"
|
||||
|
||||
__XDATA uint8_t buff[7];
|
||||
|
||||
uint8_t RX8025T_Write(uint8_t reg, uint8_t dat)
|
||||
{
|
||||
return I2C_Write(RX8025T_I2C_ADDR, reg, &dat, 1);
|
||||
}
|
||||
|
||||
uint8_t RX8025T_Init(void)
|
||||
{
|
||||
// Reset all flags
|
||||
RX8025T_Write(RX8025T_REG_FLAG, 0x00);
|
||||
// Default , turn off all interrupts
|
||||
RX8025T_Write(RX8025T_REG_CONTROL, 0x40);
|
||||
return HAL_OK;
|
||||
}
|
||||
|
||||
uint8_t RX8025T_GetTime(uint8_t *t)
|
||||
{
|
||||
I2C_Read(RX8025T_I2C_ADDR, RX8025T_REG_SECOND, t, 16);
|
||||
return HAL_OK;
|
||||
}
|
||||
|
||||
uint8_t RX8025T_SetTime(uint8_t *t)
|
||||
{
|
||||
RX8025T_Write(RX8025T_REG_YEAR, t[0]);
|
||||
RX8025T_Write(RX8025T_REG_MONTH, t[0]);
|
||||
RX8025T_Write(RX8025T_REG_DAY, t[0]);
|
||||
RX8025T_Write(RX8025T_REG_HOUR, t[0]);
|
||||
RX8025T_Write(RX8025T_REG_MINUTE, t[0]);
|
||||
RX8025T_Write(RX8025T_REG_SECOND, t[0]);
|
||||
return HAL_OK;
|
||||
}
|
86
demo/i2c/rx8025t/rx8025t.h
Executable file
86
demo/i2c/rx8025t/rx8025t.h
Executable file
@ -0,0 +1,86 @@
|
||||
// Copyright 2021 IOsetting <iosetting(at)outlook.com>
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
#ifndef __FW_RX8025T_H__
|
||||
#define __FW_RX8025T_H__
|
||||
|
||||
#include "fw_hal.h"
|
||||
|
||||
#define RX8025T_I2C_ADDR 0x64
|
||||
|
||||
/**
|
||||
* REGISTER TABLE
|
||||
*
|
||||
* * RX-8025T is different from RX-8025 SA/NB
|
||||
*/
|
||||
#define RX8025T_REG_SECOND 0x00 // BCD value 00 -> 59
|
||||
#define RX8025T_REG_MINUTE 0x01 // BCD value 00 -> 59
|
||||
#define RX8025T_REG_HOUR 0x02 // BCD value 00 -> 23
|
||||
#define RX8025T_REG_WEEKDAY 0x03 // bit 0->6: sunday->saturday
|
||||
#define RX8025T_REG_DAY 0x04 // BCD value 01 -> 31
|
||||
#define RX8025T_REG_MONTH 0x05 // BCD value 01 -> 12
|
||||
#define RX8025T_REG_YEAR 0x06 // BCD value 00 -> 99
|
||||
#define RX8025T_REG_RAM 0x07 // R/W accessible for any data in the range from 00 h to FF h
|
||||
|
||||
#define RX8025T_REG_ALARM_MIN 0x08 // BCD value 00 -> 59
|
||||
#define RX8025T_REG_ALARM_HOUR 0x09 // BCD value 00 -> 23
|
||||
#define RX8025T_REG_ALARM_W_OR_D 0x0A // WEEK: bit 0->6: sunday->saturday
|
||||
// DAY: BCD value
|
||||
|
||||
#define RX8025T_REG_TIMER_COUNTER0 0x0B // Fixed-cycle timer control registers to set the preset countdown value
|
||||
// for the fixed-cycle timer interrupt. (COUNTER1, COUNTER0) = 12bit number
|
||||
#define RX8025T_REG_TIMER_COUNTER1 0x0C // When control register changes from 001h to 000h, the /INT pin goes to
|
||||
// low level and "1" is set to the TF.
|
||||
|
||||
#define RX8025T_REG_EXTEN 0x0D
|
||||
#define RX8025T_EXTEN_TEST 0x80 // TEST bit. value should always be "0"
|
||||
#define RX8025T_EXTEN_WADA 0x40 // Week Alarm/Day Alarm bit. R/W to specify either WEEK or DAY
|
||||
// as the target of the alarm interrupt function. 0:WEEK, 1:DAY
|
||||
#define RX8025T_EXTEN_USEL 0x20 // Update Interrupt Select bit. R/W specify either "second"
|
||||
// or "minute" as update interrupt, 0:second update, 1:minute update
|
||||
#define RX8025T_EXTEN_TE 0x10 // Timer Enable bit. controls the start/stop setting for the fixed-cycle
|
||||
// timer interrupt function. 1:start, 0:stop
|
||||
#define RX8025T_EXTEN_FSEL1 0x08 // FOUT frequency Select bits to set the FOUT frequency. (FSEL1, FSEL0)
|
||||
#define RX8025T_EXTEN_FSEL0 0x04 // 0,0:32.768KHz, 0,1:1024Hz, 1,0:1Hz, 1,1:32.768KHz
|
||||
#define RX8025T_EXTEN_TSEL1 0x02 // Timer Select bits to set the countdown period (source clock) for the
|
||||
// fixed-cycle timer interrupt (TSEL1, TSEL0)
|
||||
#define RX8025T_EXTEN_TSEL0 0x01 // 0,0:4096Hz, 0,1:64Hz, 1,0:1Hz(per second), 1,1:1/60Hz(per minute)
|
||||
|
||||
#define RX8025T_REG_FLAG 0x0E
|
||||
#define RX8025T_FLAG_UF 0x20 // Update Flag. 0 -> 1 when a time update interrupt event has
|
||||
// occurred. 1 is retained until a 0 is written
|
||||
#define RX8025T_FLAG_TF 0x10 // Timer Flag. 0 -> 1 when a fixed-cycle timer interrupt
|
||||
// event has occurred, 1 is retained until a 0 is written
|
||||
#define RX8025T_FLAG_AF 0x08 // Alarm Flag. 0 -> 1 when an alarm interrupt event has occurred
|
||||
// 1 is retained until a 0 is written
|
||||
#define RX8025T_FLAG_VLF 0x02 // Voltage Low Flag. 0 -> 1 when data loss occurs, e.g. a supply
|
||||
// voltage drop,
|
||||
#define RX8025T_FLAG_VDET 0x01 // Voltage Detection Flag. 0 -> 1 when stop the temperature compensation
|
||||
// such as due to a supply voltage drop, 1 is retained until a 0 is written
|
||||
|
||||
#define RX8025T_REG_CONTROL 0x0F
|
||||
#define RX8025T_CONTR_CSEL1 0x80 // Compensation interval (CSEL1, CSEL0)
|
||||
#define RX8025T_CONTR_CSEL0 0x40 // 0,0:0.5s, 0,1:2s(default), 1,0:10s, 1,1:30s
|
||||
#define RX8025T_CONTR_UIE 0x20 // Update Interrupt Enable, 0:off, 1:on
|
||||
#define RX8025T_CONTR_TIE 0x10 // Timer Interrupt Enable
|
||||
#define RX8025T_CONTR_AIE 0x08 // Alarm Interrupt Enable
|
||||
#define RX8025T_CONTR_RESET 0x01 // Writing a "1" to this bit stops the counter operation and
|
||||
// resets the RTC module's internal counter value when the
|
||||
// value is less than one second.
|
||||
|
||||
uint8_t RX8025T_Init(void);
|
||||
uint8_t RX8025T_GetTime(uint8_t* t);
|
||||
uint8_t RX8025T_SetTime(uint8_t* t);
|
||||
|
||||
#endif
|
Loading…
Reference in New Issue
Block a user