Brian Silverman | 425492b | 2015-12-30 15:23:55 -0800 | [diff] [blame] | 1 | #include "frc971/wpilib/pdp_fetcher.h" |
| 2 | |
Austin Schuh | 8aec1ed | 2016-05-01 13:29:20 -0700 | [diff] [blame] | 3 | #include <chrono> |
| 4 | |
John Park | 33858a3 | 2018-09-28 23:05:48 -0700 | [diff] [blame] | 5 | #include "aos/logging/queue_logging.h" |
John Park | 398c74a | 2018-10-20 21:17:39 -0700 | [diff] [blame] | 6 | #include "aos/init.h" |
John Park | 33858a3 | 2018-09-28 23:05:48 -0700 | [diff] [blame] | 7 | #include "aos/util/phased_loop.h" |
Parker Schuh | d3b7a887 | 2018-02-19 16:42:27 -0800 | [diff] [blame^] | 8 | #include "frc971/wpilib/ahal/PowerDistributionPanel.h" |
Brian Silverman | 39b339e | 2016-01-03 13:24:22 -0800 | [diff] [blame] | 9 | #include "frc971/wpilib/pdp_values.q.h" |
Brian Silverman | 425492b | 2015-12-30 15:23:55 -0800 | [diff] [blame] | 10 | |
| 11 | namespace frc971 { |
| 12 | namespace wpilib { |
| 13 | |
Brian Silverman | 425492b | 2015-12-30 15:23:55 -0800 | [diff] [blame] | 14 | void PDPFetcher::operator()() { |
| 15 | ::aos::SetCurrentThreadName("PDPFetcher"); |
Parker Schuh | d3b7a887 | 2018-02-19 16:42:27 -0800 | [diff] [blame^] | 16 | ::std::unique_ptr<frc::PowerDistributionPanel> pdp( |
| 17 | new frc::PowerDistributionPanel()); |
Brian Silverman | 25ff505 | 2016-01-02 14:13:46 -0800 | [diff] [blame] | 18 | |
Austin Schuh | 8aec1ed | 2016-05-01 13:29:20 -0700 | [diff] [blame] | 19 | ::aos::time::PhasedLoop phased_loop(::std::chrono::milliseconds(20), |
| 20 | ::std::chrono::milliseconds(4)); |
Brian Silverman | 25ff505 | 2016-01-02 14:13:46 -0800 | [diff] [blame] | 21 | |
Brian Silverman | 425492b | 2015-12-30 15:23:55 -0800 | [diff] [blame] | 22 | while (true) { |
| 23 | { |
Brian Silverman | 25ff505 | 2016-01-02 14:13:46 -0800 | [diff] [blame] | 24 | const int iterations = phased_loop.SleepUntilNext(); |
| 25 | if (iterations != 1) { |
| 26 | LOG(DEBUG, "PDPFetcher skipped %d iterations\n", iterations - 1); |
| 27 | } |
| 28 | } |
Brian Silverman | 39b339e | 2016-01-03 13:24:22 -0800 | [diff] [blame] | 29 | auto message = pdp_values.MakeMessage(); |
| 30 | message->voltage = pdp->GetVoltage(); |
| 31 | message->temperature = pdp->GetTemperature(); |
| 32 | message->power = pdp->GetTotalPower(); |
Brian Silverman | 425492b | 2015-12-30 15:23:55 -0800 | [diff] [blame] | 33 | for (int i = 0; i < 16; ++i) { |
Brian Silverman | 39b339e | 2016-01-03 13:24:22 -0800 | [diff] [blame] | 34 | message->currents[i] = pdp->GetCurrent(i); |
Brian Silverman | 425492b | 2015-12-30 15:23:55 -0800 | [diff] [blame] | 35 | } |
Brian Silverman | 39b339e | 2016-01-03 13:24:22 -0800 | [diff] [blame] | 36 | LOG_STRUCT(DEBUG, "got", *message); |
| 37 | if (!message.Send()) { |
| 38 | LOG(WARNING, "sending pdp values failed\n"); |
Brian Silverman | 425492b | 2015-12-30 15:23:55 -0800 | [diff] [blame] | 39 | } |
| 40 | } |
| 41 | } |
| 42 | |
| 43 | } // namespace wpilib |
| 44 | } // namespace frc971 |