head	1.2;
access;
symbols
	perseant-exfatfs-base-20250801:1.2
	perseant-exfatfs-base-20240630:1.2
	perseant-exfatfs:1.2.0.8
	perseant-exfatfs-base:1.2
	netbsd-8-3-RELEASE:1.1.1.1
	cjep_sun2x:1.2.0.6
	cjep_sun2x-base:1.2
	cjep_staticlib_x-base1:1.2
	cjep_staticlib_x:1.2.0.4
	cjep_staticlib_x-base:1.2
	phil-wifi-20200421:1.2
	phil-wifi-20200411:1.2
	phil-wifi-20200406:1.2
	netbsd-8-2-RELEASE:1.1.1.1
	netbsd-8-1-RELEASE:1.1.1.1
	netbsd-8-1-RC1:1.1.1.1
	pgoyette-compat-merge-20190127:1.2
	pgoyette-compat-20190127:1.2
	pgoyette-compat-20190118:1.2
	pgoyette-compat-1226:1.2
	pgoyette-compat-1126:1.2
	pgoyette-compat-1020:1.2
	pgoyette-compat-0930:1.2
	pgoyette-compat-0906:1.2
	netbsd-7-2-RELEASE:1.1.1.1
	pgoyette-compat-0728:1.2
	netbsd-8-0-RELEASE:1.1.1.1
	pgoyette-compat-0625:1.2
	netbsd-8-0-RC2:1.1.1.1
	pgoyette-compat-0521:1.2
	pgoyette-compat-0502:1.2
	pgoyette-compat-0422:1.2
	netbsd-8-0-RC1:1.1.1.1
	pgoyette-compat-0415:1.2
	pgoyette-compat-0407:1.2
	pgoyette-compat-0330:1.2
	pgoyette-compat-0322:1.2
	pgoyette-compat-0315:1.2
	netbsd-7-1-2-RELEASE:1.1.1.1
	pgoyette-compat:1.2.0.2
	pgoyette-compat-base:1.2
	netbsd-7-1-1-RELEASE:1.1.1.1
	matt-nb8-mediatek:1.1.1.1.0.26
	matt-nb8-mediatek-base:1.1.1.1
	perseant-stdc-iso10646:1.1.1.1.0.24
	perseant-stdc-iso10646-base:1.1.1.1
	netbsd-8:1.1.1.1.0.22
	netbsd-8-base:1.1.1.1
	prg-localcount2-base3:1.1.1.1
	prg-localcount2-base2:1.1.1.1
	prg-localcount2-base1:1.1.1.1
	prg-localcount2:1.1.1.1.0.20
	prg-localcount2-base:1.1.1.1
	pgoyette-localcount-20170426:1.1.1.1
	bouyer-socketcan-base1:1.1.1.1
	pgoyette-localcount-20170320:1.1.1.1
	netbsd-7-1:1.1.1.1.0.18
	netbsd-7-1-RELEASE:1.1.1.1
	netbsd-7-1-RC2:1.1.1.1
	netbsd-7-nhusb-base-20170116:1.1.1.1
	bouyer-socketcan:1.1.1.1.0.16
	bouyer-socketcan-base:1.1.1.1
	pgoyette-localcount-20170107:1.1.1.1
	netbsd-7-1-RC1:1.1.1.1
	pgoyette-localcount-20161104:1.1.1.1
	netbsd-7-0-2-RELEASE:1.1.1.1
	localcount-20160914:1.1.1.1
	netbsd-7-nhusb:1.1.1.1.0.14
	netbsd-7-nhusb-base:1.1.1.1
	pgoyette-localcount-20160806:1.1.1.1
	pgoyette-localcount-20160726:1.1.1.1
	pgoyette-localcount:1.1.1.1.0.12
	pgoyette-localcount-base:1.1.1.1
	netbsd-7-0-1-RELEASE:1.1.1.1
	netbsd-7-0:1.1.1.1.0.10
	netbsd-7-0-RELEASE:1.1.1.1
	netbsd-7-0-RC3:1.1.1.1
	netbsd-7-0-RC2:1.1.1.1
	netbsd-7-0-RC1:1.1.1.1
	tls-maxphys-base:1.1.1.1
	tls-maxphys:1.1.1.1.0.8
	netbsd-7:1.1.1.1.0.6
	netbsd-7-base:1.1.1.1
	yamt-pagecache:1.1.1.1.0.4
	yamt-pagecache-base9:1.1.1.1
	tls-earlyentropy:1.1.1.1.0.2
	tls-earlyentropy-base:1.1.1.1
	riastradh-xf86-video-intel-2-7-1-pre-2-21-15:1.1.1.1
	riastradh-drm2-base3:1.1.1.1
	gmp-5-1-3:1.1.1.1
	gmp:1.1.1;
