注意: これは既存の C2A core update の「リリースの間の Pull Request を眺めてなんとなく察する」という曖昧な操作を緩和していくための試みであり,C2A user に対するお知らせを行う場として使っていくことを意図しています.初めから c2a-core の全変更を取り扱うと不必要に煩雑になるだけになってしまうため,完全な変更内容の一覧についてはこれまで通り GitHub Releases などから参照してください.
- #460: Update Rust version & MSRV to 1.81.0
- #449: chore(config): migrate renovate config
- #448: chore(deps): update swatinem/rust-cache action to v2.8.0
- #447: chore(deps): update actions/setup-node action to v4.4.0
- #452: chore(deps): update actions/checkout action to v5
- #453: chore(deps): update reviewdog/action-actionlint action to v1.66.1
- #454: chore(deps): update dependency pnpm to v10
- #450: chore(deps): update actions/cache action to v4.2.4
- #451: chore(deps): update actions/setup-python action to v5.6.0
- #455: chore(deps): update reviewdog/action-actionlint action to v1.67.0
- #456: chore(deps): update actions/setup-node action to v5
- #457: chore(deps): update actions/setup-python action to v6
- #431: fix(deps): update rust crate once_cell to v1.21.3
- #443: fix(deps): update rust crate anyhow to v1.0.99
- #442: chore(deps): update dependency windows to v2025
- Rust
- MSRV (minimum supported Rust version) を 1.81.0 に上げたため、rust-toolchain.toml などで 1.81.0 以上のバージョンの Rust を指定してビルドすること
- #332: Rename tools dir to Boom tools
- #353: Move NodeJS package manager to pnpm
- #414: AOS 用 SCID を 10 bit に拡張
- #425: Configure c2a-core crate MSRV & set to 1.78
- #344: bindgen C2A RESULT type
- #348: Add C99 build option to example users
- #355: Make example user Printf() impl understandable
- #342: Update dependency ut-issl/s2e-core to v7.2.7
- #365: chore(deps): update arkedge/workflows-c2a action to v5.4.0
- #370: chore(deps): update dependency ut-issl/s2e-core to v7.2.9
- #392: C2A Boom: Install pre-compiled binaries
- #406: Add c2a-core Cargo lockfile
- #415: コマンドのパケット配送での EL 発行の追加
- #417: テレメのパケット配送での EL 発行の追加
- #380: WDTの監視周期設定コマンドの追加
- #424: Update Rust to 1.78.0
- #432: examples: Update Boom kble version to 0.4.2
- #433: examples: Update Boom Gaia version to v1.1.1
- #404: Force set home crate to 0.5.9
- #416: PH_analyze_tlm_packet の返り値を修正
- #420:
TSP_pei_dest_info_の設定ミスの修正 - #429: example: Install missing kble-serialport
- #345: Tell c2a-core crate re-build condition to cargo
- #334: Update sksat/setup-rye action to v0.23.1
- #335: Update actions/checkout action to v4.1.6
- #356: Update actions/checkout action to v4.1.7
- #357: Update sksat/action-clippy action to v1
- #358: Update sksat/setup-rye action to v0.24.0
- #361: Update actions/setup-node action to v4.0.3
- #360: Update sksat/setup-rye action to v0.25.0
- #362: Update actions/setup-python action to v5.1.1
- #367: chore(deps): update sksat/setup-rye action to v0.26.0
- #368: chore(deps): update sksat/setup-rye action to v0.28.0
- #374: chore(deps): update actions/checkout action to v4.2.2
- #378: chore(deps): update actions/cache action to v4.1.2
- #372: chore(deps): update actions/setup-node action to v4.1.0
- #371: chore(deps): update actions/setup-python action to v5.3.0
- #375: chore(deps): update sksat/setup-rye action to v0.31.0
- #382: chore(deps): update sksat/action-clippy action to v1.1.0
- #377: chore(deps): update swatinem/rust-cache action to v2.7.5
- #379: chore(deps): update crazy-max/ghaction-github-labeler action to v5.1.0
- #381: chore(deps): update python docker tag to v3.13
- #376: chore(deps): update dependency ubuntu to v24
- #387: Use Renovate Shareable config presets
- #390: Renovate generic cargo install in shell script
- #391: chore(config): migrate renovate config
- #402: cargo build with --locked option on Actions
- #403: Specify Rust toolchain version in CI with rust-toolchain.toml
- #393: Update actions/cache action to v4.2.0
- #396: Update Swatinem/rust-cache action to v2.7.7
- #397: Update sksat/action-clippy action to v1.1.1
- #399: chore: add repository to bind-utils package metadata
- #410: chore(deps): update actions/setup-node action to v4.2.0
- #422: chore(deps): update actions/cache action to v4.2.2
- #423: fix(deps): update rust crate anyhow to v1.0.97
- #409: chore(deps): update rust crate semver to v1.0.26
- #427: chore(deps): update actions/setup-python action to v5.4.0
- #428: chore(deps): update crazy-max/ghaction-github-labeler action to v5.2.0
- #430: chore(deps): update pnpm/action-setup action to v4.1.0
- #434: chore(deps): update actions/setup-node action to v4.3.0
- #435: chore(deps): pin dependencies
- #437: chore(deps): update swatinem/rust-cache action to v2.7.8
- #436: chore(deps): update actions/cache action to v4.2.3
- #439: chore(deps): update crazy-max/ghaction-github-labeler action to v5.3.0
- #438: chore(deps): update actions/setup-python action to v5.5.0
- C2A Boom
- Rust を 1.78.0 以上のバージョンに更新すること(MUST): #424, #425
- Rust の lockfile v4 移行に伴い、
c2a-corecrate の MSRV を 1.78 とした: #425 - もし C2A user プロジェクト/リポジトリで Rust バージョンが設定されていない場合は、
rust-toolchain.tomlを書いて Rust バージョンを固定すること(RECOMMENDED)
- Rust の lockfile v4 移行に伴い、
- CMake
- example user を参考に
C2A_BUILD_AS_C99option を明示的に追加すること(RECOMMENDED): #348- C99 に移行可能なプロジェクトは C99 への移行(default 値を
ONにする)ことを推奨する(RECOMMENDED)
- C99 に移行可能なプロジェクトは C99 への移行(default 値を
- example user を参考に
- WDT 監視周期設定コマンドの追加: #380
- example 実装を参考に、
WDT_SET_TIMERコマンドを実装すること(MUST)
- example 実装を参考に、
- AOS 用 SCID の 10bit 化: #414
- 8bit の SCID が枯渇したとのことなので、 CCSDS 732.0-P4.2 (DRAFT STANDARD) に則って AOS SCID を設定すること(RECOMMENDED)
- MOBC 向け CCSDS AOS Space Data Link Protocol ライブラリ(
tlm_cmd/ccsds/aos_space_data_link_protocol)の SCID の型がuint8_tからuint16_tに変更されたので、examples/mobcのパッチを参考に修正すること(MUST)
- code-generator
- #306: MOBC を想定した機能を有効化するためのビルドオプションを追加
- #310: Common Packet のディレクトリ変更
- #329: Common Packet のデフォルト実装を core から提供する(Space Packet のみ)
- #330: Rename c2a-sils-runtime to c2a-dev-runtime
- #327: Add rust-toolchain override config
- #319: Block Command Executor の Rotator の実行開始コマンド位置の修正
- BCE Rotator において,Rotate する BC の 0 番目のコマンドから実行されることを本来意図していた.
- 実際は 1 番目のコマンドから実行されていたため,意図通りの挙動になるように修正された.
- #289: Update Rust crate bindgen to 0.69.4
- #296: Update actions/cache action to v4
- #288: Update actions/deploy-pages action to v4.0.4
- #308: Update actions/upload-pages-artifact action to v3.0.1
- #295: Update sksat/setup-rye action to v0.15.0
- #293: Update sksat/action-clippy action to v0.7.1
- #294: Update dependency ut-issl/s2e-core to v7.2.5
- #290: Update Swatinem/rust-cache action to v2.7.3
- #307: Update actions/setup-node action to v4.0.2
- #316: Update actions/cache action to v4.0.1
- #315: Update Rust crate kble-socket to 0.3.0
- #311: Update Rust crate semver to 1.0.22
- #322: Update actions/deploy-pages action to v4.0.5
- #323: Update actions/cache action to v4.0.2
- #325: Update actions/setup-python action to v5.1.0
- #324: Update dependency ut-issl/s2e-core to v7.2.6
- #314: Update sksat/setup-rye action to v0.20.0
- #309: Update arkedge/workflows-c2a action to v5.2.0
- #333: Update CHANGELOG for v4.4.0 release
- コード生成
- #319: BCE Rotator の挙動を意図通りに修正したので,各 User で影響範囲を確認し,必要に応じて修正すること(MUST)
- BCE Rotator で実行順に依存するような処理がある場合は,適宜 TaskList 等の並び替えを行うこと
- Example User のデバッグ出力 App は,本 PR 適用前の BCE Rotator の誤った挙動に依存した BC 登録となっていた
- 同様なデバッグ出力 App を使用している user は,起動時の表示タイミングが変わるため,この PR の Example user の変更を取り込むこと
- #306, #329: MOBC を意図した User では,c2a-core をビルドする際
C2A_MOBC_FEATURESを define すること(MUST)- ビルドシステムに CMake を用いている場合は,同名の CMake option の
C2A_MOBC_FEATURESをONにする
- ビルドシステムに CMake を用いている場合は,同名の CMake option の
- #310, #329: Common Packet として Space Packet を利用している User では,c2a-core が提供するデフォルト実装を利用する(RECOMMENDED)
- デフォルト実装が src/src_core/tlm_cmd/common_packet/space_packet にあるので,ビルド対象に加える
- ビルドシステムに CMake を用いている場合は,C2A_USE_SPACE_PACKET_AS_COMMON_PACKET を
ONにする
- ビルドシステムに CMake を用いている場合は,C2A_USE_SPACE_PACKET_AS_COMMON_PACKET を
- User に含まれる以下のファイルが不要になるため,削除する
src/src_user/tlm_cmd/common_cmd_packet.csrc/src_user/tlm_cmd/common_tlm_cmd_packet.csrc/src_user/tlm_cmd/common_tlm_packet.c
src/src_user/settings/tlm_cmd/common_tlm_packet_define.cを新規に作成し,CTP_set_global_time()を定義する- コンパイルが通るように,以下の include の修正を行う
#include <src_core/tlm_cmd/common_cmd_packet.h>->#include <src_core/tlm_cmd/common_packet/common_cmd_packet.h>#include <src_core/tlm_cmd/common_cmd_packet_util.h>->#include <src_core/tlm_cmd/common_packet/common_cmd_packet_util.h>#include <src_core/tlm_cmd/common_tlm_cmd_packet.h>->#include <src_core/tlm_cmd/common_packet/common_tlm_cmd_packet.h>#include <src_core/tlm_cmd/common_tlm_cmd_packet.h>->#include <src_core/tlm_cmd/common_packet/common_tlm_cmd_packet.h>
- デフォルト実装が src/src_core/tlm_cmd/common_packet/space_packet にあるので,ビルド対象に加える
- #330:
c2a-sils-runtimeを用いていた C2A user のCargo.tomlやsrc/main.rsなどで crate 名をc2a-dev-runtimeに変更する
- Requirements を参考に,マイコンのスタックメモリの容量に余裕があるかどうか確認すること(MUST)
- 今後ハードウェアに対する要求事項は docs/general/requirements.md に書かれることになるので,今後のアップデートでも適宜確認すること
- 今回の経緯は #303 を参照
- #301 で要求されるスタック容量が増加している
- #302 で結果的に同程度以上のメモリ使用量削減を行っているため,実用上は今回のアップデートに伴って C2A user 側でメモリ使用量削減をする必要は無い
- #245: memory dump application のリファクタリング
- #266: example mobc の tlm の tlm id を再採番する (CDIS, CA)
- #269: Rename
src_user/settings/component_driver_super/dir tosrc_user/settings/component_driver/dir - #275: AM tlm でのキャストを緩和し,1 tlm でダウンリンクできる個数を減少させた
- C2A Boom
- c2a-core crates
- code-generator
- #261: TL TLM に TL に登録された cmd 数を追加
- #263: CDIS や BCT に保存された CCP をダンプする App を追加
- #268: GS と FSW 側での同期のために,BCT, TL のダイジェスト (CRC) を下ろせるようにする App の追加
- #270: Component Driver を統一的に c2a-core で扱えるようにし,CDS の tlm と,テレメ不通関連 Cmd を追加
- #273: 任意の Component Driver に対して,任意バイト列の送受信と HAL init, reopen Cmd を提供する
- #274:
TMGR_get_master_mode_cycle_in_msecなどの in_sec 版を実装 - #260: C2A 初期化時に実行環境のエンディアンが設定と正しいかチェックする
- #265: [code-generator] subobc の MD5 の計算のバグ修正
- #251: の修正であるため,中途半端なバージョンを使用していなければ対応不要
- #279:
component_driver_utility.cでのパラメタ取得のバグ修正 - #286: Fix examples/subobc pytest testcase dir
- #298: max_tlm_num のアサーションの off-by-one error の修正
- #243: の修正であるため,中途半端なバージョンを使用していなければ対応不要
- #238: Add missing v4.1.0 compatible tools to changelog
- #247: VS Code を使ったデバッグ手順の追加 / READMEの微修正
- #278: タスク定期実行に関するドキュメントを追加
- #246: node_modules を .gitignore に追加
- #231: Update actions/setup-python action to v5
- #248: Update actions/setup-node action to v4.0.1
- #253: Update actions/deploy-pages action to v4
- #254: Update actions/upload-pages-artifact action to v3
- #250: Update sksat/setup-rye action to v0.10.0
- #252: Update sksat/action-clippy action to v0.4.0
- #258: Update renovate default reviewers
- #241: Update dependency ut-issl/s2e-core to v7.1.1
- #271: CDS: ComponentDriverSuper の整理(コードに変更なし)
- #272: sync_with_mobc_example.bat のメンテ
- #264: Update dependency ut-issl/s2e-core to v7.2.0
- #276: Update Rust crate semver to 1.0.21
- #257: Update arkedge/workflows-c2a action to v5
- #282: Update Swatinem/rust-cache action to v2.7.2
- #283: Fix check-coding-rule v4 workflow in workflows-c2a v5
- #284: Enable example build all again
- #285: Use matrix job to build multiple example users with same config
- C2A Boom
- コード生成
- #269:
src/src_user/settings/component_driver_superの rename(MUST)src/src_user/settings/component_driver_superをsrc/src_user/settings/component_driverに rename する- user 側の include path を,
/component_driver_super/から/component_driver/に一斉置換する src_user/settings/CMakeLists.txtの/component_driver_super/が含まれる path を/component_driver/に一斉置換する
- #261:
examples/mobcの TL TLM を更新したので,examples/mobc/tlm-cmd-db/TLM_DB/SAMPLE_MOBC_TLM_DB_TL.csvを user 側の TL TLM に上書きする - #266: 以下の tlm id を変更したため,これらを user 側の tlm db に上書きする
examples/mobc/tlm-cmd-db/TLM_DB/SAMPLE_MOBC_TLM_DB_CDIS.csvexamples/mobc/tlm-cmd-db/TLM_DB/SAMPLE_MOBC_TLM_DB_CA.csv
- #245: 影響範囲は memory dump application を使う OBC のみ
- Tlm Cmd DB を
examples/mobcのものと同様にする- cmd:
MEM_* - tlm:
MEM
- cmd:
examples/mobcのsrc/src_user/settings/applications/memory_dump_define.hを参考に作成して設定する
- Tlm Cmd DB を
- #263: CcpDump App の追加
- この App を利用する user は
src/src_core/applications/ccp_dump.cをビルド対象に加え,App 登録する examples/mobc/tlm-cmd-db/TLM_DB/SAMPLE_MOBC_TLM_DB_CCP_DUMP.csvを user 側の tlm db に追加するexamples/mobc/tlm-cmd-db/CMD_DB/SAMPLE_MOBC_CMD_DB_CMD_DB.csvのCCP_DUMP_*コマンドを user 側の cmd db に追加するexamples/mobcからsrc/src_user/test/src_core/applications/test_ccp_dump.pyをコピーする- もし,汎用テスト用 BCT
BC_TEST_USE_PYTESTが user 側に存在しない場合, user 側の BCT ID にも加える
- もし,汎用テスト用 BCT
- この App を利用する user は
- #268: TL BCT Digest App の追加
- この App を利用する user は
applications/tl_bct_digest.cをビルド対象に加え,App 登録する examples/mobc/tlm-cmd-db/TLM_DB/{SAMPLE_MOBC_TLM_DB_TL_DIGEST.csv,SAMPLE_MOBC_TLM_DB_BCT_DIGEST.csv}を user 側の tlm db に追加するexamples/mobc/tlm-cmd-db/CMD_DB/SAMPLE_MOBC_CMD_DB_CMD_DB.csvのTL_BCT_DIGEST_*コマンドを user 側の cmd db に追加するexamples/mobcからsrc/src_user/test/src_core/applications/test_tl_bct_digest.pyをコピーする- もし,汎用テスト用 BCT
BC_TEST_USE_PYTESTが user 側に存在しない場合, user 側の BCT ID にも加える
- もし,汎用テスト用 BCT
- この App を利用する user は
- #270, #273: ComponentDriverUtility App の追加
CDRV_IDを user 側で設定するexamples/mobcを参考に,src/src_user/settings/component_driver/component_driver_define.{c,h}を配置し,ビルド対象に加える
- この App を利用する user は
src/src_core/applications/component_driver_utility.cをビルド対象に加え,App 登録する examples/mobcを参考に,src/src_user/settings/applications/component_driver_utility_params.hを配置するexamples/mobc/tlm-cmd-db/CMD_DB/SAMPLE_MOBC_CMD_DB_CMD_DB.csvのCDRV_UTIL_*コマンドを user 側の cmd db に追加するexamples/mobc/tlm-cmd-db/CMD_DB/SAMPLE_MOBC_CMD_DB_CMD_DB.csvのCDRV_UTIL_*コマンドを user 側の cmd db に追加するexamples/mobc/tlm-cmd-db/TLM_DB/SAMPLE_MOBC_TLM_DB_CDRV_UTIL.csvを user 側の tlm db に追加するexamples/mobc/tlm-cmd-db/TLM_DB/SAMPLE_MOBC_TLM_DB_CDRV_UTIL_HAL_RX_DATA.csvを user 側の tlm db に追加する- もし, user 側で subobc ありの pytest を扱っている場合,
examples/subobcからsrc/src_user/test/test_component_driver_utility.pyをコピーする
- #275: AM tlm のキャスト緩和(u8 -> u16)に伴う tlm 再設定
- App manager のテレメサイズのデフォルト設定が変わったため,再設定すること
- App の初期化時間がそこまで長くならないような状況であったり,テレメサイズを切り詰めたい場合は引き続き u8 としてよい
examples/mobcと同様にする場合は,examples/mobc/tlm-cmd-db/TLM_DB/SAMPLE_MOBC_TLM_DB_AM.csvを user 側の AM tlm に上書きするexamples/mobcを参考にsrc/src_user/settings/system/app_manager_params.hを更新する- tlm と整合が取れるように,特に
AM_TLM_PAGE_SIZE,AM_TLM_PAGE_SIZEに注意して更新する
- tlm と整合が取れるように,特に
- #193: VCDU を AOS transfer frame に rename する
- #197: M_PDU をコード規約に合わせるなどのリファクタ
- #199: Drop c2a-core crate links config
- #201: Refactor release rule
- #225: Space Packet 関連ファイルのディレクトリを変更
- #214: CCSDS の主に MOBC 向け Data Link Layer のコードを Core 管理にする
- #219: CCSDS data link layer における SCID をユーザー設定として切り出す
- #220: APIDの命名規則の更新
- 命名規則は
tlm_cmd/common_tlm_cmd_packet.hを参照
- 命名規則は
- #188: [v3.10.1 Backport] PL_BC_LIST_CLEARED を level high で EL 登録する
- #204: More match v4.0.0 script migration
- #205: Fix v4 applications rename order
- #206: More match system migration
- #211: Fix v4 system rename typo
- #212: More match v4 tlmcmd rename migration
- #218: Feedback from v4.0.0 beta.4
- #223: Feedback from v4.0.0 beta.5 migration
- #224: Feedback from v4.0.0 migration
- #222: add section 漏れを修正
- #215: Update v4.0.0 migration guide
- #207: Move doxygen config to top
- #208: Exclude Doxygen stdint_wrapper
- #209: Deploy Doxygen generated HTML to GitHub Pages
- #179: Update Rust crate bindgen to 0.69.1
- #210: Update dependency ut-issl/s2e-core to v7.1.0
- #229: Run Rust CI on all workspace crates
- #193: 影響範囲は MOBC のみ
src_user/tlm_cmd/ccsds/vcdu.{c,h}を消し,src_user/tlm_cmd/ccsds/aos_transfer_frame.{c,h}をexamples/mobcからコピーする.CMakeLists.txtも修正する.VCDUをAOSTFに置換する(TLM DB の csv なども).vcduをaostfに置換する(TLM DB の csv なども).vcdu.hをaos_transfer_frame.hに置換する(include の修正).- コンパイルが通らないところを直す.想定されるものは以下.
VCDU構造体 がAosTransferFrame構造体に変わったので,変数定義の型名が変わっているはず.
- #197: 影響範囲は MOBC のみ
src_user/tlm_cmd/ccsds/m_pdu.{c,h}を消し,src_user/tlm_cmd/ccsds/multiplexing_protocol_data_unit.{c,h}をexamples/mobcからコピーする.CMakeLists.txtも修正する.m_pdu.hをmultiplexing_protocol_data_unit.hに置換する(include の修正).- コンパイルが通らないところを直す.想定されるものは以下.
M_PDU構造体 がMultiplexingProtocolDataUnit構造体に変わったので,変数定義の型名が変わっているはず.
- #225
- コンパイルが通るように,以下の include の修正を行う.
#include <src_core/tlm_cmd/ccsds/space_packet.h>->#include <src_core/tlm_cmd/ccsds/space_packet_protocol/space_packet.h>#include <src_core/tlm_cmd/ccsds/space_packet_typedef.h>->#include <src_core/tlm_cmd/ccsds/space_packet_protocol/space_packet_typedef.h>#include <src_core/tlm_cmd/ccsds/tlm_space_packet.h>->#include <src_core/tlm_cmd/ccsds/space_packet_protocol/tlm_space_packet.h>#include <src_core/tlm_cmd/ccsds/cmd_space_packet.h>->#include <src_core/tlm_cmd/ccsds/space_packet_protocol/cmd_space_packet.h>
- コンパイルが通るように,以下の include の修正を行う.
- #214: 影響範囲は MOBC の CCSDS Data Link Layer の実装
- AOS Space Data Link Protocol の実装を c2a-core のものに切り替える
src_user/tlm_cmd/ccsds/内の既存の実装を消すaos_transfer_frame.{c,h}multiplexing_protocol_data_unit.{c,h}tcp_to_m_pdu.{c,h}
- c2a-core の実装を使うように切り替える
src_core/ccsds/aos_space_data_link_protocol/内のソースファイルをビルド対象に追加する- CMake の場合,
C2A_USE_CORE_CCSDS_AOS_SPACE_DATA_LINK_PROTOCOLoption をONにするだけでよい (C2A user top のCMakeLists.txt)examples/mobc/CMakeLists.txtを参考にできる.
- コンパイルが通らないところを直す.ファイルの場所が変わったことによる include path の修正が想定される.
- TC Space Data Link Protocol の実装を c2a-core のものに切り替える
src_user/tlm_cmd/ccsds/内の既存の実装を消すtc_segment.{c,h}tc_transfer_frame.{c,h}
- c2a-core の実装を使うように切り替える
src_core/ccsds/tc_space_data_link_protocol/内のソースファイルをビルド対象に追加する- CMake の場合,
C2A_USE_CORE_CCSDS_TC_SPACE_DATA_LINK_PROTOCOLoption をONにするだけでよい (C2A user top のCMakeLists.txt)examples/mobc/CMakeLists.txtを参考にできる.
- コンパイルが通らないところを直す.ファイルの場所が変わったことによる include path の修正が想定される.
- AOS Space Data Link Protocol の実装を c2a-core のものに切り替える
- #219: 影響範囲は MOBC のみ
- PR の diff (
examples/mobc/src/) に出ている修正を, user にも反映させる.
- PR の diff (
- #220
tlm_cmd/common_tlm_cmd_packet.hにある命名規則に従うように, APID の命名を更新する.
- ut-issl/tlm-cmd-db v2.4.0
- ut-issl/python-wings-interface v1.5.1
- arkedge/gaia v0.5.0
- tlmcmddb-cli 0.2.0
- kble 0.2.0
- C2A DevTools
- #185: Add Gaia label
arkedge/c2a-core v4.0.0 は ArkEdge Space Inc. による C2A の先行開発のための ut-issl/c2a-core の fork 後最初のリリースとなる. v4.0.0 では,fork に伴う開発体制の変更に加え,以下の大きなセマンティクス的な変更を行ったため,major update とした.
- 大規模な rename
- 各ツールの c2a-core リポジトリへの吸収合併
- Rust のエコシステム / C2A 標準開発環境 C2A Boom の導入
大規模な rename はあくまで現在の設計・コードの責務をできるだけ明らかにし,(特に C2A の開発経験の無い一般的なソフトウェアエンジニアを中心とした)開発者のディスコミュニケーションを低減する目的で実施した.
ex: IfWrapper -> HAL, Driver -> Component Driver
また,ディレクトリ名に大文字・小文字があったりなかったりする,不必要に階層構造が深いといった歪なディレクトリ構造の修正も行った.
ex: src/src_core/System -> src/src_core/system, src/src_user/Settings/TlmCmd/data_base -> tlm-cmd-db
これらの rename は大規模ではあるものの,C2A としてのロジックの変更やリファクタリングはほぼ行っていない. この移行については migration script を用意している(Migration Guide 参照).
各ツールの c2a-core リポジトリへの吸収合併については,ut-issl/c2a-enum-loader や ut-issl/c2a-tlm-cmd-code-generator などの c2a-core のコード構成に依存したツールのリリース単位は c2a-core と同一であると判断し実施した.
これらのツールについては,今後は各 C2A user で使用している c2a-core と同じバージョンのものを使用してもらうことになる(実務上は src/src_core から使うことになる).
Rust エコシステム / C2A Boom の導入については,ArkEdge Space Inc. 内での開発成果を OSS 化しつつ実施した. これらについては c2a-core v3 系に対しても互換性があり導入可能だが,新機能の開発や積極的なサポートは c2a-core v4 系以降を前提として行われる可能性がある.
- ut-issl/c2a-core v3.10.0 から ArkEdge Space Inc. による先行開発のために fork し,リポジトリを arkedge/c2a-core に移行
- #1: ライセンス情報の更新
- 94: メジャーバージョンアップ中は煩雑さ軽減のために c2a-core の Pre-Release の免除を可能に
- #18: CommandDispatcher の統一的なテレメの提供
- #19: App の initializer, entry_point の返り値を void から RESULT にする
- 各ディレクトリ名・構造の変更
- #15: example user を
minimum_user->mobc,2nd_obc_user->subobcに変更 - #20: ディレクトリ名のコーディング規約を
CamelCaseからsnake_caseに変更- v4 系統ではこの変更は移行期間とし,あらゆるディレクトリ名を一気に変更する必要はないものとしている
- #42: Rust の crate のためのディレクトリは小文字の
-区切りとする
- #8: C2A 用語の rename
- #28: 歪なディレクトリ構造の修正
- #122, #124:
src/src_core/Drivers/Super->src/src_core/driver,src/src_core/Drivers/Protocol->src/src_core/driver - #138:
src/src_user/Test->src/src_user/test,src/src_user/Test/test->src/src_user/test - #10: ディレクトリ名の CamelCase をやめて snake_case にする
- #20: コーディング規約の変更
- #21, #24:
IfWrapper->hal - #26:
c2a-core/Examples->c2a-core/examples - #31:
Docs->docs - #33, #39:
Script->script - #46, #48, #140:
Applications->applications - #50, #51, #53:
Library->library - #54, #55, #125:
System->system - #79, #80:
TlmCmd->tlm_cmd - #122, #124:
Drivers->driver - #138:
src/src_user/Test->src/src_user/test - #167, #168:
src/src_user/Settings->src/src_user/settings
- #172:
src/src_user/settings/tlm_cmd/data_base->tlm-cmd-db
- #122, #124:
- 移行には scripts/migration/ 以下の
v4-rename-*.shの migration script を使用可能- example user についてはこの migration script のみで移行しているが,あらゆる C2A user の状況について考慮できているわけではないため,適宜対応が必要
- #15: example user を
- #23, #25, #129, #130, #131:
hal(旧IfWrapper)のうち,古すぎるインターフェースを排除- 既に使われてしまっているものについては,各 C2A user で一旦雑に古いヘッダファイルを各々で持って対応可能(今後再設計する予定)
- #97:
check_coding_rule.pyの設定ファイルであるcheck_coding_rule.jsonの場所を C2A user のトップディレクトリに変更- 対応方法
Script/CI/check_coding_rule.jsonないしscript/ci/check_coding_rule.jsonを C2A user のトップディレクトリに移動- 設定ファイルから
c2a_root_dirを削除 - 設定ファイル中のディレクトリの設定を C2A user のトップディレクトリからの相対パスに変更
- 対応方法
- #99: ut-issl/c2a-enum-loader を c2a-core リポジトリで管理するように変更
- import したバージョン: ut-issl/c2a-enum-loader ae-v2.0.0
- #111: ut-issl/c2a-tlm-cmd-code-generator を c2a-core リポジトリで管理するように変更
- import したバージョン: ut-issl/c2a-tlm-cmd-code-generator ae-v2.0.0
- #83, #86, #132, #139: CMake option の整理
C2A_prefix に統一した(これはコーディング規約にも追加)- 意味が分かりにくい命名の変更,今後 optional としていく挙動を default OFF とした
option()の挙動はユーザ指定によってかなり変わるため,該当する変更は単なるビルドチェックなどではなくすべて grep して変更することBUILD_C2A_AS_UTF8->C2A_BUILD_AS_UTF8BUILD_C2A_AS_C99->C2A_BUILD_AS_C99BUILD_C2A_AS_CXX->C2A_BUILD_AS_CXX(NOT USE_32BIT_COMPILER)->C2A_BUILD_FOR_32BIT:ONの時に明示的に 32bit ターゲットとしてビルドする(-m32をつける)(NOT C2A_USE_STDINT_WRAPPER)->C2A_USE_STDINT_WRAPPER: C89 ターゲットでビルドする際にONにすることでユーザ定義のstdint.hを使うBUILD_C2A_AS_SILS_FW->C2A_BUILD_FOR_SILSUSE_ALL_C2A_CORE_APPS->C2A_USE_ALL_CORE_APPSUSE_ALL_C2A_CORE_TEST_APPS->C2A_USE_ALL_CORE_TEST_APPSUSE_ALL_C2A_CORE_LIB->C2A_USE_ALL_CORE_LIBUSE_SCI_COM_WINGS->C2A_USE_SCI_COM_WINGS: 今後 WINGS 向けビルドは optional なものとなるので,default で OFF に変更.使う場合はビルド時に指定するか,S2E user のCMakeLists.txtで設定することUSE_SCI_COM_UART->C2A_USE_SCI_COM_UARTUSE_SILS_MOCKUP->C2A_BUILD_WITH_SILS_MOCKUPSHOW_DEBUG_PRINT_ON_SILS->C2A_BUILD_WITH_SILS_MOCKUP
- #35, #37:
c2a-corecrate で Rust 向けの binding を提供する- C2A 内で共通の bindgen の設定を使用可能にするため,c2a-bind-utils crate を追加
- #38: C2A 単体での SILS のための C2A のランタイム実装である
c2a-sils-runtimecrate を追加 - 共通して使用可能な C2A HAL(旧
IfWrapper)実装群を追加 - #44, #45:
c2a-sils-runtimeと Rust 製の C2A HAL 実装を使って,example user の C2A 単体での SILS(S2E なし)を実装 - #56: 新たな C2A 標準環境である
C2A Boomを example user に導入- これに伴い,各種 ArkEdge 独自のライブラリ・ツール群が 導入・OSS 化された
- Gaia
- tlmcmddb-cli
- kble
- C2A DevTools
- #59: example user に対して,Gaia を用いた pytest を導入
- python-wings-interface 互換の Gaia(
tmtc-c2a)向けインターフェースとして c2a-pytest-gaia を導入 - これに伴い,Python の仮想環境・ツールチェーン管理に rye を導入
- #60: example user の Gaia pytest CI を導入
- python-wings-interface 互換の Gaia(
- #117:
tlm-cmd-code-generator/settings.jsonを commit しないようにし,example user 用の設定ファイルを追加した - #127: Import README.md as crate documentation
- #77: Use locked version dependencies for install jrsonnet
- #92: Build C2A example users for i686 target
- #96: Use released version tools
- #1: v4 fork に伴う README,Licence の修正
- #3: Issue/PR template の更新
- #16: Docs の中でコードを参照している URL の行数を修正
- #29: Update repository URL in Rust package due to fork
- #52: Update README about SILS runtime
- #62: 関連リポジトリをreadmeに追加
- #65: 通信プロトコルについてのドキュメントを更新
- #85: Create CHANGELOG.md & write v4 current change log
- #93: リリースルールの明瞭化
- #123: c2a-sils-runtime や C2A DevTools での開発のためのドキュメントを追加
- #135: Fix CHANGELOG.md
- #157: Update v4 changelog
- #177: インデントのスペースを GFM に準拠する
- #4: Update Rust crate semver to 1.0.18
- #27: エンコーディングチェック CI に subobc が抜けていたので追加
- #30:
c2a-corecrate のためのソースファイルをsrc/lib.rsからc2a_core.rsに移動し,紛らわしいsrcディレクトリを削除 - #34: Make c2a-core repository as cargo workspace
- #36: Add rustfmt check
- #47: Update Swatinem/rust-cache action to v2.6.2
- #57: Run Rust CI on develop
- #61: Update reviewdog/action-setup action to v1.0.6
- #63: Pre Release (v4.0.0-beta.0): v4 の最初の beta release
- #66: Update actions/setup-node action to v3.8.1
- #67: 主に S2E の更新のために Renovate regexManager で GitHub Actions workflow 内のバージョン直打ちの依存の自動更新
- #68: Update dependency ut-issl/s2e-core to v6.4.0
- #69: Remove Renovate regexManager match v prefix
- #72: Update arkedge/workflows-c2a action to v4
- #74: pytest CI の 重複を除去する
- #75: Update sksat/setup-rye action to v0.7.0
- #78: Automatically add bug label to bug report issue
- #81: Update actions/checkout action to v4
- #87: Update Rust crate bindgen to 0.68.1
- #89: Update crazy-max/ghaction-github-labeler action to v5
- #90: Update Swatinem/rust-cache action to v2.7.0
- #98: Update arkedge/workflows-c2a action to v4.3.0
- #101: Update actions/checkout action to v4.1.0
- #102: Update Rust crate semver to 1.0.19
- #109: Update sksat/setup-rye action to v0.8.0
- #110: Update arkedge/workflows-c2a action to v4.4.0
- #112: Update python Docker tag to v3.12
- #113: Update sksat/setup-rye action to v0.9.0
- #118: Remove unneeded directory
- #120: Update Rust crate semver to 1.0.20
- #126: Add example user's tlm_cmd code generation check workflow
- #136: Update arkedge/workflows-c2a action to v4.5.1
- #137: Update arkedge/workflows-c2a action to v4.5.2
- #152: Update dependency ut-issl/s2e-core to v7
- ut-issl/s2e-core#519: Fix include c2a-core v4
- #158: Update actions/checkout action to v4.1.1
- #159: Update sksat/setup-rye action to v0.9.1
- #160: Update sksat/action-clippy action to v0.3.0
- #161: Update Swatinem/rust-cache action to v2.7.1
- #164: Update actions/setup-node action to v4
- #173: Fix missing rename/drop in scripts
- c2a-code-generator: ut-issl/c2a-tlm-cmd-code-generator ae-v2.0.0 を c2a-core リポジトリに吸収し,rename した
- c2a-enum-loader: ut-issl/c2a-enum-loader ae-v2.0.0 を c2a-core リポジトリに吸収した
- ut-issl/tlm-cmd-db v2.4.0
- ut-issl/python-wings-interface v1.5.1
- arkedge/gaia v0.5.0
- tlmcmddb-cli 0.2.0
- kble 0.2.0
- C2A DevTools
注意: migration 方法やスクリプトの修正などもありえるため,本 Migration Guide 及び Migration Script は c2a-core v4 系のその時点での最新版を参照すること.例えば,使う c2a-core version が v4.0.0 であっても,v4.1.0 や v4.2.0 がリリースされていれば,その時点のものを参照すること.
- pytest への rye の導入(RECOMMENDED)
- 現在使用している c2a-core version を確認する(MUST)
- ut-issl/c2a-core v3.8 系以前: サポート外.まずは v3.9 系までアップデートすること.
- ut-issl/c2a-core v3.9.0: サポート外.ut-issl/c2a-core v3.9.1 が結果的に breaking な release となってしまっているため,必ず ut-issl/c2a-core v3.9.1 を経由して v3.10 系にアップデートすること.
- ut-issl/c2a-core v3.9.1 ~ ut-issl/c2a-core v3.9.2: 移行はほぼ確実に可能と思われるが,明示的なサポートはしない.容易にアップデートが可能であるはずなため,事前にut-issl/c2a-core v3.10.0 へアップデートすること.
- ut-issl/c2a-core v3.10.0: v4.0.0 ~ v4.0.1 への移行をサポート.
- ut-issl/c2a-core v3.10.1: 限定的にサポート.
- v4.0.0 ~ v4.0.1 への移行: 可能ではあるものの,ut-issl/c2a-core v3.10.0 からの差分は一時的に失われることになる
- v4.0.2(TBD) で移行をサポート予定
- v4.0.0-alpha.0
- #19 の変更を取り込む
- v4.0.0-alpha.1
- #21, #24: IfWrapper -> HAL の rename: v4-rename-ifwrapper.sh を実行
- #25:
IfWrapper/dc.hを使用していた場合は,一旦 C2A user にヘッダを移す(src/src_user/hal/dc.h)
- v4.0.0-alpha.2
- #18 の変更を取り込む
- [yanked] v4.0.0-beta.0: このバージョンは yank されているため,tag は存在するが使わないこと
- v4.0.0-beta.1
- #33, #39: Script ディレクトリの rename を実行(v4-rename-script.sh)
- #46, #48: Applications ディレクトリの rename を実行(v4-rename-applications.sh)
- #50, #51, #53: Library ディレクトリの rename を実行(v4-rename-library.sh)
- #54, #55: System ディレクトリの rename を実行(v4-rename-system.sh)
- #125 のため,c2a-core 部分の AddSection.pl はこの時点では動作しなくなってしまっている
- #79, #80: TlmCmd ディレクトリの rename を実行(v4-rename-tlmcmd.sh)
- #96
- ut-issl/c2a-enum-loader のバージョン変更: ae-v2.0.0
- ut-issl/c2a-tlm-cmd-code-generator のバージョン変更: ae-v2.0.0
- #97: check-coding-rule の設定ファイル(
check_coding_rule.json)をトップディレクトリに移す- workflows-c2a v4.3.0 からこの構造に対応
- ただし,この挙動変更は workflows-c2a に対しては breaking change なので,新規に .github/workflows/check-coding-rule-v4.yml という workflow を生やしており,こちらに移行する必要がある(workflows-c2a#63)
- v4.0.0-beta.2
- #100: rye の
build-backendに pdm を指定する- c2a-enum-loader の相対パスでの指定への切り替えのためにすることになる(SHALL)
- これにより,rye の lockfile にそれを実行した PC での絶対パスが吐かれてしまうという既知の問題があるが,これは別途今後対処予定(#106)であり,v4.0.0 の段階では一旦許容するものとしている
- #99: c2a-enum-loader を
src/src_core/enum-loaderのものに切り替える- このバージョンから ut-issl/c2a-enum-loader が c2a-core リポジトリに同梱されるようになった
- そのため,pytest で c2a-enum-loader を指定している部分を切り替える必要がある(SHOULD)
src/src_user/Test/pyproject.tomlのdependenciesのc2aenumの部分を以下のようにする"c2aenum @ file:///${PROJECT_ROOT}/../../src_core/enum-loader"
- #111: c2a-tlm-cmd-code-generator を c2a-core のものに切り替える
- このバージョンから ut-issl/c2a-tlm-cmd-code-generator が c2a-core リポジトリに同梱されるようになった
- そのため,各 C2A user でのコード生成は以下のディレクトリで実行することになる(SHALL)
- v4.0.0-beta.2 時点では
src/src_core/tlm-cmd-code-generator - v4.0.0-beta.5(#153)以降は
src/src_core/code-generator
- v4.0.0-beta.2 時点では
- #86: C2A 全体で共通の CMake の option 修正
- #100: rye の
- v4.0.0-beta.3
- #122: Drivers ディレクトリの rename を実行(v4-rename-driver.sh)
- c2a-tlm-cmd-code-generator にも更新があるので,念のため再度コード生成を行うこと(migration script の実行時点で diff が出て,それと変わらないはず)
- #132: C2A user 側の CMake option の整理
- C2A user ごとに設定が異なるので,手動で確認・修正する必要がある
- ただし,example user なので基本的には各 C2A user でもテンプレート的にこの実装が用いられているはずであり,同じ/同様の option 名を使っている場合は example user での命名に揃えることが推奨される(RECOMMENDED)
C2A_USE_SCI_COM_WINGSを default OFF にする(RECOMMENDED)- このオプションを使う場合(つまり,SILS-S2E で WINGS と疎通する場合),S2E user の
CMakeLists.txtないしビルドスクリプト側でこのオプションを ON にして使うこと.あくまで C2A user 単体としては,この機能は optional であるべき.
- このオプションを使う場合(つまり,SILS-S2E で WINGS と疎通する場合),S2E user の
- #122: Drivers ディレクトリの rename を実行(v4-rename-driver.sh)
- v4.0.0-beta.4
- #146, #147: Driver -> Component Driver の rename を実行(v4-rename-driver2)
- #143, #144, #150: Driver instance -> Component Service の rename を実行(v4-rename-driver-instance.sh)
- 略語の 'DI' は短すぎるため,文脈が明らかなものしか sed していない.適宜検索して置き換えること(特にコマンド名になっているようなものに注意).
- v4.0.0-beta.5
- #153: code generator のパス変更:
src/src_core/tlm-cmd-code-generator->src/src_core/code-generator - #138: C2A user の pytest のディレクトリ構成のリファクタ: v4-rename-test-dir.sh を実行
- #154, #155: v4-rename-component-driver-prefix.sh を実行
- #165, #166, #169: v4-rename-if-list.sh
- #153: code generator のパス変更:
- v4.0.0
- #167, #168:
src/src_user/Settings->src/src_user/settings: v4-rename-settings.sh を実行 - #172:
src/src_user/settings/tlm_cmd/data_base->tlm-cmd-dbの rename を実行(v4-move-db-dir.sh)
- #167, #168: