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

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

?? dumprom.cpp

?? dumprom source code,use for learning the dumprom.exe tool for wince
?? 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 _WIN32
typedef 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>
#endif

class 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 variables
MemRegions 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一区二区三区免费野_久草精品视频
日韩免费视频一区二区| 日本vs亚洲vs韩国一区三区| 国产精品美女久久久久高潮| 精品国产1区2区3区| 精品美女在线播放| 精品女同一区二区| 欧美成人在线直播| 久久综合久久综合九色| 久久精品亚洲精品国产欧美| 国产亚洲欧美色| 欧美高清在线一区二区| 中文字幕乱码久久午夜不卡| 国产精品不卡一区二区三区| |精品福利一区二区三区| 亚洲色图19p| 亚洲主播在线观看| 五月天丁香久久| 日韩成人免费看| 精品一区二区三区在线观看国产| 久久精品国产亚洲一区二区三区| 精品一区精品二区高清| 国产成人一级电影| 91在线码无精品| 欧美性生交片4| 欧美xxxxx牲另类人与| 国产免费成人在线视频| 日韩码欧中文字| 午夜亚洲福利老司机| 老司机免费视频一区二区| 国产精品资源在线观看| 91日韩在线专区| 欧美日韩成人综合天天影院 | 欧美日韩日本视频| 7777女厕盗摄久久久| 久久丝袜美腿综合| 亚洲欧洲三级电影| 天天综合日日夜夜精品| 激情久久五月天| 99re视频这里只有精品| 欧美精品1区2区3区| 久久尤物电影视频在线观看| 国产精品久久久久久久久图文区| 亚洲最色的网站| 韩国欧美一区二区| 欧美亚洲国产一卡| 久久久久99精品一区| 一区二区高清免费观看影视大全 | 国产精品一区在线| 一本久道久久综合中文字幕| 日韩精品专区在线影院重磅| 国产精品久久久久一区二区三区| 国产福利一区在线| 色婷婷av一区二区三区大白胸| 欧美一区二区三区电影| 一色屋精品亚洲香蕉网站| 美日韩一级片在线观看| 91欧美一区二区| 精品理论电影在线观看 | 国产成人无遮挡在线视频| 欧美午夜精品免费| 中文字幕免费在线观看视频一区| 婷婷综合久久一区二区三区| 成人黄色777网| 日韩欧美国产小视频| 亚洲精品国产一区二区精华液 | 国产精品每日更新| 免费高清不卡av| 欧美自拍偷拍午夜视频| 国产精品国模大尺度视频| 国产一区在线视频| 欧美一区二区三区婷婷月色| 亚洲视频在线观看一区| 国内精品伊人久久久久影院对白| 欧美午夜一区二区三区免费大片| 中文字幕av不卡| 国产一区福利在线| 欧美日本免费一区二区三区| 亚洲人成伊人成综合网小说| 国产成人亚洲综合a∨婷婷| 日韩天堂在线观看| 午夜精品爽啪视频| 欧美在线你懂的| 成人免费在线视频观看| 夫妻av一区二区| 久久精品综合网| 狠狠色伊人亚洲综合成人| 欧美一区二区黄| 午夜精品影院在线观看| 欧美亚洲动漫精品| 亚洲人成电影网站色mp4| 不卡欧美aaaaa| 国产日韩欧美在线一区| 国产麻豆视频一区二区| 精品国产凹凸成av人网站| 天涯成人国产亚洲精品一区av| 欧美三片在线视频观看| 一区二区三区影院| 色哟哟日韩精品| 亚洲欧美电影院| 91色.com| 亚洲狠狠爱一区二区三区| 色婷婷综合中文久久一本| 国产精品国产三级国产普通话蜜臀 | 久久精品99久久久| 日韩欧美成人一区| 麻豆国产欧美一区二区三区| 欧美一激情一区二区三区| 奇米一区二区三区| 精品1区2区在线观看| 激情欧美一区二区三区在线观看| 日韩一区二区三区免费看| 蜜臀av性久久久久av蜜臀妖精 | 国产精品三级电影| 成人h动漫精品一区二| 中文字幕一区在线| av不卡在线播放| 亚洲精品久久嫩草网站秘色| 在线观看国产一区二区| 亚洲第一av色| 日韩一本二本av| 国产精品一区二区男女羞羞无遮挡| 久久久久国产精品厨房| www.欧美色图| 夜夜操天天操亚洲| 欧美一区二区三区视频在线 | 欧美日韩中文字幕精品| 亚洲1区2区3区视频| 日韩欧美一二区| 高清不卡一二三区| 亚洲柠檬福利资源导航| 欧美日韩午夜在线视频| 久久99精品一区二区三区三区| 欧美大片免费久久精品三p| 国产suv精品一区二区6| 亚洲少妇30p| 欧美日韩高清一区二区三区| 国内精品久久久久影院薰衣草| 亚洲欧洲精品一区二区三区不卡| 91蝌蚪国产九色| 日本不卡视频一二三区| 久久久精品欧美丰满| 在线亚洲高清视频| 老司机一区二区| 亚洲三级在线看| 欧美一区二区三区四区在线观看 | 日本韩国精品在线| 麻豆成人av在线| 亚洲欧美韩国综合色| 日韩欧美在线综合网| 成人h动漫精品| 蜜桃视频在线观看一区| 亚洲日本va午夜在线电影| 欧美一区二区三区色| 成av人片一区二区| 奇米精品一区二区三区在线观看一 | 精品美女一区二区| 日本高清免费不卡视频| 国产一区二区三区观看| 亚洲韩国一区二区三区| 国产日韩欧美a| 欧美精品1区2区3区| 成人性生交大片| 免费的成人av| 亚洲国产欧美在线人成| 国产欧美视频在线观看| 欧美丰满少妇xxxbbb| 97久久久精品综合88久久| 久久aⅴ国产欧美74aaa| 亚洲国产人成综合网站| 国产精品久久久久婷婷| 欧美成人精精品一区二区频| 欧美系列亚洲系列| 大胆亚洲人体视频| 久久精品国产77777蜜臀| 亚洲成人第一页| 亚洲欧美另类久久久精品2019| 国产清纯白嫩初高生在线观看91 | 亚洲色图一区二区三区| 日韩欧美自拍偷拍| 欧美性感一区二区三区| av欧美精品.com| 国产成人精品一区二区三区网站观看| 日韩激情一区二区| 一区二区三区在线观看动漫| 中文字幕五月欧美| 久久精品人人做| 久久综合成人精品亚洲另类欧美 | 亚洲成av人综合在线观看| 一色桃子久久精品亚洲| 中文字幕不卡在线播放| 精品日韩一区二区三区| 欧美乱妇20p| 欧美三级三级三级爽爽爽| 色悠悠久久综合| 日本韩国精品一区二区在线观看| www.一区二区| 99久久综合狠狠综合久久| 成人精品视频一区二区三区 | 国产欧美日韩精品一区| 欧美精品一区二区三区很污很色的|