view target-utils/loadagent/bindump.c @ 752:c79aaed75bd8

compile-fc-batt: allow possible third field in source lines Battery tables maintained in the fc-battery-conf repository will now have a third field added, defining thresholds for the battery bars icon, and there will be a new utility to compile them into the new /etc/batterytab2 file read by the FC Tourmaline version of our FCHG driver. For backward compatibility with the original Magnetite version of FCHG, compile-fc-batt remains the tool for compiling the original /etc/batterytab file format, and it needs to ignore the newly added third field in battery table sources.
author Mychaela Falconia <falcon@freecalypso.org>
date Thu, 05 Nov 2020 20:37:55 +0000
parents 963d15a808eb
children
line wrap: on
line source

/*
 * Here we are going to implement a new memory dump command for use by
 * fc-loadtool, sending the dump stream to the host in binary instead of hex
 * S-records.
 *
 * We could send the entire stream continuously without any structure or
 * breaks, but if we did that, fc-loadtool would not be able to detect a slip
 * (byte loss error) in the serial stream until the end of the dump,
 * potentially minutes long.  For this reason we are taking a different
 * approach: we are going to send the dump stream in blocks of 8192 bytes,
 * with each block preceded by an 8-byte binary header.  Loadtool will know
 * and expect the same block structure, and seeing our block headers in the
 * right positions in the stream will provide assurance of synchronization.
 */

#include <sys/types.h>
#include "types.h"

void
cmd_memdump_binary(argbulk)
	char *argbulk;
{
	char *argv[3];
	u_long start, length;
	u_long addr, remlen;
	unsigned blklen, n;

	if (parse_args(argbulk, 2, 2, argv, 0) < 0)
		return;
	if (parse_hexarg(argv[0], 8, &start) < 0) {
		printf("ERROR: arg1 must be a valid 32-bit hex address\n");
		return;
	}
	if (parse_hexarg(argv[1], 8, &length) < 0) {
	    printf("ERROR: arg2 must be a valid 32-bit hex value (length)\n");
		return;
	}
	addr = start;
	for (remlen = length; remlen; remlen -= blklen) {
		blklen = 8192;
		if (remlen < blklen)
			blklen = remlen;
		serial_out(0x55);
		serial_out(0xAA);
		serial_out(addr >> 24);
		serial_out(addr >> 16);
		serial_out(addr >> 8);
		serial_out(addr);
		serial_out(blklen >> 8);
		serial_out(blklen);
		for (n = blklen; n; n--) {
			serial_out(*(volatile u8 *)addr);
			addr++;
		}
	}
}