STM32程序之MAX6675热电偶温度读取

STM32程序之MAX6675热电偶温度读取,第1张

第一次编写STM32程序,有很多问题请教,我想把MAX6675的SO的数据读出来转换成实际温度,用串口工具读出来。

电路是标准的SPI接法,SO没有上拉电阻

MISO脚配置为浮空,没有做内部上拉。

用HAL很简单,CS拉低以后,一个SPI读两个字节进来,然后就是凑成12位,换算。

MAX6675文档强调是在时钟下降沿读取数据,因此将SPI2配置为:

[cpp] view plain copyhspi2.Init.CLKPolarity = SPI_POLARITY_LOW;

hspi2.Init.CLKPhase = SPI_PHASE_2EDGE;

hspi2.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_128;

端口定义根据实际进行修改,这里使用了spi2

[cpp] view plain copy/*

*

* max667.h

*/

#ifndef _MAX6675_H

#define _MAX667_H

#include “stm32f1xx_hal.h”

#include “pinname.h”

#define K_PORT GPIOC

typedef struct {

int16_t v;

int8_t error;

} K_Value;

K_Value read_k(void);

#endif

不考虑前导D15,只是直接读。

[cpp] view plain copy/*

* max6675.c

*

*/

#include “max6675.h”

extern SPI_HandleTypeDef hspi2;

K_Value read_k(void)

{

uint8_t data_temp[2]; // [0] 高位 [1]低位

K_Value k;

// 拉低

HAL_GPIO_WritePin(K_PORT, K_CS, GPIO_PIN_RESET);

// 读取

HAL_SPI_Receive(&hspi2, &data_temp[0], 2, 1);

// D2 low: 正常 high: 开路

if (data_temp[1] & 0x4) {

// printf(“No Probe ”);

k.v = 0;

k.error = 1;

}

else {

k.v = (int16_t)(( (data_temp[0] 《《 5) | (data_temp[1] 》》 3) ) * 0.25);

k.error = 0;

}

// 拉高

HAL_GPIO_WritePin(K_PORT, K_CS, GPIO_PIN_SET);

return k;

}

使用一个结构体,返回K的状态和读数。

因为热电偶是电阻测量,因此热电偶和MAX6675之间的连接必须可靠,连接处的电阻会影响读数。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/dianzi/2642150.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-08-12
下一篇 2022-08-12

发表评论

登录后才能评论

评论列表(0条)

保存