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

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

?? elf.py

?? tinyos最新版
?? PY
字號:
#!/usr/bin/env pythonimport struct# ELF object file reader# (C) 2003 cliechti@gmx.net# Python license#            size  alignment# Elf32_Addr    4  4  Unsigned program address# Elf32_Half    2  2  Unsigned medium integer# Elf32_Off     4  4  Unsigned file offset# Elf32_Sword   4  4  Signed large integer# Elf32_Word    4  4  Unsigned large integer# unsignedchar  1  1  Unsigned small integer#define EI_NIDENT 16#~ typedef struct{    #~ unsigned char e_ident[EI_NIDENT];    #~ Elf32_Half e_type;    #~ Elf32_Half e_machine;    #~ Elf32_Word e_version;    #~ Elf32_Addr e_entry;    #~ Elf32_Off  e_phoff;    #~ Elf32_Off  e_shoff;    #~ Elf32_Word e_flags;    #~ Elf32_Half e_ehsize;    #~ Elf32_Half e_phentsize;    #~ Elf32_Half e_phnum;    #~ Elf32_Half e_shentsize;    #~ Elf32_Half e_shnum;    #~ Elf32_Half e_shstrndx;#~ } Elf32_Ehdr;#Section Header#~ typedef struct {    #~ Elf32_Word sh_name;    #~ Elf32_Word sh_type;    #~ Elf32_Word sh_flags;    #~ Elf32_Addr sh_addr;    #~ Elf32_Off  sh_offset;    #~ Elf32_Word sh_size;    #~ Elf32_Word sh_link;    #~ Elf32_Word sh_info;    #~ Elf32_Word sh_addralign;    #~ Elf32_Word sh_entsize;#~ } Elf32_Shdr; #~ typedef struct {    #~ Elf32_Word p_type;    #~ Elf32_Off  p_offset;    #~ Elf32_Addr p_vaddr;    #~ Elf32_Addr p_paddr;    #~ Elf32_Word p_filesz;    #~ Elf32_Word p_memsz;    #~ Elf32_Word p_flags;    #~ Elf32_Word p_align;#~ } Elf32_Phdr;class ELFException(Exception): passclass ELFSection:    """read and store a section"""    Elf32_Shdr = "<IIIIIIIIII"          #header format        #section types    SHT_NULL        = 0    SHT_PROGBITS    = 1    SHT_SYMTAB      = 2    SHT_STRTAB      = 3    SHT_RELA        = 4    SHT_HASH        = 5    SHT_DYNAMIC     = 6    SHT_NOTE        = 7    SHT_NOBITS      = 8    SHT_REL         = 9    SHT_SHLIB       = 10    SHT_DYNSYM      = 11    SHT_LOPROC      = 0x70000000L    SHT_HIPROC      = 0x7fffffffL    SHT_LOUSER      = 0x80000000L    SHT_HIUSER      = 0xffffffffL    #section attribute flags    SHF_WRITE       = 0x1    SHF_ALLOC       = 0x2    SHF_EXECINSTR   = 0x4    SHF_MASKPROC    = 0xf0000000L    def __init__(self):        """creat a new empty section object"""        (self.sh_name, self.sh_type, self.sh_flags, self.sh_addr,         self.sh_offset, self.sh_size, self.sh_link, self.sh_info,         self.sh_addralign, self.sh_entsize) = [0]*10        self.name = None        self.data = None        self.lma =  None    def fromString(self, s):        """get section header from string"""        (self.sh_name, self.sh_type, self.sh_flags, self.sh_addr,         self.sh_offset, self.sh_size, self.sh_link, self.sh_info,         self.sh_addralign, self.sh_entsize) = struct.unpack(self.Elf32_Shdr, s)             def __str__(self):        """pretty print for debug..."""        return "%s(%s, sh_type=%s, sh_flags=%s, "\               "sh_addr=0x%04x, sh_offset=0x%04x, sh_size=%s, sh_link=%s, "\               "sh_info=%s, sh_addralign=%s, sh_entsize=%s, lma=0x%04x)" % (            self.__class__.__name__,            self.name is not None and "%r" % self.name or "sh_name=%s" % self.sh_name,            self.sh_type, self.sh_flags, self.sh_addr,            self.sh_offset, self.sh_size, self.sh_link, self.sh_info,            self.sh_addralign, self.sh_entsize, self.lma)class ELFProgramHeader:    """Store and parse a program header"""    Elf32_Phdr = "<IIIIIIII"            #header format        #segmet types    PT_NULL         = 0    PT_LOAD         = 1    PT_DYNAMIC      = 2    PT_INTERP       = 3    PT_NOTE         = 4    PT_SHLIB        = 5    PT_PHDR         = 6    PT_LOPROC       = 0x70000000L    PT_HIPROC       = 0x7fffffffL        #segment flags    PF_R            = 0x4       #segment is readable    PF_W            = 0x2       #segment is writable    PF_X            = 0x1       #segment is executable         def __init__(self):        """create a new, empty segment/program header"""        (self.p_type, self.p_offset, self.p_vaddr, self.p_paddr,            self.p_filesz, self.p_memsz, self.p_flags, self.p_align) = [0]*8        self.data = None    def fromString(self, s):        """parse header info from string"""        (self.p_type, self.p_offset, self.p_vaddr, self.p_paddr,            self.p_filesz, self.p_memsz, self.p_flags,            self.p_align) = struct.unpack(self.Elf32_Phdr, s)    def __str__(self):        """pretty print for debug..."""        return "%s(p_type=%s, p_offset=0x%04x, p_vaddr=0x%04x, p_paddr=0x%04x, "\            "p_filesz=%s, p_memsz=%s, p_flags=%s, "\            "p_align=%s)" % (            self.__class__.__name__,            self.p_type, self.p_offset, self.p_vaddr, self.p_paddr,            self.p_filesz, self.p_memsz, self.p_flags,            self.p_align)class ELFObject:    """Object to read and handle an LEF object file"""    #header information    Elf32_Ehdr = "<16sHHIIIIIHHHHHH"        #offsets within e_ident    EI_MAG0         = 0     #File identification    EI_MAG1         = 1     #File identification    EI_MAG2         = 2     #File identification    EI_MAG3         = 3     #File identification    EI_CLASS        = 4     #File class    EI_DATA         = 5     #Data encoding    EI_VERSION      = 6     #File version    EI_PAD          = 7     #Start of padding bytes    EI_NIDENT       = 16    #Size of e_ident[]    #elf file type flags    ET_NONE         = 0     #No file type    ET_REL          = 1     #Relocatable file    ET_EXEC         = 2     #Executable file    ET_DYN          = 3     #Shared object file    ET_CORE         = 4     #Core file    ET_LOPROC       = 0xff00 #Processor-specific    ET_HIPROC       = 0xffff #Processor-specific    #ELF format    ELFCLASSNONE    = 0     #Invalid class    ELFCLASS32      = 1     #32-bit objects    ELFCLASS64      = 2     #64-bit objects    #encoding    ELFDATANONE     = 0     #Invalid data encoding    ELFDATA2LSB     = 1     #See below    ELFDATA2MSB     = 2     #See below    def __init__(self):        """create a new elf object"""        (self.e_ident, self.e_type, self.e_machine, self.e_version,        self.e_entry, self.e_phoff, self.e_shoff,        self.e_flags, self.e_ehsize, self.e_phentsize, self.e_phnum,        self.e_shentsize, self.e_shnum, self.e_shstrndx) = [0]*14    def fromFile(self, fileobj):        """read all relevant data from fileobj.        the file must be seekable"""        #get file header        (self.e_ident, self.e_type, self.e_machine, self.e_version,        self.e_entry, self.e_phoff, self.e_shoff,        self.e_flags, self.e_ehsize, self.e_phentsize, self.e_phnum,        self.e_shentsize, self.e_shnum, self.e_shstrndx) = struct.unpack(            self.Elf32_Ehdr, fileobj.read(struct.calcsize(self.Elf32_Ehdr)))        #verify if its a known format and realy an ELF file        if self.e_ident[0:4]             != '\x7fELF' and\           self.e_ident[self.EI_CLASS]   != self.ELFCLASS32 and\           self.e_ident[self.EI_DATA]    != self.ELFDATA2LSB and\           self.e_ident[self.EI_VERSION] != 1:                raise ELFException("Not a valid ELF file")        #load programm headers        self.programmheaders = []        if self.e_phnum:            #load program headers            fileobj.seek(self.e_phoff)            for sectionnum in range(self.e_phnum):                shdr = (fileobj.read(self.e_phentsize) + '\0'* struct.calcsize(ELFProgramHeader.Elf32_Phdr))[0:struct.calcsize(ELFProgramHeader.Elf32_Phdr)]                psection = ELFProgramHeader()                psection.fromString(shdr)                if psection.p_offset:   #skip if section has invalid offset in file                    self.programmheaders.append(psection)            #~ #get the segment data from the file for each prg header            #~ for phdr in self.programmheaders:                #~ fileobj.seek(phdr.p_offset)                #~ phdr.data = fileobj.read(phdr.p_filesz)                #~ #pad if needed                #~ if phdr.p_filesz < phdr.p_memsz:                    #~ phdr.data = phdr.data + '\0' * (phdr.p_memsz-phdr.p_filesz)        #load sections        self.sections = []        fileobj.seek(self.e_shoff)        for sectionnum in range(self.e_shnum):            shdr = (fileobj.read(self.e_shentsize) + '\0'* struct.calcsize(ELFSection.Elf32_Shdr))[0:struct.calcsize(ELFSection.Elf32_Shdr)]            elfsection = ELFSection()            elfsection.fromString(shdr)            self.sections.append(elfsection)                #load data for all sections        for section in self.sections:            fileobj.seek(section.sh_offset)            data = fileobj.read(section.sh_size)            section.data = data            if section.sh_type == ELFSection.SHT_STRTAB:                section.values = data.split('\0')            section.lma = self.getLMA(section)                #get section names        for section in self.sections:            start = self.sections[self.e_shstrndx].data[section.sh_name:]            section.name = start.split('\0')[0]            def getSection(self, name):        """get section by name"""        for section in self.sections:            if section.name == '.text':                return section        def getProgrammableSections(self):        """get all program headers that are marked as executable and        have suitable attributes to be code"""        res = []        for p in self.programmheaders:            #~ print p            #~ if section.sh_flags & self.SHF_ALLOC and section.name not in ('.data', '.data1', '.bss'):            #~ if p.p_type == ELFProgramHeader.PT_LOAD:# and p.p_paddr == p.p_vaddr and p.p_flags & ELFProgramHeader.PF_X:            if p.p_type == ELFProgramHeader.PT_LOAD:                res.append(p)        return res    def getLMA(self, section):        #magic load memory address calculation ;-)        for p in self.programmheaders:            if (p.p_paddr != 0 and \                p.p_type == ELFProgramHeader.PT_LOAD and \                p.p_vaddr != p.p_paddr and \                p.p_vaddr <= section.sh_addr and \                (p.p_vaddr + p.p_memsz >= section.sh_addr + section.sh_size) \                    and (not (section.sh_flags & ELFSection.SHF_ALLOC and section.sh_type != ELFSection.SHT_NOBITS) \                    or  (p.p_offset <= section.sh_offset \                    and (p.p_offset + p.p_filesz >= section.sh_offset + section.sh_size)))):                return section.sh_addr + p.p_paddr - p.p_vaddr        return section.sh_addr    def getSections(self):        """get sections relevant for the application"""        res = []        for section in self.sections:            if section.sh_flags & ELFSection.SHF_ALLOC and section.sh_type != ELFSection.SHT_NOBITS:                res.append(section)        return res    def __str__(self):        """pretty print for debug..."""        return "%s(self.e_type=%r, self.e_machine=%r, self.e_version=%r, sections=%r)" % (            self.__class__.__name__,             self.e_type, self.e_machine, self.e_version,            [section.name for section in self.sections])if __name__ == '__main__':    print "This is only a module test!"    elf = ELFObject()    elf.fromFile(open("test.elf"))    if elf.e_type != ELFObject.ET_EXEC:        raise Exception("No executable")    print elf    #~ print repr(elf.getSection('.text').data)    #~ print [(s.name, hex(s.sh_addr)) for s in elf.getSections()]    print "-"*20    for p in elf.sections: print p    print "-"*20    for p in elf.getSections(): print p    print "-"*20    for p in elf.getProgrammableSections(): print p

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美日韩国产一区二区三区| 91精品国产欧美日韩| 欧美国产日韩在线观看| 国产老肥熟一区二区三区| 久久久九九九九| 国产91精品露脸国语对白| 欧美激情中文字幕一区二区| 成人性生交大片免费看在线播放| 五月激情丁香一区二区三区| 欧美日韩一区二区在线视频| 日本不卡一区二区三区高清视频| 日韩一级大片在线观看| 精品一区二区在线视频| 国产精品视频一区二区三区不卡| 99久久99久久综合| 午夜精品久久久久影视| 欧美精品一区二区蜜臀亚洲| 成人免费av网站| 亚洲一区二区三区不卡国产欧美| 欧美一卡二卡在线观看| 国产91对白在线观看九色| 自拍视频在线观看一区二区| 欧美精品v国产精品v日韩精品| 久久激情综合网| 最新热久久免费视频| 9191国产精品| 成人午夜又粗又硬又大| 亚洲高清在线精品| 26uuu久久天堂性欧美| 91免费视频网址| 男女男精品视频网| 欧美国产日韩精品免费观看| 欧美无砖专区一中文字| 韩日av一区二区| 一区二区三区欧美视频| 精品少妇一区二区三区在线播放| 99精品在线观看视频| 免费成人在线影院| 亚洲欧美日韩国产手机在线| 欧美白人最猛性xxxxx69交| 视频一区二区欧美| 国产不卡免费视频| 亚洲精品伦理在线| 欧美精品一区二区精品网| 波多野结衣亚洲| 免费的成人av| 一区二区三区在线观看欧美| 久久免费视频色| 欧美日韩精品一区二区三区蜜桃| 国产精品亚洲午夜一区二区三区| 亚洲成精国产精品女| 国产日韩欧美精品一区| 欧美精品久久久久久久多人混战| www.欧美.com| 国产一区二区三区四| 丝袜诱惑亚洲看片| 一区二区欧美精品| 国产精品视频第一区| 日韩女优毛片在线| 欧美精品精品一区| 欧洲精品在线观看| 91猫先生在线| a美女胸又www黄视频久久| 黄网站免费久久| 高清视频一区二区| 久久激情五月激情| 日韩av在线免费观看不卡| 亚洲一卡二卡三卡四卡无卡久久| 国产精品毛片a∨一区二区三区| 精品国产乱子伦一区| 在线不卡欧美精品一区二区三区| 色噜噜狠狠色综合中国| 91亚洲精品久久久蜜桃网站| 丁香婷婷深情五月亚洲| 国产精品一区二区在线播放| 九九国产精品视频| 激情欧美一区二区| 毛片av一区二区| 麻豆精品久久久| 蜜桃久久久久久| 久久国产精品一区二区| 激情深爱一区二区| 国产精品羞羞答答xxdd| 国产美女主播视频一区| 国产麻豆欧美日韩一区| 国产成人精品www牛牛影视| 国产资源在线一区| 国产伦精品一区二区三区免费迷| 国产在线观看一区二区| 国产尤物一区二区| 国产激情视频一区二区三区欧美| 国产精品99久久久| av不卡免费在线观看| 91蜜桃视频在线| 欧美日韩精品三区| 91精品欧美久久久久久动漫| 日韩欧美国产三级电影视频| 日韩欧美一区二区久久婷婷| 精品免费视频.| 国产精品三级av在线播放| 中文字幕一区二区三区乱码在线| 亚洲欧美日韩国产综合| 亚洲成人激情自拍| 激情成人午夜视频| 成人免费av网站| 精品视频一区二区三区免费| 日韩美女在线视频| 国产欧美精品国产国产专区| 一区二区三区四区中文字幕| 青青草原综合久久大伊人精品优势| 精品一区二区三区久久| 成人动漫av在线| 欧美精品第1页| 国产欧美综合在线观看第十页 | 国产精品麻豆网站| 久久www免费人成看片高清| 国产精品66部| 在线观看免费一区| 日韩欧美国产午夜精品| 国产精品的网站| 视频一区二区不卡| 成人永久看片免费视频天堂| 欧美日韩一区精品| 国产欧美日韩不卡| 午夜精品影院在线观看| 国内精品在线播放| 色偷偷成人一区二区三区91| 欧美α欧美αv大片| 亚洲女同ⅹxx女同tv| 国产一区免费电影| 欧美三级电影精品| 欧美高清在线视频| 日本一不卡视频| 色成年激情久久综合| 久久嫩草精品久久久精品一| 亚洲gay无套男同| 成人免费三级在线| 欧美va日韩va| 亚洲成年人影院| 色综合天天综合狠狠| 久久色中文字幕| 日本大胆欧美人术艺术动态 | 亚洲婷婷综合色高清在线| 久久国产免费看| 欧美日韩美少妇| 最近中文字幕一区二区三区| 黄色日韩三级电影| 这里只有精品免费| 亚洲一区二区三区三| 99视频在线观看一区三区| 精品日韩av一区二区| 五月天激情综合| 在线精品国精品国产尤物884a| 国产人成一区二区三区影院| 捆绑变态av一区二区三区| 欧美日韩卡一卡二| 亚洲国产精品久久人人爱| 成人高清av在线| 国产欧美日韩另类视频免费观看| 开心九九激情九九欧美日韩精美视频电影| 在线视频你懂得一区二区三区| 亚洲色图欧美激情| av午夜一区麻豆| 国产精品你懂的在线| 国产91高潮流白浆在线麻豆| 国产亚洲精久久久久久| 国产中文字幕精品| www国产精品av| 极品少妇xxxx偷拍精品少妇| 日韩欧美综合在线| 美洲天堂一区二卡三卡四卡视频| 国产精品不卡一区| 99精品视频在线播放观看| 日韩美女久久久| 色狠狠综合天天综合综合| 亚洲精品成人悠悠色影视| 色综合天天天天做夜夜夜夜做| 国产精品对白交换视频| 99riav久久精品riav| 亚洲精品国产a久久久久久| 色诱亚洲精品久久久久久| 一区二区高清视频在线观看| 欧美三区在线观看| 青青草原综合久久大伊人精品优势| 日韩一区二区影院| 国产一区在线看| 欧美国产1区2区| 91色婷婷久久久久合中文| 一区二区三区四区蜜桃| 欧美日韩国产bt| 精品一区二区三区在线播放| 久久久精品人体av艺术| 不卡欧美aaaaa| 夜夜嗨av一区二区三区 | 欧美喷潮久久久xxxxx| 人人超碰91尤物精品国产| www久久精品| 91视频.com| 蜜桃av一区二区三区| 国产欧美日本一区视频|