mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-28 03:00:25 +08:00
154 lines
5.4 KiB
C
154 lines
5.4 KiB
C
//###########################################################################
|
|
//
|
|
// FILE: F2837xD_TempSensorConv.c
|
|
//
|
|
// TITLE: F2837xD Temperature Sensor Conversion Functions
|
|
//
|
|
//###########################################################################
|
|
// $TI Release: F2837xD Support Library v3.05.00.00 $
|
|
// $Release Date: Tue Jun 26 03:15:23 CDT 2018 $
|
|
// $Copyright:
|
|
// Copyright (C) 2013-2018 Texas Instruments Incorporated - http://www.ti.com/
|
|
//
|
|
// Redistribution and use in source and binary forms, with or without
|
|
// modification, are permitted provided that the following conditions
|
|
// are met:
|
|
//
|
|
// Redistributions of source code must retain the above copyright
|
|
// notice, this list of conditions and the following disclaimer.
|
|
//
|
|
// Redistributions in binary form must reproduce the above copyright
|
|
// notice, this list of conditions and the following disclaimer in the
|
|
// documentation and/or other materials provided with the
|
|
// distribution.
|
|
//
|
|
// Neither the name of Texas Instruments Incorporated nor the names of
|
|
// its contributors may be used to endorse or promote products derived
|
|
// from this software without specific prior written permission.
|
|
//
|
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
// $
|
|
//###########################################################################
|
|
|
|
//
|
|
// Included Files
|
|
//
|
|
#include "F2837xD_device.h"
|
|
#include "F2837xD_Examples.h"
|
|
|
|
//
|
|
// Defines
|
|
//
|
|
#define FP_SCALE 32768 //Scale factor for Q15 fixed point numbers (2^15)
|
|
#define FP_ROUND FP_SCALE/2 //Added to Q15 numbers before converting to
|
|
//integer to round the number.
|
|
#define KELVIN 273 // Amount to add to Q15 fixed point numbers
|
|
// to shift from Celsius to Kelvin
|
|
// (Converting guarantees number is
|
|
// positive, which makes rounding more
|
|
// efficient)
|
|
#define KELVIN_OFF FP_SCALE*KELVIN
|
|
#define getTempSlope() (*(int (*)(void))0x7036E)() //Slope of temperature sensor
|
|
//(deg. C / ADC code).
|
|
//Stored in fixed point Q15
|
|
//format.
|
|
#define getTempOffset() (*(int (*)(void))0x70372)() //ADC code corresponding to
|
|
//temperature sensor output
|
|
//at 0 deg. C
|
|
|
|
//
|
|
// Globals
|
|
//
|
|
float32 tempSensor_tempSlope;
|
|
float32 tempSensor_tempOffset;
|
|
float32 tempSensor_scaleFactor;
|
|
|
|
//
|
|
// InitTempSensor - Initialize the temperature sensor by powering up the
|
|
// sensor, loading the calibration values from OTP to RAM,
|
|
// and recording the intended VREFHI voltage.
|
|
// Note: This function doesn't support VREFLO != 0.0V,
|
|
// but this could be implemented if desired.
|
|
//
|
|
void InitTempSensor(float32 vrefhi_voltage)
|
|
{
|
|
EALLOW;
|
|
|
|
//
|
|
//power up the the temperature sensor
|
|
//
|
|
AnalogSubsysRegs.TSNSCTL.bit.ENABLE = 1;
|
|
|
|
//
|
|
//delay to allow the sensor to power up
|
|
//
|
|
DELAY_US(1000);
|
|
|
|
EDIS;
|
|
|
|
//
|
|
//need to remember VREFHI voltage so that sensor readings can be scaled
|
|
//to match 2.5V values used for calibration data.
|
|
//
|
|
tempSensor_scaleFactor = vrefhi_voltage;
|
|
|
|
//
|
|
//check the device revision
|
|
//
|
|
if(DevCfgRegs.REVID >= 3)
|
|
{
|
|
//
|
|
//for production devices (Rev. C), pull the slope and offset from OTP
|
|
//
|
|
tempSensor_tempSlope = (int32)getTempSlope();
|
|
tempSensor_tempOffset = getTempOffset();
|
|
}
|
|
else
|
|
{
|
|
//
|
|
//for pre-production devices, use these static values for slope
|
|
//and offset
|
|
//
|
|
tempSensor_tempSlope = 5196;
|
|
tempSensor_tempOffset = 1788;
|
|
}
|
|
}
|
|
|
|
//
|
|
// GetTemperatureC - This function uses the reference data stored in OTP to
|
|
// convert the raw temperature sensor reading into degrees C
|
|
//
|
|
int16 GetTemperatureC(int16 sensorSample)
|
|
{
|
|
sensorSample = (int16)((tempSensor_scaleFactor/2.5)*(sensorSample));
|
|
|
|
return (((sensorSample - tempSensor_tempOffset)*tempSensor_tempSlope +
|
|
FP_ROUND + KELVIN_OFF)/FP_SCALE - KELVIN);
|
|
}
|
|
|
|
//
|
|
// GetTemperatureK - This function uses the reference data stored in OTP to
|
|
// convert the raw temperature sensor reading into degrees K
|
|
//
|
|
int16 GetTemperatureK(int16 sensorSample)
|
|
{
|
|
sensorSample = (int16)((2.5/tempSensor_scaleFactor)*(sensorSample));
|
|
|
|
return (((sensorSample - tempSensor_tempOffset)*tempSensor_tempSlope +
|
|
FP_ROUND + KELVIN_OFF)/FP_SCALE);
|
|
}
|
|
|
|
//
|
|
// End of file
|
|
//
|