diff --git a/CMakeLists.txt b/CMakeLists.txt index 1e60650e0..de896e4c7 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -19,6 +19,7 @@ option(C2A_BUILD_FOR_SILS "Build C2A for SILS target" ON) option(C2A_USE_ALL_CORE_APPS "Use C2A-core all Applications" ON) option(C2A_USE_ALL_CORE_TEST_APPS "Use C2A-core all Test Applications" ON) option(C2A_USE_ALL_CORE_LIB "Use C2A-core all library" ON) +option(C2A_USE_SPACE_PACKET_AS_COMMON_PACKET "Use C2A-core Space Packet as Common Packet implementation" ON) ## C2A build target board option (標準実装などがこのオプションによってスイッチされる.デフォルトでは sub OBC を想定) option(C2A_MOBC_FEATURES "Enable some features for MOBC" OFF) @@ -108,6 +109,16 @@ if(C2A_USE_ALL_CORE_LIB) target_sources(${PROJECT_NAME} PUBLIC $) endif() +if(C2A_MOBC_FEATURES) + message("Enable some features for MOBC") + target_compile_definitions(${PROJECT_NAME} PUBLIC C2A_MOBC_FEATURES) +endif() + +if(C2A_USE_SPACE_PACKET_AS_COMMON_PACKET) + add_subdirectory(tlm_cmd/common_packet/space_packet) + target_sources(${PROJECT_NAME} PUBLIC $) +endif() + if(C2A_USE_CORE_CCSDS_AOS_SPACE_DATA_LINK_PROTOCOL) add_subdirectory(tlm_cmd/ccsds/aos_space_data_link_protocol) target_sources(${PROJECT_NAME} PUBLIC $) diff --git a/examples/mobc/CMakeLists.txt b/examples/mobc/CMakeLists.txt index 0583bd82d..dec6d5278 100644 --- a/examples/mobc/CMakeLists.txt +++ b/examples/mobc/CMakeLists.txt @@ -20,6 +20,8 @@ option(C2A_BUILD_WITH_SILS_MOCKUP "Build C2A with SILS mockup for check undefine option(C2A_BUILD_FOR_SILS "Build C2A for SILS target" ON) +set(C2A_MOBC_FEATURES ON) + # core に同梱されている CCSDS の実装を使う set(C2A_USE_CORE_CCSDS_AOS_SPACE_DATA_LINK_PROTOCOL ON) set(C2A_USE_CORE_CCSDS_TC_SPACE_DATA_LINK_PROTOCOL ON) diff --git a/examples/mobc/src/src_user/settings/CMakeLists.txt b/examples/mobc/src/src_user/settings/CMakeLists.txt index 85905036d..b65d78263 100644 --- a/examples/mobc/src/src_user/settings/CMakeLists.txt +++ b/examples/mobc/src/src_user/settings/CMakeLists.txt @@ -18,6 +18,7 @@ set(C2A_SRCS system/event_handler_rules/event_handler_rules.c system/event_handler_rules/event_handler_rule_test.c tlm_cmd/common_cmd_packet_define.c + tlm_cmd/common_tlm_packet_define.c tlm_cmd/ccsds/aos_transfer_frame_define.c tlm_cmd/ccsds/apid_define.c tlm_cmd/ccsds/tc_transfer_frame_define.c diff --git a/examples/mobc/src/src_user/settings/tlm_cmd/common_tlm_packet_define.c b/examples/mobc/src/src_user/settings/tlm_cmd/common_tlm_packet_define.c new file mode 100644 index 000000000..3cead370c --- /dev/null +++ b/examples/mobc/src/src_user/settings/tlm_cmd/common_tlm_packet_define.c @@ -0,0 +1,16 @@ +#pragma section REPRO +/** + * @file + * @brief CTP 型の user 定義 + */ +#include +#include + +void CTP_set_global_time(CommonTlmPacket* packet) +{ + // 何を設定するかはユーザー定義 + // TMGR_get_curret_unixtime() で現在の unixtime を入れたり, gps 時刻 を入れたり, など + TSP_set_global_time(packet, 0.0); +} + +#pragma section diff --git a/examples/mobc/src/src_user/tlm_cmd/CMakeLists.txt b/examples/mobc/src/src_user/tlm_cmd/CMakeLists.txt index cc0d7962a..3e21fd0d6 100644 --- a/examples/mobc/src/src_user/tlm_cmd/CMakeLists.txt +++ b/examples/mobc/src/src_user/tlm_cmd/CMakeLists.txt @@ -6,9 +6,6 @@ set(C2A_SRCS block_command_definitions.c block_command_user_settings.c command_definitions.c - common_cmd_packet.c - common_tlm_cmd_packet.c - common_tlm_packet.c telemetry_definitions.c user_packet_handler.c normal_block_command_definition/nbc_start_hk_tlm.c diff --git a/examples/mobc/src/src_user/tlm_cmd/common_tlm_cmd_packet.c b/examples/mobc/src/src_user/tlm_cmd/common_tlm_cmd_packet.c deleted file mode 100644 index 0ab4f01f9..000000000 --- a/examples/mobc/src/src_user/tlm_cmd/common_tlm_cmd_packet.c +++ /dev/null @@ -1,80 +0,0 @@ -#pragma section REPRO -/** - * @file - * @brief CTCP 関連基本関数の定義 - * @note CTCP: CommonTlmCmdPacket - * @note CTP: CommonTlmPacket - * @note CCP: CommonCmdPacket - */ -#include -#include -#include - - -int CTCP_is_valid_packet(const CommonTlmCmdPacket* packet) -{ - if (packet == NULL) return 0; - if ( CTCP_get_packet_len(packet) > CTCP_MAX_LEN ) return 0; - - return 1; -} - -CTCP_PACKET_TYPE CTCP_get_packet_type(const CommonTlmCmdPacket* packet) -{ - switch (SP_get_type(packet)) - { - case SP_TYPE_TLM: - return CTCP_PACKET_TYPE_TLM; - - case SP_TYPE_CMD: - return CTCP_PACKET_TYPE_CMD; - - default: - return CTCP_PACKET_TYPE_UNKNOWN; - } -} - -uint16_t CTCP_get_packet_len(const CommonTlmCmdPacket* packet) -{ - return SP_get_packet_len(packet); -} - -APID CTCP_get_apid(const CommonTlmCmdPacket* packet) -{ - return SP_get_apid(packet); -} - -void CTCP_set_apid(CommonTlmCmdPacket* packet, APID apid) -{ - SP_set_apid(packet, apid); -} - -void CTCP_copy_packet(CommonTlmCmdPacket* dest, const CommonTlmCmdPacket* src) -{ - SP_copy_packet(dest, src); -} - -// FIXME: 以下4関数について, Space Packet が整備されたら, `if len(ctcp) > CCP_MAX_LEN return NULL;` のようなアサーションをいれる! -const CommonTlmPacket* CTCP_convert_to_ctp(const CommonTlmCmdPacket* ctcp) -{ - if (CTCP_get_packet_type(ctcp) != CTCP_PACKET_TYPE_TLM) return NULL; - return (const CommonTlmPacket*)ctcp; -} - -const CommonTlmCmdPacket* CTCP_convert_from_ctp(const CommonTlmPacket* ctp) -{ - return (const CommonTlmCmdPacket*)ctp; -} - -const CommonCmdPacket* CTCP_convert_to_ccp(const CommonTlmCmdPacket* ctcp) -{ - if (CTCP_get_packet_type(ctcp) != CTCP_PACKET_TYPE_CMD) return NULL; - return (const CommonCmdPacket*)ctcp; -} - -const CommonTlmCmdPacket* CTCP_convert_from_ccp(const CommonCmdPacket* ccp) -{ - return (const CommonTlmCmdPacket*)ccp; -} - -#pragma section diff --git a/examples/mobc/src/src_user/tlm_cmd/common_tlm_packet.c b/examples/mobc/src/src_user/tlm_cmd/common_tlm_packet.c deleted file mode 100644 index f08fd37cc..000000000 --- a/examples/mobc/src/src_user/tlm_cmd/common_tlm_packet.c +++ /dev/null @@ -1,90 +0,0 @@ -#pragma section REPRO -/** - * @file - * @brief CTP 関連基本関数の定義 - * @note CTP: CommonTlmPacket - */ -#include -#include -#include -#include - - -int CTP_is_valid_packet(const CommonTlmPacket* packet) -{ - if (packet == NULL) return 0; - if ( CTP_get_packet_len(packet) > CTP_MAX_LEN ) return 0; - - return 1; -} - -APID CTP_get_apid(const CommonTlmPacket* packet) -{ - return TSP_get_apid(packet); -} - -void CTP_set_apid(CommonTlmPacket* packet, APID apid) -{ - TSP_set_apid(packet, apid); -} - -double CTP_get_global_time(const CommonTlmPacket* packet) -{ - return TSP_get_global_time(packet); -} - -void CTP_set_global_time(CommonTlmPacket* packet) -{ - // 何を設定するかはユーザー定義 - // TMGR_get_curret_unixtime() で現在の unixtime を入れたり, gps 時刻 を入れたり, など - TSP_set_global_time(packet, 0.0); -} - -uint32_t CTP_get_on_board_subnet_time(const CommonTlmPacket* packet) -{ - return TSP_get_on_board_subnet_time(packet); -} - -void CTP_set_on_board_subnet_time(CommonTlmPacket* packet) -{ - // 何を設定するかはユーザー定義 - // MOBC では主に TI を,sub OBC では主に 0xffffffff を - TSP_set_on_board_subnet_time(packet, (uint32_t)TMGR_get_master_total_cycle()); -} - -ctp_dest_flags_t CTP_get_dest_flags(const CommonTlmPacket* packet) -{ - return TSP_get_dest_flags(packet); -} - -void CTP_set_dest_flags(CommonTlmPacket* packet, ctp_dest_flags_t flags) -{ - TSP_set_dest_flags(packet, flags); -} - -TLM_CODE CTP_get_id(const CommonTlmPacket* packet) -{ - return TSP_get_tlm_id(packet); -} - -void CTP_set_id(CommonTlmPacket* packet, TLM_CODE id) -{ - TSP_set_tlm_id(packet, id); -} - -uint16_t CTP_get_packet_len(const CommonTlmPacket* packet) -{ - return TSP_get_packet_len(packet); -} - -uint8_t* CTP_get_user_data_head(CommonTlmPacket* packet) -{ - return TSP_get_user_data_head(packet); -} - -void CTP_copy_packet(CommonTlmPacket* dest, const CommonTlmPacket* src) -{ - TSP_copy_packet(dest, src); -} - -#pragma section diff --git a/examples/subobc/src/src_user/settings/CMakeLists.txt b/examples/subobc/src/src_user/settings/CMakeLists.txt index 93716c0c5..9aff96e45 100644 --- a/examples/subobc/src/src_user/settings/CMakeLists.txt +++ b/examples/subobc/src/src_user/settings/CMakeLists.txt @@ -15,6 +15,7 @@ set(C2A_SRCS system/event_logger_settings.c system/event_handler_rules/event_handler_rules.c tlm_cmd/common_cmd_packet_define.c + tlm_cmd/common_tlm_packet_define.c tlm_cmd/ccsds/apid_define.c ) diff --git a/examples/subobc/src/src_user/settings/tlm_cmd/common_tlm_packet_define.c b/examples/subobc/src/src_user/settings/tlm_cmd/common_tlm_packet_define.c new file mode 100644 index 000000000..3cead370c --- /dev/null +++ b/examples/subobc/src/src_user/settings/tlm_cmd/common_tlm_packet_define.c @@ -0,0 +1,16 @@ +#pragma section REPRO +/** + * @file + * @brief CTP 型の user 定義 + */ +#include +#include + +void CTP_set_global_time(CommonTlmPacket* packet) +{ + // 何を設定するかはユーザー定義 + // TMGR_get_curret_unixtime() で現在の unixtime を入れたり, gps 時刻 を入れたり, など + TSP_set_global_time(packet, 0.0); +} + +#pragma section diff --git a/examples/subobc/src/src_user/tlm_cmd/CMakeLists.txt b/examples/subobc/src/src_user/tlm_cmd/CMakeLists.txt index 3b4ea3a5d..0a0544420 100644 --- a/examples/subobc/src/src_user/tlm_cmd/CMakeLists.txt +++ b/examples/subobc/src/src_user/tlm_cmd/CMakeLists.txt @@ -6,9 +6,6 @@ set(C2A_SRCS block_command_definitions.c block_command_user_settings.c command_definitions.c - common_cmd_packet.c - common_tlm_cmd_packet.c - common_tlm_packet.c telemetry_definitions.c user_packet_handler.c normal_block_command_definition/nbc_start_hk_tlm.c diff --git a/examples/subobc/src/src_user/tlm_cmd/common_cmd_packet.c b/examples/subobc/src/src_user/tlm_cmd/common_cmd_packet.c deleted file mode 100644 index 851227d07..000000000 --- a/examples/subobc/src/src_user/tlm_cmd/common_cmd_packet.c +++ /dev/null @@ -1,105 +0,0 @@ -#pragma section REPRO -/** - * @file - * @brief CTP 関連基本関数の定義 - * @note CCP: CommonCmdPacket - */ -#include -#include -#include - - -int CCP_is_valid_packet(const CommonCmdPacket* packet) -{ - if (packet == NULL) return 0; - if ( CCP_get_packet_len(packet) > CCP_MAX_LEN ) return 0; - - return 1; -} - -cycle_t CCP_get_ti(const CommonCmdPacket* packet) -{ - return (cycle_t)CSP_get_ti(packet); -} - -void CCP_set_ti(CommonCmdPacket* packet, cycle_t ti) -{ - CSP_set_ti(packet, (uint32_t)ti); -} - -APID CCP_get_apid(const CommonCmdPacket* packet) -{ - return CSP_get_apid(packet); -} - -void CCP_set_apid(CommonCmdPacket* packet, APID apid) -{ - CSP_set_apid(packet, apid); -} - -CCP_EXEC_TYPE CCP_get_exec_type(const CommonCmdPacket* packet) -{ - return CSP_get_exec_type(packet); -} - -void CCP_set_exec_type(CommonCmdPacket* packet, CCP_EXEC_TYPE type) -{ - CSP_set_exec_type(packet, type); -} - -CCP_DEST_TYPE CCP_get_dest_type(const CommonCmdPacket* packet) -{ - return CSP_get_dest_type(packet); -} - -void CCP_set_dest_type(CommonCmdPacket* packet, CCP_DEST_TYPE type) -{ - CSP_set_dest_type(packet, type); -} - -CMD_CODE CCP_get_id(const CommonCmdPacket* packet) -{ - return CSP_get_cmd_id(packet); -} - -void CCP_set_id(CommonCmdPacket* packet, CMD_CODE id) -{ - CSP_set_cmd_id(packet, id); -} - -uint16_t CCP_get_packet_len(const CommonCmdPacket* packet) -{ - return CSP_get_packet_len(packet); -} - -uint16_t CCP_get_param_len(const CommonCmdPacket* packet) -{ - return CSP_get_param_len(packet); -} - -uint16_t CCP_get_max_param_len(void) -{ - return (uint16_t)(CSP_MAX_LEN - SP_PRM_HDR_LEN - CSP_SND_HDR_LEN); -} - -const uint8_t* CCP_get_param_head(const CommonCmdPacket* packet) -{ - return CSP_get_param_head(packet); -} - -void CCP_set_param(CommonCmdPacket* packet, const uint8_t* param, uint16_t len) -{ - CSP_set_param(packet, param, len); -} - -void CCP_set_common_hdr(CommonCmdPacket* packet) -{ - CSP_set_common_hdr(packet); -} - -void CCP_copy_packet(CommonCmdPacket* dest, const CommonCmdPacket* src) -{ - CSP_copy_packet(dest, src); -} - -#pragma section diff --git a/examples/subobc/sync_with_mobc_example.bat b/examples/subobc/sync_with_mobc_example.bat index 0eb71b6b0..0df6b46ad 100644 --- a/examples/subobc/sync_with_mobc_example.bat +++ b/examples/subobc/sync_with_mobc_example.bat @@ -19,6 +19,7 @@ call :sync_file ".\src\src_user\hal\sils_mockup\wdt_sils.c" "..\mobc\src\src_use call :sync_file ".\src\src_user\settings\git_revision_config.h" "..\mobc\src\src_user\settings\git_revision_config.h" call :sync_file ".\src\src_user\settings\component_driver_super\driver_buffer_define.h" "..\mobc\src\src_user\settings\component_driver_super\driver_buffer_define.h" call :sync_file ".\src\src_user\settings\tlm_cmd\common_cmd_packet_define.c" "..\mobc\src\src_user\settings\tlm_cmd\common_cmd_packet_define.c" +call :sync_file ".\src\src_user\settings\tlm_cmd\common_tlm_packet_define.c" "..\mobc\src\src_user\settings\tlm_cmd\common_tlm_packet_define.c" call :sync_file ".\src\src_user\settings\tlm_cmd\common_tlm_cmd_packet_define.h" "..\mobc\src\src_user\settings\tlm_cmd\common_tlm_cmd_packet_define.h" call :sync_file ".\src\src_user\settings\tlm_cmd\ccsds\apid_define.c" "..\mobc\src\src_user\settings\tlm_cmd\ccsds\apid_define.c" call :sync_file ".\src\src_user\settings\tlm_cmd\ccsds\apid_define.h" "..\mobc\src\src_user\settings\tlm_cmd\ccsds\apid_define.h" diff --git a/tlm_cmd/common_packet/space_packet/CMakeLists.txt b/tlm_cmd/common_packet/space_packet/CMakeLists.txt new file mode 100644 index 000000000..984a86e91 --- /dev/null +++ b/tlm_cmd/common_packet/space_packet/CMakeLists.txt @@ -0,0 +1,17 @@ +cmake_minimum_required(VERSION 3.13) + +project(C2A_CORE_SPACE_PACKET_AS_COMMON_PACKET) + +set(C2A_SRCS + common_cmd_packet.c + common_tlm_cmd_packet.c + common_tlm_packet.c +) + +if(C2A_BUILD_AS_CXX) + set_source_files_properties(${C2A_SRCS} PROPERTIES LANGUAGE CXX) # C++ +endif() + +add_library(${PROJECT_NAME} OBJECT ${C2A_SRCS}) + +include(${C2A_CORE_DIR}/common.cmake) diff --git a/examples/mobc/src/src_user/tlm_cmd/common_cmd_packet.c b/tlm_cmd/common_packet/space_packet/common_cmd_packet.c similarity index 93% rename from examples/mobc/src/src_user/tlm_cmd/common_cmd_packet.c rename to tlm_cmd/common_packet/space_packet/common_cmd_packet.c index 851227d07..b4fc1ce1e 100644 --- a/examples/mobc/src/src_user/tlm_cmd/common_cmd_packet.c +++ b/tlm_cmd/common_packet/space_packet/common_cmd_packet.c @@ -4,8 +4,8 @@ * @brief CTP 関連基本関数の定義 * @note CCP: CommonCmdPacket */ -#include -#include +#include "../common_cmd_packet.h" +#include "../../ccsds/space_packet_protocol/cmd_space_packet.h" #include diff --git a/examples/subobc/src/src_user/tlm_cmd/common_tlm_cmd_packet.c b/tlm_cmd/common_packet/space_packet/common_tlm_cmd_packet.c similarity index 93% rename from examples/subobc/src/src_user/tlm_cmd/common_tlm_cmd_packet.c rename to tlm_cmd/common_packet/space_packet/common_tlm_cmd_packet.c index 0ab4f01f9..3ad7be63b 100644 --- a/examples/subobc/src/src_user/tlm_cmd/common_tlm_cmd_packet.c +++ b/tlm_cmd/common_packet/space_packet/common_tlm_cmd_packet.c @@ -6,8 +6,8 @@ * @note CTP: CommonTlmPacket * @note CCP: CommonCmdPacket */ -#include -#include +#include "../common_tlm_cmd_packet.h" +#include "../../ccsds/space_packet_protocol/space_packet.h" #include diff --git a/examples/subobc/src/src_user/tlm_cmd/common_tlm_packet.c b/tlm_cmd/common_packet/space_packet/common_tlm_packet.c similarity index 78% rename from examples/subobc/src/src_user/tlm_cmd/common_tlm_packet.c rename to tlm_cmd/common_packet/space_packet/common_tlm_packet.c index 0bab0a732..4c192bceb 100644 --- a/examples/subobc/src/src_user/tlm_cmd/common_tlm_packet.c +++ b/tlm_cmd/common_packet/space_packet/common_tlm_packet.c @@ -4,8 +4,9 @@ * @brief CTP 関連基本関数の定義 * @note CTP: CommonTlmPacket */ -#include -#include +#include "../common_tlm_packet.h" +#include "../../ccsds/space_packet_protocol/tlm_space_packet.h" +#include "../../../system/time_manager/time_manager.h" #include @@ -32,13 +33,6 @@ double CTP_get_global_time(const CommonTlmPacket* packet) return TSP_get_global_time(packet); } -void CTP_set_global_time(CommonTlmPacket* packet) -{ - // 何を設定するかはユーザー定義 - // TMGR_get_curret_unixtime() で現在の unixtime を入れたり, gps 時刻 を入れたり, など - TSP_set_global_time(packet, 0.0); -} - uint32_t CTP_get_on_board_subnet_time(const CommonTlmPacket* packet) { return TSP_get_on_board_subnet_time(packet); @@ -48,7 +42,11 @@ void CTP_set_on_board_subnet_time(CommonTlmPacket* packet) { // 何を設定するかはユーザー定義 // MOBC では主に TI を,sub OBC では主に 0xffffffff を - TSP_set_on_board_subnet_time(packet, 0xffffffff); + uint32_t time = 0xffffffff; +#ifdef C2A_MOBC_FEATURES + time = (uint32_t)TMGR_get_master_total_cycle(); +#endif + TSP_set_on_board_subnet_time(packet, time); } ctp_dest_flags_t CTP_get_dest_flags(const CommonTlmPacket* packet)