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

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

?? usbdrvasm.s

?? USB programmer For AVR
?? 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一区二区三区免费野_久草精品视频
日本一区二区三区四区| 日韩精品一区二区三区视频在线观看| 国产清纯美女被跳蛋高潮一区二区久久w | 日韩精品一级二级| 欧美一区二区三区在线电影 | 亚洲一线二线三线视频| 欧美色图12p| 人妖欧美一区二区| 国产欧美一区二区三区网站| 丁香婷婷综合激情五月色| 亚洲乱码一区二区三区在线观看| 色乱码一区二区三区88| 五月婷婷激情综合网| 精品国产91乱码一区二区三区| 韩国v欧美v日本v亚洲v| 亚洲欧美一区二区在线观看| 欧美日韩高清在线播放| 国产资源精品在线观看| 亚洲美女屁股眼交3| 91麻豆精品国产综合久久久久久| 国产在线观看一区二区| 亚洲精品成人悠悠色影视| 欧美日韩视频在线观看一区二区三区 | 日韩视频永久免费| 99久久综合99久久综合网站| 日韩高清在线不卡| 国产精品你懂的在线| 欧美专区日韩专区| 国产精品996| 日韩国产在线观看一区| 亚洲国产精品v| 日韩一区二区免费电影| 91色在线porny| 国内精品久久久久影院一蜜桃| 伊人婷婷欧美激情| 久久久久久久综合日本| 欧美卡1卡2卡| 色综合天天综合给合国产| 久久成人羞羞网站| 亚洲成av人片www| 国产精品美女一区二区在线观看| 欧美日本不卡视频| 色一情一伦一子一伦一区| 久久国产麻豆精品| 天堂va蜜桃一区二区三区| 国产精品视频第一区| 精品国产成人系列| 91精品免费观看| 欧美性受极品xxxx喷水| 99久久免费视频.com| 国产高清一区日本| 精品影视av免费| 视频一区视频二区中文字幕| 亚洲综合免费观看高清完整版 | 欧美精品一区二区精品网| 欧美三级电影一区| 91免费视频网| gogo大胆日本视频一区| 粉嫩欧美一区二区三区高清影视 | 国产乱码精品一区二区三区忘忧草 | 久久不见久久见免费视频7| 亚洲成人高清在线| 亚洲精品视频在线观看网站| 国产精品久久久久毛片软件| 国产亚洲一本大道中文在线| 日韩欧美亚洲另类制服综合在线| 欧美日韩国产一区二区三区地区| 在线免费不卡电影| 欧美在线999| 欧美丝袜自拍制服另类| 日本高清不卡视频| 欧美专区日韩专区| 欧美日韩视频在线第一区 | 亚洲激情网站免费观看| 亚洲欧洲美洲综合色网| 一区在线播放视频| 国产精品网站在线播放| 欧美激情一区二区| 国产精品久久久久久久久搜平片 | 99久久久国产精品| 91亚洲精华国产精华精华液| 91蜜桃网址入口| 97精品国产露脸对白| 97精品国产97久久久久久久久久久久| 成人av网址在线观看| 99精品国产99久久久久久白柏| 91亚洲精品久久久蜜桃| 欧美日韩午夜影院| 欧美大度的电影原声| 2022国产精品视频| 日本一区二区动态图| 亚洲嫩草精品久久| 亚洲成av人片在www色猫咪| 日韩精品五月天| 国产一区不卡视频| 成人黄色电影在线 | 国产资源在线一区| jlzzjlzz亚洲日本少妇| 欧美揉bbbbb揉bbbbb| 日韩欧美国产一区二区三区| 久久蜜桃av一区精品变态类天堂 | 日韩视频免费观看高清完整版 | 亚洲色图第一区| 亚洲国产成人av| 国内精品免费**视频| 91香蕉视频黄| 日韩三级高清在线| 中文字幕成人在线观看| 亚洲福利视频三区| 国产一区二区在线影院| 91麻豆视频网站| 日韩小视频在线观看专区| 国产精品灌醉下药二区| 秋霞国产午夜精品免费视频| 成人av片在线观看| 日韩一区二区三区免费看| 国产精品每日更新在线播放网址 | 日韩欧美国产三级| 亚洲免费电影在线| 久热成人在线视频| 色综合天天综合| 久久久精品影视| 五月婷婷综合在线| 白白色亚洲国产精品| 日韩欧美国产1| 亚洲制服丝袜av| 丁香婷婷综合网| 日韩欧美激情一区| 亚洲国产综合色| av毛片久久久久**hd| 欧美xingq一区二区| 一区2区3区在线看| 懂色中文一区二区在线播放| 欧美不卡视频一区| 天天射综合影视| 色悠久久久久综合欧美99| 久久久国产一区二区三区四区小说| 亚洲成在人线在线播放| 99精品久久只有精品| 欧美激情一区三区| 国产一区二区三区观看| 日韩一级欧美一级| 亚洲高清一区二区三区| 色综合咪咪久久| 国产精品久久久久影院| 国产成人免费在线视频| 亚洲精品一区二区三区99| 日本不卡1234视频| 欧美精选一区二区| 亚洲成av人片在www色猫咪| 在线亚洲高清视频| 亚洲视频中文字幕| av一本久道久久综合久久鬼色| 日本一区二区三区四区| 国产激情精品久久久第一区二区| 2023国产一二三区日本精品2022| 久久精品国产精品青草| 91精品一区二区三区久久久久久| 亚洲3atv精品一区二区三区| 欧洲精品在线观看| 亚洲国产欧美在线| 欧美久久久久中文字幕| 日韩精品亚洲专区| 日韩一区二区三区电影| 日韩精品乱码av一区二区| 91麻豆精品国产自产在线| 日韩在线一区二区| 日韩欧美国产一区二区在线播放| 另类欧美日韩国产在线| 精品久久久久久久久久久久包黑料| 久久99久久精品| www国产精品av| 成人国产精品免费观看动漫| 国产精品乱人伦一区二区| av动漫一区二区| 亚洲乱码中文字幕综合| 欧美视频在线一区二区三区| 爽好久久久欧美精品| 欧美一级黄色录像| 国产一区二区三区日韩| 欧美激情综合五月色丁香| 99国内精品久久| 亚洲超碰精品一区二区| 欧美一区二区三区免费观看视频 | 日韩免费一区二区| 国产自产2019最新不卡| 国产精品久久看| 欧美午夜理伦三级在线观看| 日韩高清不卡一区二区| 久久久久久夜精品精品免费| 97久久精品人人做人人爽50路| 亚洲国产色一区| 欧美精品一区二区三区在线 | 亚洲国产精品一区二区久久恐怖片| 欧美日韩成人一区| 国产成人在线看| 亚洲一区二区三区四区五区中文 | 国产999精品久久| 亚洲美女电影在线| 日韩欧美成人午夜|