From 9b12a7e5bd8a4bf29d49548e36111e50da4024a3 Mon Sep 17 00:00:00 2001 From: Michael Zillgith Date: Fri, 18 Aug 2023 16:27:00 +0100 Subject: [PATCH] - R-SESSION: send correct payload type tag depending on payload --- src/r_session/r_session.c | 3 ++- src/r_session/r_session.h | 1 + 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/src/r_session/r_session.c b/src/r_session/r_session.c index 704aba19..973a1f01 100644 --- a/src/r_session/r_session.c +++ b/src/r_session/r_session.c @@ -862,7 +862,7 @@ encodePacket(RSession self, uint8_t payloadType, uint8_t* buffer, int bufPos, RS while (element) { /* payload type ? (according to example in annex G) */ - buffer[bufPos++] = 0x82; + buffer[bufPos++] = element->payloadType; /* simulation */ buffer[bufPos++] = element->simulation; @@ -964,6 +964,7 @@ RSession_sendMessage(RSession self, RSessionProtocol_SPDU_ID spduId, bool simula element.simulation = simulation; element.appId = appId; element.payload = payload; + element.payloadType = (spduId & 0x0f) + 0x80; element.payloadSize = payloadSize; element.nextElement = NULL; diff --git a/src/r_session/r_session.h b/src/r_session/r_session.h index f0e5a2e1..438d6bf7 100644 --- a/src/r_session/r_session.h +++ b/src/r_session/r_session.h @@ -69,6 +69,7 @@ struct sRSessionPayloadElement { bool simulation; uint16_t appId; + uint8_t payloadType; uint8_t* payload; int payloadSize; RSessionPayloadElement nextElement; /* NULL when no more elements follow */