Blame vas_crash.h

Packit bf408e
/* vas_crash.h - kernel crash dump file format (on swap)
Packit bf408e
 *
Packit bf408e
 * Copyright (C) 1999, 2000, 2001, 2002 Mission Critical Linux, Inc.
Packit bf408e
 * Copyright (C) 2002, 2003, 2004, 2005, 2006 David Anderson
Packit bf408e
 * Copyright (C) 2002, 2003, 2004, 2005, 2006 Red Hat, Inc. All rights reserved.
Packit bf408e
 *
Packit bf408e
 * This program is free software; you can redistribute it and/or modify
Packit bf408e
 * it under the terms of the GNU General Public License as published by
Packit bf408e
 * the Free Software Foundation; either version 2 of the License, or
Packit bf408e
 * (at your option) any later version.
Packit bf408e
 *
Packit bf408e
 * This program is distributed in the hope that it will be useful,
Packit bf408e
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit bf408e
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit bf408e
 * GNU General Public License for more details.
Packit bf408e
 *
Packit bf408e
 * 10/99, Dave Winchell, Initial release for kernel crash dump support.
Packit bf408e
 * 11/12/99, Dave Winchell, Add support for in memory dumps.
Packit bf408e
 */
Packit bf408e
Packit bf408e
#include <sys/types.h>
Packit bf408e
//#include <asm/page.h>
Packit bf408e
Packit bf408e
void save_core(void);
Packit bf408e
Packit bf408e
Packit bf408e
/*  struct crash_map_hdr located at byte offset 0 */
Packit bf408e
/* on-disk formats */
Packit bf408e
Packit bf408e
#define trunc_page(x)   ((void *)(((unsigned long)(x)) & ~((unsigned long)(Page_Size - 1))))
Packit bf408e
#define round_page(x)   trunc_page(((unsigned long)(x)) + ((unsigned long)(Page_Size - 1)))
Packit bf408e
Packit bf408e
#define CRASH_MAGIC 0x9a8bccdd
Packit bf408e
#define CRASH_SOURCE_PAGES 128
Packit bf408e
#define CRASH_SUB_MAP_BYTES ((u_long)round_page((CRASH_SOURCE_PAGES+1)*sizeof(u_long)))
Packit bf408e
#define CRASH_SUB_MAP_PAGES (CRASH_SUB_MAP_BYTES / Page_Size)
Packit bf408e
#define CRASH_UNCOMPR_BUF_PAGES (CRASH_SOURCE_PAGES + CRASH_SUB_MAP_PAGES)
Packit bf408e
#define CRASH_COMPR_BUF_PAGES (CRASH_UNCOMPR_BUF_PAGES + (CRASH_UNCOMPR_BUF_PAGES/4))
Packit bf408e
#define CRASH_COMPESS_PRIME_PAGES (2*CRASH_COMPR_BUF_PAGES)
Packit bf408e
#define CRASH_ZALLOC_PAGES 16*5*2   /* 2 to handle crash in crash */
Packit bf408e
#define CRASH_LOW_WATER_PAGES 100
Packit bf408e
Packit bf408e
#define HP_BIOS_HIGH_PAGES_USED 2000
Packit bf408e
Packit bf408e
#define CRASH_MARK_RESERVED(addr) (set_bit(PG_reserved,&mem_map[MAP_NR(addr)].flags))
Packit bf408e
#define CRASH_CLEAR_RESERVED(addr) (clear_bit(PG_reserved,&mem_map[MAP_NR(addr)].flags))
Packit bf408e
Packit bf408e
#ifdef NOT_DEF
Packit bf408e
typedef int boolean_t;
Packit bf408e
#endif
Packit bf408e
Packit bf408e
#define TRUE 1
Packit bf408e
#define FALSE 0
Packit bf408e
Packit bf408e
Packit bf408e
Packit bf408e
/* mem structure */
Packit bf408e
Packit bf408e
struct mem_crash_map_hdr {
Packit bf408e
      long magic[4];                 /* identify crash dump */
Packit bf408e
      u_long map;                    /* location of map */
Packit bf408e
      u_long map_pages;
Packit bf408e
      u_long data_pages;
Packit bf408e
      u_long compr_units;
Packit bf408e
};
Packit bf408e
struct mem_crash_map_entry {
Packit bf408e
      u_long src_va;                 /* source start of larger non-contig block */
Packit bf408e
                                     /* a src_va of -1 means that the dest_page_va
Packit bf408e
				      *	is the location of the next map page */
Packit bf408e
      u_long dest_page_va;           /* dest of this sub block */
Packit bf408e
      u_long check_sum;              /* check_sum for dest data */
Packit bf408e
};
Packit bf408e
Packit bf408e
Packit bf408e
/* file structure */
Packit bf408e
Packit bf408e
struct crash_map_hdr {
Packit bf408e
      long magic[4];                 /* identify crash dump */
Packit bf408e
      int blk_size;                  /* block size for this device */
Packit bf408e
      int map_block;                 /* location of map */
Packit bf408e
      int map_blocks;                /* number of blocks for map */
Packit bf408e
};
Packit bf408e
struct crash_map_entry {
Packit bf408e
      u_long start_va;               /* virtual address */
Packit bf408e
      char *exp_data;                /* expanded data in memory */
Packit bf408e
      int start_blk;                 /* device location */
Packit bf408e
      int num_blks;
Packit bf408e
};
Packit bf408e
Packit bf408e
#define CRASH_OFFSET_BLKS 100
Packit bf408e
#define CRASH_MAGIC 0x9a8bccdd
Packit bf408e
struct crash_map_hdr_v1 {
Packit bf408e
      long magic[4];                 /* identify crash dump */
Packit bf408e
      int blk_size;                  /* block size for this device */
Packit bf408e
      int map_block;                 /* location of map */
Packit bf408e
      int map_blocks;                /* number of blocks for map */
Packit bf408e
      int map_entries;
Packit bf408e
      u_long va_per_entry;           /* va covered by each map_entry */
Packit bf408e
      u_long bytes_not_dumped;       /* ran out of swap space */
Packit bf408e
      int total_blocks;              /* CRASH_OFFSET_BLKS + header + map + data */
Packit bf408e
};
Packit bf408e
struct crash_map_entry_v1 {
Packit bf408e
      u_long start_va;               /* virtual address */
Packit bf408e
      char *exp_data;                /* expanded data in memory */
Packit bf408e
      int start_blk;                 /* device location */
Packit bf408e
      int num_blks;
Packit bf408e
      int chk_sum;                   /* check sum */
Packit bf408e
};