|  | /* | 
|  | * Copyright (C) 2004-2006 Atmel Corporation | 
|  | * | 
|  | * This program is free software; you can redistribute it and/or modify | 
|  | * it under the terms of the GNU General Public License version 2 as | 
|  | * published by the Free Software Foundation. | 
|  | */ | 
|  |  | 
|  | .Lnot_word_aligned: | 
|  | /* | 
|  | * Bad alignment will cause a hardware exception, which is as | 
|  | * good as anything. No need for us to check for proper alignment. | 
|  | */ | 
|  | ld.uh	r8, r12[0] | 
|  | sub	r10, 1 | 
|  | st.h	r11++, r8 | 
|  |  | 
|  | /* fall through */ | 
|  |  | 
|  | .global	__raw_readsw | 
|  | .type	__raw_readsw,@function | 
|  | __raw_readsw: | 
|  | cp.w	r10, 0 | 
|  | reteq	r12 | 
|  | mov	r9, 3 | 
|  | tst	r11, r9 | 
|  | brne	.Lnot_word_aligned | 
|  |  | 
|  | sub	r10, 2 | 
|  | brlt	2f | 
|  |  | 
|  | 1:	ldins.h	r8:t, r12[0] | 
|  | ldins.h	r8:b, r12[0] | 
|  | st.w	r11++, r8 | 
|  | sub	r10, 2 | 
|  | brge	1b | 
|  |  | 
|  | 2:	sub	r10, -2 | 
|  | reteq	r12 | 
|  |  | 
|  | ld.uh	r8, r12[0] | 
|  | st.h	r11++, r8 | 
|  | retal	r12 |