找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3727|回复: 5
打印 上一主题 下一主题
收起左侧

野火STM32F429+AD7705程序移植

[复制链接]
跳转到指定楼层
楼主
因为项目需要所以把AD7705程序移植到野火stm32挑战者开发板上,需要的朋友可以下载


单片机源程序如下:
  1. /*
  2. *********************************************************************************************************
  3. 需要注意的是模块使用3.3V供电较稳定,使用5V供电可能回出问题,读出来的数据有时候是错的
  4. 还有就是AIN1-和AIN2-引脚的电压最高为1V,AIN1+,AIN2+的最高电压为2.5V,详情请见数据手册说明,
  5. 用来检测开发板3.3V和5V的的电压也是可以的,一般不会出现问题。
  6. 本例程是单极性输入,增益为1,带输入缓冲。带缓冲可以解决ADC采样端,由于未进行电压跟随而造成的
  7. ADC检测错误。
  8. 测试条件:串接3个1K的电阻和一个10K的电阻进行采样,采样的结果和万用表测量的结果基本一致

  9. AD7705的供电电压尽量    不要为5V这点很重要!!!!!   不要为5V这点很重要!!!!!
  10. 不要为5V这点很重要!!!!!不要为5V这点很重要!!!!!不要为5V这点很重要!!!!!
  11. *********************************************************************************************************
  12. */
  13. #include "AD7705.h"
  14. #include "systick.h"
  15. #define SOFT_SPI                /* 定义此行表示使用GPIO模拟SPI接口 */
  16. //#define HARD_SPI                /* 定义此行表示使用CPU的硬件SPI接口 */

  17. /* 通道1和通道2的增益,输入缓冲,单极性 */
  18. #define __CH1_GAIN_BIPOLAR_BUF        (GAIN_1 | UNIPOLAR | BUF_EN)
  19. #define __CH2_GAIN_BIPOLAR_BUF        (GAIN_1 | UNIPOLAR | BUF_EN)

  20. /*

  21.                         TM7705模块   野火STM32挑战者 STM32F429开发板
  22.       SCK   ------  PE2
  23.       DOUT  ------  PE4
  24.       DIN   ------  PE3
  25.       CS    ------  PE5
  26.       DRDY  ------  PE6
  27.       RST   ------  PI8
  28. */

  29. #if !defined(SOFT_SPI) && !defined(HARD_SPI)
  30.         #error "Please define SPI Interface mode : SOFT_SPI or HARD_SPI"
  31. #endif

  32. #ifdef SOFT_SPI                /* 软件SPI */
  33.         /* 定义GPIO端口 */
  34.         #define RCC_SCK         RCC_AHB1Periph_GPIOE
  35.         #define PORT_SCK        GPIOE
  36.         #define PIN_SCK                GPIO_Pin_2

  37.         #define RCC_DIN         RCC_AHB1Periph_GPIOE
  38.         #define PORT_DIN        GPIOE
  39.         #define PIN_DIN                GPIO_Pin_3

  40.         #define RCC_DOUT         RCC_AHB1Periph_GPIOE
  41.         #define PORT_DOUT        GPIOE
  42.         #define PIN_DOUT        GPIO_Pin_4

  43.         #define RCC_CS                 RCC_AHB1Periph_GPIOE
  44.         #define PORT_CS                GPIOE
  45.         #define PIN_CS                GPIO_Pin_5

  46.         #define RCC_DRDY         RCC_AHB1Periph_GPIOE
  47.         #define PORT_DRDY        GPIOE
  48.         #define PIN_DRDY        GPIO_Pin_6

  49.         #define RCC_RESET         RCC_AHB1Periph_GPIOI
  50.         #define PORT_RESET        GPIOI
  51.         #define PIN_RESET        GPIO_Pin_8

  52.         /* 定义口线置0和置1的宏 */
  53.         #define RESET_0()        GPIO_ResetBits(PORT_RESET, PIN_RESET)
  54.         #define RESET_1()        GPIO_SetBits(PORT_RESET, PIN_RESET)

  55.         #define CS_0()                GPIO_ResetBits(PORT_CS, PIN_CS)
  56.         #define CS_1()                GPIO_SetBits(PORT_CS, PIN_CS)

  57.         #define SCK_0()                GPIO_ResetBits(PORT_SCK, PIN_SCK)
  58.         #define SCK_1()                GPIO_SetBits(PORT_SCK, PIN_SCK)

  59.         #define DI_0()                GPIO_ResetBits(PORT_DIN, PIN_DIN)
  60.         #define DI_1()                GPIO_SetBits(PORT_DIN, PIN_DIN)

  61.         #define DO_IS_HIGH()        (GPIO_ReadInputDataBit(PORT_DOUT, PIN_DOUT) == Bit_SET)

  62.         #define DRDY_IS_LOW()        (GPIO_ReadInputDataBit(PORT_DRDY, PIN_DRDY) == Bit_RESET)
  63. #endif

  64. #ifdef HARD_SPI                /* 硬件SPI */
  65.         ;
  66. #endif

  67. /* 通信寄存器bit定义 */
  68. enum
  69. {
  70.         /* 寄存器选择  RS2 RS1 RS0  */
  71.         REG_COMM        = 0x00,        /* 通信寄存器 */
  72.         REG_SETUP        = 0x10,        /* 设置寄存器 */
  73.         REG_CLOCK        = 0x20,        /* 时钟寄存器 */
  74.         REG_DATA        = 0x30,        /* 数据寄存器 */
  75.         REG_ZERO_CH1        = 0x60,        /* CH1 偏移寄存器 */
  76.         REG_FULL_CH1        = 0x70,        /* CH1 满量程寄存器 */
  77.         REG_ZERO_CH2        = 0x61,        /* CH2 偏移寄存器 */
  78.         REG_FULL_CH2        = 0x71,        /* CH2 满量程寄存器 */

  79.         /* 读写操作 */
  80.         WRITE                 = 0x00,        /* 写操作 */
  81.         READ                 = 0x08,        /* 读操作 */

  82.         /* 通道 */
  83.         CH_1                = 0,        /* AIN1+  AIN1- */
  84.         CH_2                = 1,        /* AIN2+  AIN2- */
  85.         CH_3                = 2,        /* AIN1-  AIN1- */
  86.         CH_4                = 3                /* AIN1-  AIN2- */
  87. };

  88. /* 设置寄存器bit定义 */
  89. enum
  90. {
  91.         MD_NORMAL                = (0 << 6),        /* 正常模式 */
  92.         MD_CAL_SELF                = (1 << 6),        /* 自校准模式 */
  93.         MD_CAL_ZERO                = (2 << 6),        /* 校准0刻度模式 */
  94.         MD_CAL_FULL                = (3 << 6),        /* 校准满刻度模式 */

  95.         GAIN_1                        = (0 << 3),        /* 增益 */
  96.         GAIN_2                        = (1 << 3),        /* 增益 */
  97.         GAIN_4                        = (2 << 3),        /* 增益 */
  98.         GAIN_8                        = (3 << 3),        /* 增益 */
  99.         GAIN_16                        = (4 << 3),        /* 增益 */
  100.         GAIN_32                        = (5 << 3),        /* 增益 */
  101.         GAIN_64                        = (6 << 3),        /* 增益 */
  102.         GAIN_128                = (7 << 3),        /* 增益 */

  103.         /* 无论双极性还是单极性都不改变任何输入信号的状态,它只改变输出数据的代码和转换函数上的校准点 */
  104.         BIPOLAR                        = (0 << 2),        /* 双极性输入 */
  105.         UNIPOLAR                = (1 << 2),        /* 单极性输入 */

  106.         BUF_NO                        = (0 << 1),        /* 输入无缓冲(内部缓冲器不启用) */
  107.         BUF_EN                        = (1 << 1),        /* 输入有缓冲 (启用内部缓冲器) */

  108.         FSYNC_0                        = 0,
  109.         FSYNC_1                        = 1                /* 不启用 */
  110. };

  111. /* 时钟寄存器bit定义 */
  112. enum
  113. {
  114.         CLKDIS_0        = 0x00,                /* 时钟输出使能 (当外接晶振时,必须使能才能振荡) */
  115.         CLKDIS_1        = 0x10,                /* 时钟禁止 (当外部提供时钟时,设置该位可以禁止MCK_OUT引脚输出时钟以省电 */

  116.         /*
  117.                 2.4576MHz(CLKDIV=0 )或为 4.9152MHz (CLKDIV=1 ),CLK 应置 “0”。
  118.                 1MHz (CLKDIV=0 )或 2MHz   (CLKDIV=1 ),CLK 该位应置  “1”
  119.         */
  120.         CLK_4_9152M = 0x08,
  121.         CLK_2_4576M = 0x00,
  122.         CLK_1M                 = 0x04,
  123.         CLK_2M                 = 0x0C,

  124.         FS_50HZ                = 0x00,
  125.         FS_60HZ                = 0x01,
  126.         FS_250HZ        = 0x02,
  127.         FS_500HZ        = 0x04,

  128. //        FS_50HZ                = 0x04,
  129. //        FS_60HZ                = 0x05,
  130. //        FS_250HZ        = 0x06,
  131. //        FS_500HZ        = 0x07,
  132.         /*
  133.                 四十九、电子秤应用中提高TM7705 精度的方法
  134.                         当使用主时钟为 2.4576MHz 时,强烈建议将时钟寄存器设为 84H,此时数据输出更新率为10Hz,即每0.1S 输出一个新数据。
  135.                         当使用主时钟为 1MHz 时,强烈建议将时钟寄存器设为80H, 此时数据输出更新率为4Hz, 即每0.25S 输出一个新数据
  136.         */
  137.         ZERO_0                = 0x00,
  138.         ZERO_1                = 0x80
  139. };

  140. static void TM7705_SyncSPI(void);
  141. static void TM7705_Send8Bit(uint8_t _data);
  142. static uint8_t TM7705_Recive8Bit(void);
  143. static void TM7705_WriteByte(uint8_t _data);
  144. static void TM7705_Write3Byte(uint32_t _data);
  145. static uint8_t TM7705_ReadByte(void);
  146. static uint16_t TM7705_Read2Byte(void);
  147. static uint32_t TM7705_Read3Byte(void);
  148. static void TM7705_WaitDRDY(void);
  149. void TM7705_ResetHard(void);
  150. static void TM7705_Delay(void);

  151. /*
  152. *********************************************************************************************************
  153. *        函 数 名: bsp_DelayMS
  154. *        功能说明: ms级延迟,延迟精度为正负1ms
  155. *        形    参:  n : 延迟长度,单位1 ms。 n 应大于2
  156. *        返 回 值: 无
  157. * 这2个全局变量转用于 bsp_DelayMS() 函数
  158. */
  159. extern volatile uint32_t s_uiDelayCount;
  160. extern volatile uint8_t s_ucTimeOutFlag;

  161. /* 开关全局中断的宏 */
  162. #define ENABLE_INT()        __set_PRIMASK(0)        /* 使能全局中断  core_cmFunc.h 的头文件中*/
  163. #define DISABLE_INT()        __set_PRIMASK(1)        /* 禁止全局中断 */

  164. void bsp_DelayMS(uint32_t n)
  165. {
  166.         if (n == 0)
  167.         {
  168.                 return;
  169.         }
  170.         else if (n == 1)
  171.         {
  172.                 n = 2;
  173.         }
  174.        
  175.         DISABLE_INT();                          /* 关中断 */
  176.        
  177.         s_uiDelayCount = n;
  178.         s_ucTimeOutFlag = 0;
  179.        
  180.         ENABLE_INT();                                  /* 开中断 */
  181.        
  182.         while (1)
  183.         {
  184.                 /*
  185.                         等待延迟时间到
  186.                         注意:编译器认为 s_ucTimeOutFlag = 0,所以可能优化错误,因此 s_ucTimeOutFlag 变量必须申明为 volatile
  187.                 */
  188.                 if (s_ucTimeOutFlag == 1)
  189.                 {
  190.                         break;
  191.                 }
  192.         }
  193. }

  194. /*
  195. *********************************************************************************************************
  196. *        函 数 名: bsp_InitTM7705
  197. *        功能说明: 配置STM32的GPIO和SPI接口,用于连接 TM7705
  198. *        形    参: 无
  199. *        返 回 值: 无
  200. *********************************************************************************************************
  201. */
  202. void bsp_InitTM7705(void)
  203. {
  204.         GPIO_InitTypeDef GPIO_InitStructure;

  205. #ifdef SOFT_SPI                /* 软件SPI */
  206.         CS_1();
  207.         SCK_1();
  208.         DI_1();       
  209.        
  210.         /* 打开GPIO时钟 */
  211.         RCC_AHB1PeriphClockCmd(RCC_SCK | RCC_DIN | RCC_DOUT | RCC_CS | RCC_DRDY | RCC_RESET, ENABLE);
  212.        
  213.         /* 配置几个推完输出IO */
  214.         GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;                /* 设为输出口 */
  215.         GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;                /* 设为推挽模式 */
  216.         GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;        /* 上下拉电阻不使能 */
  217.         GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;        /* IO口最大速度 */

  218.         GPIO_InitStructure.GPIO_Pin = PIN_SCK;
  219.         GPIO_Init(PORT_SCK, &GPIO_InitStructure);

  220.         GPIO_InitStructure.GPIO_Pin = PIN_DIN;
  221.         GPIO_Init(PORT_DIN, &GPIO_InitStructure);

  222.         GPIO_InitStructure.GPIO_Pin = PIN_CS;
  223.         GPIO_Init(PORT_CS, &GPIO_InitStructure);

  224.         GPIO_InitStructure.GPIO_Pin = PIN_RESET;
  225.         GPIO_Init(PORT_RESET, &GPIO_InitStructure);

  226.         /* 配置GPIO为浮动输入模式(实际上CPU复位后就是输入状态) */
  227.         GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;                /* 设为输入口 */
  228.         GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;                /* 设为推挽模式 */
  229.         GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;        /* 无需上下拉电阻 */
  230.         GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;        /* IO口最大速度 */

  231.         GPIO_InitStructure.GPIO_Pin = PIN_DOUT;
  232.         GPIO_Init(PORT_DOUT, &GPIO_InitStructure);

  233.         GPIO_InitStructure.GPIO_Pin = PIN_DRDY;
  234.         GPIO_Init(PORT_DRDY, &GPIO_InitStructure);
  235.        

  236. #endif

  237.         bsp_DelayMS(10);
  238.        
  239.         TM7705_ResetHard();                /* 硬件复位 */
  240.        
  241.         /*
  242.                 在接口序列丢失的情况下,如果在DIN 高电平的写操作持续了足够长的时间(至少 32个串行时钟周期),
  243.                 TM7705 将会回到默认状态。
  244.         */       
  245.         bsp_DelayMS(5);

  246.         TM7705_SyncSPI();                /* 同步SPI接口时序 */

  247.         bsp_DelayMS(5);

  248.         /* 配置时钟寄存器 通道1*/
  249.         TM7705_WriteByte(REG_CLOCK | WRITE | CH_1);                        /* 先写通信寄存器,下一步是写时钟寄存器 */
  250.         TM7705_WriteByte(CLKDIS_0 | CLK_4_9152M | FS_50HZ);        /* 刷新速率50Hz */
  251. //        TM7705_WriteByte(CLKDIS_0 | CLK_4_9152M | FS_500HZ);        /* 刷新速率500Hz */
  252.         /* 配置时钟寄存器 通道2*/
  253.         TM7705_WriteByte(REG_CLOCK | WRITE | CH_2);                        /* 先写通信寄存器,下一步是写时钟寄存器 */
  254.         TM7705_WriteByte(CLKDIS_0 | CLK_4_9152M | FS_500HZ);        /* 刷新速率50Hz */
  255.        
  256.         /* 每次上电进行一次自校准  通道2 */
  257.         TM7705_CalibSelf(1);        /* 内部自校准 CH1 */
  258.         bsp_DelayMS(5);
  259.        
  260.                 /* 每次上电进行一次自校准 */
  261.         TM7705_CalibSelf(2);        /* 内部自校准 CH2 */
  262.         bsp_DelayMS(5);
  263. }

  264. /*
  265. *********************************************************************************************************
  266. *        函 数 名: TM7705_Delay
  267. *        功能说明: CLK之间的延迟,时序延迟. 用于STM32F407  168M主频
  268. *        形    参: 无
  269. *        返 回 值: 无
  270. *********************************************************************************************************
  271. */
  272. static void TM7705_Delay(void)
  273. {
  274.         uint16_t i;

  275.         for (i = 0; i < 5; i++);
  276. }



  277. /*
  278. *********************************************************************************************************
  279. *        函 数 名: TM7705_ResetHard
  280. *        功能说明: 硬件复位 TM7705芯片
  281. *        形    参: 无
  282. *        返 回 值: 无
  283. *********************************************************************************************************
  284. */
  285. void TM7705_ResetHard(void)
  286. {
  287.         RESET_1();
  288. //        bsp_DelayMS(1);                                                ///增大延时时间,从407 移植到429上
  289.         bsp_DelayMS(5);
  290.         RESET_0();
  291. //        bsp_DelayMS(2);
  292.         bsp_DelayMS(10);
  293.         RESET_1();
  294. //        bsp_DelayMS(1);
  295.         bsp_DelayMS(5);
  296. }

  297. /*
  298. *********************************************************************************************************
  299. *        函 数 名: TM7705_SyncSPI
  300. *        功能说明: 同步TM7705芯片SPI接口时序
  301. *        形    参: 无
  302. *        返 回 值: 无
  303. *********************************************************************************************************
  304. */
  305. static void TM7705_SyncSPI(void)
  306. {
  307.         /* AD7705串行接口失步后将其复位。复位后要延时500us再访问 */
  308.         CS_0();
  309.         TM7705_Send8Bit(0xFF);
  310.         TM7705_Send8Bit(0xFF);
  311.         TM7705_Send8Bit(0xFF);
  312.         TM7705_Send8Bit(0xFF);       
  313.         CS_1();
  314. }

  315. /*
  316. *********************************************************************************************************
  317. *        函 数 名: TM7705_Send8Bit
  318. *        功能说明: 向SPI总线发送8个bit数据。 不带CS控制。
  319. *        形    参: _data : 数据
  320. *        返 回 值: 无
  321. *********************************************************************************************************
  322. */
  323. static void TM7705_Send8Bit(uint8_t _data)
  324. {
  325.         uint8_t i;

  326.         for(i = 0; i < 8; i++)
  327.         {
  328.                 if (_data & 0x80)
  329.                 {
  330.                         DI_1();
  331.                 }
  332.                 else
  333.                 {
  334.                         DI_0();
  335.                 }
  336.                 SCK_0();
  337.                 _data <<= 1;
  338.                 TM7705_Delay();
  339.                 SCK_1();       
  340.                 TM7705_Delay();               
  341.         }
  342. }

  343. /*
  344. *********************************************************************************************************
  345. *        函 数 名: TM7705_Recive8Bit
  346. *        功能说明: 从SPI总线接收8个bit数据。 不带CS控制。
  347. *        形    参: 无
  348. *        返 回 值: 无
  349. *********************************************************************************************************
  350. */
  351. static uint8_t TM7705_Recive8Bit(void)
  352. {
  353.         uint8_t i;
  354.         uint8_t read = 0;

  355.         for (i = 0; i < 8; i++)
  356.         {
  357.                 SCK_0();
  358.                 TM7705_Delay();               
  359.                 read = read<<1;
  360.                 if (DO_IS_HIGH())
  361.                 {
  362.                         read++;
  363.                 }
  364.                 SCK_1();               
  365.                 TM7705_Delay();
  366.         }
  367.         return read;
  368. }

  369. /*
  370. *********************************************************************************************************
  371. *        函 数 名: TM7705_WriteByte
  372. *        功能说明: 写入1个字节。带CS控制
  373. *        形    参: _data :将要写入的数据
  374. *        返 回 值: 无
  375. *********************************************************************************************************
  376. */
  377. void TM7705_WriteByte(uint8_t _data)
  378. {
  379.         CS_0();
  380.         TM7705_Send8Bit(_data);
  381.         CS_1();
  382. }

  383. /*
  384. *********************************************************************************************************
  385. *        函 数 名: TM7705_Write3Byte
  386. *        功能说明: 写入3个字节。带CS控制
  387. *        形    参: _data :将要写入的数据
  388. *        返 回 值: 无
  389. *********************************************************************************************************
  390. */
  391. static void TM7705_Write3Byte(uint32_t _data)
  392. {
  393.         CS_0();
  394.         TM7705_Send8Bit((_data >> 16) & 0xFF);
  395.         TM7705_Send8Bit((_data >> 8) & 0xFF);
  396.         TM7705_Send8Bit(_data);
  397.         CS_1();
  398. }

  399. /*
  400. *********************************************************************************************************
  401. *        函 数 名: TM7705_ReadByte
  402. *        功能说明: 从AD芯片读取一个字(16位)
  403. *        形    参: 无
  404. *        返 回 值: 读取的字(16位)
  405. *********************************************************************************************************
  406. */
  407. static uint8_t TM7705_ReadByte(void)
  408. {
  409.         uint8_t read;

  410.         CS_0();
  411.         read = TM7705_Recive8Bit();
  412.         CS_1();
  413.        
  414.         return read;
  415. }

  416. /*
  417. *********************************************************************************************************
  418. *        函 数 名: TM7705_Read2Byte
  419. *        功能说明: 读2字节数据
  420. *        形    参: 无
  421. *        返 回 值: 读取的数据(16位)
  422. *********************************************************************************************************
  423. */
  424. static uint16_t TM7705_Read2Byte(void)
  425. {
  426.         uint16_t read;

  427.         CS_0();
  428.         read = TM7705_Recive8Bit();
  429.         read <<= 8;
  430.         read += TM7705_Recive8Bit();
  431.         CS_1();

  432.         return read;
  433. }

  434. /*
  435. *********************************************************************************************************
  436. *        函 数 名: TM7705_Read3Byte
  437. *        功能说明: 读3字节数据
  438. *        形    参: 无
  439. *        返 回 值: 读取到的数据(24bit) 高8位固定为0.
  440. *********************************************************************************************************
  441. */
  442. static uint32_t TM7705_Read3Byte(void)
  443. {
  444.         uint32_t read;

  445.         CS_0();
  446.         read = TM7705_Recive8Bit();
  447.         read <<= 8;
  448.         read += TM7705_Recive8Bit();
  449.         read <<= 8;
  450.         read += TM7705_Recive8Bit();
  451.         CS_1();
  452.         return read;
  453. }

  454. /*
  455. *********************************************************************************************************
  456. *        函 数 名: TM7705_WaitDRDY
  457. *        功能说明: 等待内部操作完成。 自校准时间较长,需要等待。
  458. *        形    参: 无
  459. *        返 回 值: 无
  460. *********************************************************************************************************
  461. */
  462. static void TM7705_WaitDRDY(void)
  463. {
  464.         uint32_t i;

  465.         for (i = 0; i < 4000000; i++)
  466.         {
  467.                 if (DRDY_IS_LOW())
  468.                 {
  469.                         break;
  470.                 }
  471.         }
  472.         if (i >= 4000000)
  473.         {
  474.                 printf("TM7705_WaitDRDY() Time Out ...\r\n");                /* 调试语句. 用语排错 */
  475.         }
  476. }

  477. /*
  478. *********************************************************************************************************
  479. *        函 数 名: TM7705_WriteReg
  480. *        功能说明: 写指定的寄存器
  481. *        形    参:  _RegID : 寄存器ID
  482. *                          _RegValue : 寄存器值。 对于8位的寄存器,取32位形参的低8bit
  483. *        返 回 值: 无
  484. *********************************************************************************************************
  485. */
  486. void TM7705_WriteReg(uint8_t _RegID, uint32_t _RegValue)
  487. {
  488.         uint8_t bits;

  489.         switch (_RegID)
  490.         {
  491.                 case REG_COMM:                /* 通信寄存器 */               
  492.                 case REG_SETUP:                /* 设置寄存器 8bit */
  493.                 case REG_CLOCK:                /* 时钟寄存器 8bit */
  494.                         bits = 8;
  495.                         break;

  496.                 case REG_ZERO_CH1:        /* CH1 偏移寄存器 24bit */
  497.                 case REG_FULL_CH1:        /* CH1 满量程寄存器 24bit */
  498.                 case REG_ZERO_CH2:        /* CH2 偏移寄存器 24bit */
  499.                 case REG_FULL_CH2:        /* CH2 满量程寄存器 24bit*/
  500.                         bits = 24;
  501.                         break;

  502.                 case REG_DATA:                /* 数据寄存器 16bit */
  503.                 default:
  504.                         return;
  505.         }

  506.         TM7705_WriteByte(_RegID | WRITE);        /* 写通信寄存器, 指定下一步是写操作,并指定写哪个寄存器 */

  507.         if (bits == 8)
  508.         {
  509.                 TM7705_WriteByte((uint8_t)_RegValue);
  510.         }
  511.         else        /* 24bit */
  512.         {
  513.                 TM7705_Write3Byte(_RegValue);
  514.         }
  515. }

  516. /*
  517. *********************************************************************************************************
  518. *        函 数 名: TM7705_ReadReg
  519. *        功能说明: 读指定的寄存器
  520. *        形    参:  _RegID : 寄存器ID
  521. *                          _RegValue : 寄存器值。 对于8位的寄存器,取32位形参的低8bit
  522. *        返 回 值: 读到的寄存器值。 对于8位的寄存器,取32位形参的低8bit
  523. *********************************************************************************************************
  524. */
  525. uint32_t TM7705_ReadReg(uint8_t _RegID)
  526. {
  527.         uint8_t bits;
  528.         uint32_t read;

  529.         switch (_RegID)
  530.         {
  531.                 case REG_COMM:                /* 通信寄存器 */
  532.                 case REG_SETUP:                /* 设置寄存器 8bit */
  533.                 case REG_CLOCK:                /* 时钟寄存器 8bit */
  534.                         bits = 8;
  535.                         break;

  536.                 case REG_ZERO_CH1:        /* CH1 偏移寄存器 24bit */
  537.                 case REG_FULL_CH1:        /* CH1 满量程寄存器 24bit */
  538.                 case REG_ZERO_CH2:        /* CH2 偏移寄存器 24bit */
  539.                 case REG_FULL_CH2:        /* CH2 满量程寄存器 24bit*/
  540.                         bits = 24;
  541.                         break;

  542.                 case REG_DATA:                /* 数据寄存器 16bit */
  543.                 default:
  544.                         return 0xFFFFFFFF;
  545.         }

  546.         TM7705_WriteByte(_RegID | READ);        /* 写通信寄存器, 指定下一步是写操作,并指定写哪个寄存器 */

  547.         if (bits == 16)
  548.         {
  549.                 read = TM7705_Read2Byte();
  550.         }
  551.         else if (bits == 8)
  552.         {
  553.                 read = TM7705_ReadByte();
  554.         }
  555.         else        /* 24bit */
  556.         {
  557.                 read = TM7705_Read3Byte();
  558.         }
  559.         return read;
  560. }

  561. /*
  562. *********************************************************************************************************
  563. *        函 数 名: TM7705_CalibSelf
  564. *        功能说明: 启动自校准. 内部自动短接AIN+ AIN-校准0位,内部短接到Vref 校准满位。此函数执行过程较长,
  565. *                          实测约 180ms
  566. *        形    参:  _ch : ADC通道,1或2
  567. *        返 回 值: 无
  568. *********************************************************************************************************
  569. */
  570. void TM7705_CalibSelf(uint8_t _ch)
  571. {
  572.         if (_ch == 1)
  573.         {
  574.                 /* 自校准CH1 */
  575.                 TM7705_WriteByte(REG_SETUP | WRITE | CH_1);        /* 写通信寄存器,下一步是写设置寄存器,通道1 */               
  576.                 TM7705_WriteByte(MD_CAL_SELF | __CH1_GAIN_BIPOLAR_BUF | FSYNC_0);/* 启动自校准 */
  577.                 TM7705_WaitDRDY();        /* 等待内部操作完成 --- 时间较长,约180ms */
  578.         }
  579.         else if (_ch == 2)
  580.         {
  581.                 /* 自校准CH2 */
  582.                 TM7705_WriteByte(REG_SETUP | WRITE | CH_2);        /* 写通信寄存器,下一步是写设置寄存器,通道2 */
  583.                 TM7705_WriteByte(MD_CAL_SELF | __CH2_GAIN_BIPOLAR_BUF | FSYNC_0);        /* 启动自校准 */
  584.                 TM7705_WaitDRDY();        /* 等待内部操作完成  --- 时间较长,约180ms */
  585.         }
  586. }

  587. /*
  588. *********************************************************************************************************
  589. *        函 数 名: TM7705_SytemCalibZero
  590. *        功能说明: 启动系统校准零位. 请将AIN+ AIN-短接后,执行该函数。校准应该由主程序控制并保存校准参数。
  591. *                         执行完毕后。可以通过 TM7705_ReadReg(REG_ZERO_CH1) 和  TM7705_ReadReg(REG_ZERO_CH2) 读取校准参数。
  592. *        形    参: _ch : ADC通道,1或2
  593. *        返 回 值: 无
  594. *********************************************************************************************************
  595. */
  596. ……………………

  597. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码
  1.   #include "stm32f4xx.h"
  2.         #include "uart.h"
  3.         #include "systick.h"
  4.         #include "AD7705.h"
  5.         #include "time.h"
  6. uint16_t receive_bit = 0,ADC_Value = 0,ADC_succse = 0,ADC_Value1,mm = 0,nn = 0;
  7. #define ADC_Error_MAX   10000
  8. float adc1,adc2;
  9. /*
  10.         如果ADC一直读不出来,每次读取ADC之前重新设置一下AD7705时钟寄存器和设置寄存器
  11. */
  12. /**
  13.   * @brief  主函数
  14.   * @param  无
  15.   * @retval 无
  16.   */
  17.        
  18.         /**
  19.         *        推荐使用查询发送,中断接收的方法来实现串口功能
  20.         *
  21.         *////
  22.         void GPIO_config()
  23. {
  24.         GPIO_InitTypeDef GPIO_InitStruct;
  25.         RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOH,ENABLE);
  26.         GPIO_InitStruct.GPIO_Pin = GPIO_Pin_10;
  27.         GPIO_InitStruct.GPIO_Mode = GPIO_Mode_OUT;
  28.         GPIO_InitStruct.GPIO_OType = GPIO_OType_PP;
  29.         GPIO_InitStruct.GPIO_PuPd = GPIO_PuPd_UP;
  30.         GPIO_InitStruct.GPIO_Speed = GPIO_Speed_100MHz;
  31.         GPIO_Init(GPIOH,&GPIO_InitStruct);
  32.         GPIO_SetBits(GPIOH,GPIO_Pin_10);
  33. }
  34. void delay(unsigned int x)
  35. {
  36.         while(x--);
  37. }
  38. /*
  39. 形参为ADC的通道号   采用限幅滤波算法  
  40. */
  41. uint16_t GET_ADC(uint8_t x)
  42. {
  43.                 unsigned j;
  44.                 ADC_Value = TM7705_ReadAdc(x);                        //使用AD7705ADC通道1进行检测。                       
  45.                 if(ADC_Value != 0&&mm == 0){ADC_Value1 = ADC_Value;mm = 1;}                        //第一次获取ADC
  46.                 if((ADC_Value1 - ADC_Value) < ADC_Error_MAX||(ADC_Value - ADC_Value1) < ADC_Error_MAX)
  47.                 {
  48.                         j = 0;
  49.                         ADC_Value1 = ADC_Value;                        //数据符合要求
  50.                         return ADC_Value;
  51.                 }
  52.                 else                                                 //数据不符合要求返回上次的值
  53.                 {
  54.                         j++;
  55.                         if(j >= 15){j = 0;bsp_InitTM7705();}        //连续15次读取的数据不合要求 重新初始化ADC               
  56.                         return ADC_Value1;                               
  57.                 }
  58. }
  59. int main(void)
  60. {
  61.                 int i;
  62.                 Uart_Config();
  63.                 GPIO_config();
  64.                 TIME_config();
  65.                 systick_Init();
  66.                 TM7705_ResetHard();                //上电先AD7705复位
  67.                 bsp_InitTM7705();                        //AD7705初始化
  68.                 TM7705_CalibSelf(1);                                //校准ADC通道一
  69.                 ADC_Value = TM7705_ReadAdc(1);       
  70.                 TM7705_CalibSelf(2);                                //校准ADC通道二
  71.                 ADC_Value = TM7705_ReadAdc(2);
  72.                 while(1)
  73.                 {
  74.                         i++;
  75.                         if(i >= 10)
  76.                         {
  77.                                 i = 0;               
  78.                                 adc1 = GET_ADC(1);
  79.                                 bsp_DelayMS(10);                        //读完延时一下 不要一直读取
  80.                                 adc2 = GET_ADC(2);
  81.                                 bsp_DelayMS(10);                        //读完延时一下 不要一直读取
  82.                         }                       
  83.                         if(ADC_succse == 1)
  84.                         {
  85.                                 ADC_succse = 0;
  86.                                 printf("通道1的电压值 = %fV\n",(float)adc1*5/65535);
  87.                                 bsp_DelayMS(20);                        //延时一下,防止发的过快乱码
  88.                                 printf("通道2的电压值 = %fV\n",(float)adc2*5/65535);
  89.                                 bsp_DelayMS(20);
  90.                         }
  91.                         if(ADC_Value != 0)GPIO_ResetBits(GPIOH,GPIO_Pin_10);
  92.                 }
  93. }

  94. /*********************************************END OF FILE**********************/

