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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? dumprom.cpp

?? wince 內(nèi)核dump程序
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
/* (C) 2003-2007 Willem Jan Hengeveld <itsme@xs4all.nl> * Web: http://www.xs4all.nl/~itsme/ *      http://wiki.xda-developers.com/ * * $Id: dumprom.cpp 1502 2007-04-15 07:54:20Z itsme $ */// for more info on rom layout, see //      http://www.xs4all.nl/~itsme/projects/xda/wince-rom-layout.html// compile with: cl /Wall /wd4710 /wd4217 /wd4668 /wd4820 /EHsc dumprom.cpp nkcompr.lib// nkcompr.lib is in "/WINCE410/PUBLIC/COMMON/OAK/LIB/X86/RETAIL/nkcompr.lib"// compiler used is "Microsoft (R) 32-bit C/C++ Optimizing Compiler Version 13.00.9466 for 80x86"//   ( from visual studio .net )// some details for my specific rom// 80000000-80028000 is copied to ram: 8c078000-8c0a0000 - this is the bootloader.//// (0x80001000, 0x27000, "boootloader");// I don't know how to find this other than that is is not referenced anywhere.// (0x81400000, 0x1284, "rsa sig for all XIP sections");//    - the header file mentions a ROM_CHAIN_OFFSET, but I don't know how to//      interpret that.//    - the xip regions are not very accurate, most are too short.//       -> the 'end's are only displayed when '-v' is specified.//// (0x81900000, 0, "");// (0x81940000, 0, "");// (0x81f00000, 0, "saved contacts etc.");// (0x82000000, 0, "end");//// example commandline:// dumprom rom80000000.bin -x 0x81400000 -u "0x81f00000:0:saved contacts"  -u "0x80001000:0x27000:bootloader" -u "0x81900000:0:" -u "0x81940000:0:" -d tst > info.txt// // some images start at 80040000, in that case you should dump it like this:// dumprom 3-15-15-ENG-O2euro.nb1 0x80040000//// or another one I have has a 1024 byte header, and no bootloader, dump it with://// dumprom ce.img 0x8003fc00//// or another one I saw, has a 1024 byte header and a bootloader, dump it with://// dumprom ce_boot.img 0x7ffffc00////// how to find the file offset://// I may have to automate this. what I do to find this offset, is// look at where I see "ECEC" -> offset 0x5b// // if "ECEC" is followed by 0x8c0a0000 then this 'ECEC'// must be the bootloader's, in which case it should be at// rom-offset 0x80000040 -> use filestart-offset //   of 0x80000040-0x5b= 0x7fffffe5// // but in this case, ECEC is followed by an address that is in// the address range of the rom (0x80000000-0x82000000).// // in that case this 'ECEC' must be at 0x80040040 -> use filestart ofs//   of 0x80040040-0x5b= 0x8003ffe5// // testing with spv phone rom://     - spv phone rom starts at 81c00000//// bug://    determine start offset only finds majority, this is not good.//    each block can have it's own start offset////    because of this, only one block is loaded into m_blocks,//    causing calls to DumpExtensions to fail with 'GetPtr cannot find offset'////    wm2005 xip files have the corrected offset incorrect i think.//    --> allow to prevent correctiong offset.#include <stdarg.h>#include <stdlib.h>#include <stdio.h>#include <string.h>#include <vector>#include <set>#include <map>#include <algorithm>#include <string>using namespace std;char *g_outputdirectory=NULL;int g_verbose=0;bool b_use_negative_rva= true;bool b_wm2005_rom= false;#ifndef _WIN32typedef bool BOOL;typedef char CHAR;typedef unsigned char BYTE;typedef unsigned short WORD;typedef unsigned long DWORD;typedef long LONG;typedef unsigned long ULONG;typedef unsigned short USHORT;typedef char *LPSTR;typedef void *LPVOID;typedef void *PVOID;typedef BYTE *LPBYTE;typedef struct _tagFILETIME {    DWORD dwLowDateTime;    DWORD dwHighDateTime;} FILETIME;#define _vsnprintf vsnprintf#define _snprintf snprintf#define __int64  long long#define strnicmp strncasecmp#else#include <windows.h>#endifclass MemoryBlock {public:    BYTE *data;    DWORD length;    DWORD start;    DWORD end;    /* no destructor, to make memory management without copy constructors and refcounting easy */    /*    I currently don't care about the data buffer leaking */    bool InRange(DWORD offset) { return (start <= offset && offset < end); }    bool operator <(const MemoryBlock& mb) const { return start < mb.start; }    bool operator <(DWORD offset) const { return end < offset; }};typedef vector<MemoryBlock> MemoryBlockVector;class MemoryMapIterator {public:    MemoryMapIterator(const MemoryBlockVector::iterator& start, const MemoryBlockVector::iterator& end)         : m_end(end)    {        m_block= start;        if (m_block != m_end)            m_ofs= (*m_block).start;        else            m_ofs= 0;    }    MemoryMapIterator(const MemoryMapIterator& m)        : m_end(m.m_end), m_ofs(m.m_ofs), m_block(m.m_block)    {    }    void findnext()     {        while (m_block!=m_end && m_ofs>=(*m_block).end) {            ++m_block;        }        if (m_block==m_end) {            m_ofs= 0;        }        else if (m_ofs<(*m_block).start) {            m_ofs= (*m_block).start;        }    }    MemoryMapIterator& operator++() // prefix inc    {        return *this += 1;    }    MemoryMapIterator& operator+=(int stepsize)    {        m_ofs+=stepsize;        findnext();        return *this;    }    bool operator==(const MemoryMapIterator& a) const    {        return m_block==a.m_block && m_ofs==a.m_ofs;    }    bool operator!=(const MemoryMapIterator& a) const    {        return !(*this==a);    }    void *GetPtr() const    {        if (m_block!=m_end)            return (*m_block).data+(m_ofs-(*m_block).start);        else            return NULL;    }    BYTE GetByte() const    {        BYTE *p= (BYTE*)GetPtr();        if (p==NULL)            return 0;        return *p;    }    DWORD GetWord() const    {        WORD *p= (WORD*)GetPtr();        if (p==NULL)            return 0;        return *p;    }    DWORD GetDword() const    {        BYTE *p= (BYTE*)GetPtr();        if (p==NULL)            return 0;        return *p;    }public:    MemoryBlockVector::iterator m_block;    DWORD m_ofs;    const MemoryBlockVector::iterator& m_end;};class MemoryMap {public:    bool LoadFile(DWORD offset, char *filename, DWORD fileoffset, DWORD length);        void *GetPtr(DWORD offset);    DWORD GetOfs(void *ptr);    BYTE GetByte(DWORD offset);    DWORD GetDword(DWORD offset);    DWORD FirstAddress();    DWORD LastAddress();    MemoryMapIterator begin();    const MemoryMapIterator end();private:    MemoryBlockVector m_blocks;};MemoryMap  g_mem;class MemRegion {public:    DWORD start;    DWORD end;    DWORD length;    string *description;    /* no destructor, to make memory management without copy constructors and refcounting easy */    /*    I currently don't care about the description buffer leaking */    MemRegion(DWORD start, DWORD end) : start(start), end(end), description(NULL), length(end-start) {}    bool operator <(const MemRegion& r) const { return start < r.start || (start==r.start && length<r.length); }    // bug: this can result in very long invalid memory access    //  .... todo: should skip invalid regions    DWORD FirstNonzero() {        for (DWORD i=start ; i<end ; ++i)            if (g_mem.GetByte(i))                return i;        return end;    }    DWORD LastNonzero() {        for (DWORD i=end-1 ; i>=start ; --i)            if (g_mem.GetByte(i))                return i;        return start-1;    }};typedef vector<MemRegion> MemRegionVector;class MemRegions {public:    MemRegion& MarkRange(DWORD start, DWORD end, const char *msg, ...);    MemRegion& MarkRegion(DWORD start, DWORD length, const char *msg, ...);    MemRegion& MarkRegion_v(DWORD start, DWORD length, const char *msg, va_list ap);    void DumpMemoryMap();private:    MemRegionVector m_list;};//--------------------------- global variablesMemRegions g_regions;// -----------------------------------------------------------------------------// -----------------------------------------------------------------------------bool MemoryMap::LoadFile(DWORD offset, char *filename, DWORD fileoffset, DWORD length){    FILE *f= fopen(filename, "rb");    if (f==NULL)    {        perror(filename);        return false;    }    if (length==0)    {        if (fseek(f, 0, SEEK_END))        {            perror(filename);            fclose(f);            return false;        }        length= ftell(f)-fileoffset;    }    if (length==0)    {        fclose(f);        printf("length not known\n");        return false;    }    MemoryBlock mb;    mb.data= new BYTE[length];    if (mb.data==NULL)    {        fclose(f);        printf("error allocating memory\n");        return false;    }    mb.length= length;    mb.start= offset;    mb.end= offset+length;    if (fseek(f, fileoffset, SEEK_SET))    {        perror(filename);        fclose(f);        return false;    }    size_t nRead= fread(mb.data, 1, mb.length, f);    if (nRead!=mb.length)    {        perror("fread");        fclose(f);        return false;    }    fclose(f);    // keep m_blocks sorted.    MemoryBlockVector::iterator i;    for (i=m_blocks.begin() ; i!=m_blocks.end(); ++i)        if (mb.start < (*i).start)            break;    m_blocks.insert(i, mb);    if (g_verbose)        printf("block %ld added buf=%08lx %08lx\n", m_blocks.size(), (DWORD)mb.data, mb.length);    return true;}BYTE MemoryMap::GetByte(DWORD offset){    BYTE *p= (BYTE*)GetPtr(offset);    if (p==NULL)        return 0;    return *p;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产偷v国产偷v亚洲高清| 日韩精品视频网站| 欧美性欧美巨大黑白大战| 激情综合色播激情啊| 亚洲永久免费av| 国产欧美一区二区精品性| 在线播放国产精品二区一二区四区| 成人性色生活片| 美女视频黄 久久| 亚洲香肠在线观看| 亚洲私人影院在线观看| 亚洲精品在线观看网站| 欧美一区二区三区男人的天堂| 99re热视频这里只精品| 国产成人综合在线观看| 久久国产欧美日韩精品| 视频一区中文字幕| 一区二区三区不卡在线观看| 亚洲国产成人自拍| 精品国产a毛片| 欧美一区欧美二区| 精品视频在线免费| 欧美三级电影一区| 日本精品一区二区三区高清| av激情成人网| k8久久久一区二区三区| 国产精品亚洲综合一区在线观看| 美女视频黄 久久| 人人狠狠综合久久亚洲| 成人动漫一区二区在线| 国产综合久久久久影院| 麻豆国产精品777777在线| 天天射综合影视| 偷窥国产亚洲免费视频| 午夜伊人狠狠久久| 亚洲午夜激情网页| 亚洲国产裸拍裸体视频在线观看乱了| 亚洲欧美日韩一区二区三区在线观看| 国产精品激情偷乱一区二区∴| 中文字幕精品一区| 中文幕一区二区三区久久蜜桃| 亚洲国产成人午夜在线一区| 中文字幕精品—区二区四季| 国产精品情趣视频| 亚洲日本在线观看| 亚洲综合色自拍一区| 亚洲大片免费看| 日韩av电影免费观看高清完整版| 日本午夜精品视频在线观看| 蜜臀av性久久久久蜜臀aⅴ| 久草这里只有精品视频| 国产真实乱对白精彩久久| 国产精品资源网| 成人国产亚洲欧美成人综合网 | 亚洲国产日韩a在线播放| 亚洲成人一区二区在线观看| 五月婷婷久久综合| 精品一区二区三区久久| 成人一区二区三区| 在线一区二区三区| 欧美乱妇一区二区三区不卡视频| 日韩一二三区视频| 国产日本欧洲亚洲| 亚洲精品videosex极品| 日韩精品高清不卡| 国产美女精品人人做人人爽| 99re这里只有精品首页| 欧美日韩国产首页在线观看| 中文字幕一区二区视频| 亚洲国产毛片aaaaa无费看| 美脚の诱脚舐め脚责91| 懂色av一区二区夜夜嗨| 日本精品视频一区二区| 日韩视频一区二区在线观看| 久久久久国产精品麻豆ai换脸 | 日韩—二三区免费观看av| 久88久久88久久久| av中文字幕在线不卡| 欧美日韩高清影院| 国产精品素人一区二区| 同产精品九九九| 不卡av在线网| 日韩视频永久免费| 亚洲色图19p| 精品亚洲porn| 色乱码一区二区三区88| 久久网站热最新地址| 亚洲一区二区三区精品在线| 韩日精品视频一区| 在线亚洲高清视频| 国产欧美日韩视频在线观看| 亚洲丰满少妇videoshd| 风间由美一区二区三区在线观看 | 色哟哟国产精品| 精品国产伦一区二区三区观看方式| 中文字幕在线不卡一区二区三区| 日韩精品电影在线| 91丨porny丨最新| 久久女同互慰一区二区三区| 亚洲国产美女搞黄色| 成人小视频免费观看| 精品国产免费人成在线观看| 亚洲精品成人在线| 国产a精品视频| 精品日韩欧美在线| 粉嫩av一区二区三区粉嫩| 欧美精品777| 亚洲成人精品一区| 99精品黄色片免费大全| 国产性做久久久久久| 日韩不卡一二三区| 91女神在线视频| 久久久91精品国产一区二区精品 | 成人黄色国产精品网站大全在线免费观看 | 亚洲一区二区中文在线| 成人激情黄色小说| 国产欧美日韩综合精品一区二区| 免播放器亚洲一区| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲一区二区视频| 91亚洲精品久久久蜜桃| 中文字幕精品三区| 高清不卡在线观看av| 久久尤物电影视频在线观看| 日韩精品一区第一页| 欧美另类变人与禽xxxxx| 亚洲图片欧美视频| 欧美色手机在线观看| 亚洲蜜桃精久久久久久久| caoporn国产一区二区| 国产精品久久久久久户外露出 | 天堂成人免费av电影一区| 欧美视频中文字幕| 亚洲午夜久久久| 欧美日韩电影在线| 亚洲国产精品尤物yw在线观看| 欧美亚洲一区二区三区四区| 亚洲影视资源网| 欧洲精品在线观看| 亚洲国产欧美在线| 欧美美女激情18p| 免费成人结看片| 久久久午夜精品| av在线不卡网| 一区二区三区久久| 欧美另类久久久品| 精品一区二区三区在线播放视频| 精品美女在线观看| 国产传媒欧美日韩成人| 国产精品高潮呻吟久久| 在线亚洲一区二区| 五月婷婷综合激情| 日韩免费视频线观看| 国产伦精品一区二区三区视频青涩 | 一本久道中文字幕精品亚洲嫩| 亚洲色图视频网站| 欧美网站一区二区| 奇米亚洲午夜久久精品| 久久久精品欧美丰满| 欧美精品久久一区| 国产剧情一区二区| 最好看的中文字幕久久| 欧美日韩激情在线| 国产在线视频精品一区| 1024成人网| 欧美一区二区三区爱爱| 成人一区二区在线观看| 亚洲国产视频在线| 久久久亚洲综合| 在线观看欧美日本| 九色porny丨国产精品| 综合色天天鬼久久鬼色| 3atv在线一区二区三区| 成人一区二区三区中文字幕| 亚洲一区二区3| 久久色成人在线| 91国偷自产一区二区三区成为亚洲经典| 日本午夜精品一区二区三区电影| 国产亚洲成aⅴ人片在线观看| 欧美午夜免费电影| 国产剧情一区二区三区| 亚洲一区视频在线| 欧美国产成人精品| 日韩一区二区三区免费看 | 91国偷自产一区二区三区观看| 蜜桃av一区二区在线观看| 亚洲欧洲日本在线| 日韩三级高清在线| 91黄色小视频| 国产精品一级片| 男男成人高潮片免费网站| 亚洲欧洲成人av每日更新| 精品国产一区二区三区不卡| 一本久道中文字幕精品亚洲嫩| 国产美女主播视频一区| 日韩av一二三| 亚洲五码中文字幕| 国产精品看片你懂得| 精品动漫一区二区三区在线观看| 色欧美乱欧美15图片|