From ef5d3b978a30447f13a4423d70a5da0970091d10 Mon Sep 17 00:00:00 2001
From: marcofilho <marco.filho@ess.eu>
Date: Tue, 3 Dec 2024 09:34:51 +0100
Subject: [PATCH] Remove all files that should be on API

---
 vmmTbl.Makefile                 |   4 -
 vmmTblApp/src/VmmTblAPI.cpp     | 446 ------------------
 vmmTblApp/src/VmmTblAPI.h       |  44 --
 vmmTblApp/src/VmmTblRegsMap.cpp | 807 --------------------------------
 vmmTblApp/src/VmmTblRegsMap.h   |   6 -
 vmmTblApp/src/hybrid.cpp        |  27 --
 vmmTblApp/src/hybrid.h          |  23 -
 vmmTblApp/src/vmm3a.cpp         | 206 --------
 vmmTblApp/src/vmm3a.h           |  37 --
 vmmTblApp/src/vmm_params.h      |   9 -
 10 files changed, 1609 deletions(-)
 delete mode 100644 vmmTblApp/src/VmmTblAPI.cpp
 delete mode 100644 vmmTblApp/src/VmmTblAPI.h
 delete mode 100644 vmmTblApp/src/VmmTblRegsMap.cpp
 delete mode 100644 vmmTblApp/src/VmmTblRegsMap.h
 delete mode 100644 vmmTblApp/src/hybrid.cpp
 delete mode 100644 vmmTblApp/src/hybrid.h
 delete mode 100644 vmmTblApp/src/vmm3a.cpp
 delete mode 100644 vmmTblApp/src/vmm3a.h
 delete mode 100644 vmmTblApp/src/vmm_params.h

diff --git a/vmmTbl.Makefile b/vmmTbl.Makefile
index 2b52e6a..f0c68b1 100644
--- a/vmmTbl.Makefile
+++ b/vmmTbl.Makefile
@@ -11,11 +11,7 @@ TMPS += $(APPDB)/hybrid.template
 TMPS += $(APPDB)/vmm_tbl.template
 SUBS = $(APPDB)/channels.sub
 
-SOURCES += $(APPSRC)/hybrid.cpp
-SOURCES += $(APPSRC)/vmm3a.cpp
-SOURCES += $(APPSRC)/VmmTblAPI.cpp
 SOURCES += $(APPSRC)/vmm_tbl.cpp
-SOURCES += $(APPSRC)/VmmTblRegsMap.cpp
 
 DBDS    += $(APPSRC)/vmm_tbl.dbd
 
