From aea8ef4813c28e4d96448da58bb3e315fb5182c4 Mon Sep 17 00:00:00 2001 From: NeoZng Date: Sat, 6 May 2023 16:23:52 +0800 Subject: [PATCH] =?UTF-8?q?=E6=B7=BB=E5=8A=A0=E4=BA=86=E5=8C=97=E9=86=92?= =?UTF-8?q?=E6=BF=80=E5=85=89=E5=8D=95=E7=82=B9=E6=B5=8B=E8=B7=9D=E6=A8=A1?= =?UTF-8?q?=E5=9D=97=EF=BC=8C=E4=BF=AE=E5=A4=8D=E4=BA=86=E9=81=A5=E6=8E=A7?= =?UTF-8?q?=E5=99=A8=E7=A6=BB=E7=BA=BF=E6=A3=80=E6=B5=8B=E5=91=BD=E5=90=8D?= =?UTF-8?q?=E9=94=99=E8=AF=AF=EF=BC=8C=E5=A2=9E=E5=8A=A0=E4=BA=86i2c?= =?UTF-8?q?=E5=AF=84=E5=AD=98=E5=99=A8=E8=AF=BB=E5=86=99=E7=9A=8416?= =?UTF-8?q?=E4=BD=8D=E5=9C=B0=E5=9D=80=E6=A8=A1=E5=BC=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- bsp/iic/bsp_iic.c | 7 ++++--- bsp/iic/bsp_iic.h | 3 ++- modules/TFminiPlus/tfminiplus.c | 30 ++++++++++++++++++++++++++++++ modules/TFminiPlus/tfminiplus.h | 20 ++++++++++++++++++++ modules/ist8310/ist8310.c | 12 ++++++------ modules/remote/remote_control.c | 2 +- 6 files changed, 63 insertions(+), 11 deletions(-) create mode 100644 modules/TFminiPlus/tfminiplus.c create mode 100644 modules/TFminiPlus/tfminiplus.h diff --git a/bsp/iic/bsp_iic.c b/bsp/iic/bsp_iic.c index 75636c1..c11580e 100644 --- a/bsp/iic/bsp_iic.c +++ b/bsp/iic/bsp_iic.c @@ -103,15 +103,16 @@ void IICReceive(IICInstance *iic, uint8_t *data, uint16_t size, IIC_Seq_Mode_e s } } -void IICAccessMem(IICInstance *iic, uint8_t mem_addr, uint8_t *data, uint16_t size, IIC_Mem_Mode_e mem_mode) +void IICAccessMem(IICInstance *iic, uint16_t mem_addr, uint8_t *data, uint16_t size, IIC_Mem_Mode_e mem_mode, uint8_t mem8bit_flag) { + uint16_t bit_flag = mem8bit_flag ? I2C_MEMADD_SIZE_8BIT : I2C_MEMADD_SIZE_16BIT; if (mem_mode == IIC_WRITE_MEM) { - HAL_I2C_Mem_Write(iic->handle, iic->dev_address, mem_addr, I2C_MEMADD_SIZE_8BIT, data, size, 100); + HAL_I2C_Mem_Write(iic->handle, iic->dev_address, mem_addr, bit_flag, data, size, 100); } else if (mem_mode == IIC_READ_MEM) { - HAL_I2C_Mem_Read(iic->handle, iic->dev_address, mem_addr, I2C_MEMADD_SIZE_8BIT, data, size, 100); + HAL_I2C_Mem_Read(iic->handle, iic->dev_address, mem_addr, bit_flag, data, size, 100); } else { diff --git a/bsp/iic/bsp_iic.h b/bsp/iic/bsp_iic.h index 2d70c59..507d23f 100644 --- a/bsp/iic/bsp_iic.h +++ b/bsp/iic/bsp_iic.h @@ -101,5 +101,6 @@ void IICReceive(IICInstance *iic, uint8_t *data, uint16_t size, IIC_Seq_Mode_e m * @param data 要读取或写入的数据首地址指针 * @param size 要读取或写入的数据长度 * @param mode 写入或读取模式: IIC_READ_MEM or IIC_WRITE_MEM + * @param mem8bit_flag 从机内存地址是否为8位 */ -void IICAccessMem(IICInstance *iic, uint8_t mem_addr, uint8_t *data, uint16_t size, IIC_Mem_Mode_e mode); +void IICAccessMem(IICInstance *iic, uint16_t mem_addr, uint8_t *data, uint16_t size, IIC_Mem_Mode_e mode, uint8_t mem8bit_flag); diff --git a/modules/TFminiPlus/tfminiplus.c b/modules/TFminiPlus/tfminiplus.c new file mode 100644 index 0000000..0b53f18 --- /dev/null +++ b/modules/TFminiPlus/tfminiplus.c @@ -0,0 +1,30 @@ +#include "tfminiplus.h" +#include "stdlib.h" +#include "bsp_dwt.h" + +static TFMiniInstance *tfmini; + +TFMiniInstance *TFMiniRegister(I2C_HandleTypeDef *hi2c) +{ + tfmini = (TFMiniInstance *)malloc(sizeof(TFMiniInstance)); + IIC_Init_Config_s conf = { + .handle = hi2c, + .dev_address = 0x10, + .id = tfmini, + .work_mode = IIC_BLOCK_MODE, + }; + tfmini->iic = IICRegister(&conf); + DWT_Delay(0.5); + return tfmini; +} + +float GetDistance(TFMiniInstance *tfmini) +{ + uint8_t cmd_buf[5] = {0x5A, 0x05, 0x00, 0x06, 0x65}; + IICTransmit(tfmini->iic, cmd_buf, 5, IIC_SEQ_RELEASE); + IICReceive(tfmini->iic, tfmini->buf, 11, IIC_SEQ_RELEASE); + tfmini->Mode = tfmini->buf[6]; + tfmini->Dist = (uint16_t)tfmini->buf[2] + (((uint16_t)tfmini->buf[3]) << 8); + tfmini->Strength = tfmini->buf[4] | (tfmini->buf[5] << 8); + return tfmini->Dist; +} diff --git a/modules/TFminiPlus/tfminiplus.h b/modules/TFminiPlus/tfminiplus.h new file mode 100644 index 0000000..62ed6b7 --- /dev/null +++ b/modules/TFminiPlus/tfminiplus.h @@ -0,0 +1,20 @@ +#ifndef __TFMINIPLUS_H__ +#define __TFMINIPLUS_H__ + +#include "stdint.h" +#include "bsp_iic.h" + +typedef struct +{ + IICInstance *iic; + uint8_t Mode; //= buf[6]; + uint16_t Dist; //= buf[2] | (buf[3] << 8); + uint32_t Strength; //= buf[4] | (buf[5] << 8); + uint8_t buf[9]; +} TFMiniInstance; + +TFMiniInstance *TFMiniRegister(I2C_HandleTypeDef *hi2c); + +float GetDistance(TFMiniInstance *tfmini); + +#endif diff --git a/modules/ist8310/ist8310.c b/modules/ist8310/ist8310.c index 4fe4427..8f22733 100644 --- a/modules/ist8310/ist8310.c +++ b/modules/ist8310/ist8310.c @@ -29,8 +29,8 @@ static uint8_t ist8310_write_reg_data_error[IST8310_WRITE_REG_NUM][3] = { */ static void IST8310Decode(IICInstance *iic) { - int16_t temp[3]; // 用于存储解码后的数据 - IST8310Instance *ist= (IST8310Instance *)(iic->id); // iic的id保存了IST8310实例的指针(父指针) + int16_t temp[3]; // 用于存储解码后的数据 + IST8310Instance *ist = (IST8310Instance *)(iic->id); // iic的id保存了IST8310实例的指针(父指针) memcpy(temp, ist->iic_buffer, 6 * sizeof(uint8_t)); // 不要强制转换,直接cpy for (uint8_t i = 0; i < 3; i++) @@ -48,7 +48,7 @@ static void IST8310StartTransfer(GPIOInstance *gpio) // 先获取IST8310实例的指针(通过gpio实例的父指针id) IST8310Instance *ist_for_transfer = (IST8310Instance *)gpio->id; // 中断说明ist已经准备好读取数据寄存器;6个字节,读取后会进入IST8310Decode函数 - IICAccessMem(ist_for_transfer->iic, IST8310_DATA_REG, ist_for_transfer->iic_buffer, 6, IIC_READ_MEM); + IICAccessMem(ist_for_transfer->iic, IST8310_DATA_REG, ist_for_transfer->iic_buffer, 6, IIC_READ_MEM, 1); // 传输完成后会进入IST8310Decode函数进行数据解析 IST8310Decode(ist_for_transfer->iic); } @@ -80,15 +80,15 @@ IST8310Instance *IST8310Init(IST8310_Init_Config_s *config) HAL_Delay(sleepTime); // 读取IST8310的ID,如果不是0x10(whoami macro的值),则返回错误 - IICAccessMem(ist->iic, IST8310_WHO_AM_I, &check_who_i_am, 1, IIC_READ_MEM); + IICAccessMem(ist->iic, IST8310_WHO_AM_I, &check_who_i_am, 1, IIC_READ_MEM, 1); if (check_who_i_am != IST8310_WHO_AM_I_VALUE) return NULL; // while(1) // 进行初始化配置写入并检查是否写入成功,这里用循环把最上面初始化数组的东西都写进去 for (uint8_t i = 0; i < IST8310_WRITE_REG_NUM; i++) { // 写入配置,写一句就读一下看看ist8310是否仍然在线 - IICAccessMem(ist->iic, ist8310_write_reg_data_error[i][0], &ist8310_write_reg_data_error[i][1], 1, IIC_WRITE_MEM); - IICAccessMem(ist->iic, ist8310_write_reg_data_error[i][0], &check_who_i_am, 1, IIC_READ_MEM); // 读回自身id + IICAccessMem(ist->iic, ist8310_write_reg_data_error[i][0], &ist8310_write_reg_data_error[i][1], 1, IIC_WRITE_MEM, 1); + IICAccessMem(ist->iic, ist8310_write_reg_data_error[i][0], &check_who_i_am, 1, IIC_READ_MEM, 1); // 读回自身id if (check_who_i_am != ist8310_write_reg_data_error[i][1]) while (1) ist8310_write_reg_data_error[i][2]; // 掉线/写入失败/未知错误,会返回对应的错误码 diff --git a/modules/remote/remote_control.c b/modules/remote/remote_control.c index 497b7c8..4dbef62 100644 --- a/modules/remote/remote_control.c +++ b/modules/remote/remote_control.c @@ -142,7 +142,7 @@ RC_ctrl_t *RemoteControlInit(UART_HandleTypeDef *rc_usart_handle) return (RC_ctrl_t *)&rc_ctrl; } -uint8_t RemotecontrolIsOnline() +uint8_t RemoteControlIsOnline() { if (rc_init_flag) return DaemonIsOnline(rc_daemon_instance);