0
1
mirror of https://github.com/radio95-rnt/rds95.git synced 2026-02-26 20:33:53 +01:00
This commit is contained in:
2025-04-13 17:53:40 +02:00
parent e7589beda1
commit c38b6cc5fa

View File

@@ -100,17 +100,16 @@ static uint16_t get_next_af(RDSEncoder* enc) {
if (enc->data[enc->program].af.num_afs) { if (enc->data[enc->program].af.num_afs) {
uint8_t* afs = enc->data[enc->program].af.afs; uint8_t* afs = enc->data[enc->program].af.afs;
uint8_t num_afs = enc->data[enc->program].af.num_afs; uint8_t num_afs = enc->data[enc->program].af.num_afs;
uint8_t* af_state = &enc->state[enc->program].af_state;
if (*af_state < num_afs) { if (enc->state[enc->program].af_state < num_afs) {
out = afs[*af_state]; out = afs[enc->state[enc->program].af_state];
(*af_state)++; enc->state[enc->program].af_state++;
} else { } else {
out = AF_CODE_FILLER; out = AF_CODE_FILLER;
} }
if (*af_state >= enc->data[enc->program].af.num_entries) { if (enc->state[enc->program].af_state >= enc->data[enc->program].af.num_entries) {
*af_state = 0; enc->state[enc->program].af_state = 0;
} }
} else { } else {
out = AF_CODE_NUM_AFS_BASE << 8 | AF_CODE_FILLER; out = AF_CODE_NUM_AFS_BASE << 8 | AF_CODE_FILLER;
@@ -122,19 +121,18 @@ static uint16_t get_next_af(RDSEncoder* enc) {
static void get_next_af_oda(RDSEncoder* enc, uint16_t* af_group) { static void get_next_af_oda(RDSEncoder* enc, uint16_t* af_group) {
uint16_t* afs = enc->data[enc->program].af_oda.afs; uint16_t* afs = enc->data[enc->program].af_oda.afs;
uint16_t num_afs = enc->data[enc->program].af_oda.num_afs; uint16_t num_afs = enc->data[enc->program].af_oda.num_afs;
uint16_t* af_state = &enc->state[enc->program].af_oda_state;
for (int i = 0; i < 4; ++i) { for (int i = 0; i < 4; ++i) {
if (*af_state < num_afs) { if (enc->state[enc->program].af_oda_state < num_afs) {
af_group[i] = afs[*af_state]; af_group[i] = afs[enc->state[enc->program].af_oda_state];
(*af_state)++; enc->state[enc->program].af_oda_state++;
} else { } else {
af_group[i] = AF_CODE_FILLER; af_group[i] = AF_CODE_FILLER;
} }
} }
if (*af_state >= enc->data[enc->program].af_oda.num_entries) { if (enc->state[enc->program].af_oda_state >= enc->data[enc->program].af_oda.num_entries) {
*af_state = 0; enc->state[enc->program].af_oda_state = 0;
} }
} }
@@ -286,7 +284,7 @@ static void get_oda_af_oda_group(RDSEncoder* enc, RDSGroup *group) {
static void get_oda_af_group(RDSEncoder* enc, RDSGroup *group) { static void get_oda_af_group(RDSEncoder* enc, RDSGroup *group) {
uint16_t af[4]; uint16_t af[4];
get_next_af_oda(enc, &af); get_next_af_oda(enc, af);
group->b |= 9 << 12; group->b |= 9 << 12;
for (int i = 0; i < 4; i++) { for (int i = 0; i < 4; i++) {