* A new mips toolchain is available @ 2001-06-12 4:03 H . J . Lu 2001-06-12 11:39 ` Ralf Baechle 2001-06-13 7:57 ` Maciej W. Rozycki 0 siblings, 2 replies; 14+ messages in thread From: H . J . Lu @ 2001-06-12 4:03 UTC (permalink / raw) To: linux-mips I put my new mips toolchain at http://ftp.kernel.org/pub/linux/devel/binutils/mips/ There are source rpms for RedHat 7.1. They may only be built correctly with rpm, especially binutils. I can provide mips and mipsel binaries rpms for them. But it will take at least a few days. BTW, my toolchain is for the SVR4 MIPS ABI. I don't know how compatible it is with the IRIX ABI. Old IRIX ABI binaries seem to run fine. But I don't know abour the IRIX ABI DSOs. Also my glibc is compiled with -mmips2 since kernel cannot handle mips I glibc. H.J. ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: A new mips toolchain is available 2001-06-12 4:03 A new mips toolchain is available H . J . Lu @ 2001-06-12 11:39 ` Ralf Baechle 2001-06-12 16:40 ` H . J . Lu 2001-06-13 7:57 ` Maciej W. Rozycki 1 sibling, 1 reply; 14+ messages in thread From: Ralf Baechle @ 2001-06-12 11:39 UTC (permalink / raw) To: H . J . Lu; +Cc: linux-mips On Mon, Jun 11, 2001 at 09:03:11PM -0700, H . J . Lu wrote: > I put my new mips toolchain at > > http://ftp.kernel.org/pub/linux/devel/binutils/mips/ > > There are source rpms for RedHat 7.1. They may only be built correctly > with rpm, especially binutils. I can provide mips and mipsel binaries > rpms for them. But it will take at least a few days. > > BTW, my toolchain is for the SVR4 MIPS ABI. I don't know how compatible > it is with the IRIX ABI. Old IRIX ABI binaries seem to run fine. But I > don't know abour the IRIX ABI DSOs. No known issues except that modutils only works ok with SVR4 ABI flavoured binaries. > Also my glibc is compiled with -mmips2 since kernel cannot handle mips I > glibc. It's noticable faster also ... Ralf ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: A new mips toolchain is available 2001-06-12 11:39 ` Ralf Baechle @ 2001-06-12 16:40 ` H . J . Lu 2001-06-12 19:11 ` Ralf Baechle 0 siblings, 1 reply; 14+ messages in thread From: H . J . Lu @ 2001-06-12 16:40 UTC (permalink / raw) To: Ralf Baechle; +Cc: linux-mips On Tue, Jun 12, 2001 at 01:39:25PM +0200, Ralf Baechle wrote: > On Mon, Jun 11, 2001 at 09:03:11PM -0700, H . J . Lu wrote: > > > I put my new mips toolchain at > > > > http://ftp.kernel.org/pub/linux/devel/binutils/mips/ > > > > There are source rpms for RedHat 7.1. They may only be built correctly > > with rpm, especially binutils. I can provide mips and mipsel binaries > > rpms for them. But it will take at least a few days. > > > > BTW, my toolchain is for the SVR4 MIPS ABI. I don't know how compatible > > it is with the IRIX ABI. Old IRIX ABI binaries seem to run fine. But I > > don't know abour the IRIX ABI DSOs. > > No known issues except that modutils only works ok with SVR4 ABI flavoured > binaries. FYI, my glibc includes * sysdeps/mips/dl-machine.h (MAP_BASE_ADDR): Commented out. * sysdeps/mips/rtld-ldscript.in: Removed. * sysdeps/mips/rtld-parms: Likewise. * sysdeps/mips/mips64/rtld-parms: Likewise. * sysdeps/mips/mipsel/rtld-parms: Likewise. As I mentioned before, the resulting glibc works fine with the IRIX ABI executables. But I have no ideas about DSOs. H.J. ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: A new mips toolchain is available 2001-06-12 16:40 ` H . J . Lu @ 2001-06-12 19:11 ` Ralf Baechle 2001-06-12 19:38 ` H . J . Lu 0 siblings, 1 reply; 14+ messages in thread From: Ralf Baechle @ 2001-06-12 19:11 UTC (permalink / raw) To: H . J . Lu; +Cc: linux-mips On Tue, Jun 12, 2001 at 09:40:55AM -0700, H . J . Lu wrote: > FYI, my glibc includes > > * sysdeps/mips/dl-machine.h (MAP_BASE_ADDR): Commented out. That means elf/dl-load.c will assume zero for the load address. That will crash static programs which expect a value of 0x5ffe0000 and are trying to dlopen a shared library which uses a different value. Most popular example is rpm. So we need to keep ``#define MAP_BASE_ADDR(l) 0x5ffe0000'' in there until we've got a real fix, unfortunately. ABI requires us to properly support DT_MIPS_BASE_ADDRESS, so that needs to fixed for real anyway ... > * sysdeps/mips/rtld-ldscript.in: Removed. > * sysdeps/mips/rtld-parms: Likewise. > * sysdeps/mips/mips64/rtld-parms: Likewise. > * sysdeps/mips/mipsel/rtld-parms: Likewise. > > As I mentioned before, the resulting glibc works fine with the IRIX ABI > executables. But I have no ideas about DSOs. This rtld stuff was an IRIX-ism which made it into Linux without the necessary reflection; nothing bad should happen if we remove it. Ralf ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: A new mips toolchain is available 2001-06-12 19:11 ` Ralf Baechle @ 2001-06-12 19:38 ` H . J . Lu 0 siblings, 0 replies; 14+ messages in thread From: H . J . Lu @ 2001-06-12 19:38 UTC (permalink / raw) To: Ralf Baechle; +Cc: linux-mips On Tue, Jun 12, 2001 at 09:11:51PM +0200, Ralf Baechle wrote: > On Tue, Jun 12, 2001 at 09:40:55AM -0700, H . J . Lu wrote: > > > FYI, my glibc includes > > > > * sysdeps/mips/dl-machine.h (MAP_BASE_ADDR): Commented out. > > That means elf/dl-load.c will assume zero for the load address. That will > crash static programs which expect a value of 0x5ffe0000 and are trying to > dlopen a shared library which uses a different value. Most popular > example is rpm. So we need to keep ``#define MAP_BASE_ADDR(l) 0x5ffe0000'' > in there until we've got a real fix, unfortunately. > > ABI requires us to properly support DT_MIPS_BASE_ADDRESS, so that needs > to fixed for real anyway ... > Please provide me some testcases. I will look into them. H.J. ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: A new mips toolchain is available 2001-06-12 4:03 A new mips toolchain is available H . J . Lu 2001-06-12 11:39 ` Ralf Baechle @ 2001-06-13 7:57 ` Maciej W. Rozycki 2001-06-13 15:08 ` H . J . Lu 1 sibling, 1 reply; 14+ messages in thread From: Maciej W. Rozycki @ 2001-06-13 7:57 UTC (permalink / raw) To: H . J . Lu; +Cc: linux-mips On Mon, 11 Jun 2001, H . J . Lu wrote: > don't know abour the IRIX ABI DSOs. Also my glibc is compiled with > -mmips2 since kernel cannot handle mips I glibc. What's the problem with the kernel? It works fine for my R3400A DECstation. Glibc is 2.2.3 as released. If there is something wrong, I definitely want to know. Of course, you might want to run MIPS II binaries for performance reasons, anyway. -- + Maciej W. Rozycki, Technical University of Gdansk, Poland + +--------------------------------------------------------------+ + e-mail: macro@ds2.pg.gda.pl, PGP key available + ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: A new mips toolchain is available 2001-06-13 7:57 ` Maciej W. Rozycki @ 2001-06-13 15:08 ` H . J . Lu 2001-06-13 15:22 ` Maciej W. Rozycki 0 siblings, 1 reply; 14+ messages in thread From: H . J . Lu @ 2001-06-13 15:08 UTC (permalink / raw) To: Maciej W. Rozycki; +Cc: linux-mips On Wed, Jun 13, 2001 at 09:57:52AM +0200, Maciej W. Rozycki wrote: > On Mon, 11 Jun 2001, H . J . Lu wrote: > > > don't know abour the IRIX ABI DSOs. Also my glibc is compiled with > > -mmips2 since kernel cannot handle mips I glibc. > > What's the problem with the kernel? It works fine for my R3400A > DECstation. Glibc is 2.2.3 as released. If there is something wrong, I > definitely want to know. > It has something to do with the atomic emulation in kernel for mips I. H.J. ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: A new mips toolchain is available 2001-06-13 15:08 ` H . J . Lu @ 2001-06-13 15:22 ` Maciej W. Rozycki 2001-06-13 15:24 ` H . J . Lu 0 siblings, 1 reply; 14+ messages in thread From: Maciej W. Rozycki @ 2001-06-13 15:22 UTC (permalink / raw) To: H . J . Lu; +Cc: linux-mips On Wed, 13 Jun 2001, H . J . Lu wrote: > > What's the problem with the kernel? It works fine for my R3400A > > DECstation. Glibc is 2.2.3 as released. If there is something wrong, I > > definitely want to know. > > It has something to do with the atomic emulation in kernel for mips I. Hmm, I thought Florian's sysmips() fixes went in. Here is a patch I use successfully for some time. It doesn't work for small negative integers, but glibc doesn't use them, AFAIK. Another possibility is to use the set of two patches for sys__test_and_set() I've sent here recently. This would break portability for now, though, if you wanted to distribute glibc or kernel binaries. This is also the reason I didn't put my current patched version of glibc on my FTP site. The patch is not against a current version of the kernel -- you might need to apply it manually. Maciej -- + Maciej W. Rozycki, Technical University of Gdansk, Poland + +--------------------------------------------------------------+ + e-mail: macro@ds2.pg.gda.pl, PGP key available + patch-mips-2.4.0-test11-20001211-sysmips-0 diff -up --recursive --new-file linux-mips-2.4.0-test11-20001211.macro/arch/mips/kernel/sysmips.c linux-mips-2.4.0-test11-20001211/arch/mips/kernel/sysmips.c --- linux-mips-2.4.0-test11-20001211.macro/arch/mips/kernel/sysmips.c Sat Nov 18 05:27:01 2000 +++ linux-mips-2.4.0-test11-20001211/arch/mips/kernel/sysmips.c Tue Dec 12 23:09:57 2000 @@ -75,21 +75,31 @@ sys_sysmips(int cmd, int arg1, int arg2, } case MIPS_ATOMIC_SET: { - unsigned int tmp; + int tmp1; p = (int *) arg1; errno = verify_area(VERIFY_WRITE, p, sizeof(*p)); if (errno) return errno; + errno = 0; +#ifndef CONFIG_CPU_HAS_LLSC + + save_and_cli(tmp1); + errno |= __get_user(tmp, p); + errno |= __put_user(arg2, p); + restore_flags(tmp1); + +#else /* CONFIG_CPU_HAS_LLSC */ + __asm__(".set\tpush\t\t\t# sysmips(MIPS_ATOMIC, ...)\n\t" ".set\tmips2\n\t" ".set\tnoat\n\t" - "1:\tll\t%0, %4\n\t" - "move\t$1, %3\n\t" - "2:\tsc\t$1, %1\n\t" - "beqz\t$1, 1b\n\t" + "1:\tll\t%0, %5\n\t" + "move\t%3, %4\n\t" + "2:\tsc\t%3, %1\n\t" + "beqz\t%3, 1b\n\t" ".set\tpop\n\t" ".section\t.fixup,\"ax\"\n" "3:\tli\t%2, 1\t\t\t# error\n\t" @@ -98,23 +108,17 @@ sys_sysmips(int cmd, int arg1, int arg2, ".word\t1b, 3b\n\t" ".word\t2b, 3b\n\t" ".previous\n\t" - : "=&r" (tmp), "=o" (* (u32 *) p), "=r" (errno) + : "=&r" (tmp), "=o" (* (u32 *) p), "=r" (errno), + "=&r" (tmp1) : "r" (arg2), "o" (* (u32 *) p), "2" (errno) : "$1"); +#endif /* CONFIG_CPU_HAS_LLSC */ + if (errno) return -EFAULT; - /* We're skipping error handling etc. */ - if (current->ptrace & PT_TRACESYS) - syscall_trace(); - - __asm__ __volatile__( - "move\t$29, %0\n\t" - "j\tret_from_sys_call" - : /* No outputs */ - : "r" (&cmd)); - /* Unreached */ + return tmp; } case MIPS_FIXADE: ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: A new mips toolchain is available 2001-06-13 15:22 ` Maciej W. Rozycki @ 2001-06-13 15:24 ` H . J . Lu 2001-06-13 15:39 ` Maciej W. Rozycki 0 siblings, 1 reply; 14+ messages in thread From: H . J . Lu @ 2001-06-13 15:24 UTC (permalink / raw) To: Maciej W. Rozycki; +Cc: linux-mips On Wed, Jun 13, 2001 at 05:22:49PM +0200, Maciej W. Rozycki wrote: > On Wed, 13 Jun 2001, H . J . Lu wrote: > > > > What's the problem with the kernel? It works fine for my R3400A > > > DECstation. Glibc is 2.2.3 as released. If there is something wrong, I > > > definitely want to know. > > > > It has something to do with the atomic emulation in kernel for mips I. > > Hmm, I thought Florian's sysmips() fixes went in. Here is a patch I use > successfully for some time. It doesn't work for small negative integers, > but glibc doesn't use them, AFAIK. > > Another possibility is to use the set of two patches for > sys__test_and_set() I've sent here recently. This would break portability > for now, though, if you wanted to distribute glibc or kernel binaries. > This is also the reason I didn't put my current patched version of glibc > on my FTP site. > > The patch is not against a current version of the kernel -- you might > need to apply it manually. > > Maciej > > -- > + Maciej W. Rozycki, Technical University of Gdansk, Poland + > +--------------------------------------------------------------+ > + e-mail: macro@ds2.pg.gda.pl, PGP key available + > > patch-mips-2.4.0-test11-20001211-sysmips-0 I don't have problem with 2.4.0-test11. It is the change in 2.4.3 which breaks glibc. H.J. ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: A new mips toolchain is available 2001-06-13 15:24 ` H . J . Lu @ 2001-06-13 15:39 ` Maciej W. Rozycki 2001-06-13 15:44 ` H . J . Lu 0 siblings, 1 reply; 14+ messages in thread From: Maciej W. Rozycki @ 2001-06-13 15:39 UTC (permalink / raw) To: H . J . Lu; +Cc: linux-mips On Wed, 13 Jun 2001, H . J . Lu wrote: > I don't have problem with 2.4.0-test11. It is the change in 2.4.3 > which breaks glibc. You mean someone changed sysmips() in an incompatible way? Aaarghh... -- + Maciej W. Rozycki, Technical University of Gdansk, Poland + +--------------------------------------------------------------+ + e-mail: macro@ds2.pg.gda.pl, PGP key available + ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: A new mips toolchain is available 2001-06-13 15:39 ` Maciej W. Rozycki @ 2001-06-13 15:44 ` H . J . Lu 2001-06-13 18:48 ` Jun Sun 0 siblings, 1 reply; 14+ messages in thread From: H . J . Lu @ 2001-06-13 15:44 UTC (permalink / raw) To: Maciej W. Rozycki; +Cc: linux-mips On Wed, Jun 13, 2001 at 05:39:08PM +0200, Maciej W. Rozycki wrote: > On Wed, 13 Jun 2001, H . J . Lu wrote: > > > I don't have problem with 2.4.0-test11. It is the change in 2.4.3 > > which breaks glibc. > > You mean someone changed sysmips() in an incompatible way? Aaarghh... I don't remeber the detail, it is eithet kernel crash or glibc crash. I switched to mips II for glibc as the result. H.J. ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: A new mips toolchain is available 2001-06-13 15:44 ` H . J . Lu @ 2001-06-13 18:48 ` Jun Sun 2001-06-13 20:55 ` Harald Koerfgen 0 siblings, 1 reply; 14+ messages in thread From: Jun Sun @ 2001-06-13 18:48 UTC (permalink / raw) To: H . J . Lu; +Cc: Maciej W. Rozycki, linux-mips [-- Attachment #1: Type: text/plain, Size: 1376 bytes --] "H . J . Lu" wrote: > > On Wed, Jun 13, 2001 at 05:39:08PM +0200, Maciej W. Rozycki wrote: > > On Wed, 13 Jun 2001, H . J . Lu wrote: > > > > > I don't have problem with 2.4.0-test11. It is the change in 2.4.3 > > > which breaks glibc. > > > > You mean someone changed sysmips() in an incompatible way? Aaarghh... > > I don't remeber the detail, it is eithet kernel crash or glibc crash. > I switched to mips II for glibc as the result. > > H.J. The latest CVS tree removed MIPS_ATOMIC_SET for CPUs without ll/sc. See the diff below. RCS file: /cvs/linux/arch/mips/kernel/sysmips.c,v retrieving revision 1.17 retrieving revision 1.18 diff -r1.17 -r1.18 77a78 > #ifdef CONFIG_CPU_HAS_LLSC 120a122,124 > #else > printk("sys_sysmips(MIPS_ATOMIC_SET, ...) not ready for !CONFIG_CPU_HAS_LLSC\n"); > #endif However the log says: date: 2001/04/08 13:24:27; author: ralf; state: Exp; lines: +4 -0 Fix ll/sc emulation. Extracted from Linux-VR tree by Harald. It seems that the checkin is a mistake because apparently it is not what linux-vr is doing. They used to have a piece of code for CPUs without ll/sc. And recently they moved to ll/sc instruction emulation. Ralf, the following patch includes the original vr code for MIPS_ATOMIC_SET, no ll/sc case. Although we all know it is buggy (for small negative set values), it is still better than nothing. Jun [-- Attachment #2: junk --] [-- Type: text/plain, Size: 998 bytes --] diff -Nru sysmips.c.orig sysmips.c --- sysmips.c.orig Wed Jun 13 11:32:09 2001 +++ sysmips.c Wed Jun 13 11:46:06 2001 @@ -120,7 +120,23 @@ : "r" (&cmd)); /* Unreached */ #else - printk("sys_sysmips(MIPS_ATOMIC_SET, ...) not ready for !CONFIG_CPU_HAS_LLSC\n"); + /* this is handled in assembly now */ + panic("Unexpected MIPS_ATOMIC_SET call in sys_sysmips()"); +#else + int flags; + + /* without ll/sc, we have a broken code that kind of works */ + /* This is broken in case of page faults and SMP ... + Risc/OS fauls after maximum 20 tries with EAGAIN. */ + p = (int *) arg1; + retval = verify_area(VERIFY_WRITE, p, sizeof(*p)); + if (retval) + goto out; + save_and_cli(flags); + retval = *p; + *p = arg2; + restore_flags(flags); + goto out; #endif } ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: A new mips toolchain is available 2001-06-13 18:48 ` Jun Sun @ 2001-06-13 20:55 ` Harald Koerfgen 2001-06-14 10:26 ` Maciej W. Rozycki 0 siblings, 1 reply; 14+ messages in thread From: Harald Koerfgen @ 2001-06-13 20:55 UTC (permalink / raw) To: Jun Sun, H . J . Lu; +Cc: linux-mips On Wednesday 13 June 2001 20:48, Jun Sun wrote: > The latest CVS tree removed MIPS_ATOMIC_SET for CPUs without ll/sc. See > the diff below. [diff snipped] > It seems that the checkin is a mistake because apparently it is not what > linux-vr is doing. They used to have a piece of code for CPUs without > ll/sc. And recently they moved to ll/sc instruction emulation. Well, you seem to have a different linux-vr tree than I do :-) > Ralf, the following patch includes the original vr code for > MIPS_ATOMIC_SET, no ll/sc case. Although we all know it is buggy (for > small negative set values), it is still better than nothing. Anyway, the linux-vr source tree has a partially working ll/sc emulation, at least enough for glibc, and MIPS_ATOMIC_SET is not neccessarily needed. In fact, MIPS_ATOMIC_SET has been removed from the vr tree. Regards, Harald ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: A new mips toolchain is available 2001-06-13 20:55 ` Harald Koerfgen @ 2001-06-14 10:26 ` Maciej W. Rozycki 0 siblings, 0 replies; 14+ messages in thread From: Maciej W. Rozycki @ 2001-06-14 10:26 UTC (permalink / raw) To: Harald Koerfgen; +Cc: Jun Sun, H . J . Lu, linux-mips On Wed, 13 Jun 2001, Harald Koerfgen wrote: > Anyway, the linux-vr source tree has a partially working ll/sc emulation, at > least enough for glibc, and MIPS_ATOMIC_SET is not neccessarily needed. > In fact, MIPS_ATOMIC_SET has been removed from the vr tree. I suppose we may remove it, too, once we agree on a sane replacement. -- + Maciej W. Rozycki, Technical University of Gdansk, Poland + +--------------------------------------------------------------+ + e-mail: macro@ds2.pg.gda.pl, PGP key available + ^ permalink raw reply [flat|nested] 14+ messages in thread
end of thread, other threads:[~2001-06-14 11:23 UTC | newest] Thread overview: 14+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2001-06-12 4:03 A new mips toolchain is available H . J . Lu 2001-06-12 11:39 ` Ralf Baechle 2001-06-12 16:40 ` H . J . Lu 2001-06-12 19:11 ` Ralf Baechle 2001-06-12 19:38 ` H . J . Lu 2001-06-13 7:57 ` Maciej W. Rozycki 2001-06-13 15:08 ` H . J . Lu 2001-06-13 15:22 ` Maciej W. Rozycki 2001-06-13 15:24 ` H . J . Lu 2001-06-13 15:39 ` Maciej W. Rozycki 2001-06-13 15:44 ` H . J . Lu 2001-06-13 18:48 ` Jun Sun 2001-06-13 20:55 ` Harald Koerfgen 2001-06-14 10:26 ` Maciej W. Rozycki
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox