diff options
| author | Keith Packard <keithp@keithp.com> | 2011-11-11 22:30:17 -0800 | 
|---|---|---|
| committer | Keith Packard <keithp@keithp.com> | 2011-11-11 22:30:17 -0800 | 
| commit | b132eefc5f63412bb4a98a4bb72b9055e40d5d42 (patch) | |
| tree | 53f0d529cf30b21649b69cee3e5f8966adf86642 /src/core/ao_telemetry.c | |
| parent | 7ecde50fbebe68a2e2200a2f8d081fd37074f840 (diff) | |
altos: Make ao_xmem funcs require __xdata void * instead of casting
Having an explicit cast in the ao_xmem wrapper macros caused the
compiler to generate garbage values for pdata addresses, making the
upper byte 0x00 instead of the required 0xf0. Removing the
casts from the ao_xmem macros exposed this problem, so a new
PDATA_TO_XDATA macros was added, along with a CODE_TO_XDATA macro
which serve to cast pointers, with suitable address modifications, so
that things work again.
Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'src/core/ao_telemetry.c')
| -rw-r--r-- | src/core/ao_telemetry.c | 8 | 
1 files changed, 4 insertions, 4 deletions
diff --git a/src/core/ao_telemetry.c b/src/core/ao_telemetry.c index e66598d1..c68f1589 100644 --- a/src/core/ao_telemetry.c +++ b/src/core/ao_telemetry.c @@ -132,11 +132,11 @@ ao_send_configuration(void)  		telemetry.configuration.main_deploy = ao_config.main_deploy;  		telemetry.configuration.flight_log_max = ao_config.flight_log_max >> 10;  		ao_xmemcpy (telemetry.configuration.callsign, -			ao_config.callsign, -			AO_MAX_CALLSIGN); +			    ao_config.callsign, +			    AO_MAX_CALLSIGN);  		ao_xmemcpy (telemetry.configuration.version, -			ao_version, -			AO_MAX_VERSION); +			    CODE_TO_XDATA(ao_version), +			    AO_MAX_VERSION);  		ao_radio_send(&telemetry, sizeof (telemetry));  		ao_telemetry_config_cur = ao_telemetry_config_max;  	}  | 
