MTF7Trailer

Macros

Line Code
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
// Class for AMC to AMC13 Trailer

#ifndef __l1t_emtf_MTF7Trailer_h__
#define __l1t_emtf_MTF7Trailer_h__

#include <vector>
#include <cstdint>

namespace l1t {
  namespace emtf {
    class MTF7Trailer {
    public:
      explicit MTF7Trailer(uint64_t dataword);

      MTF7Trailer() : crc_32(-99), lv1_id(-99), data_length(-99), format_errors(0), dataword(-99) {}

      virtual ~MTF7Trailer() {}

      void set_crc_32(int bits) { crc_32 = bits; }
      void set_lv1_id(int bits) { lv1_id = bits; }
      void set_data_length(int bits) { data_length = bits; }
      void add_format_error() { format_errors += 1; }
      void set_dataword(uint64_t bits) { dataword = bits; }

      int CRC_32() const { return crc_32; }
      int LV1_id() const { return lv1_id; }
      int Data_length() const { return data_length; }
      int Format_errors() const { return format_errors; }
      uint64_t Dataword() const { return dataword; }

    private:
      int crc_32;
      int lv1_id;
      int data_length;
      int format_errors;
      uint64_t dataword;

    };  // End class MTF7Trailer
  }  // End namespace emtf
}  // End namespace l1t

#endif /* define __l1t_emtf_MTF7Trailer_h__ */