2.3 KiB
2.3 KiB
Report di parità UDP1553 — GrifoScope C++ vs Python BusMonitor
Scopo
- Documentare le differenze rilevanti e le azioni applicate per rendere il parser Python compatibile con l'implementazione C++ (GrifoScope).
Riferimenti C++ analizzati
- cpp/GrifoScope/GrifoSdkEif/pub/TH/udp1553_types.h
- costanti: k_marker_1553=0x1553, k_marker_end_1553=0x5315, k_ctrl_marker_begin=0x3C3C, k_ctrl_marker_end=0x3E3E
- cpp/GrifoScope/GrifoSdkEif/dev/Portable/ext/b1553_udp.cpp
- funzione: processMessages(...) — logica di parsing dei blocchi messaggio
- comportamento reply builder e validazioni (~CW, 0x3E3E)
Correzioni principali applicate in Python
-
Word-count (wc) handling
- C++: se wc==0 -> wc=32; poi se SA==0 o SA==31 -> wc=0 (mode codes)
- Python: replicato esattamente (wc==0 -> 32; SA 0|31 -> wc=0)
-
TR bit semantics e presenza dati
- C++:
tr==1indica che il RT è il trasmettitore (RT->BC). Per i pacchetti BC (OTYPE_BC): wcin = tr ? 0 : wc (cioè se tr==1 non ci sono dati nel blocco BC) - Per i pacchetti di reply (OTYPE_RT) il reply include i dati quando tr==1.
- Python: implementata la stessa logica; il numero di parole dati presenti (wcin) dipende da
udp_header.otypee daltr_bit.
- C++:
-
Validazione terminatori
- C++ controlla che dopo i dati vi siano
~(cw.raw)e il markerk_ctrl_marker_end(0x3E3E). - Python: ora legge e confronta
inv_cwectrl_marker, logga mismatch inlogger.debugse non corrispondono.
- C++ controlla che dopo i dati vi siano
-
Creazione oggetti Message
- Python ora istanzia gli oggetti messaggio solo quando è presente il payload dati effettivo. Questo rispetta il fatto che le richieste BC->RT (tr==1) non contengono payload nel frame iniziale.
File modificati
- pybusmonitor1553/core/dispatcher.py
parse_packet()aggiornato per rispecchiare la logica C++ (wc, wcin, tr semantics, validate ~CW+0x3E3E)
Prossimi passi
- Eseguire
tools/verify_all_messages.pyper validare che i messaggi A/B vengono impacchettati/parsi come GrifoScope. - Se emergono discrepanze residue, applicare patch mirate a:
lib1553/MessageBase.pack()otools/network_sniffer.py.
Note
- Ho mantenuto endianness e uso di
ctypesgià presenti nel progetto. - I log di debug mostrano mismatch di marker/CW ma non interrompono il parsing; possiamo rendere il comportamento più rigido se necessario.
Creato automaticamente il: 2025-12-15