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

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

?? ecc.s

?? nand flash的驅(qū)動(dòng)
?? S
字號(hào):
;/**************************************************************************
;* FILENAME:      ECC.s                                                    *         
;*                                                                         *  
;* VERSION:       V1.0                                                     *  
;*                                                                         *  
;* DESCRIPTION:   Error Correction Code for NXP LPC2200 interface to NAND  *                       
;*                flash reference design. For more detail, Pls. refer to   * 
;*                corresponding Hamming Code based ECC code articles       *  
;*                                                                         *  
;* TOOLS:         ARM Developer Suite v1.2                                 *
;*                Flash Magic V3.33.157                                    *
;*                                                                         *  
;*                                                                         *  
;* REVISION HISTORY                                                        *  
;* Version  Author           Date         Remarks                          *
;* 1.0      Xiaodong Xie     12/12/2006   Created                          *         
;***************************************************************************/

			AREA	|ECC|, CODE, READONLY

;//***************************************************************************
;//* Function Name: ecc512
;//* Input(s) : 	unsigned char 		*Buffer, 
;//*				unsigned char		*EccByte.
;//* Returns :  	void.
;//* Description : generate ECC code for 512 data bytes
;//* Notes:        EccByte
;//*               D0 - D17   ECC row information from LP0 to LP17
;//*               D18 - D23  ECC column information from CP0 to CP5
;//***************************************************************************
			EXPORT	ecc512
			
ecc512

			;register used in function ecc512
			;R0  the first argument of function ecc512
			;R1  the second argument of function ecc512
			;R2  register to load the first 4 bytes of 512 data bytes 
			;R3  register to load the second 4 bytes of 512 data bytes 
			;R4  register to load the third 4 bytes of 512 data bytes 
			;R5  register to load the fourth 4 bytes of 512 data bytes 
			;R6  byte index of 512 data bytes
			;R7-R12  temp value

	        STMFD   SP!, {R0-R12, LR}	;store R0-R12 & LR in stack
			
			MOV		R6,#0				;init the byte index
			LDR		R11,[R1]			;load EccByte[0] to R11

_loopBuffer
			;load 4 words of 512 data byte at one time
			;single instruction multiple data (SIMD)
			LDMIA	R0!,{R2-R5}		

;Calculating ECC row information

			MOV		R10,R2
			EOR		R10,R10,R3
			EOR		R10,R10,R4
			EOR		R10,R10,R5			;R10 is the EOR result of R2,R3,R4,R5
			MOV		R12,R10				;store R10 in R12

			MOV		R7,R10
			EOR		R7,R7,R10,LSR #1
			EOR		R7,R7,R10,LSR #2
			EOR		R7,R7,R10,LSR #3
			EOR		R7,R7,R10,LSR #4
			EOR		R7,R7,R10,LSR #5
			EOR		R7,R7,R10,LSR #6
			EOR		R7,R7,R10,LSR #7

			MOV		R8,R7
			EOR		R8,R8,R7,LSR #8
			EOR		R8,R8,R7,LSR #16
			EOR		R8,R8,R7,LSR #24
			AND		R8,R8,#1			;1st bit of R8 is the EOR result of each 
										;sigle byte stored in R2,R3,R4,R5

			;calculate ECC LP8-LP17
			MACRO
			LP8_LP17	$NthLP, $NextLP, $IndBitPos
				MOV		R9,#0
				ANDS	R9,R6,#$IndBitPos
				EOREQ	R11,R11,R8,LSL #$NthLP
				EORNE	R11,R11,R8,LSL #$NextLP
			MEND

			LP8_LP17	8, 9, 0x10			;ECC LP8, LP9
			
			LP8_LP17	10, 11, 0x20		;ECC LP10, LP11

			LP8_LP17	12, 13, 0x40		;ECC LP12, LP13

			LP8_LP17	14, 15, 0x80		;ECC LP14, LP15

			LP8_LP17	16, 17, 0x100		;ECC LP16, LP17
			

			;calculate ECC LP0-LP3
			MACRO
			LP0_LP3	$NthLP, $Shifter1, $Shifter2
				IF	$Shifter1 = 0
					MOV		R8,R7
				ELSE
					MOV		R8,R7,LSR #$Shifter1
				ENDIF
				EOR		R8,R8,R7,LSR #$Shifter2
				AND		R8,R8,#1
				IF	$NthLP = 0
					EOR		R11,R11,R8
				ELSE
					EOR		R11,R11,R8,LSL #$NthLP
				ENDIF
			MEND
			
			LP0_LP3	1, 8, 24		;ECC LP1

			LP0_LP3	0, 0, 16		;ECC LP0

			LP0_LP3	3, 16, 24		;ECC LP3
			
			LP0_LP3	2, 0, 8			;ECC LP2


			;calculate LP4-LP7
			MACRO
			LP4_LP7	$NthLP, $Reg1, $Reg2
				MOV		R10,$Reg1
				EOR		R10,R10,$Reg2
				
				MOV		R7,R10
				EOR		R7,R7,R10,LSR #1
				EOR		R7,R7,R10,LSR #2
				EOR		R7,R7,R10,LSR #3
				EOR		R7,R7,R10,LSR #4
				EOR		R7,R7,R10,LSR #5
				EOR		R7,R7,R10,LSR #6
				EOR		R7,R7,R10,LSR #7

				MOV		R8,R7
				EOR		R8,R8,R7,LSR #8
				EOR		R8,R8,R7,LSR #16
				EOR		R8,R8,R7,LSR #24
				AND		R8,R8,#1

				EOR		R11,R11,R8,LSL #$NthLP
			MEND

			LP4_LP7	5, R3, R5		;ECC LP5
			
			LP4_LP7	4, R2, R4		;ECC LP4
			
			LP4_LP7	7, R4, R5		;ECC LP7
		
			LP4_LP7	6, R2, R3		;ECC LP6

			
