spi-topcliff-pch: add recovery processing in case wait-event timeout
[zen-stable.git] / arch / m68k / tools / amiga / dmesg.c
blob7340f5b6cf6d55dbafe7b86fbf18ff58f4f6ada3
1 /*
2 * linux/arch/m68k/tools/amiga/dmesg.c -- Retrieve the kernel messages stored
3 * in Chip RAM with the kernel command
4 * line option `debug=mem'.
6 * © Copyright 1996 by Geert Uytterhoeven <geert@linux-m68k.org>
9 * Usage:
11 * dmesg
12 * dmesg <CHIPMEM_END>
15 * This file is subject to the terms and conditions of the GNU General Public
16 * License. See the file COPYING in the main directory of the Linux
17 * distribution for more details.
21 #include <stdio.h>
22 #include <stdlib.h>
23 #include <unistd.h>
26 #define CHIPMEM_START 0x00000000
27 #define CHIPMEM_END 0x00200000 /* overridden by argv[1] */
29 #define SAVEKMSG_MAGIC1 0x53415645 /* 'SAVE' */
30 #define SAVEKMSG_MAGIC2 0x4B4D5347 /* 'KMSG' */
32 struct savekmsg {
33 u_long magic1; /* SAVEKMSG_MAGIC1 */
34 u_long magic2; /* SAVEKMSG_MAGIC2 */
35 u_long magicptr; /* address of magic1 */
36 u_long size;
37 char data[0];
41 int main(int argc, char *argv[])
43 u_long start = CHIPMEM_START, end = CHIPMEM_END, p;
44 int found = 0;
45 struct savekmsg *m = NULL;
47 if (argc >= 2)
48 end = strtoul(argv[1], NULL, 0);
49 printf("Searching for SAVEKMSG magic...\n");
50 for (p = start; p <= end-sizeof(struct savekmsg); p += 4) {
51 m = (struct savekmsg *)p;
52 if ((m->magic1 == SAVEKMSG_MAGIC1) && (m->magic2 == SAVEKMSG_MAGIC2) &&
53 (m->magicptr == p)) {
54 found = 1;
55 break;
58 if (!found)
59 printf("Not found\n");
60 else {
61 printf("Found %ld bytes at 0x%08lx\n", m->size, (u_long)&m->data);
62 puts(">>>>>>>>>>>>>>>>>>>>");
63 fflush(stdout);
64 write(1, &m->data, m->size);
65 fflush(stdout);
66 puts("<<<<<<<<<<<<<<<<<<<<");
68 return(0);