复制代码


所有资料51hei提供下载:
stm32f429+16位ADC AD7705.7z (364.58 KB, 下载次数: 44)


评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶1 踩
回复

使用道具 举报

沙发
ID:578991 发表于 2019-8-8 21:03 | 只看该作者
输出全是0是什么原因     还总超时  求解答
回复

使用道具 举报

板凳
ID:484359 发表于 2019-8-26 21:24 | 只看该作者
余思宇 发表于 2019-8-8 21:03
输出全是0是什么原因     还总超时  求解答

看看是不是通信的问题
回复

使用道具 举报

地板
ID:603436 发表于 2019-8-31 13:50 | 只看该作者
用3.3v供电,然后计算公式是(float)adc1*5/65535吗?这里有没有搞错呢?为什么是乘以5,不是乘以3.3??
回复

使用道具 举报

5#
ID:282095 发表于 2019-8-31 17:02 | 只看该作者
应该是有范围的吧
回复

使用道具 举报

6#
ID:484359 发表于 2019-9-17 22:14 | 只看该作者
wenfengtou 发表于 2019-8-31 13:50
用3.3v供电,然后计算公式是(float)adc1*5/65535吗?这里有没有搞错呢?为什么是乘以5,不是乘以3.3??

经过测试发现这样是对的,,你说为啥,我也不清楚。模块在用5v供电的时候会出问题,会时不时的冒出来一个很小的值,后来发现5v供电的问题,造成模块输出问题
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表