OpenCores
URL https://opencores.org/ocsvn/or1k_old/or1k_old/trunk

Subversion Repositories or1k_old

[/] [or1k_old/] [trunk/] [rc203soc/] [sw/] [uClinux/] [arch/] [m68k/] [tools/] [amiga/] [dmesg.c] - Diff between revs 1765 and 1782

Only display areas with differences | Details | Blame | View Log

Rev 1765 Rev 1782
/*
/*
 *  linux/arch/m68k/tools/amiga/dmesg.c -- Retrieve the kernel messages stored
 *  linux/arch/m68k/tools/amiga/dmesg.c -- Retrieve the kernel messages stored
 *                                         in Chip RAM with the kernel command
 *                                         in Chip RAM with the kernel command
 *                                         line option `debug=mem'.
 *                                         line option `debug=mem'.
 *
 *
 *  © Copyright 1996 by Geert Uytterhoeven
 *  © Copyright 1996 by Geert Uytterhoeven
 *                     (Geert.Uytterhoeven@cs.kuleuven.ac.be)
 *                     (Geert.Uytterhoeven@cs.kuleuven.ac.be)
 *
 *
 *
 *
 *  Compilation (under AmigaOS):
 *  Compilation (under AmigaOS):
 *
 *
 *      gcc -o dmesg dmesg.c -noixemul -idirafter INCLUDE: -Wall -s -O3
 *      gcc -o dmesg dmesg.c -noixemul -idirafter INCLUDE: -Wall -s -O3
 *
 *
 *  Usage:
 *  Usage:
 *
 *
 *      dmesg
 *      dmesg
 *      dmesg <CHIPMEM_END>
 *      dmesg <CHIPMEM_END>
 *
 *
 *
 *
 *  This file is subject to the terms and conditions of the GNU General Public
 *  This file is subject to the terms and conditions of the GNU General Public
 *  License.  See the file COPYING in the main directory of the Linux
 *  License.  See the file COPYING in the main directory of the Linux
 *  distribution for more details.
 *  distribution for more details.
 */
 */
 
 
 
 
#include <stdio.h>
#include <stdio.h>
#include <stdlib.h>
#include <stdlib.h>
#include <unistd.h>
#include <unistd.h>
 
 
 
 
#define CHIPMEM_START   0x00000000
#define CHIPMEM_START   0x00000000
#define CHIPMEM_END     0x00200000      /* overridden by argv[1] */
#define CHIPMEM_END     0x00200000      /* overridden by argv[1] */
 
 
#define SAVEKMSG_MAGIC1 0x53415645      /* 'SAVE' */
#define SAVEKMSG_MAGIC1 0x53415645      /* 'SAVE' */
#define SAVEKMSG_MAGIC2 0x4B4D5347      /* 'KMSG' */
#define SAVEKMSG_MAGIC2 0x4B4D5347      /* 'KMSG' */
 
 
struct savekmsg {
struct savekmsg {
    u_long magic1;      /* SAVEKMSG_MAGIC1 */
    u_long magic1;      /* SAVEKMSG_MAGIC1 */
    u_long magic2;      /* SAVEKMSG_MAGIC2 */
    u_long magic2;      /* SAVEKMSG_MAGIC2 */
    u_long magicptr;    /* address of magic1 */
    u_long magicptr;    /* address of magic1 */
    u_long size;
    u_long size;
    char data[0];
    char data[0];
};
};
 
 
 
 
int main(int argc, char *argv[])
int main(int argc, char *argv[])
{
{
    u_long start = CHIPMEM_START, end = CHIPMEM_END, p;
    u_long start = CHIPMEM_START, end = CHIPMEM_END, p;
    int found = 0;
    int found = 0;
    struct savekmsg *m = NULL;
    struct savekmsg *m = NULL;
 
 
    if (argc >= 2)
    if (argc >= 2)
        end = strtoul(argv[1], NULL, 0);
        end = strtoul(argv[1], NULL, 0);
    printf("Searching for SAVEKMSG magic...\n");
    printf("Searching for SAVEKMSG magic...\n");
    for (p = start; p <= end-sizeof(struct savekmsg); p += 4) {
    for (p = start; p <= end-sizeof(struct savekmsg); p += 4) {
        m = (struct savekmsg *)p;
        m = (struct savekmsg *)p;
        if ((m->magic1 == SAVEKMSG_MAGIC1) && (m->magic2 == SAVEKMSG_MAGIC2) &&
        if ((m->magic1 == SAVEKMSG_MAGIC1) && (m->magic2 == SAVEKMSG_MAGIC2) &&
            (m->magicptr == p)) {
            (m->magicptr == p)) {
            found = 1;
            found = 1;
            break;
            break;
        }
        }
    }
    }
    if (!found)
    if (!found)
        printf("Not found\n");
        printf("Not found\n");
    else {
    else {
        printf("Found %ld bytes at 0x%08lx\n", m->size, (u_long)&m->data);
        printf("Found %ld bytes at 0x%08lx\n", m->size, (u_long)&m->data);
        puts(">>>>>>>>>>>>>>>>>>>>");
        puts(">>>>>>>>>>>>>>>>>>>>");
        fflush(stdout);
        fflush(stdout);
        write(1, &m->data, m->size);
        write(1, &m->data, m->size);
        fflush(stdout);
        fflush(stdout);
        puts("<<<<<<<<<<<<<<<<<<<<");
        puts("<<<<<<<<<<<<<<<<<<<<");
    }
    }
    return(0);
    return(0);
}
}
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.