M1M3 Support System
Loading...
Searching...
No Matches
HealthAndStatusFPGAData.h
1/*
2 * This file is part of LSST M1M3 support system package.
3 *
4 * Developed for the Vera C. Rubin Telescope and Site System.
5 * This product includes software developed by the LSST Project
6 * (https://www.lsst.org).
7 * See the COPYRIGHT file at the top-level directory of this distribution
8 * for details of code ownership.
9 *
10 * This program is free software: you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation, either version 3 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program. If not, see <https://www.gnu.org/licenses/>.
22 */
23
24#ifndef LSST_M1M3_SS_FPGA_HealthAndStatusFPGAData_H_
25#define LSST_M1M3_SS_FPGA_HealthAndStatusFPGAData_H_
26
27#include <stdint.h>
28
29namespace LSST {
30namespace M1M3 {
31namespace SS {
32
33// number of Modbus ports
34const int PORTNUM = 5;
35// Number of counters/flags per port
36const int PORT_COUNTNUM = 6;
37
42public:
43 ModbusPort();
44
48 void fillFromFIFO(uint64_t *buffer);
49
50 // flag's constants
51 const uint64_t TxInternalFIFOOverflow = 0x01;
52
53 uint64_t errorFlag;
54 uint64_t txBytes;
55 uint64_t txFrames;
56 uint64_t rxBytes;
57 uint64_t rxFrames;
58 uint64_t instructionCount;
59};
60
65public:
67
73 void refresh(uint64_t buffer[PORTNUM * PORT_COUNTNUM]);
74
75 ModbusPort ports[PORTNUM];
76};
77
78} // namespace SS
79} // namespace M1M3
80} // namespace LSST
81
82#endif // !LSST_M1M3_SS_FPGA_HealthAndStatusFPGAData_H_
Health and status reader.
Definition HealthAndStatusFPGAData.h:64
void refresh(uint64_t buffer[PORTNUM *PORT_COUNTNUM])
Reads data from FIFO, populates local variables.
Definition HealthAndStatusFPGAData.cpp:42
A single modbus port data.
Definition HealthAndStatusFPGAData.h:41
void fillFromFIFO(uint64_t *buffer)
Fill values from FIFO buffer.
Definition HealthAndStatusFPGAData.cpp:33