patch-2.1.4 linux/arch/alpha/lib/copy_user.S

Next file: linux/arch/alpha/lib/divide.S
Previous file: linux/arch/alpha/lib/Makefile
Back to the patch index
Back to the overall index

diff -u --recursive --new-file v2.1.3/linux/arch/alpha/lib/copy_user.S linux/arch/alpha/lib/copy_user.S
@@ -0,0 +1,118 @@
+/*
+ * arch/alpha/lib/copy_user.S
+ *
+ * Copy to/from user space, handling exceptions as we go..  This
+ * isn't exactly pretty.
+ *
+ * This is essentially the same as "memcpy()", but with a few twists.
+ * Notably, we have to make sure that $0 is always up-to-date and
+ * contains the right "bytes left to copy" value (and that it is updated
+ * only _after_ a successful copy). There is also some rather minor
+ * exception setup stuff..
+ *
+ * NOTE! This is not directly C-callable, because the calling semantics are
+ * different:
+ *
+ * Inputs:
+ *	length in $0
+ *	destination address in $6
+ *	source address in $7
+ *	exception pointer in $8
+ *	return address in $28 (exceptions expect it there)
+ *
+ * Outputs:
+ *	bytes left to copy in $0
+ *
+ * Clobbers:
+ *	$1,$2,$3,$4,$5,$6,$7
+ */
+
+	.set noat
+	.align 3
+	.globl __copy_user
+	.ent __copy_user
+__copy_user:
+	ldq $5,0($8)
+	beq $0,$35
+	and $6,7,$3
+	addq $5,1,$1
+	stq $1,0($8)
+	beq $3,$36
+	subq $3,8,$3
+	.align 5
+$37:
+	ldq_u $1,0($7)
+	ldq_u $2,0($6)
+	extbl $1,$7,$1
+	mskbl $2,$6,$2
+	insbl $1,$6,$1
+	addq $3,1,$3
+	bis $1,$2,$1
+	stq_u $1,0($6)
+	subq $0,1,$0
+	addq $6,1,$6
+	addq $7,1,$7
+	beq $0,$41
+	bne $3,$37
+$36:
+	and $7,7,$1
+	bic $0,7,$4
+	beq $1,$43
+	beq $4,$48
+	ldq_u $3,0($7)
+	.align 5
+$50:
+	ldq_u $2,8($7)
+	subq $4,8,$4
+	extql $3,$7,$3
+	extqh $2,$7,$1
+	bis $3,$1,$1
+	stq $1,0($6)
+	addq $7,8,$7
+	subq $0,8,$0
+	addq $6,8,$6
+	bis $2,$2,$3
+	bne $4,$50
+$48:
+	beq $0,$41
+	.align 5
+$57:
+	ldq_u $1,0($7)
+	ldq_u $2,0($6)
+	extbl $1,$7,$1
+	mskbl $2,$6,$2
+	insbl $1,$6,$1
+	bis $1,$2,$1
+	stq_u $1,0($6)
+	subq $0,1,$0
+	addq $6,1,$6
+	addq $7,1,$7
+	bne $0,$57
+	br $31,$41
+	.align 4
+$43:
+	beq $4,$65
+	.align 5
+	.align 5
+$66:
+	ldq $1,0($7)
+	subq $4,8,$4
+	stq $1,0($6)
+	addq $7,8,$7
+	subq $0,8,$0
+	addq $6,8,$6
+	bne $4,$66
+$65:
+	beq $0,$41
+	ldq $2,0($7)
+	ldq $1,0($6)
+	mskql $2,$0,$2
+	mskqh $1,$0,$1
+	bis $2,$1,$2
+	stq $2,0($6)
+	bis $31,$31,$0
+$41:
+	stq $5,0($8)
+$35:
+	ret $31,($28),1
+	.end __copy_user

FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen, slshen@lbl.gov