stm32单片机的红外测温MLX90614代码
- IC解密1.起始信号与停止信号:void SMBus_StartBit(void)
 - {
 -     IC解密SMBUS_SDA_H();        // 首先拉高数据线
 -    IC解密IC解密 SMBus_Delay(5);        // 延时几微妙
 -     SMBUS_SCK_H();// 拉高时钟线
 -     SMBus_Delay(5);        // 延时几微妙
 -     SMBUS_SDA_L();  // 拉低数据线
 -     SMBus_Delay(5);        // 延时几微妙
 -     //在SCK=1时,检测到SDA由1到0表示通信开始(下降沿)
 -     SMBUS_SCK_L();        // 拉低时钟线
 -     SMBus_Delay(5);        // 延时几微妙
 - }
 - void SMBus_StopBit(void)
 - {
 -    SMBUS_SCK_L();   // 拉低时钟线
 -     SMBus_Delay(5);         // 延时几微妙
 -     SMBUS_SDA_L();   // 拉低数据线
 -     SMBus_Delay(5);         // 延时几微妙
 -     SMBUS_SCK_H();   // 拉高时钟线
 -     SMBus_Delay(5);         // 延时几微妙
 -     SMBUS_SDA_H();    // 拉高数据线
 - }
 - 2.发送一个字节:
 - u8 SMBus_SendByte(u8 Tx_buffer)
 - {
 -     u8        Bit_counter;
 -     u8        Ack_bit;
 -     u8        bit_out;
 -     for(Bit_counter=8; Bit_counter; Bit_counter--)
 -     {
 -         if (Tx_buffer&0x80)//如果最高位为1
 -         {
 -             bit_out=1;   // 把最高位置1
 -         }
 -         else  //如果最高位为0
 -         {
 -             bit_out=0;  // 把最高位置0
 -         }
 -         SMBus_SendBit(bit_out);        // 把最高位发送出去
 -         Tx_buffer<<=1;// 左移一位把最高位移出去等待下一个最高位,循环8次,每次都发最高位,就可把一个字节发出去了
 -     }
 -     Ack_bit=SMBus_ReceiveBit();        // Get acknowledgment bit
 -     return        Ack_bit;
 - }
 - 3.接收一个字节:
 - u8 SMBus_ReceiveByte(u8 ack_nack)
 - {
 -     u8         RX_buffer;
 -     u8        Bit_Counter;
 -     for(Bit_Counter=8; Bit_Counter; Bit_Counter--)
 -     {
 -         if(SMBus_ReceiveBit())// Get a bit from the SDA line
 -         {
 -             RX_buffer <<= 1;// If the bit is HIGH save 1  in RX_buffer
 -             RX_buffer |=0x01;//如果Ack_bit=1,把收到应答信号1与0000 0001 进行或运算,确保为1
 -         }
 -         else
 -         {
 -             RX_buffer <<= 1;// If the bit is LOW save 0 in RX_buffer
 -             RX_buffer &=0xfe;//如果Ack_bit=1,把收到应答信号0与1111 1110 进行与运算,确保为0
 -         }
 -     }
 -     SMBus_SendBit(ack_nack);//把应答信号发出去,如果0,就进行下一次通信,如果为1,就拜拜了。
 -     return RX_buffer;
 - }
 - 4.数据校验:
 - u8 PEC_Calculation(u8 pec[])
 - {
 -     u8         crc[6];//存放多项式
 -     u8        BitPosition=47;//存放所有数据最高位,6*8=48 最高位就是47位
 -     u8        shift;
 -     u8        i;
 -     u8        j;
 -     u8        temp;
 - do
 
  
 
  芯片解密