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

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

?? usbdrvasm.s

?? 絕對完整的UsbISP的下載線制做過程和資料.rar
?? S
?? 第 1 頁 / 共 2 頁
字號:
/* Name: usbdrvasm.S * Project: AVR USB driver * Author: Christian Starkjohann * Creation Date: 2004-12-29 * Tabsize: 4 * Copyright: (c) 2005 by OBJECTIVE DEVELOPMENT Software GmbH * License: Proprietary, free under certain conditions. See Documentation. * This Revision: $Id: usbdrvasm.S 52 2005-04-12 16:57:29Z cs $ *//*General Description:This module implements the assembler part of the USB driver. See usbdrv.hfor a description of the entire driver.Since almost all of this code is timing critical, don't change unless youreally know what you are doing! Many parts require not only a maximum numberof CPU cycles, but even an exact number of cycles!*//* configs for io.h */#define __SFR_OFFSET 0#define _VECTOR(N) __vector_ ## N	/* io.h does not define this for asm */#include <avr/io.h>	/* for CPU I/O register definitions and vectors */#include "usbdrv.h"	/* for common defs *//* register names */#define	x1		r16#define	x2		r17#define	shift	r18#define	cnt		r19#define	x3		r20#define	x4		r21#define	nop2	rjmp	.+0	/* jump to next instruction */.text.global	SIG_INTERRUPT0	.type	SIG_INTERRUPT0, @functionSIG_INTERRUPT0:;Software-receiver engine. Strict timing! Don't change unless you can preserve timing!;interrupt response time: 4 cycles + insn running = 7 max if interrupts always enabled;max allowable interrupt latency: 32 cycles -> max 25 cycles interrupt disable;max stack usage: [ret(2), x1, SREG, x2, cnt, shift, YH, YL, x3, x4] = 11 bytesusbInterrupt:;order of registers pushed:;x1, SREG, x2, cnt, shift, [YH, YL, x3]	push	x1				;2  push only what is necessary to sync with edge ASAP	in		x1, SREG		;1	push	x1				;2;sync byte (D-) pattern LSb to MSb: 01010100 [1 = idle = J, 0 = K];sync up with J to K edge during sync pattern -- use fastest possible loops;first part has no timeout because it waits for IDLE or SE1 (== disconnected)#if !USB_CFG_SAMPLE_EXACT	ldi		x1, 5			;1 setup a timeout for waitForK#endifwaitForJ:	sbis	USBIN, USBMINUS	;1 wait for D- == 1	rjmp	waitForJ		;2#if USB_CFG_SAMPLE_EXACT;The following code represents the unrolled loop in the else branch. It;results in a sampling window of 1/4 bit which meets the spec.	sbis	USBIN, USBMINUS	rjmp	foundK	sbis	USBIN, USBMINUS	rjmp	foundK	sbis	USBIN, USBMINUS	rjmp	foundK	nop	nop2foundK:#elsewaitForK:	dec		x1				;1	sbic	USBIN, USBMINUS	;1 wait for D- == 0	brne	waitForK		;2#endif;{2, 6} after falling D- edge, average delay: 4 cycles [we want 4 for center sampling];we have 1 bit time for setup purposes, then sample again:	push	x2				;2	push	cnt				;2	push	shift			;2shortcutEntry:	ldi		cnt, 1			;1 pre-init bit counter (-1 because no dec follows, -1 because 1 bit already sampled)	ldi		x2, 1<<USB_CFG_DPLUS_BIT	;1 -> 8   edge sync ended with D- == 0;now wait until SYNC byte is over. Wait for either 2 bits low (success) or 2 bits high (failure)waitNoChange:	in		x1, USBIN		;1 <-- sample, timing: edge + {2, 6} cycles	eor		x2, x1			;1	sbrc	x2, 0			;1 | 2	ldi		cnt, 2			;1 | 0 cnt = numBits - 1 (because dec follows)	mov		x2, x1			;1	dec		cnt				;1	brne	waitNoChange	;2 | 1	sbrc	x1, USBMINUS	;2	rjmp	sofError		;0 two consecutive "1" bits -> framing error;start reading data, but don't check for bitstuffing because these are the;first bits. Use the cycles for initialization instead. Note that we read and;store the binary complement of the data stream because eor results in 1 for;a change and 0 for no change.	in		x1, USBIN		;1 <-- sample bit 0, timing: edge + {3, 7} cycles	eor		x2, x1			;1	ror		x2				;1	ldi		shift, 0x7f		;1 The last bit of the sync pattern was a "no change"	ror		shift			;1	push	YH				;2 -> 7	in		x2, USBIN		;1 <-- sample bit 1, timing: edge + {2, 6} cycles	eor		x1, x2			;1	ror		x1				;1	ror		shift			;1	push	YL				;2	lds		YL, usbInputBuf	;2 -> 8	in		x1, USBIN		;1 <-- sample bit 2, timing: edge + {2, 6} cycles	eor		x2, x1			;1	ror		x2				;1	ror		shift			;1	ldi		cnt, USB_BUFSIZE;1	clr		YH				;1	push	x3				;2 -> 8	in		x2, USBIN		;1 <-- sample bit 3, timing: edge + {2, 6} cycles	eor		x1, x2			;1	ror		x1				;1	ror		shift			;1	ser		x3				;1	nop						;1	rjmp	rxbit4			;2 -> 8shortcutToStart:			;{,43} into next frame: max 5.5 sync bits missed#if !USB_CFG_SAMPLE_EXACT	ldi		x1, 5			;2 setup timeout#endifwaitForJ1:	sbis	USBIN, USBMINUS	;1 wait for D- == 1	rjmp	waitForJ1		;2#if USB_CFG_SAMPLE_EXACT;The following code represents the unrolled loop in the else branch. It;results in a sampling window of 1/4 bit which meets the spec.	sbis	USBIN, USBMINUS	rjmp	foundK1	sbis	USBIN, USBMINUS	rjmp	foundK1	sbis	USBIN, USBMINUS	rjmp	foundK1	nop	nop2foundK1:#elsewaitForK1:	dec		x1				;1	sbic	USBIN, USBMINUS	;1 wait for D- == 0	brne	waitForK1		;2#endif	pop		YH				;2 correct stack alignment	nop2					;2 delay for the same time as the pushes in the original code	rjmp	shortcutEntry	;2; ################# receiver loop #################; extra jobs done during bit interval:; bit 6:	se0 check; bit 7:	or, store, clear; bit 0:	recover from delay	[SE0 is unreliable here due to bit dribbling in hubs]; bit 1:	se0 check; bit 2:	se0 check; bit 3:	overflow check; bit 4:	se0 check; bit 5:	rjmp; stuffed* helpers have the functionality of a subroutine, but we can't afford; the overhead of a call. We therefore need a separate routine for each caller; which jumps back appropriately.stuffed5:				;1 for branch taken	in		x2, USBIN	;1 <-- sample @ +1	andi	x2, USBMASK	;1	breq	se0a		;1	andi	x3, 0xc0	;1 (0xff03 >> 2) & 0xff	ori		shift, 0xfc	;1	rjmp	rxbit6		;2stuffed6:				;1 for branch taken	in		x1, USBIN	;1 <-- sample @ +1	andi	x1, USBMASK	;1	breq	se0a		;1	andi	x3, 0x81	;1 (0xff03 >> 1) & 0xff	ori		shift, 0xfc	;1	rjmp	rxbit7		;2; This is somewhat special because it has to compensate for the delay in bit 7stuffed7:				;1 for branch taken	andi	x1, USBMASK	;1 already sampled by caller	breq	se0a		;1	mov		x2, x1		;1 ensure correct NRZI sequence [we can save andi x3 here]	ori		shift, 0xfc	;1	in		x1, USBIN	;1 <-- sample bit 0	rjmp	unstuffed7	;2stuffed0:				;1 for branch taken	in		x1, USBIN	;1 <-- sample @ +1	andi	x1, USBMASK	;1	breq	se0a		;1	andi	x3, 0xfe	;1 (0xff03 >> 7) & 0xff	ori		shift, 0xfc	;1	rjmp	rxbit1		;2;-----------------------------rxLoop:	brlo	stuffed5	;1rxbit6:	in		x1, USBIN	;1 <-- sample bit 6	andi	x1, USBMASK	;1	breq	se0a		;1	eor		x2, x1		;1	ror		x2			;1	ror		shift		;1	cpi		shift, 4	;1	brlo	stuffed6	;1rxbit7:	in		x2, USBIN	;1 <-- sample bit 7	eor		x1, x2		;1	ror		x1			;1	ror		shift		;1	eor		x3,	shift	;1 x3 is 0 at bit locations we changed, 1 at others	st		y+, x3		;2 the eor above reconstructed modified bits and inverted rx data	ser		x3			;1rxbit0:	in		x1, USBIN	;1 <-- sample bit 0	cpi		shift, 4	;1	brlo	stuffed7	;1unstuffed7:	eor		x2, x1		;1	ror		x2			;1	ror		shift		;1	cpi		shift, 4	;1	brlo	stuffed0	;1rxbit1:	in		x2, USBIN	;1 <-- sample bit 1	andi	x2, USBMASK	;1se0a:					; enlarge jump range to SE0	breq	se0			;1 check for SE0 more often close to start of byte	eor		x1, x2		;1	ror		x1			;1	ror		shift		;1	cpi		shift, 4	;1	brlo	stuffed1	;1rxbit2:	in		x1, USBIN	;1 <-- sample bit 2	andi	x1, USBMASK	;1	breq	se0			;1	eor		x2, x1		;1	ror		x2			;1	ror		shift		;1	cpi		shift, 4	;1	brlo	stuffed2	;1rxbit3:	in		x2, USBIN	;1 <-- sample bit 3	eor		x1, x2		;1	ror		x1			;1	ror		shift		;1	dec		cnt			;1	check for buffer overflow	breq	overflow	;1	cpi		shift, 4	;1	brlo	stuffed3	;1rxbit4:	in		x1, USBIN	;1 <-- sample bit 4	andi	x1, USBMASK	;1	breq	se0			;1	eor		x2, x1		;1	ror		x2			;1	ror		shift		;1	cpi		shift, 4	;1	brlo	stuffed4	;1rxbit5:	in		x2, USBIN	;1 <-- sample bit 5	eor		x1, x2		;1	ror		x1			;1	ror		shift		;1	cpi		shift, 4	;1	rjmp	rxLoop		;2;-----------------------------stuffed1:				;1 for branch taken	in		x2, USBIN	;1 <-- sample @ +1	andi	x2, USBMASK	;1	breq	se0			;1	andi	x3, 0xfc	;1 (0xff03 >> 6) & 0xff	ori		shift, 0xfc	;1	rjmp	rxbit2		;2stuffed2:				;1 for branch taken	in		x1, USBIN	;1 <-- sample @ +1	andi	x1, USBMASK	;1	breq	se0			;1	andi	x3, 0xf8	;1 (0xff03 >> 5) & 0xff	ori		shift, 0xfc	;1	rjmp	rxbit3		;2stuffed3:				;1 for branch taken	in		x2, USBIN	;1 <-- sample @ +1	andi	x2, USBMASK	;1	breq	se0			;1	andi	x3, 0xf0	;1 (0xff03 >> 4) & 0xff	ori		shift, 0xfc	;1	rjmp	rxbit4		;2stuffed4:				;1 for branch taken	in		x1, USBIN	;1 <-- sample @ +1	andi	x1, USBMASK	;1	breq	se0			;1	andi	x3, 0xe0	;1 (0xff03 >> 3) & 0xff	ori		shift, 0xfc	;1	rjmp	rxbit5		;2;################ end receiver loop ###############overflow:					; ignore package if buffer overflow	rjmp	rxDoReturn		; enlarge jump range;This is the only non-error exit point for the software receiver loop;{4, 20} cycles after start of SE0, typically {10, 18} after SE0 start = {-6, 2} from end of SE0;next sync starts {16,} cycles after SE0 -> worst case start: +4 from next sync start;we don't check any CRCs here because there is no time left.se0:							;{-6, 2} from end of SE0 / {,4} into next frame	mov		cnt, YL				;1 assume buffer in lower 256 bytes of memory

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品一级爱片| 日本视频一区二区三区| 国产成人精品一区二区三区四区 | 欧美精品亚洲二区| 亚洲第一福利一区| 91精品国产91久久综合桃花| 午夜精品久久久久久久久久| 91精品国产色综合久久不卡蜜臀| 日本视频在线一区| 久久久久久久久久久99999| 国产成人在线视频免费播放| 国产精品久久毛片av大全日韩| 一本久久a久久免费精品不卡| 一区二区视频在线| 91精品国产综合久久久久久漫画| 经典三级视频一区| 国产精品久久午夜| 欧美日韩成人在线| 九九九久久久精品| 亚洲素人一区二区| 91精品免费在线| 高清不卡在线观看| 一区二区高清在线| 日韩欧美aaaaaa| www.av亚洲| 蜜桃视频免费观看一区| 精品福利在线导航| 91亚洲午夜精品久久久久久| 丝瓜av网站精品一区二区| www日韩大片| 91久久人澡人人添人人爽欧美| 美日韩一区二区| 日韩美女视频一区| 欧美一级欧美一级在线播放| 国产成人免费在线观看| 亚洲国产另类av| 国产精品私人自拍| 欧美一区二区视频观看视频 | 国产精品乱人伦| 国产精品久久久久久久久免费相片| 97精品超碰一区二区三区| 天天综合日日夜夜精品| 国产欧美精品国产国产专区| 欧美日韩一区二区三区视频| 高清日韩电视剧大全免费| 亚欧色一区w666天堂| 亚洲国产精品t66y| 精品久久久网站| 欧美日韩国产123区| 国产精品69久久久久水密桃| 日韩激情一区二区| 国产精品乱码人人做人人爱| 欧美大片一区二区三区| 欧美丝袜自拍制服另类| 成人激情免费视频| 国产专区欧美精品| 日韩成人午夜电影| 亚洲国产婷婷综合在线精品| 国产精品电影一区二区| 精品人在线二区三区| 欧美日韩一级大片网址| 99久久久免费精品国产一区二区| 韩国女主播一区二区三区| 亚洲国产精品人人做人人爽| 亚洲欧美成aⅴ人在线观看| 国产午夜一区二区三区| 久久夜色精品国产噜噜av| 欧美一区二区三区影视| 欧美日韩和欧美的一区二区| 色婷婷综合五月| jizzjizzjizz欧美| 成人高清免费在线播放| 国产成人av电影在线播放| 国产高清不卡二三区| 国模一区二区三区白浆 | 国产美女av一区二区三区| 日韩av在线播放中文字幕| 亚洲国产成人av网| 一区二区三区欧美日| 亚洲另类在线一区| 一区二区三区成人在线视频| 亚洲精品视频在线| 亚洲免费在线看| 亚洲免费观看在线观看| 亚洲乱码国产乱码精品精可以看| 中文字幕在线不卡国产视频| 中文字幕国产一区| 亚洲特级片在线| 亚洲一区二区三区中文字幕在线| 一区二区在线观看免费视频播放| 亚洲一区二区三区不卡国产欧美 | 中文字幕日韩一区| 亚洲另类春色校园小说| 亚洲成av人片一区二区| 午夜电影网一区| 久久激情五月激情| 国产一区二区三区久久悠悠色av| 国产精品一区二区在线观看网站 | 日本韩国视频一区二区| 欧美亚洲国产一区二区三区| 7777女厕盗摄久久久| 日韩女优电影在线观看| 日本va欧美va欧美va精品| 美腿丝袜亚洲三区| 成人在线视频一区二区| 色美美综合视频| 日韩亚洲欧美一区二区三区| 亚洲精品一区二区三区蜜桃下载| 国产精品免费观看视频| 亚洲成av人在线观看| 国产精品系列在线播放| 一本一本大道香蕉久在线精品 | 福利91精品一区二区三区| 91在线视频在线| 91精品国产综合久久国产大片 | 在线观看区一区二| 91精品国产一区二区三区香蕉| 国产日韩欧美电影| 亚洲一区日韩精品中文字幕| 国产一区二区三区四| 欧美综合亚洲图片综合区| 精品国产伦一区二区三区免费| 中文字幕一区二| 免费视频最近日韩| 91污在线观看| 久久综合九色综合97_久久久| 亚洲品质自拍视频| 久久国产精品72免费观看| 91视频.com| 久久精品一区二区三区不卡牛牛| 亚洲成人av福利| av午夜一区麻豆| 欧美mv日韩mv亚洲| 一区二区三区欧美激情| 国v精品久久久网| 2023国产一二三区日本精品2022| 伊人色综合久久天天人手人婷| 国产精品综合视频| 日韩视频免费观看高清在线视频| 亚洲欧洲av在线| 国产成人精品一区二| 日韩欧美一级在线播放| 一区二区三区在线观看视频| 精品一区二区在线视频| 欧美日韩激情一区| 亚洲一二三四在线观看| 99国产精品一区| 国产欧美日韩亚州综合| 久久精品国产精品亚洲红杏| 欧美综合一区二区| 亚洲精品国产无天堂网2021 | 韩国精品一区二区| 欧美一区二区三区人| 亚洲激情图片小说视频| 不卡一卡二卡三乱码免费网站| 久久免费偷拍视频| 老司机精品视频在线| 9191精品国产综合久久久久久| 亚洲伦理在线精品| 99久久精品一区| 《视频一区视频二区| 国产91精品一区二区| 亚洲精品在线一区二区| 伦理电影国产精品| 日韩欧美www| 国产尤物一区二区| 久久无码av三级| 国产老妇另类xxxxx| 精品理论电影在线观看| 精品一区精品二区高清| 久久网这里都是精品| 国产成人综合在线播放| 久久se精品一区精品二区| 欧美一区二区久久久| 日本伊人色综合网| 精品免费日韩av| 国产一区二区成人久久免费影院| 久久伊99综合婷婷久久伊| 国产精品99久久不卡二区| 国产精品久久久久国产精品日日| 成人精品gif动图一区| 国产精品电影一区二区三区| 91久久精品网| 视频一区免费在线观看| 日韩欧美色综合| 国产一二精品视频| 国产精品久久久久久久久久免费看| www.久久精品| 五月开心婷婷久久| 精品国产a毛片| 不卡欧美aaaaa| 亚洲一区二区影院| 欧美成人精品二区三区99精品| 国产精品一品视频| 一区二区三区在线免费播放| 欧美一区二区视频在线观看2020| 国产乱一区二区| 艳妇臀荡乳欲伦亚洲一区| 日韩三级视频在线观看| 成人免费视频一区二区|