blob: 391c38b03211802df0264e5287bf3a7d71661354 [file] [log] [blame]
Brian Silvermanf7f267a2017-02-04 16:16:08 -08001/*----------------------------------------------------------------------------*/
2/* Copyright (c) FIRST 2016-2017. All Rights Reserved. */
3/* Open Source Software - may be modified and shared by FRC teams. The code */
4/* must be accompanied by the FIRST BSD license file in the root directory of */
5/* the project. */
6/*----------------------------------------------------------------------------*/
7
8#pragma once
9
10#include <stdint.h>
11
12#include "HAL/ChipObject.h"
13
14namespace hal {
15constexpr int32_t kNumAccumulators = tAccumulator::kNumSystems;
16constexpr int32_t kNumAnalogTriggers = tAnalogTrigger::kNumSystems;
17constexpr int32_t kNumAnalogInputs = 8;
18constexpr int32_t kNumAnalogOutputs = tAO::kNumMXPRegisters;
19constexpr int32_t kNumCounters = tCounter::kNumSystems;
20constexpr int32_t kNumDigitalHeaders = 10;
21constexpr int32_t kNumDigitalMXPChannels = 16;
22constexpr int32_t kNumDigitalSPIPortChannels = 5;
23constexpr int32_t kNumPWMHeaders = tPWM::kNumHdrRegisters;
24constexpr int32_t kNumDigitalChannels =
25 kNumDigitalHeaders + kNumDigitalMXPChannels + kNumDigitalSPIPortChannels;
26constexpr int32_t kNumPWMChannels = tPWM::kNumMXPRegisters + kNumPWMHeaders;
27constexpr int32_t kNumDigitalPWMOutputs =
28 tDIO::kNumPWMDutyCycleAElements + tDIO::kNumPWMDutyCycleBElements;
29constexpr int32_t kNumEncoders = tEncoder::kNumSystems;
30constexpr int32_t kNumInterrupts = tInterrupt::kNumSystems;
31constexpr int32_t kNumRelayChannels = 8;
32constexpr int32_t kNumRelayHeaders = kNumRelayChannels / 2;
33constexpr int32_t kNumPCMModules = 63;
34constexpr int32_t kNumSolenoidChannels = 8;
35constexpr int32_t kNumPDPModules = 63;
36constexpr int32_t kNumPDPChannels = 16;
37} // namespace hal