亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? oops.c

?? Linux設(shè)備驅(qū)動程序第二版
?? C
字號:
/* * ksymoops v2.0 -- A simple filter to resolve symbols in Linux Oops-logs * * Copyright (C) 1995 Greg McGary <gkm@magilla.cichlid.com> (version 1.x) * Copyright (C) 1996 Alessandro Rubini <rubini@ipvvis.unipc.it> (upgrades) *//* * New features: *       strips syslog prefixes *       decodes registers and stack *       uses %esp to show pointers to local vars *       uses symbols in modules from /proc/ksyms */ /*  * Missing features: *       check /proc/ksyms against the map for mismatches */#include <stdio.h>#include <stdlib.h>#include <string.h>#include <unistd.h>#include <ctype.h>#include <linux/module.h>#define MAX_NAME MOD_MAX_NAME /* quite big, indeed ... */struct ksym {  unsigned long address, extent;  struct ksym *next;  char name[MAX_NAME];  char id[MAX_NAME];};struct ksym *gsymlist; /* global symlist *//*----------------------------------------------------------------------*//* read a text line into a symbol */struct  ksym *linesym(char *line){    struct ksym *newsym=malloc(sizeof(struct ksym));    char s[MAX_NAME];    int i;        i=sscanf(line,"%lx %s %s",&newsym->address,newsym->name,s);    switch(i) {      case 2:        newsym->id[0]='\0'; /* no id available, but allright */        break;      case 3:        if (strlen(newsym->name)==1) {        /* a line in the system map */            strcpy(newsym->id,newsym->name);  /* use segment as id */            newsym->id[0]=toupper(newsym->id[0]);            strcpy(newsym->name,s);           /* this was the name */            break;        }        if (s[0]=='[') { /* a module from "ksyms" */            s[strlen(s)-1]='\0'; /* trim the bracket */            strcpy(newsym->id,s+1);            break;        }      default:         /* unknown format */        free(newsym);        return NULL;    }    newsym->extent = newsym->extent = 0;    newsym->next = NULL;    return newsym;}/*----------------------------------------------------------------------*//* * insert a symbol in the list. * "trial" is an hint used to speed things  -- it's tenfold faster  */struct ksym *insert(struct ksym *symlist, struct ksym *newsym,                   struct ksym *trial){    if (!symlist) return newsym;    if (!trial || trial->address > newsym->address) {        if (newsym->address < symlist->address) {            newsym->next = symlist;            return newsym;        }        trial = symlist;        /* disregard hint */    }    for ( ; trial->next; trial=trial->next)        if (trial->next->address > newsym->address)            break;    newsym->next = trial->next;    trial->next = newsym;    return symlist;}/*----------------------------------------------------------------------*//* read a file into a symlist */struct ksym *filesym(struct ksym *symlist, FILE *f, const char *fname){    char s[80];    int lineno = 0;    struct ksym *last = NULL, *sym;    if (!f) {        f=fopen(fname,"r");        if (!f) {            perror(fname);            return symlist;        }    }    while (fgets(s,80,f)) {        lineno++;        sym = linesym(s);        if (!sym) {            fprintf(stderr,"%s:%i: Unknown format for data line\n",                    fname,lineno);            continue;        }        symlist = insert(symlist,sym,last);        last = sym;    }    return symlist;}/*----------------------------------------------------------------------*//* write extents and remove duplicate items */struct ksym *fixlist(struct ksym *symlist){     struct ksym *ptr, *next;        for (ptr=symlist; ptr && ptr->next; ptr = ptr->next) {        while (ptr->address == ptr->next->address) { /* remove duplicates */            next=ptr->next;            if (ptr->id[0] && next->id[0]) /* both valid... hmmm */                break;            if (next->id[0])                strcpy(ptr->id,next->id);            ptr->next=next->next;            free(next);        }        if (!strcmp(ptr->id,ptr->next->id))            ptr->extent = ptr->next->address - ptr->address;        else            ptr->extent = 0;    }    ptr->extent=0;     return symlist;}/*----------------------------------------------------------------------*/#ifdef DEBUGint dumplist(struct ksym *symlist){    for (; symlist; symlist=symlist->next) {       printf("%08lx %-30s (e %08lx, id \"%s\")\n",              symlist->address,              symlist->name, symlist->extent, symlist->id);       fflush(stdout);    }    return 0;}    #endif /* DEBUG */                       /*----------------------------------------------------------------------*//* print an address in symbolic form */char *decode(unsigned int add, unsigned int esp){    static char res[64];    static struct ksym *symlist=NULL; /* used to remember last time */    if (!symlist || symlist->address > add) symlist=gsymlist;    for (;symlist && symlist->next && symlist->next->address <= add;         symlist=symlist->next)        /* nothing */;    if (add < symlist->address || !symlist->extent) { /* out of regions */        if (abs(add-esp) < 2000) {            sprintf(res,"<%%esp+%x>",add-esp);            return res;        } else            return "";    }    sprintf(res,"<%s+%lx/%lx>",symlist->name,add-symlist->address,            symlist->extent);    return res;}/*----------------------------------------------------------------------*/int disass(char *data, unsigned int eip, unsigned int esp){    /*     * This is a hack to avoid using gcc.  We create an object file by     * concatenating objfile_head, the twenty bytes of code, and     * objfile_tail.      */    static unsigned char objfile_head[] = {	0x07, 0x01, 0x00, 0x00, 0x18, 0x00, 0x00, 0x00,	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,	0x24, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00    };    static unsigned char objfile_tail[] = {	0x00, 0x90, 0x90, 0x90,	0x04, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00,	0x00, 0x00, 0x00, 0x00, 0x13, 0x00, 0x00, 0x00,	0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,	0x25, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00,	0x00, 0x00, 0x00, 0x00, 0x2a, 0x00, 0x00, 0x00,	'g',  'c',  'c',  '2',  '_',  'c',  'o',  'm',  	'p',  'i',  'l',  'e',  'd',  '.',  '\0', '_',  	'E',  'I',  'P',  '\0', '\0', '\0', '\0', '\0',	'\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0',	'\0', '\0', '\0', '\0', '\0', '\0'    };    char * objdump = "objdump -d /tmp/oops_decode.o";    char * objfile = "/tmp/oops_decode.o";    char buf[128], *bptr;    char *s;    FILE *f;    long l;    if (!(f=fopen(objfile,"w"))) {        perror(objfile); return -1;    }    fwrite(objfile_head, 1, sizeof(objfile_head), f);    fwrite(data, 1, 20, f);    fwrite(objfile_tail, 1, sizeof(objfile_tail), f);    fclose(f);    if (!(f=popen(objdump,"r"))) {        perror("objdump"); return -1;    }    while (fgets(buf,128,f)) {        if (strncmp(&buf[9], "<_EIP", 5))            continue;	if (strstr(buf, " is out of bounds"))	    break;        printf("Code: ");        /* try to print eip in decoded form */	l = strtol(buf, &bptr, 16);        s=decode(eip+l,esp);        if (s[0])            printf("%s",s); /* the decoded address */        else            printf("%08lx",eip+l);        while (*bptr++ != '>')            /* skip */ ;                /* print the rest of line, without newline */        bptr[strlen(bptr)-1]='\0';        printf("%s",bptr);                /* and now decode any address it embedded */        while ( (bptr=strstr(bptr, "0x")) ) {            l=strtol(bptr, &bptr, 0);            s=decode(l, esp);            if (s[0])                printf(" %s", s);        }        putchar('\n');    }    pclose(f);    unlink(objfile);               return 0;}/*----------------------------------------------------------------------*//* * All is there: now use it */int main(int argc, char **argv){    char s[512];    char *subs=NULL, *savedsubs;    int status=0, offset;    unsigned int j, k, esp, eip;    unsigned int i[16];        /* 8 suffice by now, but who knows... */    char names[16][8], c[20];  /* [8][8] suffice, but who knows */    char *ptr;    char *prgname=argv[0];    struct ksym *symlist=NULL;    char defaultmap[]="/usr/src/linux/System.map";    char *mapname=defaultmap;    if (argc>2) {        fprintf(stderr,"%s: Usage: \"%s [mapfile_name] < oops-log\"\n",                prgname, prgname);        exit(1);    }    if (argc==2)        mapname=argv[1];    fprintf(stderr,"%s: Using %s as map\n", prgname, mapname);    symlist = filesym(symlist,NULL,mapname);    symlist = filesym(symlist,NULL,"/proc/ksyms");    symlist=fixlist(symlist);    /* dumplist(symlist); */    gsymlist=symlist;    /*     * Ok, the symbol table is there, now get the message     */    if (isatty(0)) {        fprintf(stderr,"%s: please paste the oops on my stdin\n",prgname);    }    while (fgets(s,512,stdin)) {        if (!subs) { /* nothing yet */            savedsubs = subs = strstr(s,"EIP: ");        }        switch(status) {        case 0: /* not found */            if (!subs) continue;            status++;            offset=0;            esp=0;            j=sscanf(subs,"%s %x:[<%x>]",s,&i[0],&i[1]);            if (j!=3) {                fprintf(stderr,"Wrong \"EIP\" line\n");                continue;            }            printf("\n%-7s %04x:%08x %s\n",s,i[0],i[1],decode(i[1],0));            eip=i[1]; /* keep to disass */            break;                    case 1: /* before the stack */            j=sscanf(subs,"%s %x %s %x %s %x %s %x",names[0+offset],i+offset,                     names[1+offset],i+1+offset,names[2+offset],i+2+offset,                     names[3+offset],i+3+offset);            if (j==8 && strlen(names[0])==4) { /* registers */                /*                 * The problem with registers is that I need "esp"                 * first, on order to refer registers to the stack.                 * So, I save them, and decode later on                 */                if ( (ptr=strstr(subs,"esp:")) ) {                    sscanf(ptr,"%*s %x",&esp);                }                if (esp) { /* decode only when they can be ref'd to stack */                    for (j=0; j<4+offset; j++)                        printf("%s %08x %s\n",names[j],i[j],decode(i[j],esp));                    offset=0;                } else {                    offset+=4; /* next time, write after these ones */                }                continue;            }            else if (strncmp(subs,"Stack: ",7)) {                printf("%s",subs);                continue;            } else {                status++;                offset=0;                subs+=6; /* skip the string, and fall through */            }        case 2: /* stack and trace*/            if (strncmp(subs,"Call Trace",4) != 0) {                k=sscanf(subs,"%x %x %x %x %x %x %x %x",i,i+1,i+2,i+3,                         i+4,i+5,i+6,i+7);                if (k<=0) {                    fprintf(stderr,"Bad stack line (%i items)\n",j);                } else {                    for (j=0; j<k; j++)                        printf("esp+%02x: %08x %s\n",(offset+j)*4,i[j],                               decode(i[j],esp));                }                if (!offset) subs = savedsubs; /* restore */                offset+=8;                continue;            }            /* call trace */            status++;            offset=0;            subs+=12; /* skip the string, and fall through */        case 3: /* the trace */            if (strncmp(subs,"Code",4)) {                k=sscanf(subs," [<%x>] [<%x>] [<%x>] [<%x>] "                         "[<%x>] [<%x>] [<%x>] [<%x>]",i,i+1,i+2,i+3,                         i+4,i+5,i+6,i+7);                if (k==0) {                    fprintf(stderr,"Bad trace line %s(no add found)\n",subs);                } else {                    for (j=0; j<k; j++)                        printf("Trace: %08x %s\n", i[j], decode(i[j],esp));                }                subs = savedsubs; /* restore */                continue;            }            /* the code */            ptr = subs+5; /* skip "Code:" */            for (j=0; j<20; j++) {                long l=strtol(ptr,&ptr,16);                c[j]=(char)l;            }               disass(c, eip, esp);            esp=0; status=0; subs=NULL; /* ready for another oops */        }                            }    return 0;}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
2020国产精品久久精品美国| 日韩一区二区三区视频在线| 韩国中文字幕2020精品| 一区二区高清在线| 亚洲欧美日韩在线不卡| 亚洲精品欧美二区三区中文字幕| 国产精品久久久久影视| 国产精品美女久久久久久久| 中文字幕一区二区5566日韩| 18欧美乱大交hd1984| 综合久久国产九一剧情麻豆| 一区二区在线观看免费视频播放| 亚洲欧洲中文日韩久久av乱码| 最新热久久免费视频| 成人欧美一区二区三区视频网页| 亚洲精品免费在线播放| 午夜一区二区三区在线观看| 日韩av电影免费观看高清完整版| 亚洲v日本v欧美v久久精品| 亚洲超丰满肉感bbw| 免费观看久久久4p| 国产成人亚洲综合a∨婷婷图片| jlzzjlzz亚洲日本少妇| 色综合中文字幕国产 | 欧美色精品在线视频| 欧美伦理影视网| 日韩欧美一级二级| 国产精品久久久一本精品 | 欧美美女bb生活片| 日韩女同互慰一区二区| 国产精品久久久久久久久免费丝袜| 亚洲女子a中天字幕| 午夜精品久久久久久久久久 | 国产精品一二三四| 色先锋久久av资源部| 91精品国产欧美一区二区18| 国产网站一区二区| 亚洲已满18点击进入久久| 麻豆91精品视频| 91毛片在线观看| 日韩欧美激情一区| 亚洲狠狠丁香婷婷综合久久久| 久久激情五月婷婷| 99精品视频一区二区| 欧美成人video| 亚洲伊人伊色伊影伊综合网| 国产盗摄女厕一区二区三区| 欧美亚洲尤物久久| 国产精品色婷婷| 精品影院一区二区久久久| 在线亚洲免费视频| 国产欧美日韩三级| 久久精品久久久精品美女| 色欧美片视频在线观看| 亚洲国产精品99久久久久久久久| 日日夜夜一区二区| 91福利社在线观看| 国产精品免费网站在线观看| 久久国产精品99精品国产| 欧美色精品在线视频| 亚洲精品国产品国语在线app| 国产精品亚洲午夜一区二区三区| 欧美精品三级在线观看| 一区二区三区四区中文字幕| 成人听书哪个软件好| 久久毛片高清国产| 日av在线不卡| 制服丝袜激情欧洲亚洲| 亚洲国产精品久久人人爱| 91美女蜜桃在线| 亚洲欧洲日韩综合一区二区| 国产v综合v亚洲欧| 久久精品人人做人人综合 | 国产激情91久久精品导航| 欧美肥妇bbw| 青青草97国产精品免费观看 | 欧美日韩一区中文字幕| 亚洲男人的天堂在线观看| av资源站一区| 亚洲精品中文在线观看| 91女神在线视频| 一区二区三区精品| 欧美日韩精品免费| 偷拍一区二区三区| 欧美一区二区三区性视频| 日韩国产欧美三级| 日韩写真欧美这视频| 久久99久久久久久久久久久| 精品对白一区国产伦| 国产高清在线精品| 亚洲视频中文字幕| 欧美视频一区二区三区四区 | 欧美成人激情免费网| 狠狠色丁香久久婷婷综合丁香| 精品国产乱码91久久久久久网站| 国精产品一区一区三区mba桃花 | 国产欧美精品国产国产专区| 国产成人免费xxxxxxxx| 亚洲综合在线视频| 欧美福利视频一区| 国产精品系列在线播放| 最近日韩中文字幕| 在线不卡一区二区| 懂色中文一区二区在线播放| 亚洲精品自拍动漫在线| 欧美一级黄色大片| 国产麻豆精品在线观看| 亚洲精品第1页| 欧美一区二区观看视频| 国产福利不卡视频| 亚洲风情在线资源站| 久久精品男人的天堂| 在线观看日韩av先锋影音电影院| 久久精品国产99国产| 日韩美女视频一区二区| 欧美成人vr18sexvr| 色94色欧美sute亚洲线路一久| 老司机免费视频一区二区| 一色桃子久久精品亚洲| 日韩精品一区二区三区蜜臀| 99久久亚洲一区二区三区青草 | 国产精品一区二区三区99| 亚洲欧美国产三级| 久久精品欧美一区二区三区不卡| 91黄色免费网站| 成人综合婷婷国产精品久久| 日韩和欧美一区二区| 亚洲欧美日韩国产另类专区| 久久女同互慰一区二区三区| 欧美网站大全在线观看| av不卡免费电影| 国产精品亚洲第一区在线暖暖韩国 | 丰满放荡岳乱妇91ww| 日本成人在线电影网| 一区二区三区四区视频精品免费| 久久精品一区四区| 欧美一区二区日韩| 欧美乱妇一区二区三区不卡视频| 99久久久久免费精品国产| 国产高清不卡一区| 美国一区二区三区在线播放| 香蕉久久夜色精品国产使用方法 | 国产欧美精品一区二区三区四区| 宅男噜噜噜66一区二区66| 日本久久电影网| 99视频精品在线| 成人黄色国产精品网站大全在线免费观看 | 蜜桃av一区二区| 日韩电影在线一区二区| 午夜精品一区在线观看| 夜夜嗨av一区二区三区中文字幕| 中文字幕在线播放不卡一区| 日本一区二区三区dvd视频在线| 精品国产乱码久久久久久牛牛| 3d动漫精品啪啪| 欧美大片免费久久精品三p| 欧美一区二区三区免费视频| 欧美一区二区三区性视频| 日韩一区二区三区视频在线 | 欧美在线不卡视频| 色老综合老女人久久久| 欧美主播一区二区三区| 在线观看www91| 欧美精三区欧美精三区| 中文字幕亚洲一区二区av在线| 精品国产第一区二区三区观看体验| 日韩欧美成人午夜| 久久亚洲春色中文字幕久久久| 国产亚洲欧美日韩日本| 中文字幕一区二区三区乱码在线 | 亚洲国产精品传媒在线观看| 中文文精品字幕一区二区| |精品福利一区二区三区| 亚洲精品欧美在线| 美日韩一区二区三区| 国产美女精品人人做人人爽| 成人av在线电影| 欧美自拍偷拍一区| 欧美白人最猛性xxxxx69交| 欧美精品一区视频| 亚洲精品视频观看| 蜜桃av一区二区在线观看| 国产不卡在线一区| 色婷婷综合久久久久中文| 69堂精品视频| 久久久久国产成人精品亚洲午夜| 国产精品久久久久久久久免费桃花| 亚洲黄色片在线观看| 精品午夜久久福利影院| caoporen国产精品视频| 91精品国产91综合久久蜜臀| 国产欧美一区二区精品婷婷| 一区二区三区四区激情| 狠狠色丁香久久婷婷综合_中| 99久久久无码国产精品| 精品免费99久久| 亚洲一区二区三区精品在线| 国产精品一区二区你懂的| 欧美丰满少妇xxxxx高潮对白| 国产精品青草综合久久久久99|