view target-utils/include/romvars.h @ 924:d452188587b4

rvinterf: begin change to backslash escape output format Right now throughout the rvinterf suite, any time we emit output that is expected to be ASCII, but may contain non-printable garbage, we use 'cat -v' form of garbage character representation. Unfortunately, this transformation is lossy (can't be reversed 100% reliably in the user's wetware), hence we would like to migrate to C-style backslash escapes, including doubling of any already-present backslashes - this escape mechanism is lossless. Begin this change by converting the output of RV and L1 traces in rvinterf and rvtdump.
author Mychaela Falconia <falcon@freecalypso.org>
date Tue, 23 May 2023 03:10:50 +0000
parents e7502631a0f9
children
line wrap: on
line source

/*
 * Our loadagent will always be loaded into Calypso targets by the on-chip
 * boot ROM operating in the UART download mode.  The lowest IRAM address
 * at which we can load our code is 0x800750; somewhat lower at 0x800518
 * the boot ROM downloader has a few variables which may have been intended
 * to be private to the boot ROM, but which are useful to us.  For example,
 * by looking at these variables, we can see which of the two UARTs was
 * used to feed our code to the boot ROM, and use the same UART for
 * subsequent communication - without building multiple versions of our
 * loadagent or resorting to other ugliness.
 *
 * This header file defines the layout of the IRAM structure in question,
 * based on the disassembly of the boot ROM.
 */

#ifndef __ROMVARS_H
#define	__ROMVARS_H

#include "types.h"

struct boot_rom_vars {
	u8	baud_rate_code;
	u8	pad1[3];
	u32	uart_timeout;
	u8	uart_id;
	u8	pll_config;
	u16	cs_ws_config;
	u8	clktcxo_13mhz;
	u8	rhea_cntl;
	u16	chksum_cmd;
	u16	chksum_accum;
	u16	pad2;
	u32	branch_addr;
};

#endif	/* include guard */