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

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

?? gdb-low.s

?? LINUX 2.6.17.4的源碼
?? S
字號:
/* * gdb-low.S contains the low-level trap handler for the GDB stub. * * Copyright (C) 1995 Andreas Busse */#include <linux/config.h>#include <linux/sys.h>#include <asm/asm.h>#include <asm/errno.h>#include <asm/mipsregs.h>#include <asm/regdef.h>#include <asm/stackframe.h>#include <asm/gdb-stub.h>#ifdef CONFIG_32BIT#define DMFC0	mfc0#define DMTC0	mtc0#define LDC1	lwc1#define SDC1	lwc1#endif#ifdef CONFIG_64BIT#define DMFC0	dmfc0#define DMTC0	dmtc0#define LDC1	ldc1#define SDC1	ldc1#endif/* * [jsun] We reserves about 2x GDB_FR_SIZE in stack.  The lower (addressed) * part is used to store registers and passed to exception handler. * The upper part is reserved for "call func" feature where gdb client * saves some of the regs, setups call frame and passes args. * * A trace shows about 200 bytes are used to store about half of all regs. * The rest should be big enough for frame setup and passing args. *//* * The low level trap handler */		.align 	5		NESTED(trap_low, GDB_FR_SIZE, sp)		.set	noat		.set 	noreorder		mfc0	k0, CP0_STATUS		sll	k0, 3     		/* extract cu0 bit */		bltz	k0, 1f		move	k1, sp		/*		 * Called from user mode, go somewhere else.		 */		mfc0	k0, CP0_CAUSE		andi	k0, k0, 0x7c#ifdef CONFIG_64BIT		dsll	k0, k0, 1#endif		PTR_L	k1, saved_vectors(k0)		jr	k1		nop1:		move	k0, sp		PTR_SUBU sp, k1, GDB_FR_SIZE*2	# see comment above		LONG_S	k0, GDB_FR_REG29(sp)		LONG_S	$2, GDB_FR_REG2(sp)/* * First save the CP0 and special registers */		mfc0	v0, CP0_STATUS		LONG_S	v0, GDB_FR_STATUS(sp)		mfc0	v0, CP0_CAUSE		LONG_S	v0, GDB_FR_CAUSE(sp)		DMFC0	v0, CP0_EPC		LONG_S	v0, GDB_FR_EPC(sp)		DMFC0	v0, CP0_BADVADDR		LONG_S	v0, GDB_FR_BADVADDR(sp)		mfhi	v0		LONG_S	v0, GDB_FR_HI(sp)		mflo	v0		LONG_S	v0, GDB_FR_LO(sp)/* * Now the integer registers */		LONG_S	zero, GDB_FR_REG0(sp)		/* I know... */		LONG_S	$1, GDB_FR_REG1(sp)		/* v0 already saved */		LONG_S	$3, GDB_FR_REG3(sp)		LONG_S	$4, GDB_FR_REG4(sp)		LONG_S	$5, GDB_FR_REG5(sp)		LONG_S	$6, GDB_FR_REG6(sp)		LONG_S	$7, GDB_FR_REG7(sp)		LONG_S	$8, GDB_FR_REG8(sp)		LONG_S	$9, GDB_FR_REG9(sp)		LONG_S	$10, GDB_FR_REG10(sp)		LONG_S	$11, GDB_FR_REG11(sp)		LONG_S	$12, GDB_FR_REG12(sp)		LONG_S	$13, GDB_FR_REG13(sp)		LONG_S	$14, GDB_FR_REG14(sp)		LONG_S	$15, GDB_FR_REG15(sp)		LONG_S	$16, GDB_FR_REG16(sp)		LONG_S	$17, GDB_FR_REG17(sp)		LONG_S	$18, GDB_FR_REG18(sp)		LONG_S	$19, GDB_FR_REG19(sp)		LONG_S	$20, GDB_FR_REG20(sp)		LONG_S	$21, GDB_FR_REG21(sp)		LONG_S	$22, GDB_FR_REG22(sp)		LONG_S	$23, GDB_FR_REG23(sp)		LONG_S	$24, GDB_FR_REG24(sp)		LONG_S	$25, GDB_FR_REG25(sp)		LONG_S	$26, GDB_FR_REG26(sp)		LONG_S	$27, GDB_FR_REG27(sp)		LONG_S	$28, GDB_FR_REG28(sp)		/* sp already saved */		LONG_S	$30, GDB_FR_REG30(sp)		LONG_S	$31, GDB_FR_REG31(sp)		CLI				/* disable interrupts *//* * Followed by the floating point registers */		mfc0	v0, CP0_STATUS		/* FPU enabled? */		srl	v0, v0, 16		andi	v0, v0, (ST0_CU1 >> 16)		beqz	v0,2f			/* disabled, skip */		 nop		SDC1	$0, GDB_FR_FPR0(sp)		SDC1	$1, GDB_FR_FPR1(sp)		SDC1	$2, GDB_FR_FPR2(sp)		SDC1	$3, GDB_FR_FPR3(sp)		SDC1	$4, GDB_FR_FPR4(sp)		SDC1	$5, GDB_FR_FPR5(sp)		SDC1	$6, GDB_FR_FPR6(sp)		SDC1	$7, GDB_FR_FPR7(sp)		SDC1	$8, GDB_FR_FPR8(sp)		SDC1	$9, GDB_FR_FPR9(sp)		SDC1	$10, GDB_FR_FPR10(sp)		SDC1	$11, GDB_FR_FPR11(sp)		SDC1	$12, GDB_FR_FPR12(sp)		SDC1	$13, GDB_FR_FPR13(sp)		SDC1	$14, GDB_FR_FPR14(sp)		SDC1	$15, GDB_FR_FPR15(sp)		SDC1	$16, GDB_FR_FPR16(sp)		SDC1	$17, GDB_FR_FPR17(sp)		SDC1	$18, GDB_FR_FPR18(sp)		SDC1	$19, GDB_FR_FPR19(sp)		SDC1	$20, GDB_FR_FPR20(sp)		SDC1	$21, GDB_FR_FPR21(sp)		SDC1	$22, GDB_FR_FPR22(sp)		SDC1	$23, GDB_FR_FPR23(sp)		SDC1	$24, GDB_FR_FPR24(sp)		SDC1	$25, GDB_FR_FPR25(sp)		SDC1	$26, GDB_FR_FPR26(sp)		SDC1	$27, GDB_FR_FPR27(sp)		SDC1	$28, GDB_FR_FPR28(sp)		SDC1	$29, GDB_FR_FPR29(sp)		SDC1	$30, GDB_FR_FPR30(sp)		SDC1	$31, GDB_FR_FPR31(sp)/* * FPU control registers */		cfc1	v0, CP1_STATUS		LONG_S	v0, GDB_FR_FSR(sp)		cfc1	v0, CP1_REVISION		LONG_S	v0, GDB_FR_FIR(sp)/* * Current stack frame ptr */2:		LONG_S	sp, GDB_FR_FRP(sp)/* * CP0 registers (R4000/R4400 unused registers skipped) */		mfc0	v0, CP0_INDEX		LONG_S	v0, GDB_FR_CP0_INDEX(sp)		mfc0	v0, CP0_RANDOM		LONG_S	v0, GDB_FR_CP0_RANDOM(sp)		DMFC0	v0, CP0_ENTRYLO0		LONG_S	v0, GDB_FR_CP0_ENTRYLO0(sp)		DMFC0	v0, CP0_ENTRYLO1		LONG_S	v0, GDB_FR_CP0_ENTRYLO1(sp)		DMFC0	v0, CP0_CONTEXT		LONG_S	v0, GDB_FR_CP0_CONTEXT(sp)		mfc0	v0, CP0_PAGEMASK		LONG_S	v0, GDB_FR_CP0_PAGEMASK(sp)		mfc0	v0, CP0_WIRED		LONG_S	v0, GDB_FR_CP0_WIRED(sp)		DMFC0	v0, CP0_ENTRYHI		LONG_S	v0, GDB_FR_CP0_ENTRYHI(sp)		mfc0	v0, CP0_PRID		LONG_S	v0, GDB_FR_CP0_PRID(sp)		.set	at/* * Continue with the higher level handler */		move	a0,sp		jal	handle_exception		 nop/* * Restore all writable registers, in reverse order */		.set	noat		LONG_L	v0, GDB_FR_CP0_ENTRYHI(sp)		LONG_L	v1, GDB_FR_CP0_WIRED(sp)		DMTC0	v0, CP0_ENTRYHI		mtc0	v1, CP0_WIRED		LONG_L	v0, GDB_FR_CP0_PAGEMASK(sp)		LONG_L	v1, GDB_FR_CP0_ENTRYLO1(sp)		mtc0	v0, CP0_PAGEMASK		DMTC0	v1, CP0_ENTRYLO1		LONG_L	v0, GDB_FR_CP0_ENTRYLO0(sp)		LONG_L	v1, GDB_FR_CP0_INDEX(sp)		DMTC0	v0, CP0_ENTRYLO0		LONG_L	v0, GDB_FR_CP0_CONTEXT(sp)		mtc0	v1, CP0_INDEX		DMTC0	v0, CP0_CONTEXT/* * Next, the floating point registers */		mfc0	v0, CP0_STATUS		/* check if the FPU is enabled */		srl	v0, v0, 16		andi	v0, v0, (ST0_CU1 >> 16)		beqz	v0, 3f			/* disabled, skip */		 nop		LDC1	$31, GDB_FR_FPR31(sp)		LDC1	$30, GDB_FR_FPR30(sp)		LDC1	$29, GDB_FR_FPR29(sp)		LDC1	$28, GDB_FR_FPR28(sp)		LDC1	$27, GDB_FR_FPR27(sp)		LDC1	$26, GDB_FR_FPR26(sp)		LDC1	$25, GDB_FR_FPR25(sp)		LDC1	$24, GDB_FR_FPR24(sp)		LDC1	$23, GDB_FR_FPR23(sp)		LDC1	$22, GDB_FR_FPR22(sp)		LDC1	$21, GDB_FR_FPR21(sp)		LDC1	$20, GDB_FR_FPR20(sp)		LDC1	$19, GDB_FR_FPR19(sp)		LDC1	$18, GDB_FR_FPR18(sp)		LDC1	$17, GDB_FR_FPR17(sp)		LDC1	$16, GDB_FR_FPR16(sp)		LDC1	$15, GDB_FR_FPR15(sp)		LDC1	$14, GDB_FR_FPR14(sp)		LDC1	$13, GDB_FR_FPR13(sp)		LDC1	$12, GDB_FR_FPR12(sp)		LDC1	$11, GDB_FR_FPR11(sp)		LDC1	$10, GDB_FR_FPR10(sp)		LDC1	$9, GDB_FR_FPR9(sp)		LDC1	$8, GDB_FR_FPR8(sp)		LDC1	$7, GDB_FR_FPR7(sp)		LDC1	$6, GDB_FR_FPR6(sp)		LDC1	$5, GDB_FR_FPR5(sp)		LDC1	$4, GDB_FR_FPR4(sp)		LDC1	$3, GDB_FR_FPR3(sp)		LDC1	$2, GDB_FR_FPR2(sp)		LDC1	$1, GDB_FR_FPR1(sp)		LDC1	$0, GDB_FR_FPR0(sp)/* * Now the CP0 and integer registers */3:#ifdef CONFIG_MIPS_MT_SMTC		/* Read-modify write of Status must be atomic */		mfc0	t2, CP0_TCSTATUS		ori	t1, t2, TCSTATUS_IXMT		mtc0	t1, CP0_TCSTATUS		andi	t2, t2, TCSTATUS_IXMT		ehb		DMT	9				# dmt	t1		jal	mips_ihb		nop#endif /* CONFIG_MIPS_MT_SMTC */		mfc0	t0, CP0_STATUS		ori	t0, 0x1f		xori	t0, 0x1f		mtc0	t0, CP0_STATUS#ifdef CONFIG_MIPS_MT_SMTC        	andi    t1, t1, VPECONTROL_TE        	beqz    t1, 9f		nop        	EMT					# emt9:		mfc0	t1, CP0_TCSTATUS		xori	t1, t1, TCSTATUS_IXMT		or	t1, t1, t2		mtc0	t1, CP0_TCSTATUS		ehb#endif /* CONFIG_MIPS_MT_SMTC */		LONG_L	v0, GDB_FR_STATUS(sp)		LONG_L	v1, GDB_FR_EPC(sp)		mtc0	v0, CP0_STATUS		DMTC0	v1, CP0_EPC		LONG_L	v0, GDB_FR_HI(sp)		LONG_L	v1, GDB_FR_LO(sp)		mthi	v0		mtlo	v1		LONG_L	$31, GDB_FR_REG31(sp)		LONG_L	$30, GDB_FR_REG30(sp)		LONG_L	$28, GDB_FR_REG28(sp)		LONG_L	$27, GDB_FR_REG27(sp)		LONG_L	$26, GDB_FR_REG26(sp)		LONG_L	$25, GDB_FR_REG25(sp)		LONG_L	$24, GDB_FR_REG24(sp)		LONG_L	$23, GDB_FR_REG23(sp)		LONG_L	$22, GDB_FR_REG22(sp)		LONG_L	$21, GDB_FR_REG21(sp)		LONG_L	$20, GDB_FR_REG20(sp)		LONG_L	$19, GDB_FR_REG19(sp)		LONG_L	$18, GDB_FR_REG18(sp)		LONG_L	$17, GDB_FR_REG17(sp)		LONG_L	$16, GDB_FR_REG16(sp)		LONG_L	$15, GDB_FR_REG15(sp)		LONG_L	$14, GDB_FR_REG14(sp)		LONG_L	$13, GDB_FR_REG13(sp)		LONG_L	$12, GDB_FR_REG12(sp)		LONG_L	$11, GDB_FR_REG11(sp)		LONG_L	$10, GDB_FR_REG10(sp)		LONG_L	$9, GDB_FR_REG9(sp)		LONG_L	$8, GDB_FR_REG8(sp)		LONG_L	$7, GDB_FR_REG7(sp)		LONG_L	$6, GDB_FR_REG6(sp)		LONG_L	$5, GDB_FR_REG5(sp)		LONG_L	$4, GDB_FR_REG4(sp)		LONG_L	$3, GDB_FR_REG3(sp)		LONG_L	$2, GDB_FR_REG2(sp)		LONG_L	$1, GDB_FR_REG1(sp)#if defined(CONFIG_CPU_R3000) || defined(CONFIG_CPU_TX39XX)		LONG_L	k0, GDB_FR_EPC(sp)		LONG_L	$29, GDB_FR_REG29(sp)		/* Deallocate stack */		jr	k0		rfe#else		LONG_L	sp, GDB_FR_REG29(sp)		/* Deallocate stack */		.set	mips3		eret		.set	mips0#endif		.set	at		.set	reorder		END(trap_low)LEAF(kgdb_read_byte)4:		lb	t0, (a0)		sb	t0, (a1)		li	v0, 0		jr	ra		.section __ex_table,"a"		PTR	4b, kgdbfault		.previous		END(kgdb_read_byte)LEAF(kgdb_write_byte)5:		sb	a0, (a1)		li	v0, 0		jr	ra		.section __ex_table,"a"		PTR	5b, kgdbfault		.previous		END(kgdb_write_byte)		.type	kgdbfault@function		.ent	kgdbfaultkgdbfault:	li	v0, -EFAULT		jr	ra		.end	kgdbfault

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产福利91精品| 欧美色图第一页| 国产三级精品视频| 色偷偷88欧美精品久久久| 一区二区在线电影| 精品国产91久久久久久久妲己| 国产自产高清不卡| 亚洲伊人色欲综合网| 日韩欧美国产精品一区| 99久久er热在这里只有精品15 | 不卡大黄网站免费看| 日韩精品五月天| 亚洲欧洲综合另类在线| 国产午夜一区二区三区| 欧美私人免费视频| 色婷婷精品大在线视频| 国产在线精品免费av| 天堂成人国产精品一区| 亚洲精品国产a久久久久久| 欧美不卡一区二区三区四区| 色婷婷国产精品久久包臀 | 一区二区三区精密机械公司| 中文字幕不卡在线播放| 久久精品免费在线观看| 欧美大胆人体bbbb| 日韩免费高清av| 69av一区二区三区| 91精品欧美久久久久久动漫 | 一本一道波多野结衣一区二区| 成人亚洲精品久久久久软件| 毛片一区二区三区| 国产在线视频不卡二| 免费一级欧美片在线观看| 男人操女人的视频在线观看欧美| 香港成人在线视频| 看国产成人h片视频| 国产主播一区二区| 99久久精品免费看国产| 欧美综合久久久| 91精品国产色综合久久不卡电影| 日韩视频中午一区| 国产精品国产自产拍在线| 亚洲第一精品在线| 成人免费黄色在线| 5566中文字幕一区二区电影 | 久久男人中文字幕资源站| 亚洲欧美综合在线精品| 奇米色一区二区| 色成年激情久久综合| 久久综合久久综合久久| 亚洲激情综合网| 国产91丝袜在线播放九色| 欧美在线综合视频| 欧美激情艳妇裸体舞| 视频一区视频二区中文字幕| 国产成人在线电影| 精品国产乱码久久久久久闺蜜| 亚洲日本中文字幕区| 成人永久aaa| 国产色产综合色产在线视频| 免费在线观看一区| 91精品国产一区二区三区香蕉| 国产日韩欧美高清| 国产激情视频一区二区在线观看| 91精品国模一区二区三区| 亚洲一区二区三区影院| 在线精品视频免费播放| 中文字幕av一区二区三区免费看| 美女看a上一区| 精品91自产拍在线观看一区| 轻轻草成人在线| 精品久久五月天| 懂色av一区二区夜夜嗨| 国产精品美女视频| 91女厕偷拍女厕偷拍高清| 亚洲欧美日韩电影| 欧美中文字幕一二三区视频| 亚洲高清三级视频| 国产精品私房写真福利视频| 波多野结衣在线aⅴ中文字幕不卡| 国产欧美日本一区视频| 在线视频欧美精品| 奇米888四色在线精品| 国产日韩三级在线| 日韩免费看网站| 色哟哟欧美精品| 美腿丝袜一区二区三区| 综合色天天鬼久久鬼色| 日韩午夜在线观看| 在线视频一区二区免费| 精品亚洲porn| 一区二区三区日韩精品| 亚洲天堂精品视频| 久久天天做天天爱综合色| 成人激情小说网站| 奇米色一区二区三区四区| 亚洲日本va在线观看| 精品国产亚洲在线| 欧美日韩三级视频| 99国产精品视频免费观看| 国产真实乱对白精彩久久| 亚洲成a人片综合在线| 一二三区精品视频| 亚洲欧美日韩国产一区二区三区 | 日韩欧美的一区| 欧美日韩国产中文| 欧美日韩免费一区二区三区| 91麻豆福利精品推荐| 91片在线免费观看| 99久久精品免费观看| 成人国产精品视频| 色综合天天综合| 99久久婷婷国产综合精品| 成人美女在线观看| 99久久精品国产麻豆演员表| 国产91精品欧美| 99精品热视频| 欧美色网站导航| 精品精品国产高清a毛片牛牛 | 色婷婷av一区二区| 欧美精品v日韩精品v韩国精品v| 欧美亚洲综合一区| 精品久久久久久亚洲综合网 | 欧美影视一区二区三区| 在线成人av影院| 国产亚洲美州欧州综合国| 综合激情网...| 国产一区91精品张津瑜| 成人av在线播放网址| 欧洲国内综合视频| 精品欧美一区二区在线观看| 中文子幕无线码一区tr| 亚洲一区二区视频在线| 丁香六月久久综合狠狠色| 色域天天综合网| 久久精品一区二区三区av| 亚洲精品大片www| 欧美系列亚洲系列| www.视频一区| 懂色av中文一区二区三区| 国产综合久久久久久鬼色| 中文字幕一区二区5566日韩| 欧美一区二区黄色| 91一区一区三区| 成人h精品动漫一区二区三区| 337p日本欧洲亚洲大胆精品 | 91网址在线看| 欧美精选在线播放| 精品99一区二区三区| 欧美国产视频在线| 亚洲尤物在线视频观看| 蜜桃视频一区二区| 成人在线综合网| 欧美少妇性性性| 中文乱码免费一区二区| 日韩av一二三| 日韩av中文字幕一区二区三区| 午夜精品在线视频一区| 日韩精品中文字幕在线不卡尤物 | 99国产精品国产精品毛片| 中文字幕av不卡| 97成人超碰视| 婷婷久久综合九色综合伊人色| 欧美日韩精品是欧美日韩精品| 午夜精品在线视频一区| 久久久久久久久伊人| 国产福利一区二区三区| 亚洲国产精品传媒在线观看| 99久久精品99国产精品| 亚洲精品自拍动漫在线| 欧美男男青年gay1069videost| 激情亚洲综合在线| 一区二区三区在线视频观看| 91麻豆精品国产自产在线| 九一久久久久久| 亚洲电影欧美电影有声小说| 久久嫩草精品久久久久| 欧美男女性生活在线直播观看| 国产精品99久久久久久有的能看| 久久夜色精品一区| 91精品欧美久久久久久动漫| 成人激情视频网站| 国产精品自在欧美一区| 日本一道高清亚洲日美韩| 一区二区三区四区在线免费观看| 久久综合给合久久狠狠狠97色69| 91色porny在线视频| 本田岬高潮一区二区三区| 免费在线观看成人| 视频一区在线播放| 亚洲福利视频三区| 洋洋av久久久久久久一区| 亚洲欧美在线另类| 亚洲欧洲性图库| 亚洲视频免费在线观看| 亚洲图片欧美激情| 亚洲精品国产精华液| 怡红院av一区二区三区| 中文字幕中文字幕在线一区| 久久久久久99精品|