;Calculating ECC column information
			;calculate CP0-CP7
			MACRO
			CP0_CP7	$NthCP, $Shifter1, $Shifter2, $Shifter3, $Shifter4
				IF	$Shifter1 = 0				
					MOV		R7,R12
				ELSE
					MOV		R7,R12,LSR #$Shifter1
				ENDIF
				EOR		R7,R7,R12,LSR #$Shifter2
				EOR		R7,R7,R12,LSR #$Shifter3
				EOR		R7,R7,R12,LSR #$Shifter4	
				
				MOV		R8,R7
				EOR		R8,R8,R7,LSR #8
				EOR		R8,R8,R7,LSR #16
				EOR		R8,R8,R7,LSR #24
				AND		R8,R8,#1
				
				EOR		R11,R11,R8,LSL #$NthCP
			MEND

			CP0_CP7	18, 0, 2, 4, 6		;ECC CP0
			
			CP0_CP7	19, 1, 3, 5, 7		;ECC CP1
			
			CP0_CP7	20, 0, 1, 4, 5		;ECC CP2
			
			CP0_CP7	21, 2, 3, 6, 7		;ECC CP3
			
			CP0_CP7	22, 0, 1, 2, 3		;ECC CP4

			CP0_CP7	23, 4, 5, 6, 7		;ECC CP5


			ADD		R6,R6,#16			;Buffer[Index + 16]
			CMP		R6,#512				;if (Index + 16) != 512
			BNE		_loopBuffer			;then jump to _loopBuffer
			
			STR		R11,[R1]			;EccByte[0] = R11
			
	        LDMFD   SP!, {R0-R12, LR}
			MOV		PC,LR	

		
;//***************************************************************************
;//* Function Name: eccCheck512
;//* Input(s) : 	unsigned char 		*Buffer, 
;//*				unsigned char	 	*EccByte.
;//*				struct EccAddr 		*ErrAddr
;//* Returns :  	unsigned char	  	EccStatus
;//* Description : ECC based data check and correction for 512 bytes data
;//* Notes:        EccStatus:
;//*               	0		No Error found
;//*               	1		One bit Error found and corrected
;//*				2		Not Correctable Error found
;//***************************************************************************
			EXPORT	eccCheck512

eccCheck512

			STMFD	SP!,{R1-R7,LR}
			BL		ecc512			;jump to ecc512 function

			MVN		R4,#0xFF
			LDR		R3,[R1]
			AND		R3,R3,R4,LSR #8
			
			MOV		R4,#0			;How many "1" in ECC information bytes?
			MOV		R5,#0
_loopCount_1
			CMP		R3,#0
			BEQ		_endLoopCount_1
			ADD		R4,R4,#1;		;R4 stores the number of "1"
			SUB		R5,R3,#1
			AND		R3,R3,R5
			B		_loopCount_1			
