File: sensor.h

package info (click to toggle)
openhpi 3.6.1-2.2
  • links: PTS
  • area: main
  • in suites: stretch
  • size: 25,544 kB
  • ctags: 25,275
  • sloc: ansic: 202,885; cpp: 63,639; java: 16,472; cs: 15,161; python: 11,884; makefile: 4,872; perl: 1,529; sh: 371; xml: 36; asm: 13
file content (106 lines) | stat: -rw-r--r-- 3,086 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*      -*- c++ -*-
 *
 * (C) Copyright Pigeon Point Systems. 2011
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTSENSORLITY or FITNESS FOR A PARTICULAR PURPOSE.  This
 * file and program are licensed under a BSD style license.  See
 * the Copying file included with the OpenHPI distribution for
 * full licensing terms.
 *
 * Author(s):
 *        Anton Pak <anton.pak@pigeonpoint.com>
 */

#ifndef SENSOR_H_FB2B5DD5_4E7D_49F5_9397_C2FEC21B4010
#define SENSOR_H_FB2B5DD5_4E7D_49F5_9397_C2FEC21B4010

#include <string>

#include <SaHpi.h>

#include "instrument.h"


namespace TA {


/**************************************************************
 * class cSensor
 *************************************************************/
class cSensor : public cInstrument
{
public:

    static const std::string classname;

    explicit cSensor( cHandler& handler, cResource& resource, SaHpiSensorNumT num );
    virtual ~cSensor();

public:  // HPI interface

    SaErrorT GetReading( SaHpiSensorReadingT& r, SaHpiEventStateT& s ) const;
    SaErrorT GetThresholds( SaHpiSensorThresholdsT& ths ) const;
    SaErrorT SetThresholds( const SaHpiSensorThresholdsT& ths );
    SaErrorT GetEnable( SaHpiBoolT& e ) const;
    SaErrorT SetEnable( SaHpiBoolT e );
    SaErrorT GetEventEnable( SaHpiBoolT& e ) const;
    SaErrorT SetEventEnable( SaHpiBoolT e );
    SaErrorT GetMasks( SaHpiEventStateT& amask, SaHpiEventStateT& dmask ) const;
    SaErrorT SetMasks( SaHpiSensorEventMaskActionT act,
                       SaHpiEventStateT amask,
                       SaHpiEventStateT dmask );

protected: // cObject virtual functions

    virtual void GetVars( cVars& vars );
    virtual void BeforeVarSet( const std::string& var_name );
    virtual void AfterVarSet( const std::string& var_name );

private:

    cSensor( const cSensor& );
    cSensor& operator =( const cSensor& );

private: // Handling RDR changes

    virtual void UpdateRdr( const std::string& field_name,
                            SaHpiRdrTypeUnionT& data );

private:

    virtual SaHpiCapabilitiesT RequiredResourceCap() const
    {
        return SAHPI_CAPABILITY_SENSOR;
    }

    void PostEnableChangeEvent() const;
    void PostEvent( bool assertion, SaHpiEventStateT state ) const;
    SaHpiEventStateT CalculateThresholdEventStates() const;
    void CommitChanges();

private: // data

    const SaHpiSensorRecT& m_rec;
    SaHpiBoolT             m_enabled;
    SaHpiBoolT             m_new_enabled;
    SaHpiBoolT             m_event_enabled;
    SaHpiBoolT             m_new_event_enabled;
    SaHpiSensorReadingT    m_reading;
    SaHpiEventStateT       m_prev_states;
    SaHpiEventStateT       m_states;
    SaHpiEventStateT       m_new_states;
    SaHpiEventStateT       m_amask;
    SaHpiEventStateT       m_new_amask;
    SaHpiEventStateT       m_dmask;
    SaHpiEventStateT       m_new_dmask;
    SaHpiSensorThresholdsT m_ths;
};


}; // namespace TA


#endif // SENSOR_H_FB2B5DD5_4E7D_49F5_9397_C2FEC21B4010