| Haavard Skinnemoen | 5f97f7f | 2006-09-25 23:32:13 -0700 | [diff] [blame] | 1 | /* | 
|  | 2 | * Copyright (C) 2004-2006 Atmel Corporation | 
|  | 3 | * | 
|  | 4 | * This program is free software; you can redistribute it and/or modify | 
|  | 5 | * it under the terms of the GNU General Public License version 2 as | 
|  | 6 | * published by the Free Software Foundation. | 
|  | 7 | */ | 
|  | 8 |  | 
|  | 9 | .Lnot_word_aligned: | 
|  | 10 | /* | 
|  | 11 | * Bad alignment will cause a hardware exception, which is as | 
|  | 12 | * good as anything. No need for us to check for proper alignment. | 
|  | 13 | */ | 
|  | 14 | ld.uh	r8, r12[0] | 
|  | 15 | sub	r10, 1 | 
|  | 16 | st.h	r11++, r8 | 
|  | 17 |  | 
|  | 18 | /* fall through */ | 
|  | 19 |  | 
|  | 20 | .global	__raw_readsw | 
|  | 21 | .type	__raw_readsw,@function | 
|  | 22 | __raw_readsw: | 
|  | 23 | cp.w	r10, 0 | 
|  | 24 | reteq	r12 | 
|  | 25 | mov	r9, 3 | 
|  | 26 | tst	r11, r9 | 
|  | 27 | brne	.Lnot_word_aligned | 
|  | 28 |  | 
|  | 29 | sub	r10, 2 | 
|  | 30 | brlt	2f | 
|  | 31 |  | 
|  | 32 | 1:	ldins.h	r8:t, r12[0] | 
|  | 33 | ldins.h	r8:b, r12[0] | 
|  | 34 | st.w	r11++, r8 | 
|  | 35 | sub	r10, 2 | 
|  | 36 | brge	1b | 
|  | 37 |  | 
|  | 38 | 2:	sub	r10, -2 | 
|  | 39 | reteq	r12 | 
|  | 40 |  | 
|  | 41 | ld.uh	r8, r12[0] | 
|  | 42 | st.h	r11++, r8 | 
|  | 43 | retal	r12 |