_endLoopCount_1			
			
			CMP		R4,#0			;if R4 == 0, no error, R0 = 0
			MOVEQ	R0,#0
			BEQ		_endEccCheck512
			
			CMP		R4,#12			;if R4 != 14, not correctable err, R0 = 2
			MOVNE	R0,#2			
			BNE		_endEccCheck512

			;Correctable error
			;Firstly, calculate the error bit''s bit address			
			MOV		R4,#0
			MOV		R5,#0
			MOV		R6,#0
			LDR		R3,[R1]
						
			MOV		R4,R3,LSR #23

			ANDS	R4,R4,#1
			ADDNE	R5,R5,R4,LSL #2	;If CP5 != 0, R5 += 1<<2

			MOV		R4,R3,LSR #21
			ANDS	R4,R4,#1
			ADDNE	R5,R5,R4,LSL #1	;If CP3 != 0, R5 += 1<<1	
 		
			MOV		R4,R3,LSR #19
			ANDS	R4,R4,#1
			ADDNE	R5,R5,#2		;If CP1 != 0, R5 += #2	
			ADDEQ	R5,R5,#1		;If CP1 == 0, R5 += #1
		
			;R5 now contain the error bit address
			;store error bit''s bit address in ErrAddr.bit_addr
			STRB	R5,[R2,#4]
			
			;Then calcuate the error bit''s byte address
			MOV		R4,#0
			MOV		R5,#0
			MOV		R6,#0
			
			MOV		R4,R3,LSR #17
			ANDS	R4,R4,#1
			ADDNE	R5,R5,R4,LSL #8	;If LP17 is not zero, R5 += 1<<8
			
			MOV		R4,R3,LSR #15
			ANDS	R4,R4,#1
			ADDNE	R5,R5,R4,LSL #7			

			MOV		R4,R3,LSR #13
			ANDS	R4,R4,#1
			ADDNE	R5,R5,R4,LSL #6			

			MOV		R4,R3,LSR #11
			ANDS	R4,R4,#1
			ADDNE	R5,R5,R4,LSL #5			

			MOV		R4,R3,LSR #9
			ANDS	R4,R4,#1
			ADDNE	R5,R5,R4,LSL #4			

			MOV		R4,R3,LSR #7
			ANDS	R4,R4,#1
			ADDNE	R5,R5,R4,LSL #3	

			MOV		R4,R3,LSR #5
			ANDS	R4,R4,#1
			ADDNE	R5,R5,R4,LSL #2

			MOV		R4,R3,LSR #3
			ANDS	R4,R4,#1
			ADDNE	R5,R5,R4,LSL #1	

			MOV		R4,R3,LSR #1
			ANDS	R4,R4,#1
			ADDNE	R5,R5,#2		
			ADDEQ	R5,R5,#1
			;R5 now contain the error byte address
			SUB		R5,R5,#1
			;store erroe bit''s byte address in ErrAddr.byte_addr
			STR		R5,[R2]
			
			MOV		R0,#1	;one error bit detected and corrected, R0 = 1

_endEccCheck512			

			LDMFD	SP!,{R1-R7,LR}
			MOV		PC,LR
			
			END

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产一区二区三区四区四| 99精品国产一区二区三区不卡| 国产精品毛片无遮挡高清| av中文字幕亚洲| 青青国产91久久久久久| 亚洲欧美在线aaa| 26uuu另类欧美亚洲曰本| 97精品国产露脸对白| 国产在线一区二区| 婷婷综合在线观看| 精品人在线二区三区| 国产精品一区二区在线观看不卡 | 国产999精品久久久久久绿帽| 亚洲欧美日韩电影| 国产三级欧美三级日产三级99 | 日韩一级视频免费观看在线| 91丨九色丨尤物| 成人午夜电影网站| 韩国午夜理伦三级不卡影院| 日日嗨av一区二区三区四区| 亚洲欧洲日韩女同| 中文字幕不卡一区| 久久久久久久久久久久久夜| 欧美男女性生活在线直播观看| 色就色 综合激情| 成人激情免费电影网址| 精品污污网站免费看| 精品一区二区成人精品| 欧美在线视频日韩| 成人国产精品免费网站| 国产精品一区久久久久| 久久aⅴ国产欧美74aaa| 日韩国产在线观看| 午夜视黄欧洲亚洲| 亚洲www啪成人一区二区麻豆| 一区二区三区四区av| 成人欧美一区二区三区| 国产精品私房写真福利视频| 中文在线一区二区| 国产精品久久久久天堂| 欧美激情一区三区| 国产精品萝li| 亚洲欧美日韩系列| 亚洲精品视频在线观看网站| 亚洲欧美视频一区| 亚洲精品视频观看| 亚洲小说春色综合另类电影| 亚洲动漫第一页| 午夜av区久久| 免费欧美日韩国产三级电影| 裸体一区二区三区| 国产毛片精品国产一区二区三区| 国产精品一区二区在线看| 国产成人综合自拍| 99久久精品免费| 91久久久免费一区二区| 欧美日韩1区2区| 日韩欧美黄色影院| 青青青伊人色综合久久| 亚洲综合网站在线观看| 亚洲va韩国va欧美va| 日韩精品一区第一页| 精品一区二区综合| 成人动漫视频在线| 欧美伊人精品成人久久综合97| 欧美在线制服丝袜| 一区二区三区国产精华| 日韩精品一区第一页| 久久国产精品色婷婷| 成人一区二区三区视频在线观看| 色先锋aa成人| 91精品国产欧美一区二区| 久久久蜜桃精品| 亚洲精品视频在线观看免费 | 亚洲制服丝袜av| 美女精品一区二区| 成人教育av在线| 欧美日韩国产中文| 久久久久青草大香线综合精品| 国产精品久久久久久久久动漫| 亚洲国产精品一区二区www在线| 精品午夜久久福利影院| 91在线视频网址| 欧美一级精品在线| 亚洲一区二区三区四区五区黄 | 国产精品久久久久影院色老大 | 国产一区二区三区在线观看免费| 成人三级在线视频| 欧美日韩成人综合天天影院| 久久久久9999亚洲精品| 亚洲曰韩产成在线| 久久99久久99| 色哟哟一区二区| 国产亚洲人成网站| 午夜精品久久久久久久| 高清久久久久久| 日韩一区二区在线看| **欧美大码日韩| 国产一区二区中文字幕| 欧美视频完全免费看| 国产精品色哟哟网站| 麻豆91小视频| 欧美久久久久久久久久| 亚洲男人的天堂在线观看| 69堂成人精品免费视频| 日本一区二区三区免费乱视频| jlzzjlzz欧美大全| 欧美日精品一区视频| 国产精品网站在线观看| 久久国产精品第一页| 欧美日韩国产高清一区| 最新不卡av在线| 国产成人av福利| 欧美大片一区二区三区| 亚洲成人www| 91激情在线视频| 国产精品久久久久久亚洲毛片| 精品一区二区免费看| 欧美久久久久久久久久| 亚洲无人区一区| 色综合久久天天| 国产精品久久精品日日| 国产成人精品免费在线| 精品日韩在线观看| 精品亚洲成a人在线观看| 91精品国产综合久久香蕉麻豆| 亚洲成人免费视| 欧美网站大全在线观看| 一区二区三区在线视频播放| 色综合久久精品| 亚洲欧美日韩国产一区二区三区| 成人动漫中文字幕| 欧美国产精品中文字幕| 粉嫩一区二区三区在线看| 国产欧美日韩亚州综合| 国产伦精品一区二区三区免费迷| 亚洲精品在线一区二区| 国产在线精品不卡| 久久久久久久免费视频了| 韩国成人在线视频| 国产午夜精品久久久久久免费视 | 中文字幕在线观看一区| 波多野结衣精品在线| 中文字幕在线播放不卡一区| 99在线精品一区二区三区| 亚洲少妇中出一区| 91麻豆产精品久久久久久| 亚洲精品第一国产综合野| 在线免费亚洲电影| 婷婷综合五月天| 日韩免费看网站| 国产精品小仙女| 国产精品理论片| 色婷婷av一区| 日韩和欧美一区二区| 欧美成人综合网站| 国产精品一二二区| 亚洲日本va午夜在线影院| 在线看不卡av| 麻豆国产精品777777在线| 久久av老司机精品网站导航| 精品噜噜噜噜久久久久久久久试看 | 色综合久久天天| 成人小视频在线| 欧美久久一区二区| 免费成人在线影院| 久久女同互慰一区二区三区| 成人久久久精品乱码一区二区三区| 中文字幕一区二区不卡| 日本久久电影网| 老司机午夜精品| 国产精品乱子久久久久| 欧美日韩久久久| 国产制服丝袜一区| 一个色在线综合| 精品久久久久久亚洲综合网| 成人sese在线| 日韩二区在线观看| 国产精品欧美久久久久无广告 | 在线欧美小视频| 精品一区二区三区视频| 亚洲人快播电影网| 欧美成人一级视频| 99精品视频一区二区三区| 欧美色综合天天久久综合精品| 蓝色福利精品导航| 亚洲三级在线播放| 日韩一区二区电影网| 99久久精品国产一区二区三区| 免费成人美女在线观看.| 成人欧美一区二区三区小说| 不卡的av在线播放| 精品国产人成亚洲区| voyeur盗摄精品| 毛片基地黄久久久久久天堂| 亚洲欧美日韩久久| 久久蜜桃av一区精品变态类天堂 | 色狠狠av一区二区三区| 国产自产高清不卡| 日本成人在线电影网|