xref: /titanic_52/usr/src/uts/intel/ia32/ml/ovbcopy.s (revision 7c478bd95313f5f23a4c958a745db2134aa03244)
1*7c478bd9Sstevel@tonic-gate/*
2*7c478bd9Sstevel@tonic-gate * Copyright 2004 Sun Microsystems, Inc.  All rights reserved.
3*7c478bd9Sstevel@tonic-gate * Use is subject to license terms.
4*7c478bd9Sstevel@tonic-gate */
5*7c478bd9Sstevel@tonic-gate
6*7c478bd9Sstevel@tonic-gate#pragma ident	"%Z%%M%	%I%	%E% SMI"
7*7c478bd9Sstevel@tonic-gate
8*7c478bd9Sstevel@tonic-gate/*-
9*7c478bd9Sstevel@tonic-gate * Copyright (c) 1993 The Regents of the University of California.
10*7c478bd9Sstevel@tonic-gate * All rights reserved.
11*7c478bd9Sstevel@tonic-gate *
12*7c478bd9Sstevel@tonic-gate * Redistribution and use in source and binary forms, with or without
13*7c478bd9Sstevel@tonic-gate * modification, are permitted provided that the following conditions
14*7c478bd9Sstevel@tonic-gate * are met:
15*7c478bd9Sstevel@tonic-gate * 1. Redistributions of source code must retain the above copyright
16*7c478bd9Sstevel@tonic-gate *    notice, this list of conditions and the following disclaimer.
17*7c478bd9Sstevel@tonic-gate * 2. Redistributions in binary form must reproduce the above copyright
18*7c478bd9Sstevel@tonic-gate *    notice, this list of conditions and the following disclaimer in the
19*7c478bd9Sstevel@tonic-gate *    documentation and/or other materials provided with the distribution.
20*7c478bd9Sstevel@tonic-gate * 3. All advertising materials mentioning features or use of this software
21*7c478bd9Sstevel@tonic-gate *    must display the following acknowledgement:
22*7c478bd9Sstevel@tonic-gate *	This product includes software developed by the University of
23*7c478bd9Sstevel@tonic-gate *	California, Berkeley and its contributors.
24*7c478bd9Sstevel@tonic-gate * 4. Neither the name of the University nor the names of its contributors
25*7c478bd9Sstevel@tonic-gate *    may be used to endorse or promote products derived from this software
26*7c478bd9Sstevel@tonic-gate *    without specific prior written permission.
27*7c478bd9Sstevel@tonic-gate *
28*7c478bd9Sstevel@tonic-gate * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
29*7c478bd9Sstevel@tonic-gate * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
30*7c478bd9Sstevel@tonic-gate * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
31*7c478bd9Sstevel@tonic-gate * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
32*7c478bd9Sstevel@tonic-gate * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
33*7c478bd9Sstevel@tonic-gate * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
34*7c478bd9Sstevel@tonic-gate * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
35*7c478bd9Sstevel@tonic-gate * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
36*7c478bd9Sstevel@tonic-gate * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
37*7c478bd9Sstevel@tonic-gate * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
38*7c478bd9Sstevel@tonic-gate * SUCH DAMAGE.
39*7c478bd9Sstevel@tonic-gate *
40*7c478bd9Sstevel@tonic-gate * $FreeBSD: src/sys/amd64/amd64/support.S,v 1.102 2003/10/02 05:08:13 alc Exp $
41*7c478bd9Sstevel@tonic-gate */
42*7c478bd9Sstevel@tonic-gate
43*7c478bd9Sstevel@tonic-gate#include <sys/asm_linkage.h>
44*7c478bd9Sstevel@tonic-gate
45*7c478bd9Sstevel@tonic-gate#if defined(__lint)
46*7c478bd9Sstevel@tonic-gate
47*7c478bd9Sstevel@tonic-gate/*
48*7c478bd9Sstevel@tonic-gate * Overlapping bcopy (source and target may overlap arbitrarily).
49*7c478bd9Sstevel@tonic-gate */
50*7c478bd9Sstevel@tonic-gate/* ARGSUSED */
51*7c478bd9Sstevel@tonic-gatevoid
52*7c478bd9Sstevel@tonic-gateovbcopy(const void *from, void *to, size_t count)
53*7c478bd9Sstevel@tonic-gate{}
54*7c478bd9Sstevel@tonic-gate
55*7c478bd9Sstevel@tonic-gate#else	/* __lint */
56*7c478bd9Sstevel@tonic-gate
57*7c478bd9Sstevel@tonic-gate/*
58*7c478bd9Sstevel@tonic-gate * Adapted from fbsd bcopy().
59*7c478bd9Sstevel@tonic-gate *
60*7c478bd9Sstevel@tonic-gate * bcopy(src, dst, cnt)
61*7c478bd9Sstevel@tonic-gate *       rdi, rsi, rdx
62*7c478bd9Sstevel@tonic-gate *  ws@tools.de     (Wolfgang Solfrank, TooLs GmbH) +49-228-985800
63*7c478bd9Sstevel@tonic-gate */
64*7c478bd9Sstevel@tonic-gate
65*7c478bd9Sstevel@tonic-gate#if defined(__amd64)
66*7c478bd9Sstevel@tonic-gate
67*7c478bd9Sstevel@tonic-gate	ENTRY(ovbcopy)
68*7c478bd9Sstevel@tonic-gate	xchgq	%rsi,%rdi
69*7c478bd9Sstevel@tonic-gate	movq	%rdx,%rcx
70*7c478bd9Sstevel@tonic-gate
71*7c478bd9Sstevel@tonic-gate	movq	%rdi,%rax
72*7c478bd9Sstevel@tonic-gate	subq	%rsi,%rax
73*7c478bd9Sstevel@tonic-gate	cmpq	%rcx,%rax		/* overlapping && src < dst? */
74*7c478bd9Sstevel@tonic-gate	jb	reverse
75*7c478bd9Sstevel@tonic-gate
76*7c478bd9Sstevel@tonic-gate	shrq	$3,%rcx			/* copy by 64-bit words */
77*7c478bd9Sstevel@tonic-gate	cld				/* nope, copy forwards */
78*7c478bd9Sstevel@tonic-gate	rep
79*7c478bd9Sstevel@tonic-gate	movsq
80*7c478bd9Sstevel@tonic-gate	movq	%rdx,%rcx
81*7c478bd9Sstevel@tonic-gate	andq	$7,%rcx			/* any bytes left? */
82*7c478bd9Sstevel@tonic-gate	rep
83*7c478bd9Sstevel@tonic-gate	movsb
84*7c478bd9Sstevel@tonic-gate	ret
85*7c478bd9Sstevel@tonic-gate
86*7c478bd9Sstevel@tonic-gatereverse:
87*7c478bd9Sstevel@tonic-gate	addq	%rcx,%rdi		/* copy backwards */
88*7c478bd9Sstevel@tonic-gate	addq	%rcx,%rsi
89*7c478bd9Sstevel@tonic-gate	decq	%rdi
90*7c478bd9Sstevel@tonic-gate	decq	%rsi
91*7c478bd9Sstevel@tonic-gate	andq	$7,%rcx			/* any fractional bytes? */
92*7c478bd9Sstevel@tonic-gate	std
93*7c478bd9Sstevel@tonic-gate	rep
94*7c478bd9Sstevel@tonic-gate	movsb
95*7c478bd9Sstevel@tonic-gate	movq	%rdx,%rcx		/* copy remainder by 32-bit words */
96*7c478bd9Sstevel@tonic-gate	shrq	$3,%rcx
97*7c478bd9Sstevel@tonic-gate	subq	$7,%rsi
98*7c478bd9Sstevel@tonic-gate	subq	$7,%rdi
99*7c478bd9Sstevel@tonic-gate	rep
100*7c478bd9Sstevel@tonic-gate	movsq
101*7c478bd9Sstevel@tonic-gate	cld
102*7c478bd9Sstevel@tonic-gate	ret
103*7c478bd9Sstevel@tonic-gate	SET_SIZE(ovbcopy)
104*7c478bd9Sstevel@tonic-gate
105*7c478bd9Sstevel@tonic-gate#elif defined(__i386)
106*7c478bd9Sstevel@tonic-gate
107*7c478bd9Sstevel@tonic-gate	ENTRY(ovbcopy)
108*7c478bd9Sstevel@tonic-gate	pushl	%esi
109*7c478bd9Sstevel@tonic-gate	pushl	%edi
110*7c478bd9Sstevel@tonic-gate	movl	12(%esp),%esi
111*7c478bd9Sstevel@tonic-gate	movl	16(%esp),%edi
112*7c478bd9Sstevel@tonic-gate	movl	20(%esp),%ecx
113*7c478bd9Sstevel@tonic-gate
114*7c478bd9Sstevel@tonic-gate	movl	%edi,%eax
115*7c478bd9Sstevel@tonic-gate	subl	%esi,%eax
116*7c478bd9Sstevel@tonic-gate	cmpl	%ecx,%eax		/* overlapping && src < dst? */
117*7c478bd9Sstevel@tonic-gate	jb	reverse
118*7c478bd9Sstevel@tonic-gate
119*7c478bd9Sstevel@tonic-gate	shrl	$2,%ecx			/* copy by 32-bit words */
120*7c478bd9Sstevel@tonic-gate	cld				/* nope, copy forwards */
121*7c478bd9Sstevel@tonic-gate	rep
122*7c478bd9Sstevel@tonic-gate	movsl
123*7c478bd9Sstevel@tonic-gate	movl	20(%esp),%ecx
124*7c478bd9Sstevel@tonic-gate	andl	$3,%ecx			/* any bytes left? */
125*7c478bd9Sstevel@tonic-gate	rep
126*7c478bd9Sstevel@tonic-gate	movsb
127*7c478bd9Sstevel@tonic-gate	popl	%edi
128*7c478bd9Sstevel@tonic-gate	popl	%esi
129*7c478bd9Sstevel@tonic-gate	ret
130*7c478bd9Sstevel@tonic-gate
131*7c478bd9Sstevel@tonic-gatereverse:
132*7c478bd9Sstevel@tonic-gate	addl	%ecx,%edi		/* copy backwards */
133*7c478bd9Sstevel@tonic-gate	addl	%ecx,%esi
134*7c478bd9Sstevel@tonic-gate	decl	%edi
135*7c478bd9Sstevel@tonic-gate	decl	%esi
136*7c478bd9Sstevel@tonic-gate	andl	$3,%ecx			/* any fractional bytes? */
137*7c478bd9Sstevel@tonic-gate	std
138*7c478bd9Sstevel@tonic-gate	rep
139*7c478bd9Sstevel@tonic-gate	movsb
140*7c478bd9Sstevel@tonic-gate	movl	20(%esp),%ecx		/* copy remainder by 32-bit words */
141*7c478bd9Sstevel@tonic-gate	shrl	$2,%ecx
142*7c478bd9Sstevel@tonic-gate	subl	$3,%esi
143*7c478bd9Sstevel@tonic-gate	subl	$3,%edi
144*7c478bd9Sstevel@tonic-gate	rep
145*7c478bd9Sstevel@tonic-gate	movsl
146*7c478bd9Sstevel@tonic-gate	popl	%edi
147*7c478bd9Sstevel@tonic-gate	popl	%esi
148*7c478bd9Sstevel@tonic-gate	cld
149*7c478bd9Sstevel@tonic-gate	ret
150*7c478bd9Sstevel@tonic-gate	SET_SIZE(ovbcopy)
151*7c478bd9Sstevel@tonic-gate
152*7c478bd9Sstevel@tonic-gate#endif	/* __i386 */
153*7c478bd9Sstevel@tonic-gate
154*7c478bd9Sstevel@tonic-gate#endif	/* __lint */
155