locks; strict;
comment	@;; @;


1.2
date	2017.08.22.09.55.46;	author mrg;	state dead;
branches;
next	1.1;
commitid	DVNRZh45aSIRZb4A;

1.1
date	2013.11.29.07.49.48;	author mrg;	state Exp;
branches
	1.1.1.1;
next	;
commitid	L2Av4PuGmdoL39fx;

1.1.1.1
date	2013.11.29.07.49.48;	author mrg;	state Exp;
branches
	1.1.1.1.4.1
	1.1.1.1.8.1;
next	;
commitid	L2Av4PuGmdoL39fx;

1.1.1.1.4.1
date	2013.11.29.07.49.48;	author yamt;	state dead;
branches;
next	1.1.1.1.4.2;
commitid	nx2BSsHy0NPeAxBx;

1.1.1.1.4.2
date	2014.05.22.14.09.06;	author yamt;	state Exp;
branches;
next	;
commitid	nx2BSsHy0NPeAxBx;

1.1.1.1.8.1
date	2013.11.29.07.49.48;	author tls;	state dead;
branches;
next	1.1.1.1.8.2;
commitid	jTnpym9Qu0o4R1Nx;

1.1.1.1.8.2
date	2014.08.19.23.59.55;	author tls;	state Exp;
branches;
next	;
commitid	jTnpym9Qu0o4R1Nx;


desc
@@


1.2
log
@merge GMP 6.1.2.
@
text
@dnl  AMD64 mpn_addcnd_n, mpn_subcnd_n

dnl  Copyright 2011, 2012 Free Software Foundation, Inc.

dnl  This file is part of the GNU MP Library.

dnl  The GNU MP Library is free software; you can redistribute it and/or modify
dnl  it under the terms of the GNU Lesser General Public License as published
dnl  by the Free Software Foundation; either version 3 of the License, or (at
dnl  your option) any later version.

dnl  The GNU MP Library is distributed in the hope that it will be useful, but
dnl  WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
dnl  or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public
dnl  License for more details.

dnl  You should have received a copy of the GNU Lesser General Public License
dnl  along with the GNU MP Library.  If not, see http://www.gnu.org/licenses/.

