2020-09-30 17:17:01 +02:00
|
|
|
#include "ObjectFactory.h"
|
2021-05-17 16:53:06 +02:00
|
|
|
#include "OBSWConfig.h"
|
|
|
|
#include "tmtc/apid.h"
|
|
|
|
#include "devices/addresses.h"
|
|
|
|
#include "devices/gpioIds.h"
|
|
|
|
#include "tmtc/pusIds.h"
|
|
|
|
#include "devices/powerSwitcherList.h"
|
2021-05-24 01:28:31 +02:00
|
|
|
#include "spiConf.h"
|
2021-05-17 16:53:06 +02:00
|
|
|
|
2021-05-26 14:16:16 +02:00
|
|
|
#include "bsp_q7s/gpio/gpioCallbacks.h"
|
|
|
|
#include "bsp_q7s/core/CoreController.h"
|
2021-06-21 09:50:26 +02:00
|
|
|
#include "bsp_q7s/spiCallbacks/rwSpiCallback.h"
|
2021-07-19 12:44:43 +02:00
|
|
|
#include "bsp_q7s/boardtest/Q7STestTask.h"
|
2021-07-19 14:02:17 +02:00
|
|
|
#include "bsp_q7s/memory/FileSystemHandler.h"
|
2021-07-19 12:44:43 +02:00
|
|
|
|
|
|
|
#include "linux/devices/HeaterHandler.h"
|
|
|
|
#include "linux/devices/SolarArrayDeploymentHandler.h"
|
|
|
|
#include "linux/devices/devicedefinitions/SusDefinitions.h"
|
|
|
|
#include "linux/devices/SusHandler.h"
|
|
|
|
#include "linux/csp/CspCookie.h"
|
|
|
|
#include "linux/csp/CspComIF.h"
|
|
|
|
|
|
|
|
#include "mission/core/GenericFactory.h"
|
|
|
|
#include "mission/devices/PDU1Handler.h"
|
|
|
|
#include "mission/devices/PDU2Handler.h"
|
|
|
|
#include "mission/devices/ACUHandler.h"
|
|
|
|
#include "mission/devices/PCDUHandler.h"
|
|
|
|
#include "mission/devices/P60DockHandler.h"
|
|
|
|
#include "mission/devices/Tmp1075Handler.h"
|
|
|
|
#include "mission/devices/Max31865PT1000Handler.h"
|
|
|
|
#include "mission/devices/IMTQHandler.h"
|
|
|
|
#include "mission/devices/SyrlinksHkHandler.h"
|
|
|
|
#include "mission/devices/MGMHandlerLIS3MDL.h"
|
|
|
|
#include "mission/devices/MGMHandlerRM3100.h"
|
2021-07-23 17:48:11 +02:00
|
|
|
#include "mission/devices/PlocMPSoCHandler.h"
|
|
|
|
#include "mission/devices/PlocSupervisorHandler.h"
|
2021-07-19 12:44:43 +02:00
|
|
|
#include "mission/devices/RadiationSensorHandler.h"
|
|
|
|
#include "mission/devices/RwHandler.h"
|
2021-07-23 17:48:11 +02:00
|
|
|
#include "mission/devices/StarTrackerHandler.h"
|
2021-07-19 12:44:43 +02:00
|
|
|
#include "mission/devices/devicedefinitions/GomspaceDefinitions.h"
|
|
|
|
#include "mission/devices/devicedefinitions/SyrlinksDefinitions.h"
|
2021-07-23 17:48:11 +02:00
|
|
|
#include "mission/devices/devicedefinitions/PlocMPSoCDefinitions.h"
|
|
|
|
#include "mission/devices/devicedefinitions/PlocSupervisorDefinitions.h"
|
2021-07-19 12:44:43 +02:00
|
|
|
#include "mission/devices/devicedefinitions/RadSensorDefinitions.h"
|
|
|
|
#include "mission/devices/devicedefinitions/Max31865Definitions.h"
|
|
|
|
#include "mission/devices/devicedefinitions/RwDefinitions.h"
|
2021-07-07 12:12:01 +02:00
|
|
|
#include <mission/devices/devicedefinitions/StarTrackerDefinitions.h>
|
2021-07-19 12:44:43 +02:00
|
|
|
#include "mission/utility/TmFunnel.h"
|
|
|
|
#include "linux/obc/CCSDSIPCoreBridge.h"
|
2020-09-30 17:17:01 +02:00
|
|
|
|
2021-08-03 15:58:01 +02:00
|
|
|
#include "fsfw_hal/linux/uart/UartComIF.h"
|
|
|
|
#include "fsfw_hal/linux/uart/UartCookie.h"
|
|
|
|
#include "fsfw_hal/devicehandlers/GyroL3GD20Handler.h"
|
|
|
|
#include "fsfw_hal/linux/i2c/I2cCookie.h"
|
|
|
|
#include "fsfw_hal/linux/i2c/I2cComIF.h"
|
|
|
|
#include "fsfw_hal/linux/spi/SpiCookie.h"
|
|
|
|
#include "fsfw_hal/linux/spi/SpiComIF.h"
|
|
|
|
#include "fsfw_hal/linux/gpio/LinuxLibgpioIF.h"
|
|
|
|
#include "fsfw_hal/common/gpio/GpioCookie.h"
|
2021-07-19 12:44:43 +02:00
|
|
|
|
|
|
|
#include "fsfw/datapoollocal/LocalDataPoolManager.h"
|
|
|
|
#include "fsfw/tmtcservices/CommandingServiceBase.h"
|
|
|
|
#include "fsfw/tmtcservices/PusServiceBase.h"
|
|
|
|
#include "fsfw/tmtcpacket/pus/tm.h"
|
2021-02-14 18:30:12 +01:00
|
|
|
|
2021-07-26 11:33:38 +02:00
|
|
|
#if OBSW_USE_TMTC_TCP_BRIDGE == 0
|
|
|
|
// UDP server includes
|
2021-07-19 12:44:43 +02:00
|
|
|
#include "fsfw/osal/common/UdpTmTcBridge.h"
|
|
|
|
#include "fsfw/osal/common/UdpTcPollingTask.h"
|
2021-07-26 11:33:38 +02:00
|
|
|
#else
|
|
|
|
// TCP server includes
|
|
|
|
#include "fsfw/osal/common/TcpTmTcBridge.h"
|
|
|
|
#include "fsfw/osal/common/TcpTmTcServer.h"
|
|
|
|
#endif
|
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
#include "linux/boardtest/SpiTestClass.h"
|
2021-02-14 18:30:12 +01:00
|
|
|
|
2021-02-14 13:07:05 +01:00
|
|
|
#if TEST_LIBGPIOD == 1
|
2021-07-19 12:44:43 +02:00
|
|
|
#include "linux/boardtest/LibgpiodTest.h"
|
2021-02-14 09:25:40 +01:00
|
|
|
#endif
|
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
void ObjectFactory::setStatics() {
|
|
|
|
Factory::setStaticFrameworkObjectIds();
|
|
|
|
}
|
|
|
|
|
2020-11-20 18:27:07 +01:00
|
|
|
void Factory::setStaticFrameworkObjectIds() {
|
2021-02-14 14:59:43 +01:00
|
|
|
PusServiceBase::packetSource = objects::PUS_PACKET_DISTRIBUTOR;
|
|
|
|
PusServiceBase::packetDestination = objects::TM_FUNNEL;
|
2020-09-30 17:17:01 +02:00
|
|
|
|
2021-02-14 14:59:43 +01:00
|
|
|
CommandingServiceBase::defaultPacketSource = objects::PUS_PACKET_DISTRIBUTOR;
|
|
|
|
CommandingServiceBase::defaultPacketDestination = objects::TM_FUNNEL;
|
2020-09-30 17:17:01 +02:00
|
|
|
|
2021-07-26 11:33:38 +02:00
|
|
|
TmFunnel::downlinkDestination = objects::TMTC_BRIDGE;
|
2021-02-14 14:59:43 +01:00
|
|
|
// No storage object for now.
|
|
|
|
TmFunnel::storageDestination = objects::NO_OBJECT;
|
2020-09-30 17:17:01 +02:00
|
|
|
|
2021-03-01 12:23:39 +01:00
|
|
|
LocalDataPoolManager::defaultHkDestination = objects::PUS_SERVICE_3_HOUSEKEEPING;
|
2020-12-29 02:16:39 +01:00
|
|
|
|
2021-02-14 14:59:43 +01:00
|
|
|
VerificationReporter::messageReceiver = objects::PUS_SERVICE_1_VERIFICATION;
|
2021-04-24 23:04:17 +02:00
|
|
|
TmPacketBase::timeStamperId = objects::TIME_STAMPER;
|
2020-09-30 17:17:01 +02:00
|
|
|
}
|
|
|
|
|
2021-06-08 16:45:25 +02:00
|
|
|
void ObjectFactory::produce(void* args){
|
2021-07-19 12:44:43 +02:00
|
|
|
ObjectFactory::setStatics();
|
2021-02-14 14:59:43 +01:00
|
|
|
ObjectFactory::produceGenericObjects();
|
2021-07-19 12:44:43 +02:00
|
|
|
new CoreController(objects::CORE_CONTROLLER);
|
|
|
|
LinuxLibgpioIF* gpioComIF = nullptr;
|
|
|
|
createCommunicationInterfaces(&gpioComIF);
|
|
|
|
createTmpComponents();
|
|
|
|
#if BOARD_TE0720 == 0
|
|
|
|
|
|
|
|
createPcduComponents();
|
|
|
|
createRadSensorComponent(gpioComIF);
|
|
|
|
createSunSensorComponents(gpioComIF);
|
|
|
|
#if OBSW_ADD_ACS_BOARD == 1
|
|
|
|
createAcsBoardComponents(gpioComIF);
|
|
|
|
#endif /* OBSW_ADD_ACS_BOARD == 1 */
|
|
|
|
createHeaterComponents();
|
|
|
|
createSolarArrayDeploymentComponents();
|
|
|
|
#if Q7S_ADD_SYRLINKS_HANDLER == 1
|
|
|
|
createSyrlinksComponents();
|
|
|
|
#endif /* Q7S_ADD_SYRLINKS_HANDLER == 1 */
|
2021-05-26 14:16:16 +02:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
#if Q7S_ADD_RTD_DEVICES == 1
|
|
|
|
createRtdComponents();
|
|
|
|
#endif /* Q7S_ADD_RTD_DEVICES == 1 */
|
2021-05-26 14:16:16 +02:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
I2cCookie* imtqI2cCookie = new I2cCookie(addresses::IMTQ, IMTQ::MAX_REPLY_SIZE,
|
|
|
|
std::string("/dev/i2c-0"));
|
|
|
|
new IMTQHandler(objects::IMTQ_HANDLER, objects::I2C_COM_IF, imtqI2cCookie);
|
2020-09-30 17:17:01 +02:00
|
|
|
|
2021-07-23 18:04:51 +02:00
|
|
|
#if ADD_PLOC_MPSOC == 1
|
2021-07-23 17:48:11 +02:00
|
|
|
UartCookie* mpsocUartCookie = new UartCookie(objects::RW1, std::string("/dev/ttyUL3"),
|
|
|
|
UartModes::NON_CANONICAL, 115200, PLOC_MPSOC::MAX_REPLY_SIZE);
|
|
|
|
new PlocMPSoCHandler(objects::PLOC_MPSOC_HANDLER, objects::UART_COM_IF, mpsocUartCookie);
|
2021-07-23 18:04:51 +02:00
|
|
|
#endif /* ADD_PLOC_MPSOC */
|
2021-07-19 12:44:43 +02:00
|
|
|
|
|
|
|
createReactionWheelComponents(gpioComIF);
|
|
|
|
#endif /* TE7020 != 0 */
|
|
|
|
|
2021-07-26 11:33:38 +02:00
|
|
|
#if OBSW_USE_TMTC_TCP_BRIDGE == 0
|
|
|
|
new UdpTmTcBridge(objects::TMTC_BRIDGE, objects::CCSDS_PACKET_DISTRIBUTOR);
|
|
|
|
new UdpTcPollingTask(objects::TMTC_POLLING_TASK, objects::TMTC_BRIDGE);
|
|
|
|
#else
|
|
|
|
new TcpTmTcBridge(objects::TMTC_BRIDGE, objects::CCSDS_PACKET_DISTRIBUTOR);
|
|
|
|
new TcpTmTcServer(objects::TMTC_POLLING_TASK, objects::TMTC_BRIDGE);
|
|
|
|
#endif
|
2021-07-19 12:44:43 +02:00
|
|
|
|
|
|
|
/* Test Task */
|
|
|
|
#if OBSW_ADD_TEST_CODE == 1
|
|
|
|
createTestComponents();
|
|
|
|
#endif /* OBSW_ADD_TEST_CODE == 1 */
|
|
|
|
|
2021-07-19 14:02:17 +02:00
|
|
|
new FileSystemHandler(objects::FILE_SYSTEM_HANDLER);
|
2020-09-30 17:17:01 +02:00
|
|
|
|
2021-07-23 17:48:11 +02:00
|
|
|
#if ADD_PLOC_MPSOC == 1
|
|
|
|
UartCookie* plocMpsocCookie = new UartCookie(objects::RW1, std::string("/dev/ttyUL3"),
|
|
|
|
UartModes::NON_CANONICAL, 115200, PLOC_MPSOC::MAX_REPLY_SIZE);
|
|
|
|
new PlocMPSoCHandler(objects::PLOC_MPSOC_HANDLER, objects::UART_COM_IF, plocMpsocCookie);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if OBSW_ADD_STAR_TRACKER == 1
|
|
|
|
UartCookie* starTrackerCookie = new UartCookie(objects::START_TRACKER, std::string("/dev/ttyUL3"),
|
|
|
|
UartModes::NON_CANONICAL, 115200, StarTracker::MAX_FRAME_SIZE* 2 + 2);
|
|
|
|
starTrackerCookie->setNoFixedSizeReply();
|
|
|
|
new StarTrackerHandler(objects::START_TRACKER, objects::UART_COM_IF, starTrackerCookie);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if ADD_PLOC_SUPERVISOR == 1
|
|
|
|
/* Configuration for MIO0 on TE0720-03-1CFA */
|
|
|
|
UartCookie* plocSupervisorCookie = new UartCookie(objects::PLOC_SUPERVISOR_HANDLER,
|
|
|
|
std::string("/dev/ttyUL3"), UartModes::NON_CANONICAL, 115200,
|
2021-07-31 08:32:57 +02:00
|
|
|
PLOC_SPV::MAX_PACKET_SIZE * 20);
|
|
|
|
plocSupervisorCookie->setNoFixedSizeReply();
|
2021-07-23 17:48:11 +02:00
|
|
|
PlocSupervisorHandler* plocSupervisor = new PlocSupervisorHandler(
|
|
|
|
objects::PLOC_SUPERVISOR_HANDLER, objects::UART_COM_IF, plocSupervisorCookie);
|
|
|
|
plocSupervisor->setStartUpImmediately();
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void ObjectFactory::createTmpComponents() {
|
|
|
|
#if BOARD_TE0720 == 1
|
2021-02-14 14:59:43 +01:00
|
|
|
I2cCookie* i2cCookieTmp1075tcs1 = new I2cCookie(addresses::TMP1075_TCS_1,
|
|
|
|
TMP1075::MAX_REPLY_LENGTH, std::string("/dev/i2c-0"));
|
|
|
|
I2cCookie* i2cCookieTmp1075tcs2 = new I2cCookie(addresses::TMP1075_TCS_2,
|
|
|
|
TMP1075::MAX_REPLY_LENGTH, std::string("/dev/i2c-0"));
|
2021-01-28 14:55:21 +01:00
|
|
|
#else
|
2021-02-14 14:59:43 +01:00
|
|
|
I2cCookie* i2cCookieTmp1075tcs1 = new I2cCookie(addresses::TMP1075_TCS_1,
|
2021-01-28 14:55:21 +01:00
|
|
|
TMP1075::MAX_REPLY_LENGTH, std::string("/dev/i2c-1"));
|
|
|
|
I2cCookie* i2cCookieTmp1075tcs2 = new I2cCookie(addresses::TMP1075_TCS_2,
|
|
|
|
TMP1075::MAX_REPLY_LENGTH, std::string("/dev/i2c-1"));
|
|
|
|
#endif
|
2020-12-29 13:59:31 +01:00
|
|
|
|
2021-04-01 15:34:28 +02:00
|
|
|
/* Temperature sensors */
|
2021-05-03 12:49:14 +02:00
|
|
|
Tmp1075Handler* tmp1075Handler_1 = new Tmp1075Handler(
|
|
|
|
objects::TMP1075_HANDLER_1, objects::I2C_COM_IF,
|
|
|
|
i2cCookieTmp1075tcs1);
|
2021-05-12 17:01:11 +02:00
|
|
|
(void) tmp1075Handler_1;
|
2021-05-03 12:49:14 +02:00
|
|
|
Tmp1075Handler* tmp1075Handler_2 = new Tmp1075Handler(
|
|
|
|
objects::TMP1075_HANDLER_2, objects::I2C_COM_IF,
|
|
|
|
i2cCookieTmp1075tcs2);
|
2021-05-12 17:01:11 +02:00
|
|
|
(void) tmp1075Handler_2;
|
2021-07-19 12:44:43 +02:00
|
|
|
}
|
2020-12-29 13:59:31 +01:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
void ObjectFactory::createCommunicationInterfaces(LinuxLibgpioIF **gpioComIF) {
|
|
|
|
if(gpioComIF == nullptr) {
|
|
|
|
sif::error << "ObjectFactory::createCommunicationInterfaces: Invalid GPIO ComIF"
|
|
|
|
<< std::endl;
|
|
|
|
}
|
|
|
|
*gpioComIF = new LinuxLibgpioIF(objects::GPIO_IF);
|
|
|
|
|
|
|
|
/* Communication interfaces */
|
|
|
|
new CspComIF(objects::CSP_COM_IF);
|
|
|
|
new I2cComIF(objects::I2C_COM_IF);
|
|
|
|
new UartComIF(objects::UART_COM_IF);
|
|
|
|
#if Q7S_ADD_SPI_TEST == 0
|
|
|
|
new SpiComIF(objects::SPI_COM_IF, *gpioComIF);
|
|
|
|
#endif /* Q7S_ADD_SPI_TEST == 0 */
|
|
|
|
/* Adding gpios for chip select decoding to the gpioComIf */
|
|
|
|
gpioCallbacks::initSpiCsDecoder(*gpioComIF);
|
|
|
|
}
|
2020-12-29 13:59:31 +01:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
void ObjectFactory::createPcduComponents() {
|
2021-02-14 14:59:43 +01:00
|
|
|
CspCookie* p60DockCspCookie = new CspCookie(P60Dock::MAX_REPLY_LENGTH,
|
|
|
|
addresses::P60DOCK);
|
2021-02-14 09:25:40 +01:00
|
|
|
CspCookie* pdu1CspCookie = new CspCookie(PDU::MAX_REPLY_LENGTH,
|
|
|
|
addresses::PDU1);
|
|
|
|
CspCookie* pdu2CspCookie = new CspCookie(PDU::MAX_REPLY_LENGTH,
|
|
|
|
addresses::PDU2);
|
|
|
|
CspCookie* acuCspCookie = new CspCookie(ACU::MAX_REPLY_LENGTH,
|
2021-02-14 14:59:43 +01:00
|
|
|
addresses::ACU);
|
2020-12-29 13:59:31 +01:00
|
|
|
/* Device Handler */
|
2021-02-14 14:59:43 +01:00
|
|
|
P60DockHandler* p60dockhandler = new P60DockHandler(objects::P60DOCK_HANDLER,
|
|
|
|
objects::CSP_COM_IF, p60DockCspCookie);
|
|
|
|
PDU1Handler* pdu1handler = new PDU1Handler(objects::PDU1_HANDLER,
|
|
|
|
objects::CSP_COM_IF, pdu1CspCookie);
|
|
|
|
PDU2Handler* pdu2handler = new PDU2Handler(objects::PDU2_HANDLER,
|
|
|
|
objects::CSP_COM_IF, pdu2CspCookie);
|
|
|
|
ACUHandler* acuhandler = new ACUHandler(objects::ACU_HANDLER,
|
|
|
|
objects::CSP_COM_IF, acuCspCookie);
|
|
|
|
new PCDUHandler(objects::PCDU_HANDLER, 50);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Setting PCDU devices to mode normal immediately after start up because PCDU is always
|
|
|
|
* running.
|
|
|
|
*/
|
2021-02-25 15:25:49 +01:00
|
|
|
/** For now this needs to be commented out because there is no PCDU connected to the OBC */
|
|
|
|
// p60dockhandler->setModeNormal();
|
|
|
|
// pdu1handler->setModeNormal();
|
|
|
|
// pdu2handler->setModeNormal();
|
|
|
|
// acuhandler->setModeNormal();
|
2021-04-01 14:06:56 +02:00
|
|
|
(void) p60dockhandler;
|
|
|
|
(void) pdu1handler;
|
|
|
|
(void) pdu2handler;
|
|
|
|
(void) acuhandler;
|
2021-07-19 12:44:43 +02:00
|
|
|
}
|
2021-04-01 14:06:56 +02:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
void ObjectFactory::createRadSensorComponent(LinuxLibgpioIF* gpioComIF) {
|
2021-05-06 18:00:58 +02:00
|
|
|
GpioCookie* gpioCookieRadSensor = new GpioCookie;
|
|
|
|
GpiodRegular* chipSelectRadSensor = new GpiodRegular(std::string("gpiochip5"), 19,
|
|
|
|
std::string("Chip Select Radiation Sensor"), gpio::OUT, 1);
|
|
|
|
gpioCookieRadSensor->addGpio(gpioIds::CS_RAD_SENSOR, chipSelectRadSensor);
|
|
|
|
gpioComIF->addGpios(gpioCookieRadSensor);
|
|
|
|
|
|
|
|
SpiCookie* spiCookieRadSensor = new SpiCookie(addresses::RAD_SENSOR, gpioIds::CS_RAD_SENSOR,
|
2021-05-07 18:48:42 +02:00
|
|
|
std::string("/dev/spidev2.0"), RAD_SENSOR::READ_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
2021-05-06 18:00:58 +02:00
|
|
|
spi::DEFAULT_MAX_1227_SPEED);
|
2021-07-22 08:06:04 +02:00
|
|
|
new RadiationSensorHandler(objects::RAD_SENSOR, objects::SPI_COM_IF, spiCookieRadSensor);
|
2021-07-19 12:44:43 +02:00
|
|
|
}
|
2021-07-01 17:27:51 +02:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
void ObjectFactory::createSunSensorComponents(LinuxLibgpioIF *gpioComIF) {
|
2021-05-03 11:59:33 +02:00
|
|
|
GpioCookie* gpioCookieSus = new GpioCookie();
|
|
|
|
|
|
|
|
GpioCallback* susgpio = new GpioCallback(std::string("Chip select SUS 1"), gpio::OUT, 1,
|
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
|
|
|
gpioCookieSus->addGpio(gpioIds::CS_SUS_1, susgpio);
|
|
|
|
susgpio = new GpioCallback(std::string("Chip select SUS 2"), gpio::OUT, 1,
|
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
|
|
|
gpioCookieSus->addGpio(gpioIds::CS_SUS_2, susgpio);
|
|
|
|
susgpio = new GpioCallback(std::string("Chip select SUS 3"), gpio::OUT, 1,
|
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
|
|
|
gpioCookieSus->addGpio(gpioIds::CS_SUS_3, susgpio);
|
|
|
|
susgpio = new GpioCallback(std::string("Chip select SUS 4"), gpio::OUT, 1,
|
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
|
|
|
gpioCookieSus->addGpio(gpioIds::CS_SUS_4, susgpio);
|
|
|
|
susgpio = new GpioCallback(std::string("Chip select SUS 5"), gpio::OUT, 1,
|
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
|
|
|
gpioCookieSus->addGpio(gpioIds::CS_SUS_5, susgpio);
|
|
|
|
susgpio = new GpioCallback(std::string("Chip select SUS 6"), gpio::OUT, 1,
|
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
|
|
|
gpioCookieSus->addGpio(gpioIds::CS_SUS_6, susgpio);
|
|
|
|
susgpio = new GpioCallback(std::string("Chip select SUS 7"), gpio::OUT, 1,
|
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
|
|
|
gpioCookieSus->addGpio(gpioIds::CS_SUS_7, susgpio);
|
|
|
|
susgpio = new GpioCallback(std::string("Chip select SUS 8"), gpio::OUT, 1,
|
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
|
|
|
gpioCookieSus->addGpio(gpioIds::CS_SUS_8, susgpio);
|
|
|
|
susgpio = new GpioCallback(std::string("Chip select SUS 9"), gpio::OUT, 1,
|
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
|
|
|
gpioCookieSus->addGpio(gpioIds::CS_SUS_9, susgpio);
|
|
|
|
susgpio = new GpioCallback(std::string("Chip select SUS 10"), gpio::OUT, 1,
|
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
|
|
|
gpioCookieSus->addGpio(gpioIds::CS_SUS_10, susgpio);
|
|
|
|
susgpio = new GpioCallback(std::string("Chip select SUS 11"), gpio::OUT, 1,
|
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
|
|
|
gpioCookieSus->addGpio(gpioIds::CS_SUS_11, susgpio);
|
|
|
|
susgpio = new GpioCallback(std::string("Chip select SUS 12"), gpio::OUT, 1,
|
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
|
|
|
gpioCookieSus->addGpio(gpioIds::CS_SUS_12, susgpio);
|
|
|
|
susgpio = new GpioCallback(std::string("Chip select SUS 13"), gpio::OUT, 1,
|
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
|
|
|
gpioCookieSus->addGpio(gpioIds::CS_SUS_13, susgpio);
|
|
|
|
|
|
|
|
gpioComIF->addGpios(gpioCookieSus);
|
|
|
|
|
2021-05-09 18:18:27 +02:00
|
|
|
SpiCookie* spiCookieSus1 = new SpiCookie(addresses::SUS_1, gpio::NO_GPIO,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("/dev/spidev2.0"), SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
2021-05-12 13:06:56 +02:00
|
|
|
SUS::MAX1227_SPI_FREQ);
|
2021-05-09 18:18:27 +02:00
|
|
|
SpiCookie* spiCookieSus2 = new SpiCookie(addresses::SUS_2, gpio::NO_GPIO,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("/dev/spidev2.0"), SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
2021-05-12 13:06:56 +02:00
|
|
|
SUS::MAX1227_SPI_FREQ);
|
2021-05-09 18:18:27 +02:00
|
|
|
SpiCookie* spiCookieSus3 = new SpiCookie(addresses::SUS_3, gpio::NO_GPIO,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("/dev/spidev2.0"), SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
2021-05-12 13:06:56 +02:00
|
|
|
SUS::MAX1227_SPI_FREQ);
|
2021-05-09 18:18:27 +02:00
|
|
|
SpiCookie* spiCookieSus4 = new SpiCookie(addresses::SUS_4, gpio::NO_GPIO,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("/dev/spidev2.0"), SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
2021-05-12 13:06:56 +02:00
|
|
|
SUS::MAX1227_SPI_FREQ);
|
2021-05-09 18:18:27 +02:00
|
|
|
SpiCookie* spiCookieSus5 = new SpiCookie(addresses::SUS_5, gpio::NO_GPIO,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("/dev/spidev2.0"), SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
2021-05-12 13:06:56 +02:00
|
|
|
SUS::MAX1227_SPI_FREQ);
|
2021-05-09 18:18:27 +02:00
|
|
|
SpiCookie* spiCookieSus6 = new SpiCookie(addresses::SUS_6, gpio::NO_GPIO,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("/dev/spidev2.0"), SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
2021-05-12 13:06:56 +02:00
|
|
|
SUS::MAX1227_SPI_FREQ);
|
2021-05-09 18:18:27 +02:00
|
|
|
SpiCookie* spiCookieSus7 = new SpiCookie(addresses::SUS_7, gpio::NO_GPIO,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("/dev/spidev2.0"), SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
2021-05-12 13:06:56 +02:00
|
|
|
SUS::MAX1227_SPI_FREQ);
|
2021-05-08 22:49:21 +02:00
|
|
|
SpiCookie* spiCookieSus8 = new SpiCookie(addresses::SUS_8, gpio::NO_GPIO,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("/dev/spidev2.0"), SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
2021-05-12 13:06:56 +02:00
|
|
|
SUS::MAX1227_SPI_FREQ);
|
2021-05-09 18:18:27 +02:00
|
|
|
SpiCookie* spiCookieSus9 = new SpiCookie(addresses::SUS_9, gpio::NO_GPIO,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("/dev/spidev2.0"), SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
2021-05-12 13:06:56 +02:00
|
|
|
SUS::MAX1227_SPI_FREQ);
|
2021-05-09 18:18:27 +02:00
|
|
|
SpiCookie* spiCookieSus10 = new SpiCookie(addresses::SUS_10, gpio::NO_GPIO,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("/dev/spidev2.0"), SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
2021-05-12 13:06:56 +02:00
|
|
|
SUS::MAX1227_SPI_FREQ);
|
2021-05-09 18:18:27 +02:00
|
|
|
SpiCookie* spiCookieSus11 = new SpiCookie(addresses::SUS_11, gpio::NO_GPIO,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("/dev/spidev2.0"), SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
2021-05-12 13:06:56 +02:00
|
|
|
SUS::MAX1227_SPI_FREQ);
|
2021-05-09 18:18:27 +02:00
|
|
|
SpiCookie* spiCookieSus12 = new SpiCookie(addresses::SUS_12, gpio::NO_GPIO,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("/dev/spidev2.0"), SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
2021-05-12 13:06:56 +02:00
|
|
|
SUS::MAX1227_SPI_FREQ);
|
2021-05-09 18:18:27 +02:00
|
|
|
SpiCookie* spiCookieSus13 = new SpiCookie(addresses::SUS_13, gpio::NO_GPIO,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("/dev/spidev2.0"), SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
2021-05-12 13:06:56 +02:00
|
|
|
SUS::MAX1227_SPI_FREQ);
|
2021-05-03 11:59:33 +02:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
new SusHandler(objects::SUS_1, objects::SPI_COM_IF, spiCookieSus1, gpioComIF,
|
|
|
|
gpioIds::CS_SUS_1);
|
|
|
|
new SusHandler(objects::SUS_2, objects::SPI_COM_IF, spiCookieSus2, gpioComIF,
|
|
|
|
gpioIds::CS_SUS_2);
|
|
|
|
new SusHandler(objects::SUS_3, objects::SPI_COM_IF, spiCookieSus3, gpioComIF,
|
|
|
|
gpioIds::CS_SUS_3);
|
|
|
|
new SusHandler(objects::SUS_4, objects::SPI_COM_IF, spiCookieSus4, gpioComIF,
|
|
|
|
gpioIds::CS_SUS_4);
|
|
|
|
new SusHandler(objects::SUS_5, objects::SPI_COM_IF, spiCookieSus5, gpioComIF,
|
|
|
|
gpioIds::CS_SUS_5);
|
|
|
|
new SusHandler(objects::SUS_6, objects::SPI_COM_IF, spiCookieSus6, gpioComIF,
|
|
|
|
gpioIds::CS_SUS_6);
|
|
|
|
new SusHandler(objects::SUS_7, objects::SPI_COM_IF, spiCookieSus7, gpioComIF,
|
|
|
|
gpioIds::CS_SUS_7);
|
|
|
|
new SusHandler(objects::SUS_8, objects::SPI_COM_IF, spiCookieSus8, gpioComIF,
|
|
|
|
gpioIds::CS_SUS_8);
|
|
|
|
new SusHandler(objects::SUS_9, objects::SPI_COM_IF, spiCookieSus9, gpioComIF,
|
|
|
|
gpioIds::CS_SUS_9);
|
|
|
|
new SusHandler(objects::SUS_10, objects::SPI_COM_IF, spiCookieSus10, gpioComIF,
|
|
|
|
gpioIds::CS_SUS_10);
|
|
|
|
new SusHandler(objects::SUS_11, objects::SPI_COM_IF, spiCookieSus11, gpioComIF,
|
|
|
|
gpioIds::CS_SUS_11);
|
|
|
|
new SusHandler(objects::SUS_12, objects::SPI_COM_IF, spiCookieSus12, gpioComIF,
|
|
|
|
gpioIds::CS_SUS_12);
|
|
|
|
new SusHandler(objects::SUS_13, objects::SPI_COM_IF, spiCookieSus13, gpioComIF,
|
|
|
|
gpioIds::CS_SUS_13);
|
|
|
|
}
|
2021-05-03 11:59:33 +02:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
void ObjectFactory::createAcsBoardComponents(LinuxLibgpioIF *gpioComIF) {
|
2021-04-01 14:06:56 +02:00
|
|
|
GpioCookie* gpioCookieAcsBoard = new GpioCookie();
|
2021-04-01 16:21:24 +02:00
|
|
|
GpiodRegular* gpio = nullptr;
|
2021-04-29 17:45:19 +02:00
|
|
|
gpio = new GpiodRegular(std::string("gpiochip5"), 1, std::string("CS_GYRO_0_ADIS"),
|
2021-04-01 15:14:50 +02:00
|
|
|
gpio::OUT, gpio::HIGH);
|
2021-04-01 16:21:24 +02:00
|
|
|
gpioCookieAcsBoard->addGpio(gpioIds::GYRO_0_ADIS_CS, gpio);
|
2021-04-29 17:45:19 +02:00
|
|
|
gpio = new GpiodRegular(std::string("gpiochip5"), 7, std::string("CS_GYRO_1_L3G"),
|
2021-04-01 15:14:50 +02:00
|
|
|
gpio::OUT, gpio::HIGH);
|
2021-04-01 16:21:24 +02:00
|
|
|
gpioCookieAcsBoard->addGpio(gpioIds::GYRO_1_L3G_CS, gpio);
|
2021-04-29 17:45:19 +02:00
|
|
|
gpio = new GpiodRegular(std::string("gpiochip5"), 3, std::string("CS_GYRO_2_L3G"),
|
2021-04-01 15:14:50 +02:00
|
|
|
gpio::OUT, gpio::HIGH);
|
2021-04-01 16:21:24 +02:00
|
|
|
gpioCookieAcsBoard->addGpio(gpioIds::GYRO_2_L3G_CS, gpio);
|
2021-04-01 15:14:50 +02:00
|
|
|
|
2021-04-01 16:21:24 +02:00
|
|
|
gpio = new GpiodRegular(std::string("gpiochip5"), 5, std::string("CS_MGM_0_LIS3_A"),
|
2021-04-01 15:14:50 +02:00
|
|
|
gpio::OUT, gpio::HIGH);
|
2021-04-01 16:21:24 +02:00
|
|
|
gpioCookieAcsBoard->addGpio(gpioIds::MGM_0_LIS3_CS, gpio);
|
2021-04-01 17:06:35 +02:00
|
|
|
|
2021-04-29 17:45:19 +02:00
|
|
|
gpio = new GpiodRegular(std::string("gpiochip5"), 16, std::string("CS_MGM_1_RM3100_A"),
|
2021-04-01 15:14:50 +02:00
|
|
|
gpio::OUT, gpio::HIGH);
|
2021-04-01 16:21:24 +02:00
|
|
|
gpioCookieAcsBoard->addGpio(gpioIds::MGM_1_RM3100_CS, gpio);
|
2021-04-01 17:06:35 +02:00
|
|
|
|
2021-04-01 16:21:24 +02:00
|
|
|
gpio = new GpiodRegular(std::string("gpiochip6"), 0, std::string("CS_MGM_2_LIS3_B"),
|
2021-04-01 15:14:50 +02:00
|
|
|
gpio::OUT, gpio::HIGH);
|
2021-04-01 16:21:24 +02:00
|
|
|
gpioCookieAcsBoard->addGpio(gpioIds::MGM_2_LIS3_CS, gpio);
|
2021-04-01 17:06:35 +02:00
|
|
|
|
2021-04-11 15:18:55 +02:00
|
|
|
gpio = new GpiodRegular(std::string("gpiochip5"), 10, std::string("CS_MGM_3_RM3100_B"),
|
2021-04-01 15:14:50 +02:00
|
|
|
gpio::OUT, gpio::HIGH);
|
2021-04-01 16:21:24 +02:00
|
|
|
gpioCookieAcsBoard->addGpio(gpioIds::MGM_3_RM3100_CS, gpio);
|
2021-04-01 15:14:50 +02:00
|
|
|
|
2021-04-01 16:21:24 +02:00
|
|
|
gpioComIF->addGpios(gpioCookieAcsBoard);
|
2021-04-01 14:06:56 +02:00
|
|
|
|
2021-04-01 15:32:43 +02:00
|
|
|
std::string spiDev = "/dev/spidev2.0";
|
2021-04-01 14:06:56 +02:00
|
|
|
SpiCookie* spiCookie = new SpiCookie(addresses::MGM_0_LIS3, gpioIds::MGM_0_LIS3_CS, spiDev,
|
|
|
|
MGMLIS3MDL::MAX_BUFFER_SIZE, spi::DEFAULT_LIS3_MODE, spi::DEFAULT_LIS3_SPEED);
|
|
|
|
auto mgmLis3Handler = new MGMHandlerLIS3MDL(objects::MGM_0_LIS3_HANDLER,
|
|
|
|
objects::SPI_COM_IF, spiCookie);
|
|
|
|
mgmLis3Handler->setStartUpImmediately();
|
|
|
|
|
2021-04-02 13:25:37 +02:00
|
|
|
spiCookie = new SpiCookie(addresses::MGM_2_LIS3, gpioIds::MGM_2_LIS3_CS, spiDev,
|
|
|
|
MGMLIS3MDL::MAX_BUFFER_SIZE, spi::DEFAULT_LIS3_MODE, spi::DEFAULT_LIS3_SPEED);
|
2021-04-02 15:14:08 +02:00
|
|
|
auto mgmLis3Handler2 = new MGMHandlerLIS3MDL(objects::MGM_2_LIS3_HANDLER,
|
2021-04-02 13:25:37 +02:00
|
|
|
objects::SPI_COM_IF, spiCookie);
|
|
|
|
mgmLis3Handler2->setStartUpImmediately();
|
|
|
|
|
2021-04-01 14:06:56 +02:00
|
|
|
spiCookie = new SpiCookie(addresses::MGM_1_RM3100, gpioIds::MGM_1_RM3100_CS, spiDev,
|
|
|
|
RM3100::MAX_BUFFER_SIZE, spi::DEFAULT_RM3100_MODE, spi::DEFAULT_RM3100_SPEED);
|
|
|
|
auto mgmRm3100Handler = new MGMHandlerRM3100(objects::MGM_1_RM3100_HANDLER,
|
|
|
|
objects::SPI_COM_IF, spiCookie);
|
|
|
|
mgmRm3100Handler->setStartUpImmediately();
|
|
|
|
|
2021-04-29 17:45:19 +02:00
|
|
|
spiCookie = new SpiCookie(addresses::MGM_3_RM3100, gpioIds::MGM_3_RM3100_CS, spiDev,
|
|
|
|
RM3100::MAX_BUFFER_SIZE, spi::DEFAULT_RM3100_MODE, spi::DEFAULT_RM3100_SPEED);
|
|
|
|
mgmRm3100Handler = new MGMHandlerRM3100(objects::MGM_3_RM3100_HANDLER,
|
|
|
|
objects::SPI_COM_IF, spiCookie);
|
|
|
|
mgmRm3100Handler->setStartUpImmediately();
|
|
|
|
|
|
|
|
//TODO: Adis Gyro (Gyro 0 Side A)
|
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
// Commented until ACS board V2 in in clean room again
|
2021-04-29 17:45:19 +02:00
|
|
|
/* Gyro 1 Side A */
|
2021-07-19 12:44:43 +02:00
|
|
|
// spiCookie = new SpiCookie(addresses::GYRO_1_L3G, gpioIds::GYRO_1_L3G_CS, spiDev,
|
|
|
|
// L3GD20H::MAX_BUFFER_SIZE, spi::DEFAULT_L3G_MODE, spi::DEFAULT_L3G_SPEED);
|
|
|
|
// auto gyroL3gHandler = new GyroHandlerL3GD20H(objects::GYRO_1_L3G_HANDLER, objects::SPI_COM_IF,
|
|
|
|
// spiCookie);
|
|
|
|
// gyroL3gHandler->setStartUpImmediately();
|
|
|
|
//
|
|
|
|
// /* Gyro 2 Side B */
|
|
|
|
// spiCookie = new SpiCookie(addresses::GYRO_2_L3G, gpioIds::GYRO_2_L3G_CS, spiDev,
|
|
|
|
// L3GD20H::MAX_BUFFER_SIZE, spi::DEFAULT_L3G_MODE, spi::DEFAULT_L3G_SPEED);
|
|
|
|
// gyroL3gHandler = new GyroHandlerL3GD20H(objects::GYRO_2_L3G_HANDLER, objects::SPI_COM_IF,
|
|
|
|
// spiCookie);
|
|
|
|
// gyroL3gHandler->setStartUpImmediately();
|
|
|
|
}
|
|
|
|
|
|
|
|
void ObjectFactory::createHeaterComponents() {
|
2021-02-14 14:59:43 +01:00
|
|
|
|
2021-05-12 13:06:56 +02:00
|
|
|
GpioCookie* heaterGpiosCookie = new GpioCookie;
|
|
|
|
|
2021-02-14 14:59:43 +01:00
|
|
|
/* Pin H2-11 on stack connector */
|
2021-03-24 12:53:25 +01:00
|
|
|
GpiodRegular* gpioConfigHeater0 = new GpiodRegular(std::string("gpiochip7"), 6,
|
|
|
|
std::string("Heater0"), gpio::OUT, 0);
|
|
|
|
heaterGpiosCookie->addGpio(gpioIds::HEATER_0, gpioConfigHeater0);
|
2021-02-12 15:24:37 +01:00
|
|
|
|
|
|
|
/* Pin H2-12 on stack connector */
|
2021-03-24 12:53:25 +01:00
|
|
|
GpiodRegular* gpioConfigHeater1 = new GpiodRegular(std::string("gpiochip7"), 12,
|
|
|
|
std::string("Heater1"), gpio::OUT, 0);
|
|
|
|
heaterGpiosCookie->addGpio(gpioIds::HEATER_1, gpioConfigHeater1);
|
2021-02-12 15:24:37 +01:00
|
|
|
|
2021-02-14 14:59:43 +01:00
|
|
|
/* Pin H2-13 on stack connector */
|
2021-03-24 12:53:25 +01:00
|
|
|
GpiodRegular* gpioConfigHeater2 = new GpiodRegular(std::string("gpiochip7"), 7,
|
2021-02-14 14:59:43 +01:00
|
|
|
std::string("Heater2"), gpio::OUT, 0);
|
2021-03-24 12:53:25 +01:00
|
|
|
heaterGpiosCookie->addGpio(gpioIds::HEATER_2, gpioConfigHeater2);
|
2021-02-12 15:24:37 +01:00
|
|
|
|
2021-03-24 12:53:25 +01:00
|
|
|
GpiodRegular* gpioConfigHeater3 = new GpiodRegular(std::string("gpiochip7"), 5,
|
|
|
|
std::string("Heater3"), gpio::OUT, 0);
|
|
|
|
heaterGpiosCookie->addGpio(gpioIds::HEATER_3, gpioConfigHeater3);
|
2021-02-12 15:24:37 +01:00
|
|
|
|
2021-03-24 12:53:25 +01:00
|
|
|
GpiodRegular* gpioConfigHeater4 = new GpiodRegular(std::string("gpiochip7"), 3,
|
|
|
|
std::string("Heater4"), gpio::OUT, 0);
|
|
|
|
heaterGpiosCookie->addGpio(gpioIds::HEATER_4, gpioConfigHeater4);
|
2021-02-12 15:24:37 +01:00
|
|
|
|
2021-03-24 12:53:25 +01:00
|
|
|
GpiodRegular* gpioConfigHeater5 = new GpiodRegular(std::string("gpiochip7"), 0,
|
|
|
|
std::string("Heater5"), gpio::OUT, 0);
|
|
|
|
heaterGpiosCookie->addGpio(gpioIds::HEATER_5, gpioConfigHeater5);
|
2021-02-12 15:24:37 +01:00
|
|
|
|
2021-03-24 12:53:25 +01:00
|
|
|
GpiodRegular* gpioConfigHeater6 = new GpiodRegular(std::string("gpiochip7"), 1,
|
|
|
|
std::string("Heater6"), gpio::OUT, 0);
|
|
|
|
heaterGpiosCookie->addGpio(gpioIds::HEATER_6, gpioConfigHeater6);
|
2021-02-12 15:24:37 +01:00
|
|
|
|
2021-03-24 12:53:25 +01:00
|
|
|
GpiodRegular* gpioConfigHeater7 = new GpiodRegular(std::string("gpiochip7"), 11,
|
|
|
|
std::string("Heater7"), gpio::OUT, 0);
|
|
|
|
heaterGpiosCookie->addGpio(gpioIds::HEATER_7, gpioConfigHeater7);
|
2021-02-12 15:24:37 +01:00
|
|
|
|
2021-03-24 12:53:25 +01:00
|
|
|
new HeaterHandler(objects::HEATER_HANDLER, objects::GPIO_IF, heaterGpiosCookie,
|
|
|
|
objects::PCDU_HANDLER, pcduSwitches::TCS_BOARD_8V_HEATER_IN);
|
2021-07-19 12:44:43 +02:00
|
|
|
}
|
2021-02-16 15:32:24 +01:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
void ObjectFactory::createSolarArrayDeploymentComponents() {
|
2021-02-16 15:32:24 +01:00
|
|
|
GpioCookie* solarArrayDeplCookie = new GpioCookie;
|
2021-03-05 12:57:42 +01:00
|
|
|
|
2021-03-24 12:53:25 +01:00
|
|
|
GpiodRegular* gpioConfigDeplSA0 = new GpiodRegular(std::string("gpiochip7"), 4,
|
2021-02-16 15:32:24 +01:00
|
|
|
std::string("DeplSA1"), gpio::OUT, 0);
|
2021-03-24 12:53:25 +01:00
|
|
|
solarArrayDeplCookie->addGpio(gpioIds::DEPLSA1, gpioConfigDeplSA0);
|
|
|
|
GpiodRegular* gpioConfigDeplSA1 = new GpiodRegular(std::string("gpiochip7"), 2,
|
2021-02-16 15:32:24 +01:00
|
|
|
std::string("DeplSA2"), gpio::OUT, 0);
|
2021-03-24 12:53:25 +01:00
|
|
|
solarArrayDeplCookie->addGpio(gpioIds::DEPLSA2, gpioConfigDeplSA1);
|
2021-02-16 15:32:24 +01:00
|
|
|
|
|
|
|
//TODO: Find out burn time. For now set to 1000 ms.
|
|
|
|
new SolarArrayDeploymentHandler(objects::SOLAR_ARRAY_DEPL_HANDLER, objects::GPIO_IF,
|
|
|
|
solarArrayDeplCookie, objects::PCDU_HANDLER, pcduSwitches::DEPLOYMENT_MECHANISM,
|
|
|
|
gpioIds::DEPLSA1, gpioIds::DEPLSA2, 1000);
|
2021-07-19 12:44:43 +02:00
|
|
|
}
|
2021-02-22 09:24:42 +01:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
void ObjectFactory::createSyrlinksComponents() {
|
2021-06-21 16:46:49 +02:00
|
|
|
UartCookie* syrlinksUartCookie = new UartCookie(objects::SYRLINKS_HK_HANDLER,
|
|
|
|
std::string("/dev/ttyUL0"), UartModes::NON_CANONICAL, 38400, SYRLINKS::MAX_REPLY_SIZE);
|
2021-02-22 09:24:42 +01:00
|
|
|
syrlinksUartCookie->setParityEven();
|
|
|
|
|
2021-07-22 08:06:04 +02:00
|
|
|
new SyrlinksHkHandler(objects::SYRLINKS_HK_HANDLER, objects::UART_COM_IF, syrlinksUartCookie);
|
2021-07-19 12:44:43 +02:00
|
|
|
}
|
2021-02-22 09:24:42 +01:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
void ObjectFactory::createRtdComponents(LinuxLibgpioIF *gpioComIF) {
|
2021-03-13 14:42:30 +01:00
|
|
|
GpioCookie* rtdGpioCookie = new GpioCookie;
|
|
|
|
|
2021-03-24 12:53:25 +01:00
|
|
|
GpioCallback* gpioRtdIc3 = new GpioCallback(std::string("Chip select RTD IC3"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-24 12:53:25 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC3, gpioRtdIc3);
|
|
|
|
GpioCallback* gpioRtdIc4 = new GpioCallback(std::string("Chip select RTD IC4"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-24 12:53:25 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC4, gpioRtdIc4);
|
2021-03-25 13:10:48 +01:00
|
|
|
GpioCallback* gpioRtdIc5 = new GpioCallback(std::string("Chip select RTD IC5"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-25 13:10:48 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC5, gpioRtdIc5);
|
|
|
|
GpioCallback* gpioRtdIc6 = new GpioCallback(std::string("Chip select RTD IC6"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-25 13:10:48 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC6, gpioRtdIc6);
|
|
|
|
GpioCallback* gpioRtdIc7 = new GpioCallback(std::string("Chip select RTD IC7"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-25 13:10:48 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC7, gpioRtdIc7);
|
|
|
|
GpioCallback* gpioRtdIc8 = new GpioCallback(std::string("Chip select RTD IC8"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-25 13:10:48 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC8, gpioRtdIc8);
|
|
|
|
GpioCallback* gpioRtdIc9 = new GpioCallback(std::string("Chip select RTD IC9"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-25 13:10:48 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC9, gpioRtdIc9);
|
|
|
|
GpioCallback* gpioRtdIc10 = new GpioCallback(std::string("Chip select RTD IC10"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-25 13:10:48 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC10, gpioRtdIc10);
|
|
|
|
GpioCallback* gpioRtdIc11 = new GpioCallback(std::string("Chip select RTD IC11"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-25 13:10:48 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC11, gpioRtdIc11);
|
|
|
|
GpioCallback* gpioRtdIc12 = new GpioCallback(std::string("Chip select RTD IC12"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-25 13:10:48 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC12, gpioRtdIc12);
|
|
|
|
GpioCallback* gpioRtdIc13 = new GpioCallback(std::string("Chip select RTD IC13"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-25 13:10:48 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC13, gpioRtdIc13);
|
|
|
|
GpioCallback* gpioRtdIc14 = new GpioCallback(std::string("Chip select RTD IC14"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-25 13:10:48 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC14, gpioRtdIc14);
|
|
|
|
GpioCallback* gpioRtdIc15 = new GpioCallback(std::string("Chip select RTD IC15"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-25 13:10:48 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC15, gpioRtdIc15);
|
|
|
|
GpioCallback* gpioRtdIc16 = new GpioCallback(std::string("Chip select RTD IC16"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-25 13:10:48 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC16, gpioRtdIc16);
|
|
|
|
GpioCallback* gpioRtdIc17 = new GpioCallback(std::string("Chip select RTD IC17"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-25 13:10:48 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC17, gpioRtdIc17);
|
|
|
|
GpioCallback* gpioRtdIc18 = new GpioCallback(std::string("Chip select RTD IC18"), gpio::OUT, 1,
|
2021-05-27 13:34:28 +02:00
|
|
|
&gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-03-25 13:10:48 +01:00
|
|
|
rtdGpioCookie->addGpio(gpioIds::RTD_IC18, gpioRtdIc18);
|
2021-03-24 12:53:25 +01:00
|
|
|
|
|
|
|
gpioComIF->addGpios(rtdGpioCookie);
|
2021-03-13 14:42:30 +01:00
|
|
|
|
|
|
|
SpiCookie* spiRtdIc3 = new SpiCookie(addresses::RTD_IC3, gpioIds::RTD_IC3,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
2021-06-02 10:25:35 +02:00
|
|
|
spi::SpiModes::MODE_3, 2000000);
|
2021-03-13 14:42:30 +01:00
|
|
|
SpiCookie* spiRtdIc4 = new SpiCookie(addresses::RTD_IC4, gpioIds::RTD_IC4,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
2021-03-22 13:09:06 +01:00
|
|
|
spi::SpiModes::MODE_1, 2000000);
|
2021-03-25 13:10:48 +01:00
|
|
|
SpiCookie* spiRtdIc5 = new SpiCookie(addresses::RTD_IC5, gpioIds::RTD_IC5,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
|
|
|
spi::SpiModes::MODE_1, 2000000);
|
|
|
|
SpiCookie* spiRtdIc6 = new SpiCookie(addresses::RTD_IC6, gpioIds::RTD_IC6,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
|
|
|
spi::SpiModes::MODE_1, 2000000);
|
|
|
|
SpiCookie* spiRtdIc7 = new SpiCookie(addresses::RTD_IC7, gpioIds::RTD_IC7,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
|
|
|
spi::SpiModes::MODE_1, 2000000);
|
|
|
|
SpiCookie* spiRtdIc8 = new SpiCookie(addresses::RTD_IC8, gpioIds::RTD_IC8,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
|
|
|
spi::SpiModes::MODE_1, 2000000);
|
|
|
|
SpiCookie* spiRtdIc9 = new SpiCookie(addresses::RTD_IC9, gpioIds::RTD_IC9,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
|
|
|
spi::SpiModes::MODE_1, 2000000);
|
|
|
|
SpiCookie* spiRtdIc10 = new SpiCookie(addresses::RTD_IC10, gpioIds::RTD_IC10,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
|
|
|
spi::SpiModes::MODE_1, 2000000);
|
|
|
|
SpiCookie* spiRtdIc11 = new SpiCookie(addresses::RTD_IC11, gpioIds::RTD_IC11,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
|
|
|
spi::SpiModes::MODE_1, 2000000);
|
|
|
|
SpiCookie* spiRtdIc12 = new SpiCookie(addresses::RTD_IC12, gpioIds::RTD_IC12,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
|
|
|
spi::SpiModes::MODE_1, 2000000);
|
|
|
|
SpiCookie* spiRtdIc13 = new SpiCookie(addresses::RTD_IC13, gpioIds::RTD_IC13,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
|
|
|
spi::SpiModes::MODE_1, 2000000);
|
|
|
|
SpiCookie* spiRtdIc14 = new SpiCookie(addresses::RTD_IC14, gpioIds::RTD_IC14,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
|
|
|
spi::SpiModes::MODE_1, 2000000);
|
|
|
|
SpiCookie* spiRtdIc15 = new SpiCookie(addresses::RTD_IC15, gpioIds::RTD_IC15,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
2021-06-02 10:25:35 +02:00
|
|
|
spi::SpiModes::MODE_1, 3900000);
|
2021-03-25 13:10:48 +01:00
|
|
|
SpiCookie* spiRtdIc16 = new SpiCookie(addresses::RTD_IC16, gpioIds::RTD_IC16,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
|
|
|
spi::SpiModes::MODE_1, 2000000);
|
|
|
|
SpiCookie* spiRtdIc17 = new SpiCookie(addresses::RTD_IC17, gpioIds::RTD_IC17,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
|
|
|
spi::SpiModes::MODE_1, 2000000);
|
|
|
|
SpiCookie* spiRtdIc18 = new SpiCookie(addresses::RTD_IC18, gpioIds::RTD_IC18,
|
|
|
|
std::string("/dev/spidev2.0"), Max31865Definitions::MAX_REPLY_SIZE,
|
|
|
|
spi::SpiModes::MODE_1, 2000000);
|
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
Max31865PT1000Handler* rtdIc3 = new Max31865PT1000Handler(objects::RTD_IC3,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc3, 0); // 0 is switchId
|
|
|
|
Max31865PT1000Handler* rtdIc4 = new Max31865PT1000Handler(objects::RTD_IC4,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc4, 0);
|
|
|
|
Max31865PT1000Handler* rtdIc5 = new Max31865PT1000Handler(objects::RTD_IC5,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc5, 0);
|
|
|
|
Max31865PT1000Handler* rtdIc6 = new Max31865PT1000Handler(objects::RTD_IC6,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc6, 0);
|
|
|
|
Max31865PT1000Handler* rtdIc7 = new Max31865PT1000Handler(objects::RTD_IC7,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc7, 0);
|
|
|
|
Max31865PT1000Handler* rtdIc8 = new Max31865PT1000Handler(objects::RTD_IC8,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc8, 0);
|
|
|
|
Max31865PT1000Handler* rtdIc9 = new Max31865PT1000Handler(objects::RTD_IC9,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc9, 0);
|
|
|
|
Max31865PT1000Handler* rtdIc10 = new Max31865PT1000Handler(objects::RTD_IC10,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc10, 0);
|
|
|
|
Max31865PT1000Handler* rtdIc11 = new Max31865PT1000Handler(objects::RTD_IC11,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc11, 0);
|
|
|
|
Max31865PT1000Handler* rtdIc12 = new Max31865PT1000Handler(objects::RTD_IC12,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc12, 0);
|
|
|
|
Max31865PT1000Handler* rtdIc13 = new Max31865PT1000Handler(objects::RTD_IC13,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc13, 0);
|
|
|
|
Max31865PT1000Handler* rtdIc14 = new Max31865PT1000Handler(objects::RTD_IC14,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc14, 0);
|
|
|
|
Max31865PT1000Handler* rtdIc15 = new Max31865PT1000Handler(objects::RTD_IC15,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc15, 0);
|
|
|
|
Max31865PT1000Handler* rtdIc16 = new Max31865PT1000Handler(objects::RTD_IC16,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc16, 0);
|
|
|
|
Max31865PT1000Handler* rtdIc17 = new Max31865PT1000Handler(objects::RTD_IC17,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc17, 0);
|
|
|
|
Max31865PT1000Handler* rtdIc18 = new Max31865PT1000Handler(objects::RTD_IC18,
|
|
|
|
objects::SPI_COM_IF, spiRtdIc18, 0);
|
2021-03-13 14:42:30 +01:00
|
|
|
|
2021-04-24 23:41:27 +02:00
|
|
|
(void) rtdIc3;
|
|
|
|
(void) rtdIc4;
|
|
|
|
(void) rtdIc5;
|
|
|
|
(void) rtdIc6;
|
|
|
|
(void) rtdIc7;
|
|
|
|
(void) rtdIc8;
|
|
|
|
(void) rtdIc9;
|
|
|
|
(void) rtdIc10;
|
|
|
|
(void) rtdIc11;
|
|
|
|
(void) rtdIc12;
|
|
|
|
(void) rtdIc13;
|
|
|
|
(void) rtdIc14;
|
|
|
|
(void) rtdIc15;
|
|
|
|
(void) rtdIc16;
|
2021-07-01 10:53:50 +02:00
|
|
|
(void) rtdIc17;
|
2021-04-24 23:41:27 +02:00
|
|
|
(void) rtdIc18;
|
2021-07-19 12:44:43 +02:00
|
|
|
}
|
2021-04-24 23:41:27 +02:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
void ObjectFactory::createReactionWheelComponents(LinuxLibgpioIF* gpioComIF) {
|
2021-06-21 14:46:46 +02:00
|
|
|
GpioCookie* gpioCookieRw = new GpioCookie;
|
2021-06-24 12:04:36 +02:00
|
|
|
GpioCallback* csRw1 = new GpioCallback(std::string("Chip select reaction wheel 1"), gpio::OUT,
|
2021-06-21 17:15:19 +02:00
|
|
|
1, &gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-06-24 12:04:36 +02:00
|
|
|
gpioCookieRw->addGpio(gpioIds::CS_RW1, csRw1);
|
|
|
|
GpioCallback* csRw2 = new GpioCallback(std::string("Chip select reaction wheel 2"), gpio::OUT,
|
2021-06-21 17:15:19 +02:00
|
|
|
1, &gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-06-24 12:04:36 +02:00
|
|
|
gpioCookieRw->addGpio(gpioIds::CS_RW2, csRw2);
|
|
|
|
GpioCallback* csRw3 = new GpioCallback(std::string("Chip select reaction wheel 3"), gpio::OUT,
|
2021-06-21 17:15:19 +02:00
|
|
|
1, &gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-06-24 12:04:36 +02:00
|
|
|
gpioCookieRw->addGpio(gpioIds::CS_RW3, csRw3);
|
|
|
|
GpioCallback* csRw4 = new GpioCallback(std::string("Chip select reaction wheel 4"), gpio::OUT,
|
2021-06-21 17:15:19 +02:00
|
|
|
1, &gpioCallbacks::spiCsDecoderCallback, gpioComIF);
|
2021-06-24 12:04:36 +02:00
|
|
|
gpioCookieRw->addGpio(gpioIds::CS_RW4, csRw4);
|
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
GpiodRegular* enRw1 = new GpiodRegular(std::string("gpiochip5"), 7,
|
|
|
|
std::string("Enable reaction wheel 1"), gpio::OUT, 0);
|
|
|
|
gpioCookieRw->addGpio(gpioIds::EN_RW1, enRw1);
|
|
|
|
GpiodRegular* enRw2 = new GpiodRegular(std::string("gpiochip5"), 3,
|
|
|
|
std::string("Enable reaction wheel 2"), gpio::OUT, 0);
|
|
|
|
gpioCookieRw->addGpio(gpioIds::EN_RW2, enRw2);
|
|
|
|
GpiodRegular* enRw3 = new GpiodRegular(std::string("gpiochip5"), 11,
|
|
|
|
std::string("Enable reaction wheel 3"), gpio::OUT, 0);
|
|
|
|
gpioCookieRw->addGpio(gpioIds::EN_RW3, enRw3);
|
|
|
|
GpiodRegular* enRw4 = new GpiodRegular(std::string("gpiochip5"), 6,
|
|
|
|
std::string("Enable reaction wheel 4"), gpio::OUT, 0);
|
|
|
|
gpioCookieRw->addGpio(gpioIds::EN_RW4, enRw4);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This GPIO is only internally connected to the SPI MUX module and responsible to disconnect
|
|
|
|
* the PS SPI peripheral from the SPI interface and route out the SPI lines of the AXI SPI core.
|
|
|
|
* Per default the PS SPI is selected (EMIO = 0).
|
|
|
|
*/
|
|
|
|
GpiodRegular* spiMux = new GpiodRegular(std::string("gpiochip11"), 54,
|
2021-07-01 10:53:50 +02:00
|
|
|
std::string("EMIO 0 SPI Mux"), gpio::OUT, 0);
|
|
|
|
gpioCookieRw->addGpio(gpioIds::SPI_MUX, spiMux);
|
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
gpioComIF->addGpios(gpioCookieRw);
|
2021-06-21 09:50:26 +02:00
|
|
|
|
2021-07-01 10:53:50 +02:00
|
|
|
auto rw1SpiCookie = new SpiCookie(addresses::RW1, gpioIds::CS_RW1, "/dev/spidev3.0",
|
|
|
|
RwDefinitions::MAX_REPLY_SIZE, spi::RW_MODE, spi::RW_SPEED, &rwSpiCallback::spiCallback,
|
|
|
|
nullptr);
|
|
|
|
auto rw2SpiCookie = new SpiCookie(addresses::RW2, gpioIds::CS_RW2, "/dev/spidev3.0",
|
|
|
|
RwDefinitions::MAX_REPLY_SIZE, spi::RW_MODE, spi::RW_SPEED, &rwSpiCallback::spiCallback,
|
|
|
|
nullptr);
|
|
|
|
auto rw3SpiCookie = new SpiCookie(addresses::RW3, gpioIds::CS_RW3, "/dev/spidev3.0",
|
|
|
|
RwDefinitions::MAX_REPLY_SIZE, spi::RW_MODE, spi::RW_SPEED, &rwSpiCallback::spiCallback,
|
|
|
|
nullptr);
|
|
|
|
auto rw4SpiCookie = new SpiCookie(addresses::RW4, gpioIds::CS_RW4, "/dev/spidev3.0",
|
|
|
|
RwDefinitions::MAX_REPLY_SIZE, spi::RW_MODE, spi::RW_SPEED, &rwSpiCallback::spiCallback,
|
|
|
|
nullptr);
|
2021-06-21 09:50:26 +02:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
auto rwHandler1 = new RwHandler(objects::RW1, objects::SPI_COM_IF, rw1SpiCookie, gpioComIF,
|
|
|
|
gpioIds::EN_RW1);
|
2021-06-21 14:46:46 +02:00
|
|
|
rw1SpiCookie->setCallbackArgs(rwHandler1);
|
2021-05-02 13:48:39 +02:00
|
|
|
|
2021-06-28 14:07:37 +02:00
|
|
|
auto rwHandler2 = new RwHandler(objects::RW2, objects::SPI_COM_IF, rw2SpiCookie, gpioComIF,
|
2021-07-19 12:44:43 +02:00
|
|
|
gpioIds::EN_RW2);
|
2021-06-28 14:07:37 +02:00
|
|
|
rw2SpiCookie->setCallbackArgs(rwHandler2);
|
|
|
|
|
2021-06-29 09:50:50 +02:00
|
|
|
auto rwHandler3 = new RwHandler(objects::RW3, objects::SPI_COM_IF, rw3SpiCookie, gpioComIF,
|
2021-07-19 12:44:43 +02:00
|
|
|
gpioIds::EN_RW3);
|
2021-06-29 16:08:20 +02:00
|
|
|
rw3SpiCookie->setCallbackArgs(rwHandler3);
|
2021-06-29 09:50:50 +02:00
|
|
|
|
|
|
|
auto rwHandler4 = new RwHandler(objects::RW4, objects::SPI_COM_IF, rw4SpiCookie, gpioComIF,
|
2021-07-19 12:44:43 +02:00
|
|
|
gpioIds::EN_RW4);
|
2021-06-29 09:50:50 +02:00
|
|
|
rw4SpiCookie->setCallbackArgs(rwHandler4);
|
2021-07-19 12:44:43 +02:00
|
|
|
}
|
2021-05-02 13:48:39 +02:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
void ObjectFactory::createTestComponents() {
|
2021-07-05 12:09:31 +02:00
|
|
|
new Q7STestTask(objects::TEST_TASK);
|
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
#if BOARD_TE0720 == 1 && TEST_LIBGPIOD == 1
|
2021-02-14 14:59:43 +01:00
|
|
|
/* Configure MIO0 as input */
|
2021-03-05 12:57:42 +01:00
|
|
|
GpiodRegular gpioConfigMio0(std::string("gpiochip0"), 0,
|
2021-02-14 12:35:08 +01:00
|
|
|
std::string("MIO0"), gpio::IN, 0);
|
2021-02-16 15:32:24 +01:00
|
|
|
GpioCookie* gpioCookie = new GpioCookie;
|
2021-03-05 12:57:42 +01:00
|
|
|
gpioCookie->addGpio(gpioIds::TEST_ID_0, gpioConfigMio0);
|
2021-02-14 14:59:43 +01:00
|
|
|
new LibgpiodTest(objects::LIBGPIOD_TEST, objects::GPIO_IF, gpioCookie);
|
2021-05-06 18:00:58 +02:00
|
|
|
#endif
|
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
#if BOARD_TE0720 == 1 && TEST_SUS_HANDLER == 1
|
2021-05-06 18:00:58 +02:00
|
|
|
GpioCookie* gpioCookieSus = new GpioCookie;
|
2021-05-12 13:06:56 +02:00
|
|
|
GpiodRegular* chipSelectSus = new GpiodRegular(std::string("gpiochip1"), 9,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("Chip Select Sus Sensor"), gpio::OUT, 1);
|
|
|
|
gpioCookieSus->addGpio(gpioIds::CS_SUS_1, chipSelectSus);
|
|
|
|
gpioComIF->addGpios(gpioCookieSus);
|
|
|
|
|
2021-05-12 13:06:56 +02:00
|
|
|
SpiCookie* spiCookieSus = new SpiCookie(addresses::SUS_1, std::string("/dev/spidev1.0"),
|
|
|
|
SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE, spi::DEFAULT_MAX_1227_SPEED);
|
2021-05-06 18:00:58 +02:00
|
|
|
|
2021-05-16 19:22:04 +02:00
|
|
|
new SusHandler(objects::SUS_1, objects::SPI_COM_IF, spiCookieSus, gpioComIF,
|
2021-05-07 18:48:42 +02:00
|
|
|
gpioIds::CS_SUS_1);
|
2021-05-16 19:22:04 +02:00
|
|
|
#endif
|
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
#if BOARD_TE0720 == 1 && TEST_CCSDS_BRIDGE == 1
|
2021-05-16 19:22:04 +02:00
|
|
|
GpioCookie* gpioCookieCcsdsIp = new GpioCookie;
|
|
|
|
GpiodRegular* papbBusyN = new GpiodRegular(std::string("gpiochip0"), 0, std::string("PAPBBusy_N"));
|
|
|
|
gpioCookieCcsdsIp->addGpio(gpioIds::PAPB_BUSY_N, papbBusyN);
|
|
|
|
GpiodRegular* papbEmpty = new GpiodRegular(std::string("gpiochip0"), 1,
|
|
|
|
std::string("Chip Select Sus Sensor"));
|
|
|
|
gpioCookieCcsdsIp->addGpio(gpioIds::PAPB_EMPTY, papbEmpty);
|
|
|
|
gpioComIF->addGpios(gpioCookieCcsdsIp);
|
|
|
|
|
|
|
|
new CCSDSIPCoreBridge(objects::CCSDS_IP_CORE_BRIDGE, objects::CCSDS_PACKET_DISTRIBUTOR,
|
|
|
|
objects::TM_STORE, objects::TC_STORE, gpioComIF, std::string("/dev/uio0"),
|
|
|
|
gpioIds::PAPB_BUSY_N, gpioIds::PAPB_EMPTY);
|
2021-05-06 18:00:58 +02:00
|
|
|
#endif
|
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
#if BOARD_TE0720 == 1 && TEST_RADIATION_SENSOR_HANDLER == 1
|
2021-05-06 18:00:58 +02:00
|
|
|
GpioCookie* gpioCookieRadSensor = new GpioCookie;
|
2021-05-12 13:06:56 +02:00
|
|
|
GpiodRegular* chipSelectRadSensor = new GpiodRegular(std::string("gpiochip1"), 0,
|
2021-05-06 18:00:58 +02:00
|
|
|
std::string("Chip select radiation sensor"), gpio::OUT, 1);
|
|
|
|
gpioCookieRadSensor->addGpio(gpioIds::CS_RAD_SENSOR, chipSelectRadSensor);
|
|
|
|
gpioComIF->addGpios(gpioCookieRadSensor);
|
|
|
|
|
|
|
|
SpiCookie* spiCookieRadSensor = new SpiCookie(addresses::RAD_SENSOR, gpioIds::CS_RAD_SENSOR,
|
|
|
|
std::string("/dev/spidev1.0"), SUS::MAX_CMD_SIZE, spi::DEFAULT_MAX_1227_MODE,
|
|
|
|
spi::DEFAULT_MAX_1227_SPEED);
|
|
|
|
|
|
|
|
RadiationSensorHandler* radSensor = new RadiationSensorHandler(objects::RAD_SENSOR,
|
|
|
|
objects::SPI_COM_IF, spiCookieRadSensor);
|
|
|
|
radSensor->setStartUpImmediately();
|
|
|
|
#endif
|
2021-04-11 12:04:13 +02:00
|
|
|
|
2021-07-26 19:56:00 +02:00
|
|
|
#if BOARD_TE0720 == 1 && ADD_PLOC_MPSOC == 1
|
2021-04-11 12:04:13 +02:00
|
|
|
UartCookie* plocUartCookie = new UartCookie(std::string("/dev/ttyPS1"), 115200,
|
2021-07-13 08:32:14 +02:00
|
|
|
PLOC_MPSOC::MAX_REPLY_SIZE);
|
|
|
|
/* Testing PlocMPSoCHandler on TE0720-03-1CFA */
|
|
|
|
PlocMPSoCHandler* mpsocPlocHandler = new PlocMPSoCHandler(objects::PLOC_MPSOC_HANDLER, objects::UART_COM_IF,
|
2021-04-11 12:04:13 +02:00
|
|
|
plocUartCookie);
|
2021-07-13 08:32:14 +02:00
|
|
|
mpsocPlocHandler->setStartUpImmediately();
|
2021-02-14 09:25:40 +01:00
|
|
|
#endif
|
2021-04-02 15:14:08 +02:00
|
|
|
|
2021-07-19 12:44:43 +02:00
|
|
|
#if BOARD_TE0720 == 1 && TE0720_HEATER_TEST == 1
|
2021-04-27 17:34:50 +02:00
|
|
|
/* Configuration for MIO0 on TE0720-03-1CFA */
|
|
|
|
GpiodRegular* heaterGpio = new GpiodRegular(std::string("gpiochip0"), 0, std::string("MIO0"), gpio::IN, 0);
|
|
|
|
GpioCookie* gpioCookie = new GpioCookie;
|
|
|
|
gpioCookie->addGpio(gpioIds::HEATER_0, heaterGpio);
|
|
|
|
new HeaterHandler(objects::HEATER_HANDLER, objects::GPIO_IF, gpioCookie, objects::PCDU_HANDLER,
|
|
|
|
pcduSwitches::TCS_BOARD_8V_HEATER_IN);
|
|
|
|
#endif
|
|
|
|
|
2021-07-26 19:56:00 +02:00
|
|
|
#if BOARD_TE0720 == 1 && ADD_PLOC_SUPERVISOR == 1
|
2021-07-13 08:32:14 +02:00
|
|
|
/* Configuration for MIO0 on TE0720-03-1CFA */
|
|
|
|
UartCookie* plocSupervisorCookie = new UartCookie(objects::PLOC_SUPERVISOR_HANDLER,
|
|
|
|
std::string("/dev/ttyPS1"), UartModes::NON_CANONICAL, 115200,
|
|
|
|
PLOC_SPV::MAX_REPLY_SIZE);
|
|
|
|
PlocSupervisorHandler* plocSupervisor = new PlocSupervisorHandler(
|
|
|
|
objects::PLOC_SUPERVISOR_HANDLER, objects::UART_COM_IF, plocSupervisorCookie);
|
|
|
|
plocSupervisor->setStartUpImmediately();
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2021-04-02 15:14:08 +02:00
|
|
|
#if Q7S_ADD_SPI_TEST == 1
|
|
|
|
new SpiTestClass(objects::SPI_TEST, gpioComIF);
|
|
|
|
#endif
|
2021-07-05 12:09:31 +02:00
|
|
|
|
2020-09-30 17:17:01 +02:00
|
|
|
}
|