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

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

?? string.h

?? 一個(gè)操作系統(tǒng)的源代碼
?? H
字號(hào):
/* * This file was copied nearly unchanged from the Linux sources. Therefore,  * I didn't consider it necessary to make this file compliant to the standard  * Apostle file template. *  * -- Max */#ifndef _I386_STRING_H_#define _I386_STRING_H_#include <types.h>/*  * Omitted the specially optimized i486-routines at the moment, because they * don't compile out of the box and I'll first have to have a closer look at * them. * -- Max *//* * This string-include defines all string functions as inline * functions. Use gcc. It also assumes ds=es=data space, this should be * normal. Most of the string-functions are rather heavily hand-optimized, * see especially strtok,strstr,str[c]spn. They should work, but are not * very easy to understand. Everything is done entirely within the register * set, making the functions fast and clean. String instructions have been * used through-out, making for "slightly" unclear code :-) * *		NO Copyright (C) 1991, 1992 Linus Torvalds, *		consider these trivial functions to be PD. */#define __HAVE_ARCH_STRCPYextern inline char * strcpy(char * dest,const char *src){int d0, d1, d2;__asm__ __volatile__(	"cld\n"	"1:\tlodsb\n\t"	"stosb\n\t"	"testb %%al,%%al\n\t"	"jne 1b"	: "=&S" (d0), "=&D" (d1), "=&a" (d2)	:"0" (src),"1" (dest) : "memory");return dest;}#define __HAVE_ARCH_STRNCPYextern inline char * strncpy(char * dest,const char *src,size_t count){int d0, d1, d2, d3;__asm__ __volatile__(	"cld\n"	"1:\tdecl %2\n\t"	"js 2f\n\t"	"lodsb\n\t"	"stosb\n\t"	"testb %%al,%%al\n\t"	"jne 1b\n\t"	"rep\n\t"	"stosb\n"	"2:"	: "=&S" (d0), "=&D" (d1), "=&c" (d2), "=&a" (d3)	:"0" (src),"1" (dest),"2" (count) : "memory");return dest;}#define __HAVE_ARCH_STRCATextern inline char * strcat(char * dest,const char * src){int d0, d1, d2, d3;__asm__ __volatile__(	"cld\n\t"	"repne\n\t"	"scasb\n\t"	"decl %1\n"	"1:\tlodsb\n\t"	"stosb\n\t"	"testb %%al,%%al\n\t"	"jne 1b"	: "=&S" (d0), "=&D" (d1), "=&a" (d2), "=&c" (d3)	: "0" (src), "1" (dest), "2" (0), "3" (0xffffffff):"memory");return dest;}#define __HAVE_ARCH_STRNCATextern inline char * strncat(char * dest,const char * src,size_t count){int d0, d1, d2, d3;__asm__ __volatile__(	"cld\n\t"	"repne\n\t"	"scasb\n\t"	"decl %1\n\t"	"movl %8,%3\n"	"1:\tdecl %3\n\t"	"js 2f\n\t"	"lodsb\n\t"	"stosb\n\t"	"testb %%al,%%al\n\t"	"jne 1b\n"	"2:\txorl %2,%2\n\t"	"stosb"	: "=&S" (d0), "=&D" (d1), "=&a" (d2), "=&c" (d3)	: "0" (src),"1" (dest),"2" (0),"3" (0xffffffff), "g" (count)	: "memory");return dest;}#define __HAVE_ARCH_STRCMPextern inline int strcmp(const char * cs,const char * ct){int d0, d1;register int __res;__asm__ __volatile__(	"cld\n"	"1:\tlodsb\n\t"	"scasb\n\t"	"jne 2f\n\t"	"testb %%al,%%al\n\t"	"jne 1b\n\t"	"xorl %%eax,%%eax\n\t"	"jmp 3f\n"	"2:\tsbbl %%eax,%%eax\n\t"	"orb $1,%%al\n"	"3:"	:"=a" (__res), "=&S" (d0), "=&D" (d1)		     :"1" (cs),"2" (ct));return __res;}#define __HAVE_ARCH_STRNCMPextern inline int strncmp(const char * cs,const char * ct,size_t count){register int __res;int d0, d1, d2;__asm__ __volatile__(	"cld\n"	"1:\tdecl %3\n\t"	"js 2f\n\t"	"lodsb\n\t"	"scasb\n\t"	"jne 3f\n\t"	"testb %%al,%%al\n\t"	"jne 1b\n"	"2:\txorl %%eax,%%eax\n\t"	"jmp 4f\n"	"3:\tsbbl %%eax,%%eax\n\t"	"orb $1,%%al\n"	"4:"		     :"=a" (__res), "=&S" (d0), "=&D" (d1), "=&c" (d2)		     :"1" (cs),"2" (ct),"3" (count));return __res;}#define __HAVE_ARCH_STRCHRextern inline char * strchr(const char * s, int c){int d0;register char * __res;__asm__ __volatile__(	"cld\n\t"	"movb %%al,%%ah\n"	"1:\tlodsb\n\t"	"cmpb %%ah,%%al\n\t"	"je 2f\n\t"	"testb %%al,%%al\n\t"	"jne 1b\n\t"	"movl $1,%1\n"	"2:\tmovl %1,%0\n\t"	"decl %0"	:"=a" (__res), "=&S" (d0) : "1" (s),"0" (c));return __res;}#define __HAVE_ARCH_STRRCHRextern inline char * strrchr(const char * s, int c){int d0, d1;register char * __res;__asm__ __volatile__(	"cld\n\t"	"movb %%al,%%ah\n"	"1:\tlodsb\n\t"	"cmpb %%ah,%%al\n\t"	"jne 2f\n\t"	"leal -1(%%esi),%0\n"	"2:\ttestb %%al,%%al\n\t"	"jne 1b"	:"=g" (__res), "=&S" (d0), "=&a" (d1) :"0" (0),"1" (s),"2" (c));return __res;}#define __HAVE_ARCH_STRLENextern inline size_t strlen(const char * s){int d0;register int __res;__asm__ __volatile__(	"cld\n\t"	"repne\n\t"	"scasb\n\t"	"notl %0\n\t"	"decl %0"	:"=c" (__res), "=&D" (d0) :"1" (s),"a" (0), "0" (0xffffffff));return __res;}extern inline void * __memcpy(void * to, const void * from, size_t n){int d0, d1, d2;__asm__ __volatile__(	"cld\n\t"	"rep ; movsl\n\t"	"testb $2,%b4\n\t"	"je 1f\n\t"	"movsw\n"	"1:\ttestb $1,%b4\n\t"	"je 2f\n\t"	"movsb\n"	"2:"	: "=&c" (d0), "=&D" (d1), "=&S" (d2)	:"0" (n/4), "q" (n),"1" ((long) to),"2" ((long) from)	: "memory");return (to);}/* * This looks horribly ugly, but the compiler can optimize it totally, * as the count is constant. */extern inline void * __constant_memcpy(void * to, const void * from, size_t n){	switch (n) {		case 0:			return to;		case 1:			*(unsigned char *)to = *(const unsigned char *)from;			return to;		case 2:			*(unsigned short *)to = *(const unsigned short *)from;			return to;		case 3:			*(unsigned short *)to = *(const unsigned short *)from;			*(2+(unsigned char *)to) = *(2+(const unsigned char *)from);			return to;		case 4:			*(unsigned long *)to = *(const unsigned long *)from;			return to;		case 6:	/* for Ethernet addresses */			*(unsigned long *)to = *(const unsigned long *)from;			*(2+(unsigned short *)to) = *(2+(const unsigned short *)from);			return to;		case 8:			*(unsigned long *)to = *(const unsigned long *)from;			*(1+(unsigned long *)to) = *(1+(const unsigned long *)from);			return to;		case 12:			*(unsigned long *)to = *(const unsigned long *)from;			*(1+(unsigned long *)to) = *(1+(const unsigned long *)from);			*(2+(unsigned long *)to) = *(2+(const unsigned long *)from);			return to;		case 16:			*(unsigned long *)to = *(const unsigned long *)from;			*(1+(unsigned long *)to) = *(1+(const unsigned long *)from);			*(2+(unsigned long *)to) = *(2+(const unsigned long *)from);			*(3+(unsigned long *)to) = *(3+(const unsigned long *)from);			return to;		case 20:			*(unsigned long *)to = *(const unsigned long *)from;			*(1+(unsigned long *)to) = *(1+(const unsigned long *)from);			*(2+(unsigned long *)to) = *(2+(const unsigned long *)from);			*(3+(unsigned long *)to) = *(3+(const unsigned long *)from);			*(4+(unsigned long *)to) = *(4+(const unsigned long *)from);			return to;	}#define COMMON(x) \__asm__ __volatile__( \	"cld\n\t" \	"rep ; movsl" \	x \	: "=&c" (d0), "=&D" (d1), "=&S" (d2) \	: "0" (n/4),"1" ((long) to),"2" ((long) from) \	: "memory");{	int d0, d1, d2;	switch (n % 4) {		case 0: COMMON(""); return to;		case 1: COMMON("\n\tmovsb"); return to;		case 2: COMMON("\n\tmovsw"); return to;		default: COMMON("\n\tmovsw\n\tmovsb"); return to;	}}  #undef COMMON}#define __HAVE_ARCH_MEMCPY#define memcpy(t, f, n) \(__builtin_constant_p(n) ? \ __constant_memcpy((t),(f),(n)) : \ __memcpy((t),(f),(n)))#define __HAVE_ARCH_MEMMOVEextern inline void * memmove(void * dest,const void * src, size_t n){int d0, d1, d2;if (dest<src)__asm__ __volatile__(	"cld\n\t"	"rep\n\t"	"movsb"	: "=&c" (d0), "=&S" (d1), "=&D" (d2)	:"0" (n),"1" (src),"2" (dest)	: "memory");else__asm__ __volatile__(	"std\n\t"	"rep\n\t"	"movsb\n\t"	"cld"	: "=&c" (d0), "=&S" (d1), "=&D" (d2)	:"0" (n),	 "1" (n-1+(const char *)src),	 "2" (n-1+(char *)dest)	:"memory");return dest;}#define memcmp __builtin_memcmp#define __HAVE_ARCH_MEMCHRextern inline void * memchr(const void * cs,int c,size_t count){int d0;register void * __res;if (!count)	return NULL;__asm__ __volatile__(	"cld\n\t"	"repne\n\t"	"scasb\n\t"	"je 1f\n\t"	"movl $1,%0\n"	"1:\tdecl %0"	:"=D" (__res), "=&c" (d0) : "a" (c),"0" (cs),"1" (count));return __res;}extern inline void * __memset_generic(void * s, char c,size_t count){int d0, d1;__asm__ __volatile__(	"cld\n\t"	"rep\n\t"	"stosb"	: "=&c" (d0), "=&D" (d1)	:"a" (c),"1" (s),"0" (count)	:"memory");return s;}/* we might want to write optimized versions of these later */#define __constant_count_memset(s,c,count) __memset_generic((s),(c),(count))/* * memset(x,0,y) is a reasonably common thing to do, so we want to fill * things 32 bits at a time even when we don't know the size of the * area at compile-time.. */extern inline void * __constant_c_memset(void * s, unsigned long c, size_t count){int d0, d1;__asm__ __volatile__(	"cld\n\t"	"rep ; stosl\n\t"	"testb $2,%b3\n\t"	"je 1f\n\t"	"stosw\n"	"1:\ttestb $1,%b3\n\t"	"je 2f\n\t"	"stosb\n"	"2:"	: "=&c" (d0), "=&D" (d1)	:"a" (c), "q" (count), "0" (count/4), "1" ((long) s)	:"memory");return (s);	}/* Added by Gertjan van Wingerde to make minix and sysv module work */#define __HAVE_ARCH_STRNLENextern inline size_t strnlen(const char * s, size_t count){int d0;register int __res;__asm__ __volatile__(	"movl %2,%0\n\t"	"jmp 2f\n"	"1:\tcmpb $0,(%0)\n\t"	"je 3f\n\t"	"incl %0\n"	"2:\tdecl %1\n\t"	"cmpl $-1,%1\n\t"	"jne 1b\n"	"3:\tsubl %2,%0"	:"=a" (__res), "=&d" (d0)	:"c" (s),"1" (count));return __res;}/* end of additional stuff *//* * This looks horribly ugly, but the compiler can optimize it totally, * as we by now know that both pattern and count is constant.. */extern inline void * __constant_c_and_count_memset(void * s, unsigned long pattern, size_t count){	switch (count) {		case 0:			return s;		case 1:			*(unsigned char *)s = pattern;			return s;		case 2:			*(unsigned short *)s = pattern;			return s;		case 3:			*(unsigned short *)s = pattern;			*(2+(unsigned char *)s) = pattern;			return s;		case 4:			*(unsigned long *)s = pattern;			return s;	}#define COMMON(x) \__asm__  __volatile__("cld\n\t" \	"rep ; stosl" \	x \	: "=&c" (d0), "=&D" (d1) \	: "a" (pattern),"0" (count/4),"1" ((long) s) \	: "memory"){	int d0, d1;	switch (count % 4) {		case 0: COMMON(""); return s;		case 1: COMMON("\n\tstosb"); return s;		case 2: COMMON("\n\tstosw"); return s;		default: COMMON("\n\tstosw\n\tstosb"); return s;	}}  #undef COMMON}#define __constant_c_x_memset(s, c, count) \(__builtin_constant_p(count) ? \ __constant_c_and_count_memset((s),(c),(count)) : \ __constant_c_memset((s),(c),(count)))#define __memset(s, c, count) \(__builtin_constant_p(count) ? \ __constant_count_memset((s),(c),(count)) : \ __memset_generic((s),(c),(count)))#define __HAVE_ARCH_MEMSET#define memset(s, c, count) \(__builtin_constant_p(c) ? \ __constant_c_x_memset((s),(0x01010101UL*(unsigned char)(c)),(count)) : \ __memset((s),(c),(count)))/* * find the first occurrence of byte 'c', or 1 past the area if none */#define __HAVE_ARCH_MEMSCANextern inline void * memscan(void * addr, int c, size_t size){	if (!size)		return addr;	__asm__("cld		repnz; scasb		jnz 1f		dec %%edi1:		"		: "=D" (addr), "=c" (size)		: "0" (addr), "1" (size), "a" (c));	return addr;}#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲免费高清视频在线| 国产精品1区2区| 亚洲尤物视频在线| 一区二区高清免费观看影视大全| 欧美国产欧美亚州国产日韩mv天天看完整| 精品乱码亚洲一区二区不卡| 制服丝袜成人动漫| 日韩欧美久久一区| 久久综合色鬼综合色| 久久久久国产免费免费| 国产亚洲一本大道中文在线| 国产亚洲女人久久久久毛片| 国产日韩精品视频一区| 国产喷白浆一区二区三区| 中文字幕乱码久久午夜不卡| 国产精品灌醉下药二区| 亚洲天堂福利av| 亚洲第一av色| 久久爱www久久做| 丁香婷婷综合色啪| 一本色道**综合亚洲精品蜜桃冫| 欧洲一区二区三区免费视频| 欧美乱熟臀69xxxxxx| 精品少妇一区二区三区免费观看| 欧美精品一区二区在线观看| 久久精品欧美一区二区三区不卡| 中文字幕中文乱码欧美一区二区| 亚洲视频你懂的| 五月激情综合色| 精品午夜一区二区三区在线观看| 国产成人自拍网| 在线观看免费成人| 精品久久久久av影院 | 久久精品人人做| 中文字幕欧美一| 亚洲高清在线精品| 激情久久五月天| 99精品视频中文字幕| 6080国产精品一区二区| 国产免费成人在线视频| 亚洲免费观看高清在线观看| 污片在线观看一区二区| 国产成都精品91一区二区三| 欧洲精品中文字幕| 精品国产亚洲在线| 伊人一区二区三区| 黄色资源网久久资源365| 97精品国产露脸对白| 欧美一区二区观看视频| 国产精品嫩草99a| 亚洲6080在线| 成人激情免费电影网址| 欧美一区二区视频在线观看2022 | 久久97超碰色| 日本精品免费观看高清观看| 欧美sm极限捆绑bd| 亚洲一区二区在线视频| 国产精品一区免费视频| 色婷婷亚洲婷婷| 久久久久9999亚洲精品| 午夜久久久久久电影| aaa欧美大片| 26uuu色噜噜精品一区二区| 一区二区三区在线免费视频| 九九热在线视频观看这里只有精品| 色婷婷精品大在线视频| 337p粉嫩大胆噜噜噜噜噜91av| 亚洲资源在线观看| 粉嫩蜜臀av国产精品网站| 欧美一区二区三区在线观看视频| **性色生活片久久毛片| 国产精品一区二区在线播放 | 国产精品天美传媒沈樵| 免费观看久久久4p| 在线观看不卡视频| 国产精品美女久久久久久| 国产在线不卡一区| 欧美一区二区免费| 日精品一区二区三区| 色婷婷亚洲精品| 亚洲欧洲日本在线| 国产盗摄精品一区二区三区在线| 91精品婷婷国产综合久久| 曰韩精品一区二区| 91最新地址在线播放| 国产精品天美传媒| 国产成人在线视频网址| 精品电影一区二区| 青青草国产精品亚洲专区无| 欧美女孩性生活视频| 亚洲国产精品尤物yw在线观看| 色综合久久99| 亚洲欧美日韩系列| 91同城在线观看| 中文字幕一区av| 99视频在线精品| 亚洲三级电影全部在线观看高清| 成人美女在线观看| 国产精品国产自产拍高清av| 盗摄精品av一区二区三区| 久久久久久久久久久久电影| 国产米奇在线777精品观看| 亚洲精品在线观| 国产在线精品一区在线观看麻豆| 日韩一级高清毛片| 美女精品一区二区| 欧美成人性战久久| 国产乱码精品一区二区三区五月婷| 精品久久一区二区三区| 国产精品影视网| 中文字幕不卡在线| 99久久久国产精品| 一区二区三区四区不卡在线| 在线观看成人小视频| 婷婷国产在线综合| 日韩三级免费观看| 国内偷窥港台综合视频在线播放| 欧美精品一区二| 成人免费不卡视频| 一区二区三区精品视频在线| 欧美性猛交xxxxxx富婆| 奇米四色…亚洲| 国产欧美综合在线观看第十页| jizz一区二区| 亚洲大片在线观看| 日韩视频一区二区在线观看| 国产综合色视频| 国产精品久久久久久久浪潮网站| 日本精品免费观看高清观看| 天天色综合成人网| 久久综合九色综合97婷婷女人 | 亚洲 欧美综合在线网络| 日韩一区二区精品| 成人一区二区三区视频| 一区二区在线观看av| 欧美福利视频导航| 国产电影精品久久禁18| 亚洲人成精品久久久久| 欧美日韩国产一级| 国产九色sp调教91| 一区二区免费在线| 精品国产91洋老外米糕| www.亚洲人| 石原莉奈在线亚洲三区| 国产午夜精品一区二区三区嫩草 | 91福利在线导航| 久久99精品国产麻豆婷婷洗澡| 国产欧美日韩综合| 欧美色图激情小说| 国产一区二区三区在线观看免费| 亚洲日本成人在线观看| 欧美一级黄色录像| 成人动漫中文字幕| 日本不卡高清视频| 国产精品视频你懂的| 欧美高清视频www夜色资源网| 国产69精品久久久久毛片 | 成人精品电影在线观看| 午夜精品影院在线观看| 国产亚洲欧美在线| 在线不卡中文字幕| www.成人在线| 美腿丝袜亚洲三区| 亚洲久本草在线中文字幕| 91精品国产91久久久久久最新毛片| 国产99精品国产| 日本一不卡视频| 1区2区3区欧美| 久久老女人爱爱| 欧美区视频在线观看| 成人爱爱电影网址| 精品亚洲免费视频| 亚洲无人区一区| 自拍偷拍亚洲激情| 国产欧美综合在线观看第十页| 91麻豆精品国产91| 色综合久久中文综合久久97| 久久精品国产亚洲aⅴ| 亚洲愉拍自拍另类高清精品| 国产精品日产欧美久久久久| 日韩欧美亚洲国产另类| 欧美精品久久久久久久多人混战| 99国产精品一区| 国产一区二区三区在线观看免费| 黄色精品一二区| 污片在线观看一区二区| 亚洲永久精品国产| 成人欧美一区二区三区视频网页| 久久精品视频免费观看| 欧美成人精品二区三区99精品| 欧美日韩视频在线观看一区二区三区| av电影在线观看完整版一区二区| 狠狠色丁香久久婷婷综| 欧美aaaaaa午夜精品| 日韩精品电影一区亚洲| 亚洲伊人伊色伊影伊综合网 | 99久久精品久久久久久清纯| 国产精品91一区二区| 国内一区二区在线| 激情丁香综合五月|