xiuos3/kernel/kernel_test/test_i2c.c

179 lines
5.3 KiB
C
Raw Normal View History

2021-04-28 17:49:18 +08:00
/*
* Copyright (c) 2020 AIIT XUOS Lab
* XiUOS is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
* http://license.coscl.org.cn/MulanPSL2
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
*/
/**
* @file test_i2c.c
* @brief support to test i2c function
* @version 1.0
* @author AIIT XUOS Lab
* @date 2021-04-24
*/
#include <xiuos.h>
#include <device.h>
#include <bus.h>
/*********************************************************************************************************************************************************/
/*
* functionI2C device sample support reading temperature and humidity sensor data and printfing on the terminal
* shell cmdi2c_HS3000_sample i2c1
* shell cmd parami2c device name,if null means default i2c device name
*/
#define HS_I2C_BUS_NAME I2C_BUS_NAME_1 /* I2C bus name */
#define HS_I2C_DEV_NAME I2C_1_DEVICE_NAME_0/* I2C device name */
#define HS_I2C_DRV_NAME I2C_DRV_NAME_1 /* I2C driver name */
#define ADDR 0x44 /* slave address */
static struct Bus *i2c_bus = NONE; /* I2C bus handle */
typedef struct Hs300xData
{
int humi_high;
int humi_low;
int temp_high;
int temp_low;
}Hs300xDataType;
Hs300xDataType g_hs300x_data;
static x_err_t WriteReg(struct HardwareDev *dev)
{
struct BusBlockWriteParam write_param;
/* use I2C device API transfer data */
if(1 == BusDevWriteData(dev, &write_param)) {
return EOK;
}
else{
return -ERROR;
}
}
/* read sensor register data */
static x_err_t ReadRegs(struct HardwareDev *dev, uint8 len, uint8 *buf)
{
struct BusBlockReadParam read_param;
read_param.buffer = (void *)buf;
read_param.size = len;
/* use I2C device API transfer data */
if(1 == BusDevReadData(dev, &read_param)){
return EOK;
}
else{
return -ERROR;
}
}
2021-04-29 12:55:01 +08:00
static void ReadTempHumi(float *cur_temp, float *cur_humi)
2021-04-28 17:49:18 +08:00
{
uint8 temp[4],ret=0;
MdelayKTask(15);
ret = WriteReg(i2c_bus->owner_haldev); //reset
if(EOK != ret){
2021-04-29 12:55:01 +08:00
KPrintf("ReadTempHumi WriteReg failed!\n");
2021-04-28 17:49:18 +08:00
}
MdelayKTask(50);
ret = ReadRegs(i2c_bus->owner_haldev, 4, temp); /* get sensor data */
if(EOK != ret){
2021-04-29 12:55:01 +08:00
KPrintf("ReadTempHumi ReadRegs failed\n");
2021-04-28 17:49:18 +08:00
}
*cur_humi = ((temp[0] <<8 | temp[1] )& 0x3fff ) * 100.0 / ( (1 << 14) - 1); /* humidity data */
*cur_temp = ((temp[2] << 8 | temp[3]) >> 2) * 165.0 /( (1 << 14) - 1) - 40.0; /* temperature data */
}
2021-04-29 12:55:01 +08:00
static void HS3000Init(const char *bus_name, const char *dev_name, const char *drv_name)
2021-04-28 17:49:18 +08:00
{
/* find I2C device and get I2C handle */
i2c_bus = BusFind(bus_name);
if (NONE == i2c_bus){
2021-04-29 12:55:01 +08:00
KPrintf("HS3000Init can't find %s bus!\n", bus_name);
2021-04-28 17:49:18 +08:00
}
else{
2021-04-29 12:55:01 +08:00
KPrintf("HS3000Init find %s bus!\n", bus_name);
2021-04-28 17:49:18 +08:00
}
i2c_bus->owner_haldev = BusFindDevice(i2c_bus, dev_name);
i2c_bus->owner_driver = BusFindDriver(i2c_bus, drv_name);
if(i2c_bus->match(i2c_bus->owner_driver, i2c_bus->owner_haldev)){
KPrintf("i2c match drv %s %p dev %s %p error\n", drv_name, i2c_bus->owner_driver, dev_name, i2c_bus->owner_haldev);
}
else{
2021-04-29 12:55:01 +08:00
KPrintf("HS3000Init successfully!write %p read %p\n",
2021-04-28 17:49:18 +08:00
i2c_bus->owner_haldev->dev_done->write,
i2c_bus->owner_haldev->dev_done->read);
}
}
void Hs300xInit(void)
{
2021-04-29 12:55:01 +08:00
HS3000Init(HS_I2C_BUS_NAME, HS_I2C_DEV_NAME, HS_I2C_DRV_NAME); /* init sensor */
2021-04-28 17:49:18 +08:00
}
void Hs300xRead(Hs300xDataType *Hs300xDataType)
{
float humidity = 0.0, temperature = 0.0;
2021-04-29 12:55:01 +08:00
ReadTempHumi(&temperature, &humidity); /* read temperature and humidity sensor data */
2021-04-28 17:49:18 +08:00
Hs300xDataType->humi_high = (int)humidity;
Hs300xDataType->humi_low = (int)(humidity*10)%10;
if( temperature >= 0 ) {
Hs300xDataType->temp_high = (int)temperature;
Hs300xDataType->temp_low = (int)(temperature*10)%10;
}
else{
Hs300xDataType->temp_high = (int)temperature;
Hs300xDataType->temp_low = (int)(-temperature*10)%10;
}
}
2021-04-29 12:55:01 +08:00
void TskHs300xTest()
2021-04-28 17:49:18 +08:00
{
memset(&g_hs300x_data, 0, sizeof(Hs300xDataType));
KPrintf("Tsk create successfully!\n");
while(1)
{
Hs300xRead(&g_hs300x_data);
KPrintf("HS300X:I2C humidity:%d.%d temperature:%d.%d\n",
g_hs300x_data.humi_high,
g_hs300x_data.humi_low,
g_hs300x_data.temp_high,
g_hs300x_data.temp_low);
MdelayKTask(1000);
}
return;
}
void Hs300xI2cTest(void)
{
Hs300xInit();
MdelayKTask(1000);
x_err_t flag;
2021-04-29 12:55:01 +08:00
int32 Tsk_hs300x = KTaskCreate("Tsk_hs300x", TskHs300xTest, NONE, 2048, 10);
2021-04-28 17:49:18 +08:00
flag = StartupKTask(Tsk_hs300x);
if (EOK != flag){
KPrintf("Hs300xI2cTest StartupKTask failed!\n");
return;
}
}
SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0)|SHELL_CMD_TYPE(SHELL_TYPE_CMD_FUNC)|SHELL_CMD_PARAM_NUM(0),
Hs300xI2cTest, Hs300xI2cTest, Test the HS300X using I2C);