diff --git a/vmmTblApp/src/VmmTblAPI.cpp b/vmmTblApp/src/VmmTblAPI.cpp
deleted file mode 100644
index 77b69cd..0000000
--- a/vmmTblApp/src/VmmTblAPI.cpp
+++ /dev/null
@@ -1,446 +0,0 @@
-#include "VmmTblAPI.h"
-#include <sstream>
-#include <bitset>
-#include <algorithm>
-#include <chrono>
-#include <thread>
-#include <array>
-
-#include "FrontEndBase.h"
-
-void delayMilliseconds(int milliseconds) {
-  std::this_thread::sleep_for(std::chrono::milliseconds(milliseconds));
-}
-
-VmmTblAPI::VmmTblAPI(RMMAPI* rmmApi, int ring, int node, std::string name)
-        : FrontEndBase(rmmApi, ring, node, name)
-{
-}
-
-VmmTblAPI::~VmmTblAPI() {
-}
-
-void VmmTblAPI::acquire(bool acquire) {
-  if (acquire) {
-    enableAcquisition(false);
-    sendAll(true);
-    enableAcquisition(true);
-  } else {
-    enableAcquisition(false);
-  }
-}
-
-void VmmTblAPI::sendAll(bool useConfigCheck) {
-  configFE();
-  for(int hybrid = 0; hybrid <= HYBRIDS_PER_FEN; hybrid++) {
-    if (isHybridEnabled(hybrid)) {
-      configHybrid(hybrid);
-
-      for(int vmm = 0; vmm < VMMS_PER_HYBRID; vmm++) {
-        configVMM(hybrid, vmm, useConfigCheck);
-      }
-    }
-  }
-}
-
-void VmmTblAPI::enableAcquisition(bool enabled) {
-  userRegWrite("app_acq_enable", enabled);
-  userRegWrite("sc_acq_on_off", 0x00000000);
-  userRegWrite("sc_acq_on_off", 0x00000001);
-  userRegWrite("sc_acq_on_off", 0x00000000);
-}
-
-std::string VmmTblAPI::checkLinkStatus(int hyb) {
-  uint32_t result = readWriteRegs("sc_app_link_status", 0, "app_link_status");
-  int pos = 7 - hyb;
-  return intToHexString(result).substr(pos, 1);
-}
-
-void VmmTblAPI::configFE() {
-  userRegWrite("app_debug_data_format", 0);
-  userRegWrite("app_latency_reset", 27);
-  userRegWrite("app_latency_data_max", 1024);
-  userRegWrite("app_latency_data_jitter", 0);
-  userRegWrite("app_tp_offset_first", 100);
-  userRegWrite("app_tp_offset", 1000);
-  userRegWrite("app_tp_latency", 46);
-  userRegWrite("app_tp_number", 1);
-  userRegWrite("app_chmask", getChMap());
-  userRegWrite("sc_cfg_app", 0x00000000);
-  userRegWrite("sc_cfg_app", 0x00000001);
-  userRegWrite("sc_cfg_app", 0x00000000);
-}
-
-uint16_t VmmTblAPI::getChMap() {
-  std::string chMapString = "0000000000000000";
-  for (int hybrid = 0; hybrid < HYBRIDS_PER_FEN; hybrid++) {
-    if (isHybridEnabled(hybrid)) {
-      for (int vmm = 0; vmm < VMMS_PER_HYBRID; vmm++) {
-        chMapString.replace(15 - (hybrid * 2 + vmm), 1, "1");
-      }
-    }
-  }
-  uint16_t chMap = std::stoi(chMapString, nullptr, 2);
-  return chMap;
-}
-
-bool VmmTblAPI::enableHybrid(int hybrid, bool onOff) {
-  if(hybrid < HYBRIDS_PER_FEN) {
-    enabled_hybrids[hybrid] = onOff;
-    return true;
-  } else return false;
-}
-
-bool VmmTblAPI::isHybridEnabled(int hybrid) {
-  if(hybrid < HYBRIDS_PER_FEN) return enabled_hybrids[hybrid];
-  else return false;
-}
-
-Hybrid& VmmTblAPI::getHybrid(int index) {
-  if (index < 0 || index >= HYBRIDS_PER_FEN)
-    throw std::out_of_range("Invalid hybrid index");
-  return hybrids[index];
-}
-
-void VmmTblAPI::configHybrid(int hybrid_index) {
-  std::array<std::string, 3> registers = {"hyb_tp_skew0", "hyb_tp_width0", "hyb_tp_polarity0"};
-
-  for (const auto& reg : registers) {
-    unsigned short result = 0;
-    hybrids[hybrid_index].getRegister(reg, result);
-    userRegWrite(reg + std::to_string(hybrid_index), result);
-  }
-
-  uint32_t value = (1 << hybrid_index);
-  userRegWrite("sc_cfg_hyb", 0x0);
-  userRegWrite("sc_cfg_hyb", value);
-  userRegWrite("sc_cfg_hyb", 0x0);
-}
-
-std::string VmmTblAPI::readFwVersion(int hyb) {
-  uint32_t result = readWriteRegs("sc_i2c_firmware_version",
-                                  hyb,
-                                  "hyb_i2c_firmware_version0" + std::to_string(hyb));
-  return intToHexString(result);
-}
-
-std::string VmmTblAPI::readGeoPos(int hyb) {
-  uint32_t result = readWriteRegs("sc_i2c_geo_id", hyb, "hyb_i2c_geoid0" + std::to_string(hyb));
-  return intToHexString(result).substr(6);
-}
-
-std::string VmmTblAPI::readIDChip(int hyb) {
-  std::string full_string;
-  uint32_t result = 0;
-  result = readWriteRegs("sc_i2c_hybrid_id", hyb, "hyb_i2c_hybrid_id00" + std::to_string(hyb));
-  full_string += intToHexString(result);
-  result = readWriteRegs("sc_i2c_hybrid_id", hyb, "hyb_i2c_hybrid_id10" + std::to_string(hyb));
-  full_string += intToHexString(result);
-  result = readWriteRegs("sc_i2c_hybrid_id", hyb, "hyb_i2c_hybrid_id20" + std::to_string(hyb));
-  full_string += intToHexString(result);
-  result = readWriteRegs("sc_i2c_hybrid_id", hyb, "hyb_i2c_hybrid_id30" + std::to_string(hyb));
-  full_string += intToHexString(result);
-  return full_string;
-}
-
-
-bool VmmTblAPI::configVMM(int hybrid_index, int vmm_index, bool enableConfigCheck)
-{
-  bool result = true;
-  bool ok;
-
-  std::vector<std::string> globalRegisters;
-  globalRegisters.clear();
-  fillGlobalRegisters(globalRegisters, hybrid_index,  vmm_index);
-  
-  std::cout << "Global Registers:" << std::endl;
-    for (const auto& reg : globalRegisters) {
-      std::cout << reg << std::endl;
-    }
-  
-  if(globalRegisters.size()!=3){
-    std::cout << "ERROR Global SPI does not have 3 words" << std::endl;
-    return -1;
-  }
-
-  std::vector<std::string> channelRegisters;
-  channelRegisters.clear();
-  fillChRegisters(channelRegisters, hybrid_index,  vmm_index);
-  if(channelRegisters.size() != 64){
-    std::cout << "ERROR Channel registers do not have 64 values" << std::endl;
-    return -1;
-  }
-
-  std::vector<std::string> globalRegisters2;
-  globalRegisters2.clear();
-  fillGlobalRegisters2(globalRegisters2, hybrid_index,  vmm_index);
-  if(globalRegisters2.size()!=3){
-      std::cout << "ERROR Global SPI does not have 3 words" << std::endl;
-      return -1;
-  }
-
-  int idx = hybrid_index * 2 + vmm_index;
-  std::string sVmmIndex = "99";
-  if(idx < 10) sVmmIndex = "0" + std::to_string(idx);
-  else if(idx < 16) sVmmIndex = std::to_string(idx);
-  
-  bool g_use_config_check = true;
-  if(g_use_config_check) {
-    //reset I2C address 65 register 0
-    if(enableConfigCheck) {
-      // TODO: Check with we need that (the enableConfigCheck is always false in the VMM code) 
-      //uint32_t value = (1 << hybrid_index);
-      //ESS_WriteSc("sc_i2c_reset_config_check", 0x00000000, ok);
-      //ESS_WriteSc("sc_i2c_reset_config_check", value, ok);
-      //ESS_WriteSc("sc_i2c_reset_config_check", 0x00000000, ok);
-    }
-  }
-
-  unsigned int firstGlobalRegSPI_2 = 0;
-  unsigned int lastGlobalRegSPI_2 = 2;
-  unsigned int firstGlobalRegSPI_1 = 67;
-  unsigned int lastGlobalRegSPI_1 = 69;
-
-  // global SPI / VMM3: global bank 0
-  for(unsigned int i = firstGlobalRegSPI_2; i <= lastGlobalRegSPI_2; i++) {
-    std::string param = "vmm_global_bank2_sp" + std::to_string(i - firstGlobalRegSPI_2) + sVmmIndex;
-    uint32_t value = std::stoul(globalRegisters2[i - firstGlobalRegSPI_2], nullptr, 2);
-    userRegWrite(param, value);
-  }
-
-  //channel SPI
-  for(unsigned int i = 0; i < CHANNELS_PER_VMM; i++) {
-    std::string position_str = std::to_string(i);
-    if (position_str.size() == 1) position_str = "0" + position_str;
-    std::string param = "vmm_ch" + position_str + sVmmIndex;
-    uint32_t value = std::stoul(channelRegisters[i], nullptr, 2);
-    std::cout << "param: " << param << std::endl;
-    userRegWrite(param, value);
-  }
-
-  // global SPI / VMM3: global bank 1
-  for(unsigned int i = firstGlobalRegSPI_1; i <= lastGlobalRegSPI_1; i++) {
-    std::string param = "vmm_global_bank1_sp" + std::to_string(i - firstGlobalRegSPI_1) + sVmmIndex;
-    uint32_t value = std::stoul(globalRegisters[i - firstGlobalRegSPI_1], nullptr, 2);
-    userRegWrite(param, value);
-  }
-
-  uint32_t value = (1 << idx);
-  userRegWrite("sc_cfg_vmm", 0x00000000);
-  userRegWrite("sc_cfg_vmm", value);
-  userRegWrite("sc_cfg_vmm", 0x00000000);
-  
-  return result;
-}
-
-void VmmTblAPI::fillGlobalRegisters(std::vector<std::string>& global, int hybrid_index, int vmm_index)
-{
-  unsigned short result;
-
-  global.clear();
-  int sequence = 0;
-  
-  // GLOBAL SPI 0
-  std::string spi0 = "00000000000000000000000000000000";
-
-  //[0,3] reserved
-  sequence += 4;
-
-  // Function to replace a bit in the spi0 string with a value from VMM settings
-  auto replaceVMMBit = [&](int index, const std::string& settingName) {
-    // Convert value to '1' if it's not zero, otherwise '0'
-    hybrids[hybrid_index].getVMM(vmm_index).getRegister(settingName, result);
-    spi0[index] = '0' + (result != 0); 
-  };
-
-  const std::vector<std::string> settings = {"slvs", "s32", "stcr", "ssart", "srec", "stlc", "sbip", "srat", "sfrst",
-                                            "slvsbc", "slvstp", "slvstk", "slvsdt", "slvsart", "slvstki", "slvsena",
-                                            "slvs6b", "slh", "slxh", "stgc", "reset1", "reset2"};
-
-  for (const auto& setting : settings) {
-    if (setting == "reset1") sequence += 5; //[25,29] not used
-    replaceVMMBit(sequence, setting);
-    sequence++;
-  }
-
-  global.push_back(spi0);
-
-  // GLOBAL SPI 1
-  // Define a function to populate spi string based on VMM settings
-  auto populateSPI1 = [&](const std::vector<std::pair<std::string, int>>& settings) {
-    std::string spi;
-    int sequence = 0;
-    for (const auto& setting : settings) {
-      hybrids[hybrid_index].getVMM(vmm_index).getRegister(setting.first, result);
-      std::string binary_string = std::bitset<16>(result).to_string().substr(16 - setting.second);
-
-      if (setting.first == "sdt") {
-        // Populate threshold DAC lowest 6 bits
-        for (int i = 4; i < 10; ++i) spi += binary_string[i];
-      } else spi += binary_string;
-      sequence += setting.second;
-    }
-
-    // Append '0' to the end of spi to reserve the last bit: [31] reserved
-    spi += '0';
-
-    // Push back the populated spi string to the global vector
-    global.push_back(spi);
-  };
-
-  // Populate SPI 1 settings
-  populateSPI1({{"sdt", 10},{"sdp10", 10}, {"sc10b", 2}, {"sc8b", 2},
-                {"sc6b", 3}, {"s8b", 1}, {"s6b", 1}, {"s10b", 1},
-                {"sdcks", 1}, {"sdcka", 1}, {"sdck6b", 1}, {"sdrv", 1},
-                {"stpp", 1}});
-
-  // GLOBAL SPI 2
-  // Define a function to populate spi string based on VMM settings
-  auto populateSPI2 = [&](const std::vector<std::pair<std::string, int>>& settings) {
-    std::string spi;
-    int sequence = 0;
-
-    for (const auto& setting : settings) {
-      hybrids[hybrid_index].getVMM(vmm_index).getRegister(setting.first, result);
-      std::string binary_string = std::bitset<16>(result).to_string().substr(16 - setting.second);
-      if (setting.first == "sdt") {
-        // Populate threshold DAC highest 4 bits
-        for (int i = 0; i < 4; ++i) {
-          spi += binary_string[i];
-          sequence++;
-        }
-      } else {
-        spi += binary_string;
-        sequence += setting.second;
-      }
-    }
-    // Push back the populated spi string to the global vector
-    global.push_back(spi);
-  };
-
-  // Populate SPI 2 settings
-  populateSPI2({{"sp", 1}, {"sdp", 1}, {"sbmx", 1}, {"sbft", 1}, {"sbfp", 1},
-                {"sbfm", 1}, {"slg", 1}, {"sm5_sm0", 6}, {"scmx", 1}, {"sfa", 1},
-                {"sfam", 1}, {"st", 2}, {"sfm", 1}, {"sg", 3}, {"sng", 1}, {"stot", 1},
-                {"sttt", 1}, {"ssh", 1}, {"stc", 2}, {"sdt", 10}});
-
-}
-
-void VmmTblAPI::fillChRegisters(std::vector<std::string>& registers, int hybrid_index, int vmm_index)
-{
-  registers.clear();
-  unsigned short result;
-
-  auto populateRegisters = [&](const std::vector<std::pair<std::string, int>>& regs, int channel) {
-    std::string _reg = "00000000";
-    int sequence = 8;
-
-    for (const auto& reg : regs) {
-      hybrids[hybrid_index].getVMM(vmm_index).getRegister(reg.first, channel, result);
-      std::string binary_string = std::bitset<16>(result).to_string().substr(16 - reg.second);
-      if (reg.first == "sd" || reg.first == "sz10b" ||
-          reg.first == "sz08b" || reg.first == "sz06b") {
-        //According to ATLAS software, has to be reversed
-        std::reverse(binary_string.begin(), binary_string.end());
-      }
-      _reg += binary_string;
-      sequence += reg.second;
-    }
-
-    // Append '0' to the end of spi to reserve the last bit: [31] reserved
-    _reg += "0";
-
-    // Push back the populated _reg string to the registers vector
-    registers.push_back(_reg);
-  };
-
-  std::vector<std::pair<std::string, int>> registers_map = {{"sc", 1}, {"sl", 1}, {"st", 1},
-                                                        {"sth", 1}, {"sm", 1}, {"smx", 1},
-                                                        {"sd", 5}, {"sz10b", 5}, {"sz08b", 4},
-                                                        {"sz06b", 3}};
-
-  for(int ch = 0; ch < CHANNELS_PER_VMM; ch++) {
-    populateRegisters(registers_map, ch);
-  }
-}
-
-void VmmTblAPI::fillGlobalRegisters2(std::vector<std::string>& global, int hybrid_index, int vmm_index)
-{
-  unsigned short result;
-  int sequence = 0;
-
-  // GLOBAL SPI 0
-  std::string spi0 = "00000000000000000000000000000000";
-  //[0,30] not used
-  sequence+=31;
-
-  // magic number on BCID [31]
-  hybrids[hybrid_index].getVMM(vmm_index).getRegister("nskipm_i", result);
-  spi0.replace(sequence, 1, std::to_string(result));
-  
-  global.push_back(spi0);
-
-  // GLOBAL SPI 1
-  std::string spi1 = "00000000000000000000000000000000";
-  hybrids[hybrid_index].getVMM(vmm_index).getRegister("sL0cktest", result);
-  // clocks when L0 core disabled [0]
-  spi1.replace(sequence, 1, std::to_string(result));
-  sequence++;
-
-  //invert DCK [1]
-  hybrids[hybrid_index].getVMM(vmm_index).getRegister("sL0dckinv", result);
-  spi1.replace(sequence, 1, std::to_string(result));
-  sequence++;
-
-  //invert BCCLK [2]
-  hybrids[hybrid_index].getVMM(vmm_index).getRegister("sL0ckinv", result);
-  spi1.replace(sequence, 1, std::to_string(result));
-  sequence++;
-
-  //L0 core
-  hybrids[hybrid_index].getVMM(vmm_index).getRegister("sL0ena", result);
-  spi1.replace(sequence, 1, std::to_string(result));
-  sequence++;
-
-  global.push_back(spi1);
-
-  // GLOBAL SPI 2
-  std::string spi2 = "00000000000000000000000000000000";
-  global.push_back(spi2);
-}
-
-int VmmTblAPI::readADC(int hybrid_index, int vmm_index) {
-  int adc_result = 0;
-  int vmm = hybrid_index * 2 + vmm_index;
-  std::string sVmmIndex = "99";
-  if(vmm < 10) sVmmIndex = "0" + std::to_string(vmm);
-  else if(vmm < 16) sVmmIndex = std::to_string(vmm);
-
-  uint32_t result = readWriteRegs("sc_i2c_vmm_adc", vmm, "vmm_i2c_adc" + sVmmIndex);
-  adc_result = (result & 0xFFFF) >> 4; // bit shift
-
-  unsigned short sp_value = 0;
-  hybrids[hybrid_index].getVMM(vmm_index).getRegister("sp", sp_value);
-  unsigned sm5_sm0_value = 0;
-  hybrids[hybrid_index].getVMM(vmm_index).getRegister("sm5_sm0", sp_value);
-
-  if((sp_value != 0) && (sm5_sm0_value == 1)) adc_result = 1200 - adc_result;
-
-  return adc_result;
-}
-
-uint32_t VmmTblAPI::readWriteRegs(std::string command_reg, int index, std::string read_reg) {
-  unsigned int data = 0x00000000;
-  userRegWrite(command_reg, data);
-  data = (1 << index);
-  userRegWrite(command_reg, data);
-
-  //Do not read registers back too soon, otherwise old ADC value is read
-  delayMilliseconds(7);
-
-  uint32_t value = userRegRead(read_reg);
-  userRegWrite(command_reg, 0x0);
-
-  return value;
-}
-
diff --git a/vmmTblApp/src/VmmTblAPI.h b/vmmTblApp/src/VmmTblAPI.h
deleted file mode 100644
index 3a50365..0000000
--- a/vmmTblApp/src/VmmTblAPI.h
+++ /dev/null
@@ -1,44 +0,0 @@
-#pragma once
-
-#include <vector>
-#include <string>
-#include <map>
-#include <vector>
-#include <memory>
-#include <iostream>
-
-#include "FrontEndBase.h"
-#include "FrontEndFactory.h"
-#include "VmmTblRegsMap.h"
-
-#include "hybrid.h"
-
-class VmmTblAPI : public FrontEndBase {
-public:
-  VmmTblAPI(RMMAPI* rmmApi, int ring, int node, std::string name);
-  ~VmmTblAPI();
-  void configHybrid(int hybrid_index);
-  bool configVMM(int hybrid_index, int vmm_index, bool enableConfigCheck=false);
-  void fillGlobalRegisters(std::vector<std::string>& global, int hybrid_index, int vmm_index);
-  void fillGlobalRegisters2(std::vector<std::string>& global, int hybrid_index, int vmm_index);
-  void fillChRegisters(std::vector<std::string>& registers, int hybrid_index, int vmm_index);
-  int readADC(int hybrid_index, int vmm_index);
-  Hybrid& getHybrid(int index);
-  bool enableHybrid(int hybrid, bool onOff);
-  bool isHybridEnabled(int hybrid);
-  void acquire(bool acquire);
-  std::string readFwVersion(int hyb);
-  std::string readIDChip(int hyb);
-  std::string readGeoPos(int hyb);
-  std::string checkLinkStatus(int hyb);
-  void configFE();
-
-private:
-  Hybrid hybrids[HYBRIDS_PER_FEN];
-  bool enabled_hybrids[HYBRIDS_PER_FEN] = {};
-  uint32_t readWriteRegs(std::string command_reg, int index, std::string read_reg);
-  uint16_t getChMap();
-  void sendAll(bool useConfigCheck);
-  void enableAcquisition(bool enabled);
-  uint8_t linkStatus[HYBRIDS_PER_FEN];
-};
diff --git a/vmmTblApp/src/VmmTblRegsMap.cpp b/vmmTblApp/src/VmmTblRegsMap.cpp
deleted file mode 100644
index 1cdb3dd..0000000
--- a/vmmTblApp/src/VmmTblRegsMap.cpp
+++ /dev/null
@@ -1,807 +0,0 @@
-#include "VmmTblRegsMap.h"
-
-extern const std::unordered_map<std::string, uint32_t> vmm_tbl_register_map = {
-    { "REGBANK_VERSION", 0x00000000 },
-    { "PHASH", 0x00000004 },
-    { "ro_test", 0x00000008 },
-    { "rw_test", 0x0000000c },
-    { "GIT_HASH2", 0x00000010 },
-    { "GIT_HASH1", 0x00000014 },
-    { "GIT_HASH0", 0x00000018 },
-    { "led_ctl", 0x0000001c },
-    { "vmm_clk_freq", 0x00000020 },
-    { "test_data_en", 0x00000024 },
-    { "test_data_rate", 0x00000028 },
-    { "hit_cnt_rst", 0x0000002c },
-    { "hit_cnt_hv00", 0x00000030 },
-    { "hit_cnt_hv01", 0x00000034 },
-    { "hit_cnt_hv02", 0x00000038 },
-    { "hit_cnt_hv03", 0x0000003c },
-    { "sc_acq_on_off", 0x00000040 },
-    { "sc_cfg_app", 0x00000044 },
-    { "sc_cfg_hyb", 0x00000048 },
-    { "sc_cfg_vmm", 0x0000004c },
-    { "sc_eeprom_board_id", 0x00000050 },
-    { "sc_app_link_status", 0x00000054 },
-    { "sc_app_reset_assister", 0x00000058 },
-    { "sc_app_board_id", 0x0000005c },
-    { "sc_i2c_geo_id", 0x00000060 },
-    { "sc_i2c_firmware_version", 0x00000064 },
-    { "sc_i2c_hybrid_id", 0x00000068 },
-    { "sc_i2c_config_check", 0x0000006c },
-    { "sc_i2c_reset_config_check", 0x00000070 },
-    { "sc_i2c_vmm_adc", 0x00000074 },
-    { "eeprom_board_id", 0x00000078 },
-    { "app_board_id", 0x0000007c },
-    { "app_debug_data_format", 0x00000080 },
-    { "app_latency_reset", 0x00000084 },
-    { "app_latency_data_max", 0x00000088 },
-    { "app_latency_data_jitter", 0x0000008c },
-    { "app_chmask", 0x00000090 },
-    { "app_tp_offset_first", 0x00000094 },
-    { "app_tp_offset", 0x00000098 },
-    { "app_tp_latency", 0x0000009c },
-    { "app_tp_number", 0x000000a0 },
-    { "app_acq_enable", 0x000000a4 },
-    { "app_link_status", 0x000000a8 },
-    { "hyb_tp_skew00", 0x000000ac },
-    { "hyb_tp_skew01", 0x000000b0 },
-    { "hyb_tp_skew02", 0x000000b4 },
-    { "hyb_tp_skew03", 0x000000b8 },
-    { "hyb_tp_skew04", 0x000000bc },
-    { "hyb_tp_width00", 0x000000c0 },
-    { "hyb_tp_width01", 0x000000c4 },
-    { "hyb_tp_width02", 0x000000c8 },
-    { "hyb_tp_width03", 0x000000cc },
-    { "hyb_tp_width04", 0x000000d0 },
-    { "hyb_tp_polarity00", 0x000000d4 },
-    { "hyb_tp_polarity01", 0x000000d8 },
-    { "hyb_tp_polarity02", 0x000000dc },
-    { "hyb_tp_polarity03", 0x000000e0 },
-    { "hyb_tp_polarity04", 0x000000e4 },
-    { "hyb_i2c_geoid00", 0x000000e8 },
-    { "hyb_i2c_geoid01", 0x000000ec },
-    { "hyb_i2c_geoid02", 0x000000f0 },
-    { "hyb_i2c_geoid03", 0x000000f4 },
-    { "hyb_i2c_geoid04", 0x000000f8 },
-    { "hyb_i2c_firmware_version00", 0x000000fc },
-    { "hyb_i2c_firmware_version01", 0x00000100 },
-    { "hyb_i2c_firmware_version02", 0x00000104 },
-    { "hyb_i2c_firmware_version03", 0x00000108 },
-    { "hyb_i2c_firmware_version04", 0x0000010c },
-    { "hyb_i2c_hybrid_id000", 0x00000110 },
-    { "hyb_i2c_hybrid_id001", 0x00000114 },
-    { "hyb_i2c_hybrid_id002", 0x00000118 },
-    { "hyb_i2c_hybrid_id003", 0x0000011c },
-    { "hyb_i2c_hybrid_id004", 0x00000120 },
-    { "hyb_i2c_hybrid_id100", 0x00000124 },
-    { "hyb_i2c_hybrid_id101", 0x00000128 },
-    { "hyb_i2c_hybrid_id102", 0x0000012c },
-    { "hyb_i2c_hybrid_id103", 0x00000130 },
-    { "hyb_i2c_hybrid_id104", 0x00000134 },
-    { "hyb_i2c_hybrid_id200", 0x00000138 },
-    { "hyb_i2c_hybrid_id201", 0x0000013c },
-    { "hyb_i2c_hybrid_id202", 0x00000140 },
-    { "hyb_i2c_hybrid_id203", 0x00000144 },
-    { "hyb_i2c_hybrid_id204", 0x00000148 },
-    { "hyb_i2c_hybrid_id300", 0x0000014c },
-    { "hyb_i2c_hybrid_id301", 0x00000150 },
-    { "hyb_i2c_hybrid_id302", 0x00000154 },
-    { "hyb_i2c_hybrid_id303", 0x00000158 },
-    { "hyb_i2c_hybrid_id304", 0x0000015c },
-    { "hyb_i2c_config_check00", 0x00000160 },
-    { "hyb_i2c_config_check01", 0x00000164 },
-    { "hyb_i2c_config_check02", 0x00000168 },
-    { "hyb_i2c_config_check03", 0x0000016c },
-    { "hyb_i2c_config_check04", 0x00000170 },
-    { "vmm_i2c_adc00", 0x00000174 },
-    { "vmm_i2c_adc01", 0x00000178 },
-    { "vmm_i2c_adc02", 0x0000017c },
-    { "vmm_i2c_adc03", 0x00000180 },
-    { "vmm_i2c_adc04", 0x00000184 },
-    { "vmm_i2c_adc05", 0x00000188 },
-    { "vmm_i2c_adc06", 0x0000018c },
-    { "vmm_i2c_adc07", 0x00000190 },
-    { "vmm_i2c_adc08", 0x00000194 },
-    { "vmm_i2c_adc09", 0x00000198 },
-    { "vmm_global_bank2_sp000", 0x0000019c },
-    { "vmm_global_bank2_sp001", 0x000001a0 },
-    { "vmm_global_bank2_sp002", 0x000001a4 },
-    { "vmm_global_bank2_sp003", 0x000001a8 },
-    { "vmm_global_bank2_sp004", 0x000001ac },
-    { "vmm_global_bank2_sp005", 0x000001b0 },
-    { "vmm_global_bank2_sp006", 0x000001b4 },
-    { "vmm_global_bank2_sp007", 0x000001b8 },
-    { "vmm_global_bank2_sp008", 0x000001bc },
-    { "vmm_global_bank2_sp009", 0x000001c0 },
-    { "vmm_global_bank2_sp100", 0x000001c4 },
-    { "vmm_global_bank2_sp101", 0x000001c8 },
-    { "vmm_global_bank2_sp102", 0x000001cc },
-    { "vmm_global_bank2_sp103", 0x000001d0 },
-    { "vmm_global_bank2_sp104", 0x000001d4 },
-    { "vmm_global_bank2_sp105", 0x000001d8 },
-    { "vmm_global_bank2_sp106", 0x000001dc },
-    { "vmm_global_bank2_sp107", 0x000001e0 },
-    { "vmm_global_bank2_sp108", 0x000001e4 },
-    { "vmm_global_bank2_sp109", 0x000001e8 },
-    { "vmm_global_bank2_sp200", 0x000001ec },
-    { "vmm_global_bank2_sp201", 0x000001f0 },
-    { "vmm_global_bank2_sp202", 0x000001f4 },
-    { "vmm_global_bank2_sp203", 0x000001f8 },
-    { "vmm_global_bank2_sp204", 0x000001fc },
-    { "vmm_global_bank2_sp205", 0x00000200 },
-    { "vmm_global_bank2_sp206", 0x00000204 },
-    { "vmm_global_bank2_sp207", 0x00000208 },
-    { "vmm_global_bank2_sp208", 0x0000020c },
-    { "vmm_global_bank2_sp209", 0x00000210 },
-    { "vmm_ch0000", 0x00000214 },
-    { "vmm_ch0001", 0x00000218 },
-    { "vmm_ch0002", 0x0000021c },
-    { "vmm_ch0003", 0x00000220 },
-    { "vmm_ch0004", 0x00000224 },
-    { "vmm_ch0005", 0x00000228 },
-    { "vmm_ch0006", 0x0000022c },
-    { "vmm_ch0007", 0x00000230 },
-    { "vmm_ch0008", 0x00000234 },
-    { "vmm_ch0009", 0x00000238 },
-    { "vmm_ch0100", 0x0000023c },
-    { "vmm_ch0101", 0x00000240 },
-    { "vmm_ch0102", 0x00000244 },
-    { "vmm_ch0103", 0x00000248 },
-    { "vmm_ch0104", 0x0000024c },
-    { "vmm_ch0105", 0x00000250 },
-    { "vmm_ch0106", 0x00000254 },
-    { "vmm_ch0107", 0x00000258 },
-    { "vmm_ch0108", 0x0000025c },
-    { "vmm_ch0109", 0x00000260 },
-    { "vmm_ch0200", 0x00000264 },
-    { "vmm_ch0201", 0x00000268 },
-    { "vmm_ch0202", 0x0000026c },
-    { "vmm_ch0203", 0x00000270 },
-    { "vmm_ch0204", 0x00000274 },
-    { "vmm_ch0205", 0x00000278 },
-    { "vmm_ch0206", 0x0000027c },
-    { "vmm_ch0207", 0x00000280 },
-    { "vmm_ch0208", 0x00000284 },
-    { "vmm_ch0209", 0x00000288 },
-    { "vmm_ch0300", 0x0000028c },
-    { "vmm_ch0301", 0x00000290 },
-    { "vmm_ch0302", 0x00000294 },
-    { "vmm_ch0303", 0x00000298 },
-    { "vmm_ch0304", 0x0000029c },
-    { "vmm_ch0305", 0x000002a0 },
-    { "vmm_ch0306", 0x000002a4 },
-    { "vmm_ch0307", 0x000002a8 },
-    { "vmm_ch0308", 0x000002ac },
-    { "vmm_ch0309", 0x000002b0 },
-    { "vmm_ch0400", 0x000002b4 },
-    { "vmm_ch0401", 0x000002b8 },
-    { "vmm_ch0402", 0x000002bc },
-    { "vmm_ch0403", 0x000002c0 },
-    { "vmm_ch0404", 0x000002c4 },
-    { "vmm_ch0405", 0x000002c8 },
-    { "vmm_ch0406", 0x000002cc },
-    { "vmm_ch0407", 0x000002d0 },
-    { "vmm_ch0408", 0x000002d4 },
-    { "vmm_ch0409", 0x000002d8 },
-    { "vmm_ch0500", 0x000002dc },
-    { "vmm_ch0501", 0x000002e0 },
-    { "vmm_ch0502", 0x000002e4 },
-    { "vmm_ch0503", 0x000002e8 },
-    { "vmm_ch0504", 0x000002ec },
-    { "vmm_ch0505", 0x000002f0 },
-    { "vmm_ch0506", 0x000002f4 },
-    { "vmm_ch0507", 0x000002f8 },
-    { "vmm_ch0508", 0x000002fc },
-    { "vmm_ch0509", 0x00000300 },
-    { "vmm_ch0600", 0x00000304 },
-    { "vmm_ch0601", 0x00000308 },
-    { "vmm_ch0602", 0x0000030c },
-    { "vmm_ch0603", 0x00000310 },
-    { "vmm_ch0604", 0x00000314 },
-    { "vmm_ch0605", 0x00000318 },
-    { "vmm_ch0606", 0x0000031c },
-    { "vmm_ch0607", 0x00000320 },
-    { "vmm_ch0608", 0x00000324 },
-    { "vmm_ch0609", 0x00000328 },
-    { "vmm_ch0700", 0x0000032c },
-    { "vmm_ch0701", 0x00000330 },
-    { "vmm_ch0702", 0x00000334 },
-    { "vmm_ch0703", 0x00000338 },
-    { "vmm_ch0704", 0x0000033c },
-    { "vmm_ch0705", 0x00000340 },
-    { "vmm_ch0706", 0x00000344 },
-    { "vmm_ch0707", 0x00000348 },
-    { "vmm_ch0708", 0x0000034c },
-    { "vmm_ch0709", 0x00000350 },
-    { "vmm_ch0800", 0x00000354 },
-    { "vmm_ch0801", 0x00000358 },
-    { "vmm_ch0802", 0x0000035c },
-    { "vmm_ch0803", 0x00000360 },
-    { "vmm_ch0804", 0x00000364 },
-    { "vmm_ch0805", 0x00000368 },
-    { "vmm_ch0806", 0x0000036c },
-    { "vmm_ch0807", 0x00000370 },
-    { "vmm_ch0808", 0x00000374 },
-    { "vmm_ch0809", 0x00000378 },
-    { "vmm_ch0900", 0x0000037c },
-    { "vmm_ch0901", 0x00000380 },
-    { "vmm_ch0902", 0x00000384 },
-    { "vmm_ch0903", 0x00000388 },
-    { "vmm_ch0904", 0x0000038c },
-    { "vmm_ch0905", 0x00000390 },
-    { "vmm_ch0906", 0x00000394 },
-    { "vmm_ch0907", 0x00000398 },
-    { "vmm_ch0908", 0x0000039c },
-    { "vmm_ch0909", 0x000003a0 },
-    { "vmm_ch1000", 0x000003a4 },
-    { "vmm_ch1001", 0x000003a8 },
-    { "vmm_ch1002", 0x000003ac },
-    { "vmm_ch1003", 0x000003b0 },
-    { "vmm_ch1004", 0x000003b4 },
-    { "vmm_ch1005", 0x000003b8 },
-    { "vmm_ch1006", 0x000003bc },
-    { "vmm_ch1007", 0x000003c0 },
-    { "vmm_ch1008", 0x000003c4 },
-    { "vmm_ch1009", 0x000003c8 },
-    { "vmm_ch1100", 0x000003cc },
-    { "vmm_ch1101", 0x000003d0 },
-    { "vmm_ch1102", 0x000003d4 },
-    { "vmm_ch1103", 0x000003d8 },
-    { "vmm_ch1104", 0x000003dc },
-    { "vmm_ch1105", 0x000003e0 },
-    { "vmm_ch1106", 0x000003e4 },
-    { "vmm_ch1107", 0x000003e8 },
-    { "vmm_ch1108", 0x000003ec },
-    { "vmm_ch1109", 0x000003f0 },
-    { "vmm_ch1200", 0x000003f4 },
-    { "vmm_ch1201", 0x000003f8 },
-    { "vmm_ch1202", 0x000003fc },
-    { "vmm_ch1203", 0x00000400 },
-    { "vmm_ch1204", 0x00000404 },
-    { "vmm_ch1205", 0x00000408 },
-    { "vmm_ch1206", 0x0000040c },
-    { "vmm_ch1207", 0x00000410 },
-    { "vmm_ch1208", 0x00000414 },
-    { "vmm_ch1209", 0x00000418 },
-    { "vmm_ch1300", 0x0000041c },
-    { "vmm_ch1301", 0x00000420 },
-    { "vmm_ch1302", 0x00000424 },
-    { "vmm_ch1303", 0x00000428 },
-    { "vmm_ch1304", 0x0000042c },
-    { "vmm_ch1305", 0x00000430 },
-    { "vmm_ch1306", 0x00000434 },
-    { "vmm_ch1307", 0x00000438 },
-    { "vmm_ch1308", 0x0000043c },
-    { "vmm_ch1309", 0x00000440 },
-    { "vmm_ch1400", 0x00000444 },
-    { "vmm_ch1401", 0x00000448 },
-    { "vmm_ch1402", 0x0000044c },
-    { "vmm_ch1403", 0x00000450 },
-    { "vmm_ch1404", 0x00000454 },
-    { "vmm_ch1405", 0x00000458 },
-    { "vmm_ch1406", 0x0000045c },
-    { "vmm_ch1407", 0x00000460 },
-    { "vmm_ch1408", 0x00000464 },
-    { "vmm_ch1409", 0x00000468 },
-    { "vmm_ch1500", 0x0000046c },
-    { "vmm_ch1501", 0x00000470 },
-    { "vmm_ch1502", 0x00000474 },
-    { "vmm_ch1503", 0x00000478 },
-    { "vmm_ch1504", 0x0000047c },
-    { "vmm_ch1505", 0x00000480 },
-    { "vmm_ch1506", 0x00000484 },
-    { "vmm_ch1507", 0x00000488 },
-    { "vmm_ch1508", 0x0000048c },
-    { "vmm_ch1509", 0x00000490 },
-    { "vmm_ch1600", 0x00000494 },
-    { "vmm_ch1601", 0x00000498 },
-    { "vmm_ch1602", 0x0000049c },
-    { "vmm_ch1603", 0x000004a0 },
-    { "vmm_ch1604", 0x000004a4 },
-    { "vmm_ch1605", 0x000004a8 },
-    { "vmm_ch1606", 0x000004ac },
-    { "vmm_ch1607", 0x000004b0 },
-    { "vmm_ch1608", 0x000004b4 },
-    { "vmm_ch1609", 0x000004b8 },
-    { "vmm_ch1700", 0x000004bc },
-    { "vmm_ch1701", 0x000004c0 },
-    { "vmm_ch1702", 0x000004c4 },
-    { "vmm_ch1703", 0x000004c8 },
-    { "vmm_ch1704", 0x000004cc },
-    { "vmm_ch1705", 0x000004d0 },
-    { "vmm_ch1706", 0x000004d4 },
-    { "vmm_ch1707", 0x000004d8 },
-    { "vmm_ch1708", 0x000004dc },
-    { "vmm_ch1709", 0x000004e0 },
-    { "vmm_ch1800", 0x000004e4 },
-    { "vmm_ch1801", 0x000004e8 },
-    { "vmm_ch1802", 0x000004ec },
-    { "vmm_ch1803", 0x000004f0 },
-    { "vmm_ch1804", 0x000004f4 },
-    { "vmm_ch1805", 0x000004f8 },
-    { "vmm_ch1806", 0x000004fc },
-    { "vmm_ch1807", 0x00000500 },
-    { "vmm_ch1808", 0x00000504 },
-    { "vmm_ch1809", 0x00000508 },
-    { "vmm_ch1900", 0x0000050c },
-    { "vmm_ch1901", 0x00000510 },
-    { "vmm_ch1902", 0x00000514 },
-    { "vmm_ch1903", 0x00000518 },
-    { "vmm_ch1904", 0x0000051c },
-    { "vmm_ch1905", 0x00000520 },
-    { "vmm_ch1906", 0x00000524 },
-    { "vmm_ch1907", 0x00000528 },
-    { "vmm_ch1908", 0x0000052c },
-    { "vmm_ch1909", 0x00000530 },
-    { "vmm_ch2000", 0x00000534 },
-    { "vmm_ch2001", 0x00000538 },
-    { "vmm_ch2002", 0x0000053c },
-    { "vmm_ch2003", 0x00000540 },
-    { "vmm_ch2004", 0x00000544 },
-    { "vmm_ch2005", 0x00000548 },
-    { "vmm_ch2006", 0x0000054c },
-    { "vmm_ch2007", 0x00000550 },
-    { "vmm_ch2008", 0x00000554 },
-    { "vmm_ch2009", 0x00000558 },
-    { "vmm_ch2100", 0x0000055c },
-    { "vmm_ch2101", 0x00000560 },
-    { "vmm_ch2102", 0x00000564 },
-    { "vmm_ch2103", 0x00000568 },
-    { "vmm_ch2104", 0x0000056c },
-    { "vmm_ch2105", 0x00000570 },
-    { "vmm_ch2106", 0x00000574 },
-    { "vmm_ch2107", 0x00000578 },
-    { "vmm_ch2108", 0x0000057c },
-    { "vmm_ch2109", 0x00000580 },
-    { "vmm_ch2200", 0x00000584 },
-    { "vmm_ch2201", 0x00000588 },
-    { "vmm_ch2202", 0x0000058c },
-    { "vmm_ch2203", 0x00000590 },
-    { "vmm_ch2204", 0x00000594 },
-    { "vmm_ch2205", 0x00000598 },
-    { "vmm_ch2206", 0x0000059c },
-    { "vmm_ch2207", 0x000005a0 },
-    { "vmm_ch2208", 0x000005a4 },
-    { "vmm_ch2209", 0x000005a8 },
-    { "vmm_ch2300", 0x000005ac },
-    { "vmm_ch2301", 0x000005b0 },
-    { "vmm_ch2302", 0x000005b4 },
-    { "vmm_ch2303", 0x000005b8 },
-    { "vmm_ch2304", 0x000005bc },
-    { "vmm_ch2305", 0x000005c0 },
-    { "vmm_ch2306", 0x000005c4 },
-    { "vmm_ch2307", 0x000005c8 },
-    { "vmm_ch2308", 0x000005cc },
-    { "vmm_ch2309", 0x000005d0 },
-    { "vmm_ch2400", 0x000005d4 },
-    { "vmm_ch2401", 0x000005d8 },
-    { "vmm_ch2402", 0x000005dc },
-    { "vmm_ch2403", 0x000005e0 },
-    { "vmm_ch2404", 0x000005e4 },
-    { "vmm_ch2405", 0x000005e8 },
-    { "vmm_ch2406", 0x000005ec },
-    { "vmm_ch2407", 0x000005f0 },
-    { "vmm_ch2408", 0x000005f4 },
-    { "vmm_ch2409", 0x000005f8 },
-    { "vmm_ch2500", 0x000005fc },
-    { "vmm_ch2501", 0x00000600 },
-    { "vmm_ch2502", 0x00000604 },
-    { "vmm_ch2503", 0x00000608 },
-    { "vmm_ch2504", 0x0000060c },
-    { "vmm_ch2505", 0x00000610 },
-    { "vmm_ch2506", 0x00000614 },
-    { "vmm_ch2507", 0x00000618 },
-    { "vmm_ch2508", 0x0000061c },
-    { "vmm_ch2509", 0x00000620 },
-    { "vmm_ch2600", 0x00000624 },
-    { "vmm_ch2601", 0x00000628 },
-    { "vmm_ch2602", 0x0000062c },
-    { "vmm_ch2603", 0x00000630 },
-    { "vmm_ch2604", 0x00000634 },
-    { "vmm_ch2605", 0x00000638 },
-    { "vmm_ch2606", 0x0000063c },
-    { "vmm_ch2607", 0x00000640 },
-    { "vmm_ch2608", 0x00000644 },
-    { "vmm_ch2609", 0x00000648 },
-    { "vmm_ch2700", 0x0000064c },
-    { "vmm_ch2701", 0x00000650 },
-    { "vmm_ch2702", 0x00000654 },
-    { "vmm_ch2703", 0x00000658 },
-    { "vmm_ch2704", 0x0000065c },
-    { "vmm_ch2705", 0x00000660 },
-    { "vmm_ch2706", 0x00000664 },
-    { "vmm_ch2707", 0x00000668 },
-    { "vmm_ch2708", 0x0000066c },
-    { "vmm_ch2709", 0x00000670 },
-    { "vmm_ch2800", 0x00000674 },
-    { "vmm_ch2801", 0x00000678 },
-    { "vmm_ch2802", 0x0000067c },
-    { "vmm_ch2803", 0x00000680 },
-    { "vmm_ch2804", 0x00000684 },
-    { "vmm_ch2805", 0x00000688 },
-    { "vmm_ch2806", 0x0000068c },
-    { "vmm_ch2807", 0x00000690 },
-    { "vmm_ch2808", 0x00000694 },
-    { "vmm_ch2809", 0x00000698 },
-    { "vmm_ch2900", 0x0000069c },
-    { "vmm_ch2901", 0x000006a0 },
-    { "vmm_ch2902", 0x000006a4 },
-    { "vmm_ch2903", 0x000006a8 },
-    { "vmm_ch2904", 0x000006ac },
-    { "vmm_ch2905", 0x000006b0 },
-    { "vmm_ch2906", 0x000006b4 },
-    { "vmm_ch2907", 0x000006b8 },
-    { "vmm_ch2908", 0x000006bc },
-    { "vmm_ch2909", 0x000006c0 },
-    { "vmm_ch3000", 0x000006c4 },
-    { "vmm_ch3001", 0x000006c8 },
-    { "vmm_ch3002", 0x000006cc },
-    { "vmm_ch3003", 0x000006d0 },
-    { "vmm_ch3004", 0x000006d4 },
-    { "vmm_ch3005", 0x000006d8 },
-    { "vmm_ch3006", 0x000006dc },
-    { "vmm_ch3007", 0x000006e0 },
-    { "vmm_ch3008", 0x000006e4 },
-    { "vmm_ch3009", 0x000006e8 },
-    { "vmm_ch3100", 0x000006ec },
-    { "vmm_ch3101", 0x000006f0 },
-    { "vmm_ch3102", 0x000006f4 },
-    { "vmm_ch3103", 0x000006f8 },
-    { "vmm_ch3104", 0x000006fc },
-    { "vmm_ch3105", 0x00000700 },
-    { "vmm_ch3106", 0x00000704 },
-    { "vmm_ch3107", 0x00000708 },
-    { "vmm_ch3108", 0x0000070c },
-    { "vmm_ch3109", 0x00000710 },
-    { "vmm_ch3200", 0x00000714 },
-    { "vmm_ch3201", 0x00000718 },
-    { "vmm_ch3202", 0x0000071c },
-    { "vmm_ch3203", 0x00000720 },
-    { "vmm_ch3204", 0x00000724 },
-    { "vmm_ch3205", 0x00000728 },
-    { "vmm_ch3206", 0x0000072c },
-    { "vmm_ch3207", 0x00000730 },
-    { "vmm_ch3208", 0x00000734 },
-    { "vmm_ch3209", 0x00000738 },
-    { "vmm_ch3300", 0x0000073c },
-    { "vmm_ch3301", 0x00000740 },
-    { "vmm_ch3302", 0x00000744 },
-    { "vmm_ch3303", 0x00000748 },
-    { "vmm_ch3304", 0x0000074c },
-    { "vmm_ch3305", 0x00000750 },
-    { "vmm_ch3306", 0x00000754 },
-    { "vmm_ch3307", 0x00000758 },
-    { "vmm_ch3308", 0x0000075c },
-    { "vmm_ch3309", 0x00000760 },
-    { "vmm_ch3400", 0x00000764 },
-    { "vmm_ch3401", 0x00000768 },
-    { "vmm_ch3402", 0x0000076c },
-    { "vmm_ch3403", 0x00000770 },
-    { "vmm_ch3404", 0x00000774 },
-    { "vmm_ch3405", 0x00000778 },
-    { "vmm_ch3406", 0x0000077c },
-    { "vmm_ch3407", 0x00000780 },
-    { "vmm_ch3408", 0x00000784 },
-    { "vmm_ch3409", 0x00000788 },
-    { "vmm_ch3500", 0x0000078c },
-    { "vmm_ch3501", 0x00000790 },
-    { "vmm_ch3502", 0x00000794 },
-    { "vmm_ch3503", 0x00000798 },
-    { "vmm_ch3504", 0x0000079c },
-    { "vmm_ch3505", 0x000007a0 },
-    { "vmm_ch3506", 0x000007a4 },
-    { "vmm_ch3507", 0x000007a8 },
-    { "vmm_ch3508", 0x000007ac },
-    { "vmm_ch3509", 0x000007b0 },
-    { "vmm_ch3600", 0x000007b4 },
-    { "vmm_ch3601", 0x000007b8 },
-    { "vmm_ch3602", 0x000007bc },
-    { "vmm_ch3603", 0x000007c0 },
-    { "vmm_ch3604", 0x000007c4 },
-    { "vmm_ch3605", 0x000007c8 },
-    { "vmm_ch3606", 0x000007cc },
-    { "vmm_ch3607", 0x000007d0 },
-    { "vmm_ch3608", 0x000007d4 },
-    { "vmm_ch3609", 0x000007d8 },
-    { "vmm_ch3700", 0x000007dc },
-    { "vmm_ch3701", 0x000007e0 },
-    { "vmm_ch3702", 0x000007e4 },
-    { "vmm_ch3703", 0x000007e8 },
-    { "vmm_ch3704", 0x000007ec },
-    { "vmm_ch3705", 0x000007f0 },
-    { "vmm_ch3706", 0x000007f4 },
-    { "vmm_ch3707", 0x000007f8 },
-    { "vmm_ch3708", 0x000007fc },
-    { "vmm_ch3709", 0x00000800 },
-    { "vmm_ch3800", 0x00000804 },
-    { "vmm_ch3801", 0x00000808 },
-    { "vmm_ch3802", 0x0000080c },
-    { "vmm_ch3803", 0x00000810 },
-    { "vmm_ch3804", 0x00000814 },
-    { "vmm_ch3805", 0x00000818 },
-    { "vmm_ch3806", 0x0000081c },
-    { "vmm_ch3807", 0x00000820 },
-    { "vmm_ch3808", 0x00000824 },
-    { "vmm_ch3809", 0x00000828 },
-    { "vmm_ch3900", 0x0000082c },
-    { "vmm_ch3901", 0x00000830 },
-    { "vmm_ch3902", 0x00000834 },
-    { "vmm_ch3903", 0x00000838 },
-    { "vmm_ch3904", 0x0000083c },
-    { "vmm_ch3905", 0x00000840 },
-    { "vmm_ch3906", 0x00000844 },
-    { "vmm_ch3907", 0x00000848 },
-    { "vmm_ch3908", 0x0000084c },
-    { "vmm_ch3909", 0x00000850 },
-    { "vmm_ch4000", 0x00000854 },
-    { "vmm_ch4001", 0x00000858 },
-    { "vmm_ch4002", 0x0000085c },
-    { "vmm_ch4003", 0x00000860 },
-    { "vmm_ch4004", 0x00000864 },
-    { "vmm_ch4005", 0x00000868 },
-    { "vmm_ch4006", 0x0000086c },
-    { "vmm_ch4007", 0x00000870 },
-    { "vmm_ch4008", 0x00000874 },
-    { "vmm_ch4009", 0x00000878 },
-    { "vmm_ch4100", 0x0000087c },
-    { "vmm_ch4101", 0x00000880 },
-    { "vmm_ch4102", 0x00000884 },
-    { "vmm_ch4103", 0x00000888 },
-    { "vmm_ch4104", 0x0000088c },
-    { "vmm_ch4105", 0x00000890 },
-    { "vmm_ch4106", 0x00000894 },
-    { "vmm_ch4107", 0x00000898 },
-    { "vmm_ch4108", 0x0000089c },
-    { "vmm_ch4109", 0x000008a0 },
-    { "vmm_ch4200", 0x000008a4 },
-    { "vmm_ch4201", 0x000008a8 },
-    { "vmm_ch4202", 0x000008ac },
-    { "vmm_ch4203", 0x000008b0 },
-    { "vmm_ch4204", 0x000008b4 },
-    { "vmm_ch4205", 0x000008b8 },
-    { "vmm_ch4206", 0x000008bc },
-    { "vmm_ch4207", 0x000008c0 },
-    { "vmm_ch4208", 0x000008c4 },
-    { "vmm_ch4209", 0x000008c8 },
-    { "vmm_ch4300", 0x000008cc },
-    { "vmm_ch4301", 0x000008d0 },
-    { "vmm_ch4302", 0x000008d4 },
-    { "vmm_ch4303", 0x000008d8 },
-    { "vmm_ch4304", 0x000008dc },
-    { "vmm_ch4305", 0x000008e0 },
-    { "vmm_ch4306", 0x000008e4 },
-    { "vmm_ch4307", 0x000008e8 },
-    { "vmm_ch4308", 0x000008ec },
-    { "vmm_ch4309", 0x000008f0 },
-    { "vmm_ch4400", 0x000008f4 },
-    { "vmm_ch4401", 0x000008f8 },
-    { "vmm_ch4402", 0x000008fc },
-    { "vmm_ch4403", 0x00000900 },
-    { "vmm_ch4404", 0x00000904 },
-    { "vmm_ch4405", 0x00000908 },
-    { "vmm_ch4406", 0x0000090c },
-    { "vmm_ch4407", 0x00000910 },
-    { "vmm_ch4408", 0x00000914 },
-    { "vmm_ch4409", 0x00000918 },
-    { "vmm_ch4500", 0x0000091c },
-    { "vmm_ch4501", 0x00000920 },
-    { "vmm_ch4502", 0x00000924 },
-    { "vmm_ch4503", 0x00000928 },
-    { "vmm_ch4504", 0x0000092c },
-    { "vmm_ch4505", 0x00000930 },
-    { "vmm_ch4506", 0x00000934 },
-    { "vmm_ch4507", 0x00000938 },
-    { "vmm_ch4508", 0x0000093c },
-    { "vmm_ch4509", 0x00000940 },
-    { "vmm_ch4600", 0x00000944 },
-    { "vmm_ch4601", 0x00000948 },
-    { "vmm_ch4602", 0x0000094c },
-    { "vmm_ch4603", 0x00000950 },
-    { "vmm_ch4604", 0x00000954 },
-    { "vmm_ch4605", 0x00000958 },
-    { "vmm_ch4606", 0x0000095c },
-    { "vmm_ch4607", 0x00000960 },
-    { "vmm_ch4608", 0x00000964 },
-    { "vmm_ch4609", 0x00000968 },
-    { "vmm_ch4700", 0x0000096c },
-    { "vmm_ch4701", 0x00000970 },
-    { "vmm_ch4702", 0x00000974 },
-    { "vmm_ch4703", 0x00000978 },
-    { "vmm_ch4704", 0x0000097c },
-    { "vmm_ch4705", 0x00000980 },
-    { "vmm_ch4706", 0x00000984 },
-    { "vmm_ch4707", 0x00000988 },
-    { "vmm_ch4708", 0x0000098c },
-    { "vmm_ch4709", 0x00000990 },
-    { "vmm_ch4800", 0x00000994 },
-    { "vmm_ch4801", 0x00000998 },
-    { "vmm_ch4802", 0x0000099c },
-    { "vmm_ch4803", 0x000009a0 },
-    { "vmm_ch4804", 0x000009a4 },
-    { "vmm_ch4805", 0x000009a8 },
-    { "vmm_ch4806", 0x000009ac },
-    { "vmm_ch4807", 0x000009b0 },
-    { "vmm_ch4808", 0x000009b4 },
-    { "vmm_ch4809", 0x000009b8 },
-    { "vmm_ch4900", 0x000009bc },
-    { "vmm_ch4901", 0x000009c0 },
-    { "vmm_ch4902", 0x000009c4 },
-    { "vmm_ch4903", 0x000009c8 },
-    { "vmm_ch4904", 0x000009cc },
-    { "vmm_ch4905", 0x000009d0 },
-    { "vmm_ch4906", 0x000009d4 },
-    { "vmm_ch4907", 0x000009d8 },
-    { "vmm_ch4908", 0x000009dc },
-    { "vmm_ch4909", 0x000009e0 },
-    { "vmm_ch5000", 0x000009e4 },
-    { "vmm_ch5001", 0x000009e8 },
-    { "vmm_ch5002", 0x000009ec },
-    { "vmm_ch5003", 0x000009f0 },
-    { "vmm_ch5004", 0x000009f4 },
-    { "vmm_ch5005", 0x000009f8 },
-    { "vmm_ch5006", 0x000009fc },
-    { "vmm_ch5007", 0x00000a00 },
-    { "vmm_ch5008", 0x00000a04 },
-    { "vmm_ch5009", 0x00000a08 },
-    { "vmm_ch5100", 0x00000a0c },
-    { "vmm_ch5101", 0x00000a10 },
-    { "vmm_ch5102", 0x00000a14 },
-    { "vmm_ch5103", 0x00000a18 },
-    { "vmm_ch5104", 0x00000a1c },
-    { "vmm_ch5105", 0x00000a20 },
-    { "vmm_ch5106", 0x00000a24 },
-    { "vmm_ch5107", 0x00000a28 },
-    { "vmm_ch5108", 0x00000a2c },
-    { "vmm_ch5109", 0x00000a30 },
-    { "vmm_ch5200", 0x00000a34 },
-    { "vmm_ch5201", 0x00000a38 },
-    { "vmm_ch5202", 0x00000a3c },
-    { "vmm_ch5203", 0x00000a40 },
-    { "vmm_ch5204", 0x00000a44 },
-    { "vmm_ch5205", 0x00000a48 },
-    { "vmm_ch5206", 0x00000a4c },
-    { "vmm_ch5207", 0x00000a50 },
-    { "vmm_ch5208", 0x00000a54 },
-    { "vmm_ch5209", 0x00000a58 },
-    { "vmm_ch5300", 0x00000a5c },
-    { "vmm_ch5301", 0x00000a60 },
-    { "vmm_ch5302", 0x00000a64 },
-    { "vmm_ch5303", 0x00000a68 },
-    { "vmm_ch5304", 0x00000a6c },
-    { "vmm_ch5305", 0x00000a70 },
-    { "vmm_ch5306", 0x00000a74 },
-    { "vmm_ch5307", 0x00000a78 },
-    { "vmm_ch5308", 0x00000a7c },
-    { "vmm_ch5309", 0x00000a80 },
-    { "vmm_ch5400", 0x00000a84 },
-    { "vmm_ch5401", 0x00000a88 },
-    { "vmm_ch5402", 0x00000a8c },
-    { "vmm_ch5403", 0x00000a90 },
-    { "vmm_ch5404", 0x00000a94 },
-    { "vmm_ch5405", 0x00000a98 },
-    { "vmm_ch5406", 0x00000a9c },
-    { "vmm_ch5407", 0x00000aa0 },
-    { "vmm_ch5408", 0x00000aa4 },
-    { "vmm_ch5409", 0x00000aa8 },
-    { "vmm_ch5500", 0x00000aac },
-    { "vmm_ch5501", 0x00000ab0 },
-    { "vmm_ch5502", 0x00000ab4 },
-    { "vmm_ch5503", 0x00000ab8 },
-    { "vmm_ch5504", 0x00000abc },
-    { "vmm_ch5505", 0x00000ac0 },
-    { "vmm_ch5506", 0x00000ac4 },
-    { "vmm_ch5507", 0x00000ac8 },
-    { "vmm_ch5508", 0x00000acc },
-    { "vmm_ch5509", 0x00000ad0 },
-    { "vmm_ch5600", 0x00000ad4 },
-    { "vmm_ch5601", 0x00000ad8 },
-    { "vmm_ch5602", 0x00000adc },
-    { "vmm_ch5603", 0x00000ae0 },
-    { "vmm_ch5604", 0x00000ae4 },
-    { "vmm_ch5605", 0x00000ae8 },
-    { "vmm_ch5606", 0x00000aec },
-    { "vmm_ch5607", 0x00000af0 },
-    { "vmm_ch5608", 0x00000af4 },
-    { "vmm_ch5609", 0x00000af8 },
-    { "vmm_ch5700", 0x00000afc },
-    { "vmm_ch5701", 0x00000b00 },
-    { "vmm_ch5702", 0x00000b04 },
-    { "vmm_ch5703", 0x00000b08 },
-    { "vmm_ch5704", 0x00000b0c },
-    { "vmm_ch5705", 0x00000b10 },
-    { "vmm_ch5706", 0x00000b14 },
-    { "vmm_ch5707", 0x00000b18 },
-    { "vmm_ch5708", 0x00000b1c },
-    { "vmm_ch5709", 0x00000b20 },
-    { "vmm_ch5800", 0x00000b24 },
-    { "vmm_ch5801", 0x00000b28 },
-    { "vmm_ch5802", 0x00000b2c },
-    { "vmm_ch5803", 0x00000b30 },
-    { "vmm_ch5804", 0x00000b34 },
-    { "vmm_ch5805", 0x00000b38 },
-    { "vmm_ch5806", 0x00000b3c },
-    { "vmm_ch5807", 0x00000b40 },
-    { "vmm_ch5808", 0x00000b44 },
-    { "vmm_ch5809", 0x00000b48 },
-    { "vmm_ch5900", 0x00000b4c },
-    { "vmm_ch5901", 0x00000b50 },
-    { "vmm_ch5902", 0x00000b54 },
-    { "vmm_ch5903", 0x00000b58 },
-    { "vmm_ch5904", 0x00000b5c },
-    { "vmm_ch5905", 0x00000b60 },
-    { "vmm_ch5906", 0x00000b64 },
-    { "vmm_ch5907", 0x00000b68 },
-    { "vmm_ch5908", 0x00000b6c },
-    { "vmm_ch5909", 0x00000b70 },
-    { "vmm_ch6000", 0x00000b74 },
-    { "vmm_ch6001", 0x00000b78 },
-    { "vmm_ch6002", 0x00000b7c },
-    { "vmm_ch6003", 0x00000b80 },
-    { "vmm_ch6004", 0x00000b84 },
-    { "vmm_ch6005", 0x00000b88 },
-    { "vmm_ch6006", 0x00000b8c },
-    { "vmm_ch6007", 0x00000b90 },
-    { "vmm_ch6008", 0x00000b94 },
-    { "vmm_ch6009", 0x00000b98 },
-    { "vmm_ch6100", 0x00000b9c },
-    { "vmm_ch6101", 0x00000ba0 },
-    { "vmm_ch6102", 0x00000ba4 },
-    { "vmm_ch6103", 0x00000ba8 },
-    { "vmm_ch6104", 0x00000bac },
-    { "vmm_ch6105", 0x00000bb0 },
-    { "vmm_ch6106", 0x00000bb4 },
-    { "vmm_ch6107", 0x00000bb8 },
-    { "vmm_ch6108", 0x00000bbc },
-    { "vmm_ch6109", 0x00000bc0 },
-    { "vmm_ch6200", 0x00000bc4 },
-    { "vmm_ch6201", 0x00000bc8 },
-    { "vmm_ch6202", 0x00000bcc },
-    { "vmm_ch6203", 0x00000bd0 },
-    { "vmm_ch6204", 0x00000bd4 },
-    { "vmm_ch6205", 0x00000bd8 },
-    { "vmm_ch6206", 0x00000bdc },
-    { "vmm_ch6207", 0x00000be0 },
-    { "vmm_ch6208", 0x00000be4 },
-    { "vmm_ch6209", 0x00000be8 },
-    { "vmm_ch6300", 0x00000bec },
-    { "vmm_ch6301", 0x00000bf0 },
-    { "vmm_ch6302", 0x00000bf4 },
-    { "vmm_ch6303", 0x00000bf8 },
-    { "vmm_ch6304", 0x00000bfc },
-    { "vmm_ch6305", 0x00000c00 },
-    { "vmm_ch6306", 0x00000c04 },
-    { "vmm_ch6307", 0x00000c08 },
-    { "vmm_ch6308", 0x00000c0c },
-    { "vmm_ch6309", 0x00000c10 },
-    { "vmm_global_bank1_sp000", 0x00000c14 },
-    { "vmm_global_bank1_sp001", 0x00000c18 },
-    { "vmm_global_bank1_sp002", 0x00000c1c },
-    { "vmm_global_bank1_sp003", 0x00000c20 },
-    { "vmm_global_bank1_sp004", 0x00000c24 },
-    { "vmm_global_bank1_sp005", 0x00000c28 },
-    { "vmm_global_bank1_sp006", 0x00000c2c },
-    { "vmm_global_bank1_sp007", 0x00000c30 },
-    { "vmm_global_bank1_sp008", 0x00000c34 },
-    { "vmm_global_bank1_sp009", 0x00000c38 },
-    { "vmm_global_bank1_sp100", 0x00000c3c },
-    { "vmm_global_bank1_sp101", 0x00000c40 },
-    { "vmm_global_bank1_sp102", 0x00000c44 },
-    { "vmm_global_bank1_sp103", 0x00000c48 },
-    { "vmm_global_bank1_sp104", 0x00000c4c },
-    { "vmm_global_bank1_sp105", 0x00000c50 },
-    { "vmm_global_bank1_sp106", 0x00000c54 },
-    { "vmm_global_bank1_sp107", 0x00000c58 },
-    { "vmm_global_bank1_sp108", 0x00000c5c },
-    { "vmm_global_bank1_sp109", 0x00000c60 },
-    { "vmm_global_bank1_sp200", 0x00000c64 },
-    { "vmm_global_bank1_sp201", 0x00000c68 },
-    { "vmm_global_bank1_sp202", 0x00000c6c },
-    { "vmm_global_bank1_sp203", 0x00000c70 },
-    { "vmm_global_bank1_sp204", 0x00000c74 },
-    { "vmm_global_bank1_sp205", 0x00000c78 },
-    { "vmm_global_bank1_sp206", 0x00000c7c },
-    { "vmm_global_bank1_sp207", 0x00000c80 },
-    { "vmm_global_bank1_sp208", 0x00000c84 },
-    { "vmm_global_bank1_sp209", 0x00000c88 }
-};
diff --git a/vmmTblApp/src/VmmTblRegsMap.h b/vmmTblApp/src/VmmTblRegsMap.h
deleted file mode 100644
index 8f0f3d0..0000000
--- a/vmmTblApp/src/VmmTblRegsMap.h
+++ /dev/null
@@ -1,6 +0,0 @@
-#pragma once
-
-#include <unordered_map>
-#include <string>
-
-extern const std::unordered_map<std::string, uint32_t> vmm_tbl_register_map;
\ No newline at end of file
diff --git a/vmmTblApp/src/hybrid.cpp b/vmmTblApp/src/hybrid.cpp
deleted file mode 100644
index 5397c35..0000000
--- a/vmmTblApp/src/hybrid.cpp
+++ /dev/null
@@ -1,27 +0,0 @@
-#include "hybrid.h"
-
-Hybrid::Hybrid() {
-  loadDefault();
-}
-
-Hybrid::~Hybrid() {}
-
-void Hybrid::loadDefault(){
-  hybrid_registers = {{"TP_skew", 0}, {"TP_width", 0}, {"TP_pol", 0}};
-  hybrid_info = {{"firmware_version", ""}, {"geo_id", ""}, {"hybrid_id", ""},{"link_status", "0"}, {"description", ""}};
-}
-
-VMM3a& Hybrid::getVMM(int index) {
-  if (index < 0 || index >= VMMS_PER_HYBRID)
-    throw std::out_of_range("Invalid VMM index");
-  return vmms[index];
-}
-
-vmmStatus Hybrid::getRegister(std::string feature, unsigned short& result) {
-  vmmStatus status = vmmSuccess;
-  if(hybrid_registers.find(feature) != hybrid_registers.end())
-    result = hybrid_registers[feature];
-  else
-    status = vmmParamNotFound;
-  return status;
-}
diff --git a/vmmTblApp/src/hybrid.h b/vmmTblApp/src/hybrid.h
deleted file mode 100644
index 79664b6..0000000
--- a/vmmTblApp/src/hybrid.h
+++ /dev/null
@@ -1,23 +0,0 @@
-#pragma once
-
-#include <string>
-#include <map>
-#include <iostream>
-
-#include "vmm_params.h"
-#include "vmm3a.h"
-
-class Hybrid {
-public:
-  Hybrid();
-  ~Hybrid();
-
-  void loadDefault();
-  VMM3a& getVMM(int index);
-  vmmStatus getRegister(std::string feature, unsigned short& result);
-
-private:
-  VMM3a vmms[VMMS_PER_HYBRID];
-  std::map<std::string, unsigned short> hybrid_registers;
-  std::map<std::string, std::string> hybrid_info;
-};
diff --git a/vmmTblApp/src/vmm3a.cpp b/vmmTblApp/src/vmm3a.cpp
deleted file mode 100644
index d526ff4..0000000
--- a/vmmTblApp/src/vmm3a.cpp
+++ /dev/null
@@ -1,206 +0,0 @@
-#include "vmm3a.h"
-
-// Define a map to store the valid range for each feature
-std::map<std::string, std::pair<int, int>> featureRanges = {
-  {"sm5_sm0", {0, 67}},
-  {"sfam", {0, 1}},
-  {"st", {0, 3}},
-  {"sg", {0, 7}},
-  {"stc", {0, 3}},
-  {"sdt", {0, 1023}},
-  {"sdp10", {0, 1023}},
-  {"sc10b", {0, 3}},
-  {"sc8b", {0, 3}},
-  {"truncate_i", {0, 63}},
-  {"nskip_i", {0, 127}},
-  {"window_i", {0, 7}},
-  {"rollover_i", {0, 4095}},
-  {"L0offset_i", {0, 4095}},
-  {"offset_i", {0, 4095}}
-};
-
-std::map<std::string, std::pair<int, int>> featureChannelRanges = {
-  {"sd", {0, 31}},
-  {"sz10b", {0, 31}},
-  {"sz08b", {0, 15}},
-  {"sz06b", {0, 7}},
-  {"sc", {0, 1}},
-  {"sl", {0, 1}},
-  {"st", {0, 1}},
-  {"sth", {0, 1}},
-  {"sc8b", {0, 3}},
-  {"sm", {0, 1}},
-  {"smx", {0, 1}}
-};
-
-VMM3a::VMM3a(): vmm3aSettings(std::make_unique<VMM3aSettings>()) {
-  LoadDefault();
-}
-
-void VMM3a::LoadDefault() {
-  //VMM3a channel registers
-  for(int ch=0; ch<CHANNELS_PER_VMM; ch++){
-    vmm3aSettings->channels[ch] = {{"sc", 0}, {"sl", 0}, {"st", 0}, {"sth", 0}, {"sm", 0}, {"sd", 0}, {"smx", 0}, {"sz10b", 0}, {"sz08b", 0}, {"sz06b", 0}  };
-  }
-
-  //Fill default values to map for Global Register
-  std::vector<std::string> reg_names = {
-    "sp", "sdp", "sbmx", "sbft", "sbfp",
-    "sbfm", "slg", "sm5_sm0", "scmx", "sfa",
-    "sfam", "st", "sfm", "sg", "sng",
-    "stot", "sttt", "ssh", "stc",
-    "sdt", "sdp10", "sc10b", "sc8b", "sc6b",
-    "s8b", "s6b", "s10b", "sdcks", "sdcka",
-    "sdck6b", "sdrv", "stpp",
-    "slvs", "s32", "stcr", "ssart", "srec",
-    "stlc", "sbip", "srat", "sfrst", "slvsbc",
-    "slvstp", "slvstk", "slvsdt", "slvsart", "slvstki",
-    "slvsena", "slvs6b", "sL0enaV", "slh", "slxh",
-    "stgc", "reset1", "reset2", "nskipm_i", "sL0cktest",
-    "sL0dckinv", "sL0ckinv", "sL0ena", "truncate_i",
-    "nskip_i", "window_i", "rollover_i", "L0offset_i", "offset_i"
-  };
-
-  for(const std::string& reg: reg_names) {
-    vmm3aSettings->globalRegisters.insert(std::pair<std::string, unsigned short>(reg, 0));
-  }
-
-  setRegister("sg", 2);//corrsponds to 3 mV/fC
-  setRegister("sm5_sm0", 67); //Temperature_sensor
-  setRegister("sdp10", 300);
-  setRegister("sdt",300);
-  setRegister("s10b",1);
-  setRegister("s8b",1);
-  setRegister("stc",0);
-  setRegister("sc8b",3);
-  setRegister("sc10b",3);
-  setRegister("srat",0);
-  setRegister("sbip",true);
-  setRegister("sbfm",true);
-  setRegister("sdcks",false);
-}
-
-const VMM3a::VMM3aSettings& VMM3a::getVMM3aSettings() const {
-  return *vmm3aSettings;
-}
-
-vmmStatus VMM3a::setRegister(std::string feature, int val) {
-  vmmStatus status = vmmSuccess;
-  status = updateRegisterMap(feature, val);
-  
-  if (status == vmmParamNotFound)
-    std::cout << "ERROR register " << feature << " does not exist." << std::endl;
-  else if (status == vmmBadValue)
-    std::cout << "Value " << val << " is not valid to register: " << feature << std::endl;
-  return status;
-}
-
-vmmStatus VMM3a::setRegister(std::string feature, int val, int ch) {
-  vmmStatus status = vmmSuccess;
-  status = updateRegisterMap(feature, val, ch);
-  
-  if (status == vmmParamNotFound)
-    std::cout << "ERROR register " << feature << " does not exist." << std::endl;
-  else if (status == vmmBadValue)
-    std::cout << "Value " << val << " is not valid to register: " << feature << std::endl;
-  else if (status == vmmChannelOutRange)
-    std::cout << "Channel " << ch << " out of the range (0 - 63)" << std::endl;
-  return status;
-}
-
-vmmStatus VMM3a::getRegister(std::string feature, unsigned short& result) const {
-  vmmStatus status = vmmSuccess;
-  if(vmm3aSettings->globalRegisters.find(feature)!=vmm3aSettings->globalRegisters.end())
-    result = vmm3aSettings->globalRegisters.at(feature);
-  else
-    status = vmmParamNotFound;
-  return status;
-}
-
-vmmStatus VMM3a::getRegister(std::string feature, int ch, unsigned short& result) const {
-  vmmStatus status = vmmSuccess;
-  if (ch >= 0 && ch < 64) {
-    auto it = vmm3aSettings->channels[ch].find(feature);
-    if (it != vmm3aSettings->channels[ch].end())
-      result = it->second;
-    else
-      status = vmmParamNotFound;
-  }
-  else status = vmmChannelOutRange;
-  
-  return status;
-}
-
-vmmStatus VMM3a::updateRegisterMap(std::string feature, int value) {
-  vmmStatus status = vmmSuccess;
-  auto it = vmm3aSettings->globalRegisters.find(feature);
-  if (it != vmm3aSettings->globalRegisters.end()) {
-    auto range = featureRanges.find(feature);
-    if (range != featureRanges.end()) {
-      int minVal = range->second.first;
-      int maxVal = range->second.second;
-
-      if (feature == "sm5_sm0") {
-        if(value >= 0 && value <= 63) {
-          vmm3aSettings->globalRegisters.at("scmx") = 1;
-          vmm3aSettings->globalRegisters.at("sm5_sm0") = value;
-        } else if (value >= 64 && value <= 67) {
-          //Attention: Starts at 1: 1=Pulser_DAC, 2=Threshold_DAC, 3=Bandgap_reference, 4=Temperature_sensor
-          vmm3aSettings->globalRegisters.at("scmx") = 0;
-          vmm3aSettings->globalRegisters.at("sm5_sm0") = value - 63;
-        } else status = vmmBadValue;
-      } 
-      else {
-        if (value >= minVal && value <= maxVal)
-          vmm3aSettings->globalRegisters.at(feature) = value;
-        else status = vmmBadValue;
-      }
-    }
-    // If not in the featureRanges, the param expects boolean value.
-    else {
-      if(value >= 0 && value <= 1)
-        vmm3aSettings->globalRegisters.at(feature) = value;
-      else status = vmmBadValue;
-    }
-  }
-  else { status = vmmParamNotFound; }
-  return status;
-}
-
-vmmStatus VMM3a::updateRegisterMap(std::string feature, int value, int ch) {
-  vmmStatus status = vmmSuccess;
-
-  if(ch >= 0 && ch < 64) {
-    auto range = featureChannelRanges.find(feature);
-    if (range != featureChannelRanges.end()) {
-      int minVal = range->second.first;
-      int maxVal = range->second.second;
-      if (value >= minVal && value <= maxVal)
-        vmm3aSettings->channels[ch][feature] = value;
-      else status = vmmBadValue;
-    }
-    else status = vmmParamNotFound;
-  }
-  else status = vmmChannelOutRange;
-  return status;
-}
-
-vmmStatus VMM3a::getInfo(const std::string& feature, std::string& result) {
-  vmmStatus status = vmmSuccess;
-  if (vmmInfo.find(feature) != vmmInfo.end())
-    result = vmmInfo[feature];
-  else 
-    status = vmmParamNotFound;
-  return status;
-}
-
-vmmStatus VMM3a::setInfo(const std::string& feature, const std::string& value) {
-  vmmStatus status = vmmSuccess;
-  if (vmmInfo.find(feature) != vmmInfo.end())
-    vmmInfo[feature] = value;
-  else 
-    status = vmmParamNotFound;
-  return status;
-}
-
-VMM3a::~VMM3a(){}
diff --git a/vmmTblApp/src/vmm3a.h b/vmmTblApp/src/vmm3a.h
deleted file mode 100644
index da12e72..0000000
--- a/vmmTblApp/src/vmm3a.h
+++ /dev/null
@@ -1,37 +0,0 @@
-#pragma once
-
-#include <string>
-#include <map>
-#include <vector>
-#include <memory>
-#include <iostream>
-
-#include "vmm_params.h"
-
-class VMM3a {
-public:
-  VMM3a();
-  ~VMM3a();
-
-  void LoadDefault();
-
-  struct VMM3aSettings{
-    std::map<std::string, unsigned short> channels[CHANNELS_PER_VMM];
-    std::map<std::string, unsigned short> globalRegisters;
-  };
-
-  const VMM3aSettings& getVMM3aSettings() const;
-  vmmStatus setRegister(std::string feature, int val);
-  vmmStatus setRegister(std::string feature, int val, int ch);
-  vmmStatus getRegister(std::string feature, unsigned short& result) const;
-  vmmStatus getRegister(std::string feature, int ch, unsigned short& result) const;
-  vmmStatus getInfo(const std::string& feature, std::string& result);
-  vmmStatus setInfo(const std::string& feature, const std::string& value);
-
-private:
-  vmmStatus updateRegisterMap(std::string feature, int value);
-  vmmStatus updateRegisterMap(std::string feature, int value, int ch);
-  std::unique_ptr<VMM3aSettings> vmm3aSettings;
-  std::map<std::string, std::string> vmmInfo = {{"all_sc", "0"}, {"all_sl", "0"}, {"all_st", "0"}, {"all_sth", "0"},{"all_sm", "0"}, {"all_sd", "0"},{"all_smx", "0"},
-                                                    {"all_sz10b", "0"},{"all_sz08b", "0"}, {"all_sz06b", "0"},{"adc_value", ""}, {"description",""}};
-};
\ No newline at end of file
diff --git a/vmmTblApp/src/vmm_params.h b/vmmTblApp/src/vmm_params.h
deleted file mode 100644
index 93aa727..0000000
--- a/vmmTblApp/src/vmm_params.h
+++ /dev/null
@@ -1,9 +0,0 @@
-#pragma once
-
-#define CHANNELS_PER_VMM 64
-#define VMMS_PER_HYBRID 2
-#define HYBRIDS_PER_FEN 5
-
-typedef enum {
-  vmmSuccess,vmmTimeout,vmmParamNotFound,vmmBadValue,vmmChannelOutRange
-}vmmStatus;
-- 
GitLab