Arianna autonomous DAQ firmware

Dependencies:   mbed SDFileSystemFilinfo AriSnProtocol NetServicesMin AriSnComm MODSERIAL PowerControlClkPatch DS1820OW

Committer:
uci1
Date:
Tue Nov 17 04:36:52 2015 +0000
Revision:
97:9f3fe603e8b5
Parent:
96:a4b568bcfe43
Child:
98:ce72ef143b9b
S14 with conf name. Update clock set at trig start/stop. no interface chip. safety nets.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
uci1 1:e392595b4b76 1 #ifndef SN_SnConstants
uci1 1:e392595b4b76 2 #define SN_SnConstants
uci1 1:e392595b4b76 3
uci1 84:80b15993944e 4 // see this file for various switches and options
uci1 84:80b15993944e 5 // used to buid the mbed binary
uci1 84:80b15993944e 6 #include "SnPreCompOptions.h"
uci1 56:0bba0ef15697 7
uci1 1:e392595b4b76 8 #include "SnBitUtils.h"
uci1 37:ff95e7070f26 9 #include "SnCommConstants.h"
uci1 25:57b2627fe756 10
uci1 1:e392595b4b76 11 //
uci1 1:e392595b4b76 12 // constants
uci1 1:e392595b4b76 13 //
uci1 67:ec999336fcd1 14
uci1 67:ec999336fcd1 15 // this should be updated for each and every mbed board (ugh!)
uci1 86:051a09841ca3 16 //static const char kDefaultMacAdress[] = {0x00, 0x02, 0xAA, 0xAA, 0xAA, 0xAA}; // for testing SST
uci1 67:ec999336fcd1 17 //static const char kDefaultMacAdress[] = {0x00, 0x02, 0xBB, 0xBB, 0xBB, 0xBB}; // for testing ATWD
uci1 82:f2c8e2048370 18 //static const char kDefaultMacAdress[] = {0x00, 0x02, 0xF7, 0xF0, 0xAE, 0xE0}; // STN 20 (ATWD MB 1) 0002F7F0AEE0
uci1 83:a0d38ba9d6c2 19 //static const char kDefaultMacAdress[] = {0x00, 0x02, 0xF7, 0xF0, 0xC3, 0xB6}; // STN 3 (ATWD MB 5) 0002F7F0C3B6
uci1 89:62d6f72fc23d 20 //static const char kDefaultMacAdress[] = {0x00, 0x02, 0xF7, 0xF2, 0x1A, 0x8A}; // STN 18 (SST 111) 0002F7F21A8A
uci1 81:6667e2adb926 21 //static const char kDefaultMacAdress[] = {0x00, 0x02, 0xF7, 0xF0, 0xC6, 0x1A}; // STN 10 (ATWD MB 8) 0002F7F0C61A
uci1 97:9f3fe603e8b5 22 static const char kDefaultMacAdress[] = {0x00, 0x02, 0xF7, 0xF2, 0x0A, 0x9C}; // STN 14 (SST 104) 0002F7F20A9C
uci1 91:4b6e79ce9f72 23 //static const char kDefaultMacAdress[] = {0x00, 0x02, 0xF7, 0xF2, 0x02, 0xC1}; // STN 17 (SST 109) 0002F7F202C1
uci1 92:13dc55a274ce 24 //static const char kDefaultMacAdress[] = {0x00, 0x02, 0xF7, 0xF2, 0x24, 0x44}; // STN 19 (SST 105) 0002F7F22444
uci1 93:48b4c692e20e 25 //static const char kDefaultMacAdress[] = {0x00, 0x02, 0xF7, 0xF1, 0xF7, 0xA8}; // STN 15 (SST 110) 0002F7F1F7A8
uci1 94:f531e599f540 26 //static const char kDefaultMacAdress[] = {0x00, 0x02, 0xF7, 0xF2, 0x24, 0x4B}; // STN 13 (SST 102) 0002F7F2244B
uci1 95:fdbf47a66509 27 //static const char kDefaultMacAdress[] = {0x00, 0x02, 0xF7, 0xF1, 0xF6, 0x34}; // STN 31 (SST 107) 0002F7F1F634
uci1 96:a4b568bcfe43 28 //static const char kDefaultMacAdress[] = {0x00, 0x02, 0xF7, 0xF1, 0xF2, 0x1A}; // STN 32 (SST 112) 0002F7F1F21A
uci1 97:9f3fe603e8b5 29 //static const char kDefaultMacAdress[] = {0x00, 0x02, 0xF7, 0xF1, 0xF2, 0x12}; // STN 30 (SST 113) 0002F7F1F212
uci1 67:ec999336fcd1 30
uci1 40:1324da35afd4 31 // if these change, it is likely that some i/o version (config, event, etc) will need to change
uci1 83:a0d38ba9d6c2 32 static const bool kIridPwrFromAfar = false; // true if Iridium & Afar are on the same relay, false if not
uci1 1:e392595b4b76 33 static const uint32_t kBStime = 946684800u; // 1/1/2000 00:00:00 UTC
uci1 56:0bba0ef15697 34
uci1 56:0bba0ef15697 35 // these constants are used to specify the size of a specific i/o version of a frame, even if e.g. the number of samples changes for later i/o versions
uci1 56:0bba0ef15697 36 // these values should NEVER be changed!!
uci1 56:0bba0ef15697 37 // these values should be used in i/o functions
uci1 56:0bba0ef15697 38 static const uint8_t kNplasV1 = 5u; // to preserve i/o version sizes
uci1 56:0bba0ef15697 39 static const uint16_t kNsampsAtwd = 128u;
uci1 56:0bba0ef15697 40 static const uint16_t kNsampsSst = 256u;
uci1 56:0bba0ef15697 41 static const uint8_t kNchanDacsAtwd = 4u;
uci1 56:0bba0ef15697 42 static const uint8_t kNchanDacsSst = 2u;
uci1 56:0bba0ef15697 43 static const uint8_t kNchansFourAnt = 4u;
uci1 56:0bba0ef15697 44 static const uint16_t kTotSampsAtwd4ch = kNchansFourAnt*kNsampsAtwd;
uci1 56:0bba0ef15697 45 static const uint16_t kTotDacsAtwd4ch = kNchansFourAnt*kNchanDacsAtwd;
uci1 56:0bba0ef15697 46 static const uint16_t kTotSampsSst4ch = kNchansFourAnt*kNsampsSst;
uci1 56:0bba0ef15697 47 static const uint16_t kTotDacsSst4ch = kNchansFourAnt*kNchanDacsSst;
uci1 56:0bba0ef15697 48 static const uint16_t kNstopBytesSst4ch = kNsampsSst / BITS_IN_CHAR; // if the values change, may need to round this numebr
uci1 56:0bba0ef15697 49
uci1 56:0bba0ef15697 50 // these are the station config sizes, and may change. they should not be used in i/o functions. i/o versions need updating as these change!
uci1 56:0bba0ef15697 51 #if CHIPBOARD==ATWD4CH
uci1 56:0bba0ef15697 52 static const uint8_t kNchans = kNchansFourAnt;
uci1 56:0bba0ef15697 53 static const uint16_t kNsamps = kNsampsAtwd;
uci1 40:1324da35afd4 54 static const uint8_t kNplas = kNplasV1; // update config i/o version if this changes
uci1 56:0bba0ef15697 55 static const uint8_t kNchanDacs = kNchanDacsAtwd;
uci1 1:e392595b4b76 56 static const uint16_t kNoTrigPla = 0x0000u;
uci1 56:0bba0ef15697 57 static const float kAsfClkPrdUs = 8.535; // us -- change kAdcToMBtimeCut if this is <=2us
uci1 56:0bba0ef15697 58 static const float kAdcToMBtimeCut = (kNsamps*kAsfClkPrdUs)+(kAsfClkPrdUs/2.0);
uci1 56:0bba0ef15697 59 #elif CHIPBOARD==SST4CH
uci1 56:0bba0ef15697 60 static const uint8_t kNchans = kNchansFourAnt;
uci1 56:0bba0ef15697 61 static const uint16_t kNsamps = kNsampsSst;
uci1 56:0bba0ef15697 62 static const uint8_t kNchanDacs = kNchanDacsSst;
uci1 56:0bba0ef15697 63 static const uint16_t kNstopBytes = kNstopBytesSst4ch;
uci1 56:0bba0ef15697 64 static const uint8_t kAllLTC2657 = 0x73u << 1; // slave address that every LTC2657 DAC chip will respond to
uci1 56:0bba0ef15697 65 static const uint8_t kUpdateDacCmd = 0x3u; // LTC2657 DAC chip command bits that write to & update DAC value
uci1 56:0bba0ef15697 66 static const uint8_t kMaxDacSetTries = 3u; // how many times to retry setting a dac in case no ACK is received from the DAC chip
uci1 56:0bba0ef15697 67 #endif
uci1 84:80b15993944e 68 static const uint8_t kNcomms = 2u; // must match the number of comms enabled in SnPreCompOptions
uci1 84:80b15993944e 69 static const uint16_t kNvoltsAve = 500u; // must be greater than ~10 (but not checked. <2 will result in a divide by 0)
uci1 16:744ce85aede2 70
uci1 1:e392595b4b76 71 static const uint32_t kAbsMaxTimer = 1800u; // timers use integers counting us and can't go longer than ~ this many secs
uci1 3:24c5f0f50bf1 72
uci1 40:1324da35afd4 73 // NOTE: these times (in sec) must be less than kAbsMaxTimer (this is not checked, however)
uci1 84:80b15993944e 74 static const uint8_t kDefTimeoutMin = 1u; // minutes. used in case (minimum) range needs enforcing
uci1 84:80b15993944e 75 static const uint8_t kDefTimeoutSafe = 3u; // minutes. used in case a clock error is detected or max range needs enforcing
uci1 40:1324da35afd4 76 static const uint32_t kCommWinLongPrdTk = 300u; // seconds. check if it's time for a comm win every X sec. this way comm per can be longer than Timer allows
uci1 40:1324da35afd4 77
uci1 84:80b15993944e 78 // 2015-10-12: increased from 4 to 75. this raises the window before a reboot from ~1 hour to ~1 day, depending on config options
uci1 84:80b15993944e 79 static const uint16_t kMaxConsecCommFails = 75; // (exclusive) number of times a comm win can fail before the mbed resets
uci1 40:1324da35afd4 80
uci1 28:484943132bb0 81 // safety nets
uci1 40:1324da35afd4 82 static const uint16_t kMaxFirstSeq = 25000; // max specifiable seq number -- leave room to grow
uci1 28:484943132bb0 83 static const float kMinForcePer = 0.05; // seconds -- safety net for max force trigger rate
uci1 28:484943132bb0 84 static const uint16_t kMaxThrottlePerMs = 60000; // ms -- max time between thermal triggers
uci1 28:484943132bb0 85 static const uint16_t kMaxBatVoltLowPwr = 25000; // ADCs -- probably futile, but try to prevent it from being in low power mode always
uci1 40:1324da35afd4 86 static const uint32_t kMinCommWinPeriod = 120; // seconds -- min time between communication windows
uci1 28:484943132bb0 87 static const uint32_t kMaxCommWinPeriod = 259200; // seconds -- max time between communication windows
uci1 40:1324da35afd4 88 static const uint32_t kMinCommWinDur = 600; // seconds -- min communication window duration -- must be >= Ncomms*listen/connect timeout
uci1 28:484943132bb0 89 static const uint32_t kMaxWatchDogPer = 3600; // seconds -- max time before watchdog reset on idle
uci1 40:1324da35afd4 90 static const uint32_t kMinWatchDogPer = 300; // seconds -- min time before watchdog reset on idle
uci1 28:484943132bb0 91
uci1 1:e392595b4b76 92 static const uint16_t kTotSamps = kNchans*kNsamps;
uci1 56:0bba0ef15697 93 static const uint16_t kTotDacs = kNchans*kNchanDacs;
uci1 1:e392595b4b76 94
uci1 16:744ce85aede2 95
uci1 84:80b15993944e 96 enum ETrgBit_t {
uci1 84:80b15993944e 97 kThermal = BIT(0), // thermal trigger
uci1 84:80b15993944e 98 kForced = BIT(1), // forced trigger
uci1 84:80b15993944e 99 kExternal = BIT(2), // reserved for external, but impossible to set with current DAQ
uci1 84:80b15993944e 100 kSingleFreqSupp = BIT(3), // the L1 trigger to cut away events with a large fraction of power in a single frequency
uci1 84:80b15993944e 101 // bits 4,5 not yet used
uci1 84:80b15993944e 102 kL1TrgApplied = BIT(6), // whether to throw away events based on L1 triggers
uci1 84:80b15993944e 103 kAdcToMBflag = BIT(7) // flag events that took too long to get data from dCards to MB
uci1 84:80b15993944e 104 };
uci1 84:80b15993944e 105
uci1 84:80b15993944e 106 /*
uci1 84:80b15993944e 107 kThmTrg=
uci1 84:80b15993944e 108 kFrcTrg=1, // BIT 1
uci1 84:80b15993944e 109 kExtTrg=2, // BIT 2
uci1 84:80b15993944e 110 kAdcToMBflag=3, // BIT 7 **note order** (not BIT(3))
uci1 84:80b15993944e 111 // L1 triggers
uci1 84:80b15993944e 112 kSingleFreqSupp=4, // BIT 3 **note order** (not BIT(4))
uci1 84:80b15993944e 113 k
uci1 16:744ce85aede2 114
uci1 1:e392595b4b76 115 kNumTrgs
uci1 1:e392595b4b76 116 };
uci1 16:744ce85aede2 117 // order must match ESnTrgTypes
uci1 84:80b15993944e 118 static const uint8_t kTrgBW[kNumTrgs] = { BIT(0), BIT(1), BIT(2), BIT(7), BIT(3) };
uci1 84:80b15993944e 119 */
uci1 1:e392595b4b76 120
uci1 84:80b15993944e 121 enum EL1TrigStatus {
uci1 84:80b15993944e 122 kL1Fail=0,
uci1 84:80b15993944e 123 kL1Pass=1,
uci1 84:80b15993944e 124 kL1UnableToProcess=2
uci1 84:80b15993944e 125 };
uci1 1:e392595b4b76 126
uci1 0:664899e0b988 127 #endif // SN_SnConstants