第一次编写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之间的衔接有必要牢靠,衔接处的电阻会影响读数。