lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Date:	Thu, 5 Oct 2006 10:16:36 +0200
From:	Jarek Poplawski <jarkao2@...pl>
To:	Klaus Knopper <knopper@...pper.net>
Cc:	Andi Kleen <ak@...e.de>, linux-kernel@...r.kernel.org
Subject: [PATCH] Re: compile error for 2.6.18-git19 with CONFIG_RWSEM_GENERIC_SPINLOCK=y

On 03-10-2006 21:20, Klaus Knopper wrote:
> Hello everyone,
> 
> Since the "reporting bugs" FAQ told me to post here in case I can't
> identify the right person to ask, and have not found any mention of this
> problem on the list and anywhere else yet, I do.
> 
> Problem description: Compiling 2.6.18-git19 (gcc-3.3 and 4.1) fails for
> processor family i386 (when CONFIG_RWSEM_GENERIC_SPINLOCK=y) is set,
> with
> 
> arch/i386/lib/lib.a(semaphore.o): In function `call_rwsem_down_read_failed':
> arch/i386/lib/semaphore.S:(.sched.text+0x5f): undefined reference to `rwsem_down_read_failed'
> arch/i386/lib/lib.a(semaphore.o): In function `call_rwsem_down_write_failed':
> arch/i386/lib/semaphore.S:(.sched.text+0x6a): undefined reference to `rwsem_down_write_failed'
> arch/i386/lib/lib.a(semaphore.o): In function `call_rwsem_wake':
> arch/i386/lib/semaphore.S:(.sched.text+0x76): undefined reference to `rwsem_wake'
> arch/i386/lib/lib.a(semaphore.o): In function `call_rwsem_downgrade_wake':
> arch/i386/lib/semaphore.S:(.sched.text+0x7f): undefined reference to `rwsem_downgrade_wake'
> 
> This option is present in .config when setting processor family to
> plain "i386" in make menuconfig.
> 
> Using CONFIG_RWSEM_XCHGADD_ALGORITHM=y INSTEAD of
> CONFIG_RWSEM_GENERIC_SPINLOCK=y (i486 and up) kind of "fixes" the
> compile error, but I'm not sure if the resulting code would still run on
> a real i386.
> 
> This problem also exists for ealier gits, but I can't tell exactly when
> it started.
> 
> Regards
> -Klaus Knopper
> PS: Please CC any answers to me, since I'm not a subscriber to this list.

It looks there is only one person in the world who remembers i386!

I attach my patch proposal.

Best regards,

Jarek P.


diff -Nurp linux-2.6.18-rc1-/arch/i386/lib/semaphore.S linux-2.6.18-rc1/arch/i386/lib/semaphore.S
--- linux-2.6.18-rc1-/arch/i386/lib/semaphore.S	2006-10-05 09:25:44.000000000 +0200
+++ linux-2.6.18-rc1/arch/i386/lib/semaphore.S	2006-10-05 10:01:01.000000000 +0200
@@ -153,6 +153,7 @@ ENTRY(__read_lock_failed)
 #endif
 
 /* Fix up special calling conventions */
+#ifdef CONFIG_RWSEM_XCHGADD_ALGORITHM
 ENTRY(call_rwsem_down_read_failed)
 	CFI_STARTPROC
 	push %ecx
@@ -214,3 +215,4 @@ ENTRY(call_rwsem_downgrade_wake)
 	CFI_ENDPROC
 	END(call_rwsem_downgrade_wake)
 
+#endif
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