include(`../config.m4')

C	     cycles/limb
C AMD K8,K9	 2.25
C AMD K10	 2
C AMD bd1	 3.55
C AMD bobcat	 2.5
C Intel P4	13
C Intel core2	 2.9
C Intel NHM	 2.9
C Intel SBR	 2.4
C Intel atom	 6.5
C VIA nano	 3

C NOTES
C  * It might seem natural to use the cmov insn here, but since this function
C    is supposed to have the exact same execution pattern for cnd true and
C    false, and since cmov's documentation is not clear about wheather it
C    actually reads both source operands and writes the register for a false
C    condition, we cannot use it.
C  * Two cases could be optimised: (1) addcnd_n could use ADCSBB-from-memory
C    to save one insn/limb, and (2) when up=rp addcnd_n and subcnd_n could use
C    ADCSBB-to-memory, again saving 1 insn/limb.
C  * This runs optimally at decoder bandwidth on K10.  It has not been tuned
C    for any other processor.

C INPUT PARAMETERS
define(`rp',	`%rdi')
define(`up',	`%rsi')
define(`vp',	`%rdx')
define(`n',	`%rcx')
define(`cnd',	`%r8')

ifdef(`OPERATION_addcnd_n', `
	define(ADDSUB,	      add)
	define(ADCSBB,	      adc)
	define(func,	      mpn_addcnd_n)')
ifdef(`OPERATION_subcnd_n', `
	define(ADDSUB,	      sub)
	define(ADCSBB,	      sbb)
	define(func,	      mpn_subcnd_n)')

MULFUNC_PROLOGUE(mpn_addcnd_n mpn_subcnd_n)

ABI_SUPPORT(DOS64)
ABI_SUPPORT(STD64)

ASM_START()
	TEXT
	ALIGN(16)
PROLOGUE(func)
	FUNC_ENTRY(4)
IFDOS(`	mov	56(%rsp), %r8	')
	push	%rbx
	push	%rbp
	push	%r12
	push	%r13
	push	%r14

	neg	cnd
	sbb	cnd, cnd		C make cnd mask

	lea	(vp,n,8), vp
	lea	(up,n,8), up
	lea	(rp,n,8), rp

	mov	R32(n), R32(%rax)
	neg	n
	and	$3, R32(%rax)
	jz	L(top)			C carry-save reg rax = 0 in this arc
	cmp	$2, R32(%rax)
	jc	L(b1)
	jz	L(b2)

L(b3):	mov	(vp,n,8), %r12
	mov	8(vp,n,8), %r13
	mov	16(vp,n,8), %r14
	mov	(up,n,8), %r10
	mov	8(up,n,8), %rbx
	mov	16(up,n,8), %rbp
	and	cnd, %r12
	and	cnd, %r13
	and	cnd, %r14
	ADDSUB	%r12, %r10
	ADCSBB	%r13, %rbx
	ADCSBB	%r14, %rbp
	sbb	R32(%rax), R32(%rax)	C save carry
	mov	%r10, (rp,n,8)
	mov	%rbx, 8(rp,n,8)
	mov	%rbp, 16(rp,n,8)
	add	$3, n
	js	L(top)
	jmp	L(end)

L(b2):	mov	(vp,n,8), %r12
	mov	8(vp,n,8), %r13
	mov	(up,n,8), %r10
	mov	8(up,n,8), %rbx
	and	cnd, %r12
	and	cnd, %r13
	ADDSUB	%r12, %r10
	ADCSBB	%r13, %rbx
	sbb	R32(%rax), R32(%rax)	C save carry
	mov	%r10, (rp,n,8)
	mov	%rbx, 8(rp,n,8)
	add	$2, n
	js	L(top)
	jmp	L(end)

L(b1):	mov	(vp,n,8), %r12
	mov	(up,n,8), %r10
	and	cnd, %r12
	ADDSUB	%r12, %r10
	sbb	R32(%rax), R32(%rax)	C save carry
	mov	%r10, (rp,n,8)
	add	$1, n
	jns	L(end)

	ALIGN(16)
L(top):	mov	(vp,n,8), %r12
	mov	8(vp,n,8), %r13
	mov	16(vp,n,8), %r14
	mov	24(vp,n,8), %r11
	mov	(up,n,8), %r10
	mov	8(up,n,8), %rbx
	mov	16(up,n,8), %rbp
	mov	24(up,n,8), %r9
	and	cnd, %r12
	and	cnd, %r13
	and	cnd, %r14
	and	cnd, %r11
	add	R32(%rax), R32(%rax)	C restore carry
	ADCSBB	%r12, %r10
	ADCSBB	%r13, %rbx
	ADCSBB	%r14, %rbp
	ADCSBB	%r11, %r9
	sbb	R32(%rax), R32(%rax)	C save carry
	mov	%r10, (rp,n,8)
	mov	%rbx, 8(rp,n,8)
	mov	%rbp, 16(rp,n,8)
	mov	%r9, 24(rp,n,8)
	add	$4, n
	js	L(top)

L(end):	neg	R32(%rax)
	pop	%r14
	pop	%r13
	pop	%r12
	pop	%rbp
	pop	%rbx
	FUNC_EXIT()
	ret
EPILOGUE()
@


1.1
log
@Initial revision
@
text
@@


1.1.1.1
log
@initial import GMP 5.1.3 sources.  changes include:

fixes for:
- mpn_sbpi1_div_qr_sec and mpn_sbpi1_div_r_sec
- mpz_powm_ui
- AMD family 11h
- mpz_powm_sec and mpn_powm_sec
- ASSERT() fixes
- gcd, gcdext, and invert function fixes
- some PPC division operations
@
text
@@


1.1.1.1.8.1
log
@file aorscnd_n.asm was added on branch tls-maxphys on 2014-08-19 23:59:55 +0000
@
text
@d1 172
@


1.1.1.1.8.2
log
@Rebase to HEAD as of a few days ago.
@
text
@a0 172
dnl  AMD64 mpn_addcnd_n, mpn_subcnd_n

dnl  Copyright 2011, 2012 Free Software Foundation, Inc.

dnl  This file is part of the GNU MP Library.

dnl  The GNU MP Library is free software; you can redistribute it and/or modify
dnl  it under the terms of the GNU Lesser General Public License as published
dnl  by the Free Software Foundation; either version 3 of the License, or (at
dnl  your option) any later version.

dnl  The GNU MP Library is distributed in the hope that it will be useful, but
dnl  WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
dnl  or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public
dnl  License for more details.

dnl  You should have received a copy of the GNU Lesser General Public License
dnl  along with the GNU MP Library.  If not, see http://www.gnu.org/licenses/.

include(`../config.m4')

C	     cycles/limb
C AMD K8,K9	 2.25
C AMD K10	 2
C AMD bd1	 3.55
C AMD bobcat	 2.5
C Intel P4	13
C Intel core2	 2.9
C Intel NHM	 2.9
C Intel SBR	 2.4
C Intel atom	 6.5
C VIA nano	 3

C NOTES
C  * It might seem natural to use the cmov insn here, but since this function
C    is supposed to have the exact same execution pattern for cnd true and
C    false, and since cmov's documentation is not clear about wheather it
C    actually reads both source operands and writes the register for a false
C    condition, we cannot use it.
C  * Two cases could be optimised: (1) addcnd_n could use ADCSBB-from-memory
C    to save one insn/limb, and (2) when up=rp addcnd_n and subcnd_n could use
C    ADCSBB-to-memory, again saving 1 insn/limb.
C  * This runs optimally at decoder bandwidth on K10.  It has not been tuned
C    for any other processor.

C INPUT PARAMETERS
define(`rp',	`%rdi')
define(`up',	`%rsi')
define(`vp',	`%rdx')
define(`n',	`%rcx')
define(`cnd',	`%r8')

ifdef(`OPERATION_addcnd_n', `
	define(ADDSUB,	      add)
	define(ADCSBB,	      adc)
	define(func,	      mpn_addcnd_n)')
ifdef(`OPERATION_subcnd_n', `
	define(ADDSUB,	      sub)
	define(ADCSBB,	      sbb)
	define(func,	      mpn_subcnd_n)')

MULFUNC_PROLOGUE(mpn_addcnd_n mpn_subcnd_n)

ABI_SUPPORT(DOS64)
ABI_SUPPORT(STD64)

ASM_START()
	TEXT
	ALIGN(16)
PROLOGUE(func)
	FUNC_ENTRY(4)
IFDOS(`	mov	56(%rsp), %r8	')
	push	%rbx
	push	%rbp
	push	%r12
	push	%r13
	push	%r14

	neg	cnd
	sbb	cnd, cnd		C make cnd mask

	lea	(vp,n,8), vp
	lea	(up,n,8), up
	lea	(rp,n,8), rp

	mov	R32(n), R32(%rax)
	neg	n
	and	$3, R32(%rax)
	jz	L(top)			C carry-save reg rax = 0 in this arc
	cmp	$2, R32(%rax)
	jc	L(b1)
	jz	L(b2)

L(b3):	mov	(vp,n,8), %r12
	mov	8(vp,n,8), %r13
	mov	16(vp,n,8), %r14
	mov	(up,n,8), %r10
	mov	8(up,n,8), %rbx
	mov	16(up,n,8), %rbp
	and	cnd, %r12
	and	cnd, %r13
	and	cnd, %r14
	ADDSUB	%r12, %r10
	ADCSBB	%r13, %rbx
	ADCSBB	%r14, %rbp
	sbb	R32(%rax), R32(%rax)	C save carry
	mov	%r10, (rp,n,8)
	mov	%rbx, 8(rp,n,8)
	mov	%rbp, 16(rp,n,8)
	add	$3, n
	js	L(top)
	jmp	L(end)

L(b2):	mov	(vp,n,8), %r12
	mov	8(vp,n,8), %r13
	mov	(up,n,8), %r10
	mov	8(up,n,8), %rbx
	and	cnd, %r12
	and	cnd, %r13
	ADDSUB	%r12, %r10
	ADCSBB	%r13, %rbx
	sbb	R32(%rax), R32(%rax)	C save carry
	mov	%r10, (rp,n,8)
	mov	%rbx, 8(rp,n,8)
	add	$2, n
	js	L(top)
	jmp	L(end)

L(b1):	mov	(vp,n,8), %r12
	mov	(up,n,8), %r10
	and	cnd, %r12
	ADDSUB	%r12, %r10
	sbb	R32(%rax), R32(%rax)	C save carry
	mov	%r10, (rp,n,8)
	add	$1, n
	jns	L(end)

	ALIGN(16)
L(top):	mov	(vp,n,8), %r12
	mov	8(vp,n,8), %r13
	mov	16(vp,n,8), %r14
	mov	24(vp,n,8), %r11
	mov	(up,n,8), %r10
	mov	8(up,n,8), %rbx
	mov	16(up,n,8), %rbp
	mov	24(up,n,8), %r9
	and	cnd, %r12
	and	cnd, %r13
	and	cnd, %r14
	and	cnd, %r11
	add	R32(%rax), R32(%rax)	C restore carry
	ADCSBB	%r12, %r10
	ADCSBB	%r13, %rbx
	ADCSBB	%r14, %rbp
	ADCSBB	%r11, %r9
	sbb	R32(%rax), R32(%rax)	C save carry
	mov	%r10, (rp,n,8)
	mov	%rbx, 8(rp,n,8)
	mov	%rbp, 16(rp,n,8)
	mov	%r9, 24(rp,n,8)
	add	$4, n
	js	L(top)

L(end):	neg	R32(%rax)
	pop	%r14
	pop	%r13
	pop	%r12
	pop	%rbp
	pop	%rbx
	FUNC_EXIT()
	ret
EPILOGUE()
@


1.1.1.1.4.1
log
@file aorscnd_n.asm was added on branch yamt-pagecache on 2014-05-22 14:09:06 +0000
@
text
@d1 172
@


1.1.1.1.4.2
log
@sync with head.

for a reference, the tree before this commit was tagged
as yamt-pagecache-tag8.

this commit was splitted into small chunks to avoid
a limitation of cvs.  ("Protocol error: too many arguments")
@
text
@a0 172
dnl  AMD64 mpn_addcnd_n, mpn_subcnd_n

dnl  Copyright 2011, 2012 Free Software Foundation, Inc.

dnl  This file is part of the GNU MP Library.

dnl  The GNU MP Library is free software; you can redistribute it and/or modify
dnl  it under the terms of the GNU Lesser General Public License as published
dnl  by the Free Software Foundation; either version 3 of the License, or (at
dnl  your option) any later version.

dnl  The GNU MP Library is distributed in the hope that it will be useful, but
dnl  WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
dnl  or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public
dnl  License for more details.

dnl  You should have received a copy of the GNU Lesser General Public License
dnl  along with the GNU MP Library.  If not, see http://www.gnu.org/licenses/.

include(`../config.m4')

C	     cycles/limb
C AMD K8,K9	 2.25
C AMD K10	 2
C AMD bd1	 3.55
C AMD bobcat	 2.5
C Intel P4	13
C Intel core2	 2.9
C Intel NHM	 2.9
C Intel SBR	 2.4
C Intel atom	 6.5
C VIA nano	 3

C NOTES
C  * It might seem natural to use the cmov insn here, but since this function
C    is supposed to have the exact same execution pattern for cnd true and
C    false, and since cmov's documentation is not clear about wheather it
C    actually reads both source operands and writes the register for a false
C    condition, we cannot use it.
C  * Two cases could be optimised: (1) addcnd_n could use ADCSBB-from-memory
C    to save one insn/limb, and (2) when up=rp addcnd_n and subcnd_n could use
C    ADCSBB-to-memory, again saving 1 insn/limb.
C  * This runs optimally at decoder bandwidth on K10.  It has not been tuned
C    for any other processor.

C INPUT PARAMETERS
define(`rp',	`%rdi')
define(`up',	`%rsi')
define(`vp',	`%rdx')
define(`n',	`%rcx')
define(`cnd',	`%r8')

ifdef(`OPERATION_addcnd_n', `
	define(ADDSUB,	      add)
	define(ADCSBB,	      adc)
	define(func,	      mpn_addcnd_n)')
ifdef(`OPERATION_subcnd_n', `
	define(ADDSUB,	      sub)
	define(ADCSBB,	      sbb)
	define(func,	      mpn_subcnd_n)')

MULFUNC_PROLOGUE(mpn_addcnd_n mpn_subcnd_n)

ABI_SUPPORT(DOS64)
ABI_SUPPORT(STD64)

ASM_START()
	TEXT
	ALIGN(16)
PROLOGUE(func)
	FUNC_ENTRY(4)
IFDOS(`	mov	56(%rsp), %r8	')
	push	%rbx
	push	%rbp
	push	%r12
	push	%r13
	push	%r14

	neg	cnd
	sbb	cnd, cnd		C make cnd mask

	lea	(vp,n,8), vp
	lea	(up,n,8), up
	lea	(rp,n,8), rp

	mov	R32(n), R32(%rax)
	neg	n
	and	$3, R32(%rax)
	jz	L(top)			C carry-save reg rax = 0 in this arc
	cmp	$2, R32(%rax)
	jc	L(b1)
	jz	L(b2)

L(b3):	mov	(vp,n,8), %r12
	mov	8(vp,n,8), %r13
	mov	16(vp,n,8), %r14
	mov	(up,n,8), %r10
	mov	8(up,n,8), %rbx
	mov	16(up,n,8), %rbp
	and	cnd, %r12
	and	cnd, %r13
	and	cnd, %r14
	ADDSUB	%r12, %r10
	ADCSBB	%r13, %rbx
	ADCSBB	%r14, %rbp
	sbb	R32(%rax), R32(%rax)	C save carry
	mov	%r10, (rp,n,8)
	mov	%rbx, 8(rp,n,8)
	mov	%rbp, 16(rp,n,8)
	add	$3, n
	js	L(top)
	jmp	L(end)

L(b2):	mov	(vp,n,8), %r12
	mov	8(vp,n,8), %r13
	mov	(up,n,8), %r10
	mov	8(up,n,8), %rbx
	and	cnd, %r12
	and	cnd, %r13
	ADDSUB	%r12, %r10
	ADCSBB	%r13, %rbx
	sbb	R32(%rax), R32(%rax)	C save carry
	mov	%r10, (rp,n,8)
	mov	%rbx, 8(rp,n,8)
	add	$2, n
	js	L(top)
	jmp	L(end)

L(b1):	mov	(vp,n,8), %r12
	mov	(up,n,8), %r10
	and	cnd, %r12
	ADDSUB	%r12, %r10
	sbb	R32(%rax), R32(%rax)	C save carry
	mov	%r10, (rp,n,8)
	add	$1, n
	jns	L(end)

	ALIGN(16)
L(top):	mov	(vp,n,8), %r12
	mov	8(vp,n,8), %r13
	mov	16(vp,n,8), %r14
	mov	24(vp,n,8), %r11
	mov	(up,n,8), %r10
	mov	8(up,n,8), %rbx
	mov	16(up,n,8), %rbp
	mov	24(up,n,8), %r9
	and	cnd, %r12
	and	cnd, %r13
	and	cnd, %r14
	and	cnd, %r11
	add	R32(%rax), R32(%rax)	C restore carry
	ADCSBB	%r12, %r10
	ADCSBB	%r13, %rbx
	ADCSBB	%r14, %rbp
	ADCSBB	%r11, %r9
	sbb	R32(%rax), R32(%rax)	C save carry
	mov	%r10, (rp,n,8)
	mov	%rbx, 8(rp,n,8)
	mov	%rbp, 16(rp,n,8)
	mov	%r9, 24(rp,n,8)
	add	$4, n
	js	L(top)

L(end):	neg	R32(%rax)
	pop	%r14
	pop	%r13
	pop	%r12
	pop	%rbp
	pop	%rbx
	FUNC_EXIT()
	ret
EPILOGUE()
@


