2012-12-05 13:34:06 +01:00
|
|
|
/*
|
|
|
|
* Texas Instruments TMP105 Temperature Sensor
|
|
|
|
*
|
|
|
|
* Browse the data sheet:
|
|
|
|
*
|
|
|
|
* http://www.ti.com/lit/gpn/tmp105
|
|
|
|
*
|
|
|
|
* Copyright (C) 2012 Alex Horn <alex.horn@cs.ox.ac.uk>
|
|
|
|
* Copyright (C) 2008-2012 Andrzej Zaborowski <balrogg@gmail.com>
|
|
|
|
*
|
|
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or
|
|
|
|
* later. See the COPYING file in the top-level directory.
|
|
|
|
*/
|
|
|
|
#ifndef QEMU_TMP105_H
|
|
|
|
#define QEMU_TMP105_H
|
|
|
|
|
2013-02-05 17:06:20 +01:00
|
|
|
#include "hw/i2c/i2c.h"
|
2021-05-18 23:08:03 +02:00
|
|
|
#include "hw/sensor/tmp105_regs.h"
|
2020-09-03 22:43:22 +02:00
|
|
|
#include "qom/object.h"
|
2012-12-05 13:34:06 +01:00
|
|
|
|
2013-01-16 01:57:58 +01:00
|
|
|
#define TYPE_TMP105 "tmp105"
|
2020-09-16 20:25:19 +02:00
|
|
|
OBJECT_DECLARE_SIMPLE_TYPE(TMP105State, TMP105)
|
2013-01-16 01:57:58 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* TMP105State:
|
|
|
|
* @config: Bits 5 and 6 (value 32 and 64) determine the precision of the
|
|
|
|
* temperature. See Table 8 in the data sheet.
|
|
|
|
*
|
|
|
|
* @see_also: http://www.ti.com/lit/gpn/tmp105
|
|
|
|
*/
|
2020-09-03 22:43:22 +02:00
|
|
|
struct TMP105State {
|
2013-01-16 01:57:58 +01:00
|
|
|
/*< private >*/
|
|
|
|
I2CSlave i2c;
|
|
|
|
/*< public >*/
|
|
|
|
|
|
|
|
uint8_t len;
|
|
|
|
uint8_t buf[2];
|
|
|
|
qemu_irq pin;
|
|
|
|
|
|
|
|
uint8_t pointer;
|
|
|
|
uint8_t config;
|
|
|
|
int16_t temperature;
|
|
|
|
int16_t limit[2];
|
|
|
|
int faults;
|
|
|
|
uint8_t alarm;
|
2020-11-17 13:56:33 +01:00
|
|
|
/*
|
|
|
|
* The TMP105 initially looks for a temperature rising above T_high;
|
|
|
|
* once this is detected, the condition it looks for next is the
|
|
|
|
* temperature falling below T_low. This flag is false when initially
|
|
|
|
* looking for T_high, true when looking for T_low.
|
|
|
|
*/
|
|
|
|
bool detect_falling;
|
2020-09-03 22:43:22 +02:00
|
|
|
};
|
2013-01-16 01:57:58 +01:00
|
|
|
|
2012-12-05 13:34:06 +01:00
|
|
|
#endif
|