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

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

?? bcheck.c

?? 小而快的c編譯器
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* *  Tiny C Memory and bounds checker *  *  Copyright (c) 2002 Fabrice Bellard * *  This program is free software; you can redistribute it and/or modify *  it under the terms of the GNU General Public License as published by *  the Free Software Foundation; either version 2 of the License, or *  (at your option) any later version. * *  This program is distributed in the hope that it will be useful, *  but WITHOUT ANY WARRANTY; without even the implied warranty of *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *  GNU General Public License for more details. * *  You should have received a copy of the GNU General Public License *  along with this program; if not, write to the Free Software *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */#include <stdlib.h>#include <stdio.h>#include <stdarg.h>#include <string.h>#ifndef __FreeBSD__#include <malloc.h>#endif//#define BOUND_DEBUG/* define so that bound array is static (faster, but use memory if   bound checking not used) *///#define BOUND_STATIC/* use malloc hooks. Currently the code cannot be reliable if no hooks */#define CONFIG_TCC_MALLOC_HOOKS#define HAVE_MEMALIGN#ifdef __FreeBSD__#warning Bound checking not fully supported on FreeBSD#undef CONFIG_TCC_MALLOC_HOOKS#undef HAVE_MEMALIGN#endif#define BOUND_T1_BITS 13#define BOUND_T2_BITS 11#define BOUND_T3_BITS (32 - BOUND_T1_BITS - BOUND_T2_BITS)#define BOUND_T1_SIZE (1 << BOUND_T1_BITS)#define BOUND_T2_SIZE (1 << BOUND_T2_BITS)#define BOUND_T3_SIZE (1 << BOUND_T3_BITS)#define BOUND_E_BITS  4#define BOUND_T23_BITS (BOUND_T2_BITS + BOUND_T3_BITS)#define BOUND_T23_SIZE (1 << BOUND_T23_BITS)/* this pointer is generated when bound check is incorrect */#define INVALID_POINTER ((void *)(-2))/* size of an empty region */#define EMPTY_SIZE        0xffffffff/* size of an invalid region */#define INVALID_SIZE      0typedef struct BoundEntry {    unsigned long start;    unsigned long size;    struct BoundEntry *next;    unsigned long is_invalid; /* true if pointers outside region are invalid */} BoundEntry;/* external interface */void __bound_init(void);void __bound_new_region(void *p, unsigned long size);int __bound_delete_region(void *p);/* currently, tcc cannot compile that because we use unsupported GNU C   extensions */#if !defined(__TINYC__)void *__bound_ptr_add(void *p, int offset) __attribute__((regparm(2)));void *__bound_ptr_indir1(void *p, int offset) __attribute__((regparm(2)));void *__bound_ptr_indir2(void *p, int offset) __attribute__((regparm(2)));void *__bound_ptr_indir4(void *p, int offset) __attribute__((regparm(2)));void *__bound_ptr_indir8(void *p, int offset) __attribute__((regparm(2)));void *__bound_ptr_indir12(void *p, int offset) __attribute__((regparm(2)));void *__bound_ptr_indir16(void *p, int offset) __attribute__((regparm(2)));void __bound_local_new(void *p) __attribute__((regparm(1)));void __bound_local_delete(void *p) __attribute__((regparm(1)));#endifvoid *__bound_malloc(size_t size, const void *caller);void *__bound_memalign(size_t size, size_t align, const void *caller);void __bound_free(void *ptr, const void *caller);void *__bound_realloc(void *ptr, size_t size, const void *caller);static void *libc_malloc(size_t size);static void libc_free(void *ptr);static void install_malloc_hooks(void);static void restore_malloc_hooks(void);#ifdef CONFIG_TCC_MALLOC_HOOKSstatic void *saved_malloc_hook;static void *saved_free_hook;static void *saved_realloc_hook;static void *saved_memalign_hook;#endif/* linker definitions */extern char _end;/* TCC definitions */extern char __bounds_start; /* start of static bounds table *//* error message, just for TCC */const char *__bound_error_msg;/* runtime error output */extern void rt_error(unsigned long pc, const char *fmt, ...);#ifdef BOUND_STATICstatic BoundEntry *__bound_t1[BOUND_T1_SIZE]; /* page table */#elsestatic BoundEntry **__bound_t1; /* page table */#endifstatic BoundEntry *__bound_empty_t2;   /* empty page, for unused pages */static BoundEntry *__bound_invalid_t2; /* invalid page, for invalid pointers */static BoundEntry *__bound_find_region(BoundEntry *e1, void *p){    unsigned long addr, tmp;    BoundEntry *e;    e = e1;    while (e != NULL) {        addr = (unsigned long)p;        addr -= e->start;        if (addr <= e->size) {            /* put region at the head */            tmp = e1->start;            e1->start = e->start;            e->start = tmp;            tmp = e1->size;            e1->size = e->size;            e->size = tmp;            return e1;        }        e = e->next;    }    /* no entry found: return empty entry or invalid entry */    if (e1->is_invalid)        return __bound_invalid_t2;    else        return __bound_empty_t2;}/* print a bound error message */static void bound_error(const char *fmt, ...){    __bound_error_msg = fmt;    *(int *)0 = 0; /* force a runtime error */}static void bound_alloc_error(void){    bound_error("not enough memory for bound checking code");}/* currently, tcc cannot compile that because we use GNUC extensions */#if !defined(__TINYC__)/* return '(p + offset)' for pointer arithmetic (a pointer can reach   the end of a region in this case */void *__bound_ptr_add(void *p, int offset){    unsigned long addr = (unsigned long)p;    BoundEntry *e;#if defined(BOUND_DEBUG)    printf("add: 0x%x %d\n", (int)p, offset);#endif    e = __bound_t1[addr >> (BOUND_T2_BITS + BOUND_T3_BITS)];    e = (BoundEntry *)((char *)e +                        ((addr >> (BOUND_T3_BITS - BOUND_E_BITS)) &                         ((BOUND_T2_SIZE - 1) << BOUND_E_BITS)));    addr -= e->start;    if (addr > e->size) {        e = __bound_find_region(e, p);        addr = (unsigned long)p - e->start;    }    addr += offset;    if (addr > e->size)        return INVALID_POINTER; /* return an invalid pointer */    return p + offset;}/* return '(p + offset)' for pointer indirection (the resulting must   be strictly inside the region */#define BOUND_PTR_INDIR(dsize)                                          \void *__bound_ptr_indir ## dsize (void *p, int offset)                  \{                                                                       \    unsigned long addr = (unsigned long)p;                              \    BoundEntry *e;                                                      \                                                                        \    e = __bound_t1[addr >> (BOUND_T2_BITS + BOUND_T3_BITS)];            \    e = (BoundEntry *)((char *)e +                                      \                       ((addr >> (BOUND_T3_BITS - BOUND_E_BITS)) &      \                        ((BOUND_T2_SIZE - 1) << BOUND_E_BITS)));        \    addr -= e->start;                                                   \    if (addr > e->size) {                                               \        e = __bound_find_region(e, p);                                  \        addr = (unsigned long)p - e->start;                             \    }                                                                   \    addr += offset + dsize;                                             \    if (addr > e->size)                                                 \        return INVALID_POINTER; /* return an invalid pointer */         \    return p + offset;                                                  \}#ifdef __i386__/* return the frame pointer of the caller */#define GET_CALLER_FP(fp)\{\    unsigned long *fp1;\    __asm__ __volatile__ ("movl %%ebp,%0" :"=g" (fp1));\    fp = fp1[0];\}#else#error put code to extract the calling frame pointer#endif/* called when entering a function to add all the local regions */void __bound_local_new(void *p1) {    unsigned long addr, size, fp, *p = p1;    GET_CALLER_FP(fp);    for(;;) {        addr = p[0];        if (addr == 0)            break;        addr += fp;        size = p[1];        p += 2;        __bound_new_region((void *)addr, size);    }}/* called when leaving a function to delete all the local regions */void __bound_local_delete(void *p1) {    unsigned long addr, fp, *p = p1;    GET_CALLER_FP(fp);    for(;;) {        addr = p[0];        if (addr == 0)            break;        addr += fp;        p += 2;        __bound_delete_region((void *)addr);    }}#elsevoid __bound_local_new(void *p) {}void __bound_local_delete(void *p) {}void *__bound_ptr_add(void *p, int offset){    return p + offset;}#define BOUND_PTR_INDIR(dsize)                               \void *__bound_ptr_indir ## dsize (void *p, int offset)       \{                                                            \    return p + offset;                                       \}#endifBOUND_PTR_INDIR(1)BOUND_PTR_INDIR(2)BOUND_PTR_INDIR(4)BOUND_PTR_INDIR(8)BOUND_PTR_INDIR(12)BOUND_PTR_INDIR(16)static BoundEntry *__bound_new_page(void){    BoundEntry *page;    int i;    page = libc_malloc(sizeof(BoundEntry) * BOUND_T2_SIZE);    if (!page)        bound_alloc_error();    for(i=0;i<BOUND_T2_SIZE;i++) {        /* put empty entries */        page[i].start = 0;        page[i].size = EMPTY_SIZE;        page[i].next = NULL;        page[i].is_invalid = 0;    }    return page;}/* currently we use malloc(). Should use bound_new_page() */static BoundEntry *bound_new_entry(void){    BoundEntry *e;    e = libc_malloc(sizeof(BoundEntry));    return e;}static void bound_free_entry(BoundEntry *e){    libc_free(e);}static inline BoundEntry *get_page(int index){    BoundEntry *page;    page = __bound_t1[index];    if (page == __bound_empty_t2 || page == __bound_invalid_t2) {        /* create a new page if necessary */        page = __bound_new_page();        __bound_t1[index] = page;    }    return page;}/* mark a region as being invalid (can only be used during init) */static void mark_invalid(unsigned long addr, unsigned long size){    unsigned long start, end;    BoundEntry *page;    int t1_start, t1_end, i, j, t2_start, t2_end;    start = addr;    end = addr + size;    t2_start = (start + BOUND_T3_SIZE - 1) >> BOUND_T3_BITS;    if (end != 0)        t2_end = end >> BOUND_T3_BITS;    else        t2_end = 1 << (BOUND_T1_BITS + BOUND_T2_BITS);#if 0    printf("mark_invalid: start = %x %x\n", t2_start, t2_end);#endif        /* first we handle full pages */    t1_start = (t2_start + BOUND_T2_SIZE - 1) >> BOUND_T2_BITS;    t1_end = t2_end >> BOUND_T2_BITS;    i = t2_start & (BOUND_T2_SIZE - 1);    j = t2_end & (BOUND_T2_SIZE - 1);        if (t1_start == t1_end) {        page = get_page(t2_start >> BOUND_T2_BITS);        for(; i < j; i++) {            page[i].size = INVALID_SIZE;            page[i].is_invalid = 1;        }    } else {        if (i > 0) {            page = get_page(t2_start >> BOUND_T2_BITS);            for(; i < BOUND_T2_SIZE; i++) {                page[i].size = INVALID_SIZE;                page[i].is_invalid = 1;            }        }        for(i = t1_start; i < t1_end; i++) {            __bound_t1[i] = __bound_invalid_t2;        }        if (j != 0) {            page = get_page(t1_end);            for(i = 0; i < j; i++) {                page[i].size = INVALID_SIZE;                page[i].is_invalid = 1;            }        }    }}void __bound_init(void){    int i;    BoundEntry *page;    unsigned long start, size;    int *p;    /* save malloc hooks and install bound check hooks */    install_malloc_hooks();#ifndef BOUND_STATIC    __bound_t1 = libc_malloc(BOUND_T1_SIZE * sizeof(BoundEntry *));    if (!__bound_t1)        bound_alloc_error();#endif    __bound_empty_t2 = __bound_new_page();    for(i=0;i<BOUND_T1_SIZE;i++) {        __bound_t1[i] = __bound_empty_t2;    }    page = __bound_new_page();    for(i=0;i<BOUND_T2_SIZE;i++) {        /* put invalid entries */        page[i].start = 0;        page[i].size = INVALID_SIZE;        page[i].next = NULL;        page[i].is_invalid = 1;    }    __bound_invalid_t2 = page;    /* invalid pointer zone */    start = (unsigned long)INVALID_POINTER & ~(BOUND_T23_SIZE - 1);    size = BOUND_T23_SIZE;    mark_invalid(start, size);#if !defined(__TINYC__) && defined(CONFIG_TCC_MALLOC_HOOKS)    /* malloc zone is also marked invalid. can only use that with       hooks because all libs should use the same malloc. The solution       would be to build a new malloc for tcc. */    start = (unsigned long)&_end;    size = 128 * 0x100000;    mark_invalid(start, size);#endif    /* add all static bound check values */    p = (int *)&__bounds_start;    while (p[0] != 0) {        __bound_new_region((void *)p[0], p[1]);        p += 2;    }}static inline void add_region(BoundEntry *e,                               unsigned long start, unsigned long size){    BoundEntry *e1;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
麻豆免费看一区二区三区| 国产精品不卡在线| 另类综合日韩欧美亚洲| 日韩美女视频在线| 国产剧情av麻豆香蕉精品| 国产丝袜欧美中文另类| 9久草视频在线视频精品| 亚洲色图一区二区三区| 欧美日韩一区中文字幕| 奇米777欧美一区二区| 亚洲小少妇裸体bbw| 91精品国产色综合久久不卡电影| 青草av.久久免费一区| 久久一二三国产| 成人av电影免费在线播放| 亚洲精品一卡二卡| 欧美精品一二三四| 国产精品69久久久久水密桃| 中文字幕一区免费在线观看| 欧美性感一类影片在线播放| 蜜桃av噜噜一区二区三区小说| 国产午夜精品一区二区三区四区| av成人老司机| 蜜桃视频免费观看一区| 中文字幕国产一区| 91精品国产综合久久香蕉麻豆| 国产高清不卡二三区| 一区二区三区在线观看网站| 欧美一区国产二区| 成人av电影在线播放| 青青草成人在线观看| 国产精品国产三级国产| 日韩丝袜情趣美女图片| 91原创在线视频| 久久99久久久久| 亚洲精品视频在线看| 欧美成人video| 91成人在线精品| 国产**成人网毛片九色 | 久久女同互慰一区二区三区| 91在线小视频| 国产一区二区三区四| 五月激情六月综合| 一区精品在线播放| 亚洲精品一区二区在线观看| 欧美这里有精品| 波多野结衣在线一区| 麻豆传媒一区二区三区| 亚洲一区二区不卡免费| 国产精品每日更新在线播放网址| 欧美一级片在线| 在线视频中文字幕一区二区| 国产成人99久久亚洲综合精品| 日韩国产成人精品| 一区二区三区高清在线| 国产女人18毛片水真多成人如厕| 欧美一区二区在线观看| 欧美色综合天天久久综合精品| www.成人网.com| 国产成人免费视频| 国产尤物一区二区在线| 免费看黄色91| 青椒成人免费视频| 日韩成人午夜电影| 亚洲va国产va欧美va观看| 最新国产精品久久精品| 国产精品乱码人人做人人爱 | 欧美精品丝袜中出| 欧美无人高清视频在线观看| 99久久99久久免费精品蜜臀| 极品少妇xxxx精品少妇| 日本成人在线网站| 午夜免费欧美电影| 午夜精品免费在线| 午夜视黄欧洲亚洲| 日本女优在线视频一区二区| 午夜精品成人在线| 首页欧美精品中文字幕| 日韩av中文在线观看| 免费在线观看一区| 国产一区二区三区香蕉| 国模一区二区三区白浆| 国产精品原创巨作av| 国产成人精品一区二| 成人精品视频一区二区三区 | 亚洲综合一区在线| 亚洲一区成人在线| 日韩二区三区在线观看| 狂野欧美性猛交blacked| 国产专区综合网| 成人高清伦理免费影院在线观看| 99久久er热在这里只有精品15| 色综合久久久久综合体| 欧美性猛交xxxxxx富婆| 日韩限制级电影在线观看| 久久综合一区二区| 日韩毛片在线免费观看| 亚洲大片精品永久免费| 激情欧美日韩一区二区| 成人动漫在线一区| 欧美在线影院一区二区| 日韩精品一区二区三区视频| 国产精品女同互慰在线看| 亚洲六月丁香色婷婷综合久久| 午夜精品一区在线观看| 国产尤物一区二区在线| 91麻豆产精品久久久久久| 欧美日韩在线播放| 国产亚洲午夜高清国产拍精品| 亚洲欧美怡红院| 婷婷综合五月天| 国产精品一区二区免费不卡| 色哟哟欧美精品| 日韩免费高清电影| 1024成人网色www| 日韩在线一区二区| 国产ts人妖一区二区| 欧美日韩精品一二三区| 久久精品视频免费| 亚洲国产va精品久久久不卡综合| 精品夜夜嗨av一区二区三区| 色综合久久中文综合久久97| 日韩一区二区三免费高清| 成人欧美一区二区三区白人| 免费在线看一区| 91小视频免费观看| 2021国产精品久久精品| 亚洲高清免费一级二级三级| 国产精品一区二区你懂的| 欧美日韩精品一区二区在线播放| 亚洲国产精品高清| 日日夜夜精品免费视频| 一本一道综合狠狠老| 久久精品一区二区三区av| 视频在线观看一区| 日本高清视频一区二区| 久久久久久麻豆| 丝袜美腿亚洲一区二区图片| 97精品久久久午夜一区二区三区 | 91在线播放网址| 久久久久97国产精华液好用吗| 亚洲成人精品影院| 色综合久久中文综合久久牛| 久久精品亚洲精品国产欧美 | 国产精品久久久久影院色老大| 美女视频网站久久| 欧美亚洲国产怡红院影院| 国产精品久久久久影视| 国产精品18久久久| 337p粉嫩大胆色噜噜噜噜亚洲| 亚洲成av人综合在线观看| 91丝袜国产在线播放| 日本一区二区成人| 国模冰冰炮一区二区| 欧美一级生活片| 日韩中文字幕区一区有砖一区| 91国产精品成人| 亚洲欧美激情小说另类| 91视频精品在这里| 亚洲天堂成人在线观看| 99re视频这里只有精品| 中文字幕综合网| 91在线小视频| 一区二区三区在线不卡| 91丨porny丨最新| 亚洲嫩草精品久久| 色8久久精品久久久久久蜜| 国产精品国产三级国产普通话三级| 高清av一区二区| 中文字幕一区二区在线观看| 99re热视频这里只精品| 亚洲免费视频成人| 欧美性猛片aaaaaaa做受| 亚洲va欧美va人人爽午夜 | 日韩欧美一区二区不卡| 免费av成人在线| 精品999久久久| 国产成人午夜99999| 最新日韩av在线| 欧美中文一区二区三区| 人禽交欧美网站| 精品福利视频一区二区三区| 国产·精品毛片| 一区二区三区加勒比av| 8x8x8国产精品| 精品一区精品二区高清| 欧美激情一区三区| 一本一道久久a久久精品 | 亚洲一区精品在线| 欧美伊人久久久久久午夜久久久久| 亚洲午夜久久久久| 欧美一级视频精品观看| 国产在线精品免费av| 欧美激情在线一区二区三区| 色综合久久综合网| 免费成人av资源网| 国产精品入口麻豆九色| 欧美人与禽zozo性伦| 国产综合色产在线精品| 亚洲男人电影天堂|