* OOps - very obscure
@ 2001-01-24 15:30 Florian Lohoff
2001-01-24 15:59 ` Florian Lohoff
0 siblings, 1 reply; 45+ messages in thread
From: Florian Lohoff @ 2001-01-24 15:30 UTC (permalink / raw)
To: linux-mips
Hi,
here a short oops while trying to run "find" in a glibc 2.2 root
on a Indigo2 with a current cvs 2.4.0 kernel.
Unable to handle kernel paging request at virtual address 00000000, epc == 00000000, ra == 00000000
Oops in fault.c:do_page_fault, line 172:
$0 : 00000000 1004fc00 fffffff2 00000001
$4 : fffffff2 00000000 00000001 00000000
$8 : 00000000 2abf3a94 8800f4a0 00000004
$12: 8ec57f10 7ffffaf8 8ec57f18 8ec57f18
$16: 8801acf8 00000000 10011510 00000002
$20: 10011510 7ffffdd4 7ffffdcc 00000001
$24: 00000000 2abf3a80
$28: 8ec56000 8ec57ef8 7ffffd10 00000000
epc : 00000000
Status: 1004fc03
Cause : 30000008
Process find (pid: 227, stackpage=8ec56000)
Stack: 10011510 7ffffd10 88028344 00000000 7ffffc80 00402440 2aca4e00 2ac95d10
00000000 2ac95d10 10011510 00000002 00000001 8800fa88 000007d1 100234f0
10011510 00000000 00000003 00012000 00000000 1004fc01 00001035 00000000
000007d1 10011510 00000001 00000000 0000fc00 00000010 00000000 8ec57f0c
8ec57f10 8ec57f14 8ec57ef8 8ec57efc 2aca4e00 2ac95d10 10011510 00000002
00000001 ...
Call Trace: [<88028344>] [<8800fa88>]
Code: (Bad address in epc)
I cant identify which system.map ist the correct one - -ETOMANYKERNEL
i extracted this from /proc/ksyms
8800ecb8 __rwsem_wake
8801122c do_gettimeofday
88027394 del_timer
8802869c flush_signals
This oops is reproduceable but not really nice as the fsck takes
~30 minutes :)
I'll build a fresh kernel and retry ...
Flo
--
Florian Lohoff flo@rfc822.org +49-5201-669912
Why is it called "common sense" when nobody seems to have any?
^ permalink raw reply [flat|nested] 45+ messages in thread* Re: OOps - very obscure
2001-01-24 15:30 OOps - very obscure Florian Lohoff
@ 2001-01-24 15:59 ` Florian Lohoff
2001-01-24 16:22 ` Florian Lohoff
` (3 more replies)
0 siblings, 4 replies; 45+ messages in thread
From: Florian Lohoff @ 2001-01-24 15:59 UTC (permalink / raw)
To: linux-mips
On Wed, Jan 24, 2001 at 04:30:48PM +0100, Florian Lohoff wrote:
> Hi,
> here a short oops while trying to run "find" in a glibc 2.2 root
> on a Indigo2 with a current cvs 2.4.0 kernel.
>
> Unable to handle kernel paging request at virtual address 00000000, epc == 00000000, ra == 00000000
Decoded this is:
Unable to handle kernel paging request at virtual address 00000000, epc == 00000000, ra == 00000000
$0 : 00000000 1004fc00 fffffff2 00000001
$4 : fffffff2 00000000 00000001 00000000
$8 : 00000000 2abf3a94 8800f4a0 00000004
$12: 8ec09f10 7ffffaf8 8ec09f18 8ec09f18
$16: 8801acf8 00000000 10011510 00000002
$20: 10011510 7ffffdd8 7ffffdcc 00000002
$24: 00000000 2abf3a80
$28: 8ec08000 8ec09ef8 7ffffd10 00000000
epc : 00000000
Using defaults from ksymoops -t elf32-bigmips -a mips:3000
Status: 1004fc03
Cause : 30000008
Process find (pid: 242, stackpage=8ec08000)
Stack: 10011510 7ffffd10 88028344 00000000 7ffffc80 00402440 2aca4e00 2ac95d10
00000000 2ac95d10 10011510 00000002 00000001 8800fa88 000007d1 100235b0
10011510 00000000 00000003 00012000 00000000 1004fc01 00001035 00000000
000007d1 10011510 00000001 00000000 0000fc00 00000010 00000000 8ec09f0c
8ec09f10 8ec09f14 8ec09ef8 8ec09efc 2aca4e00 2ac95d10 10011510 00000002
00000001 ...
Call Trace: [<88028344>] [<8800fa88>]
Code: (Bad address in epc)
Warning (Oops_code): trailing garbage ignored on Code: line
Text: 'Code: (Bad address in epc)'
Garbage: 'ress in epc)'
Warning (Oops_code_values): Code looks like message, not hex digits. No disassembly attempted.
>>RA; 00000000 Before first symbol
>>PC; 00000000 Before first symbol
Trace; 88028344 <sys_nanosleep+190/24c>
Trace; 8800fa88 <stack_done+1c/38>
I guess the "Garbage" stuff has to be fixed in ksymoops
Flo
--
Florian Lohoff flo@rfc822.org +49-5201-669912
Why is it called "common sense" when nobody seems to have any?
^ permalink raw reply [flat|nested] 45+ messages in thread* Re: OOps - very obscure
2001-01-24 15:59 ` Florian Lohoff
@ 2001-01-24 16:22 ` Florian Lohoff
2001-01-24 21:18 ` Keith Owens
` (2 subsequent siblings)
3 siblings, 0 replies; 45+ messages in thread
From: Florian Lohoff @ 2001-01-24 16:22 UTC (permalink / raw)
To: linux-mips
On Wed, Jan 24, 2001 at 04:59:19PM +0100, Florian Lohoff wrote:
> On Wed, Jan 24, 2001 at 04:30:48PM +0100, Florian Lohoff wrote:
> Process find (pid: 242, stackpage=8ec08000)
> Stack: 10011510 7ffffd10 88028344 00000000 7ffffc80 00402440 2aca4e00 2ac95d10
> 00000000 2ac95d10 10011510 00000002 00000001 8800fa88 000007d1 100235b0
> 10011510 00000000 00000003 00012000 00000000 1004fc01 00001035 00000000
> 000007d1 10011510 00000001 00000000 0000fc00 00000010 00000000 8ec09f0c
> 8ec09f10 8ec09f14 8ec09ef8 8ec09efc 2aca4e00 2ac95d10 10011510 00000002
> 00000001 ...
[...]
> >>RA; 00000000 Before first symbol
> >>PC; 00000000 Before first symbol
> Trace; 88028344 <sys_nanosleep+190/24c>
> Trace; 8800fa88 <stack_done+1c/38>
This is the relevant code piece in sys_nanosleep:
88028338: af820000 sw $v0,0($gp)
8802833c: 0e006b70 jal 8801adc0 <schedule_timeout>
88028340: 00642021 addu $a0,$v1,$a0
88028344: 50400028 beqzl $v0,880283e8 <sys_nanosleep+0x234>
88028348: 00001021 move $v0,$zero
8802834c: 12000025 beqz $s0,880283e4 <sys_nanosleep+0x230>
Flo
--
Florian Lohoff flo@rfc822.org +49-5201-669912
Why is it called "common sense" when nobody seems to have any?
^ permalink raw reply [flat|nested] 45+ messages in thread* Re: OOps - very obscure
2001-01-24 15:59 ` Florian Lohoff
2001-01-24 16:22 ` Florian Lohoff
@ 2001-01-24 21:18 ` Keith Owens
2001-01-25 12:43 ` Florian Lohoff
2001-01-25 15:55 ` [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call Florian Lohoff
3 siblings, 0 replies; 45+ messages in thread
From: Keith Owens @ 2001-01-24 21:18 UTC (permalink / raw)
To: Florian Lohoff; +Cc: linux-mips
On Wed, 24 Jan 2001 16:59:19 +0100,
Florian Lohoff <flo@rfc822.org> wrote:
>Code: (Bad address in epc)
>Warning (Oops_code): trailing garbage ignored on Code: line
> Text: 'Code: (Bad address in epc)'
> Garbage: 'ress in epc)'
>Warning (Oops_code_values): Code looks like message, not hex digits. No disassembly attempted.
>I guess the "Garbage" stuff has to be fixed in ksymoops
ksymoops understands "(Bad EIP value.*)", it does not know about "(Bad
address in epc)". I will add it to ksymoops 2.4.1.
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: OOps - very obscure
2001-01-24 15:59 ` Florian Lohoff
2001-01-24 16:22 ` Florian Lohoff
2001-01-24 21:18 ` Keith Owens
@ 2001-01-25 12:43 ` Florian Lohoff
2001-01-25 18:59 ` Jun Sun
2001-01-25 15:55 ` [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call Florian Lohoff
3 siblings, 1 reply; 45+ messages in thread
From: Florian Lohoff @ 2001-01-25 12:43 UTC (permalink / raw)
To: linux-mips
On Wed, Jan 24, 2001 at 04:59:19PM +0100, Florian Lohoff wrote:
> Decoded this is:
> >>RA; 00000000 Before first symbol
> >>PC; 00000000 Before first symbol
> Trace; 88028344 <sys_nanosleep+190/24c>
> Trace; 8800fa88 <stack_done+1c/38>
I am trying to track this down a bit more:
with strace (very old version)
rt_sigaction(34, {SIG_DFL}, NULL, 16) = 0
rt_sigprocmask(SIG_BLOCK, [], NULL, 16) = 0
sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
sched_yield(0x7d1, 0x2ac95d24, 0x1, 0, 0x2acfad50) = 0
sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
sched_yield(0x7d1, 0x2ac95d24, 0x1, 0, 0x2acfad50) = 0
sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
sched_yield(0x7d1, 0x2ac95d24, 0x1, 0, 0x2acfad50) = 0
sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
sched_yield(0x7d1, 0x2ac95d24, 0x1, 0, 0x2acfad50) = 0
sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
[... repeated this 2 lines ...]
Every 1000 lines or something:
nanosleep({0, 2000001}, NULL) = 0
But with strace it doesnt crash it seems at least not within 10 Minutes
i let it run ...
Flo
--
Florian Lohoff flo@rfc822.org +49-5201-669912
Why is it called "common sense" when nobody seems to have any?
^ permalink raw reply [flat|nested] 45+ messages in thread* Re: OOps - very obscure
2001-01-25 12:43 ` Florian Lohoff
@ 2001-01-25 18:59 ` Jun Sun
2001-01-25 19:22 ` Florian Lohoff
0 siblings, 1 reply; 45+ messages in thread
From: Jun Sun @ 2001-01-25 18:59 UTC (permalink / raw)
To: Florian Lohoff; +Cc: linux-mips
Florian,
What is the kernel version? Your symptom seems to remind me the corrupted s0
bug in several syscalls. The bug is fixed around test9 I believe. Check for
"save_static_function(sys_sigsuspend);" statement in arch/mips/kernel/signal.c
file. If you have it, then you don't have the bug.
Jun
Florian Lohoff wrote:
>
> On Wed, Jan 24, 2001 at 04:59:19PM +0100, Florian Lohoff wrote:
>
> > Decoded this is:
>
> > >>RA; 00000000 Before first symbol
> > >>PC; 00000000 Before first symbol
> > Trace; 88028344 <sys_nanosleep+190/24c>
> > Trace; 8800fa88 <stack_done+1c/38>
>
> I am trying to track this down a bit more:
>
> with strace (very old version)
>
> rt_sigaction(34, {SIG_DFL}, NULL, 16) = 0
> rt_sigprocmask(SIG_BLOCK, [], NULL, 16) = 0
> sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
> sched_yield(0x7d1, 0x2ac95d24, 0x1, 0, 0x2acfad50) = 0
> sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
> sched_yield(0x7d1, 0x2ac95d24, 0x1, 0, 0x2acfad50) = 0
> sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
> sched_yield(0x7d1, 0x2ac95d24, 0x1, 0, 0x2acfad50) = 0
> sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
> sched_yield(0x7d1, 0x2ac95d24, 0x1, 0, 0x2acfad50) = 0
> sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
> [... repeated this 2 lines ...]
>
> Every 1000 lines or something:
>
> nanosleep({0, 2000001}, NULL) = 0
>
> But with strace it doesnt crash it seems at least not within 10 Minutes
> i let it run ...
>
> Flo
> --
> Florian Lohoff flo@rfc822.org +49-5201-669912
> Why is it called "common sense" when nobody seems to have any?
^ permalink raw reply [flat|nested] 45+ messages in thread* Re: OOps - very obscure
2001-01-25 18:59 ` Jun Sun
@ 2001-01-25 19:22 ` Florian Lohoff
0 siblings, 0 replies; 45+ messages in thread
From: Florian Lohoff @ 2001-01-25 19:22 UTC (permalink / raw)
To: Jun Sun; +Cc: linux-mips
On Thu, Jan 25, 2001 at 10:59:07AM -0800, Jun Sun wrote:
> Florian,
>
> What is the kernel version? Your symptom seems to remind me the corrupted s0
> bug in several syscalls. The bug is fixed around test9 I believe. Check for
> "save_static_function(sys_sigsuspend);" statement in arch/mips/kernel/signal.c
> file. If you have it, then you don't have the bug.
2.4.0 final - checkout on 20010111
And i have it ...
Flo
--
Florian Lohoff flo@rfc822.org +49-5201-669912
Why is it called "common sense" when nobody seems to have any?
^ permalink raw reply [flat|nested] 45+ messages in thread
* [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-24 15:59 ` Florian Lohoff
` (2 preceding siblings ...)
2001-01-25 12:43 ` Florian Lohoff
@ 2001-01-25 15:55 ` Florian Lohoff
2001-01-25 15:55 ` Florian Lohoff
` (3 more replies)
3 siblings, 4 replies; 45+ messages in thread
From: Florian Lohoff @ 2001-01-25 15:55 UTC (permalink / raw)
To: linux-mips
On Wed, Jan 24, 2001 at 04:59:19PM +0100, Florian Lohoff wrote:
> Decoded this is:
>
> Unable to handle kernel paging request at virtual address 00000000, epc == 00000000, ra == 00000000
> $0 : 00000000 1004fc00 fffffff2 00000001
> $4 : fffffff2 00000000 00000001 00000000
> $8 : 00000000 2abf3a94 8800f4a0 00000004
> $12: 8ec09f10 7ffffaf8 8ec09f18 8ec09f18
> $16: 8801acf8 00000000 10011510 00000002
> $20: 10011510 7ffffdd8 7ffffdcc 00000002
> $24: 00000000 2abf3a80
> $28: 8ec08000 8ec09ef8 7ffffd10 00000000
> epc : 00000000
> Using defaults from ksymoops -t elf32-bigmips -a mips:3000
> Status: 1004fc03
> Cause : 30000008
Ok - another one (sorry to spam you)
>From "handle_sys" i see that system call address and no of
args are in t2 and t3 which are 0x8800f4a0 and 4 with the register
dump above.
8800f4a0 is sys_sysmips which i also saw in the find strace.
>From the strace i find
sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
all the time - 0x7d1 is "MIPS_ATOMIC_SET" - Ok from the trace
i see the call comes from handle_sys which itself would end with
o32_ret_from_sys_call.
sysmips(MIPS_ATOMIC_SET, ...)
would itself return with "ret_from_sys_call".
If i now apply
Index: arch/mips/kernel/sysmips.c
===================================================================
RCS file: /cvs/linux/arch/mips/kernel/sysmips.c,v
retrieving revision 1.15
diff -u -r1.15 sysmips.c
--- arch/mips/kernel/sysmips.c 2000/11/18 01:19:35 1.15
+++ arch/mips/kernel/sysmips.c 2001/01/25 15:48:44
@@ -111,7 +111,7 @@
__asm__ __volatile__(
"move\t$29, %0\n\t"
- "j\tret_from_sys_call"
+ "j\to32_ret_from_sys_call"
: /* No outputs */
: "r" (&cmd));
/* Unreached */
The machine now at least doesnt crash anymore - Others have to decide
if this is correct. (Nevertheless find doesnt return but this might
be a different problem)
Flo
--
Florian Lohoff flo@rfc822.org +49-5201-669912
Why is it called "common sense" when nobody seems to have any?
^ permalink raw reply [flat|nested] 45+ messages in thread* [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-25 15:55 ` [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call Florian Lohoff
@ 2001-01-25 15:55 ` Florian Lohoff
2001-01-25 16:34 ` Origin 200 crash nick
` (2 subsequent siblings)
3 siblings, 0 replies; 45+ messages in thread
From: Florian Lohoff @ 2001-01-25 15:55 UTC (permalink / raw)
To: linux-mips
On Wed, Jan 24, 2001 at 04:59:19PM +0100, Florian Lohoff wrote:
> Decoded this is:
>
> Unable to handle kernel paging request at virtual address 00000000, epc == 00000000, ra == 00000000
> $0 : 00000000 1004fc00 fffffff2 00000001
> $4 : fffffff2 00000000 00000001 00000000
> $8 : 00000000 2abf3a94 8800f4a0 00000004
> $12: 8ec09f10 7ffffaf8 8ec09f18 8ec09f18
> $16: 8801acf8 00000000 10011510 00000002
> $20: 10011510 7ffffdd8 7ffffdcc 00000002
> $24: 00000000 2abf3a80
> $28: 8ec08000 8ec09ef8 7ffffd10 00000000
> epc : 00000000
> Using defaults from ksymoops -t elf32-bigmips -a mips:3000
> Status: 1004fc03
> Cause : 30000008
Ok - another one (sorry to spam you)
From "handle_sys" i see that system call address and no of
args are in t2 and t3 which are 0x8800f4a0 and 4 with the register
dump above.
8800f4a0 is sys_sysmips which i also saw in the find strace.
From the strace i find
sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
all the time - 0x7d1 is "MIPS_ATOMIC_SET" - Ok from the trace
i see the call comes from handle_sys which itself would end with
o32_ret_from_sys_call.
sysmips(MIPS_ATOMIC_SET, ...)
would itself return with "ret_from_sys_call".
If i now apply
Index: arch/mips/kernel/sysmips.c
===================================================================
RCS file: /cvs/linux/arch/mips/kernel/sysmips.c,v
retrieving revision 1.15
diff -u -r1.15 sysmips.c
--- arch/mips/kernel/sysmips.c 2000/11/18 01:19:35 1.15
+++ arch/mips/kernel/sysmips.c 2001/01/25 15:48:44
@@ -111,7 +111,7 @@
__asm__ __volatile__(
"move\t$29, %0\n\t"
- "j\tret_from_sys_call"
+ "j\to32_ret_from_sys_call"
: /* No outputs */
: "r" (&cmd));
/* Unreached */
The machine now at least doesnt crash anymore - Others have to decide
if this is correct. (Nevertheless find doesnt return but this might
be a different problem)
Flo
--
Florian Lohoff flo@rfc822.org +49-5201-669912
Why is it called "common sense" when nobody seems to have any?
^ permalink raw reply [flat|nested] 45+ messages in thread* Origin 200 crash
2001-01-25 15:55 ` [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call Florian Lohoff
2001-01-25 15:55 ` Florian Lohoff
@ 2001-01-25 16:34 ` nick
2001-01-25 18:28 ` [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call Joe deBlaquiere
2001-02-19 13:11 ` strace sysmips support (was: Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call) Wichert Akkerman
3 siblings, 0 replies; 45+ messages in thread
From: nick @ 2001-01-25 16:34 UTC (permalink / raw)
To: linux-mips
When booting any of three different kernels I have found, including a
working one from Bacchus I get this:
>> bootp():
Setting $netaddr to 10.1.1.2 (from server 10.1.1.1)
Obtaining from server 10.1.1.1
1464880+388016+339100 entry: 0xa800000000188000
ARCH: SGI-IP27
PROMLIB: ARC firmware Version 64 Revision 0
Discovered 1 cpus on 1 nodes
Total memory probed : 0x14000 pages
Linux version 2.4.0-test11 (ralf@dbear.engr.sgi.com) (gcc version
egcs-2.91.66 19990314 (egcs-1.1.2 release)) #3 SMP Tue Dec 26 11:0
Loading R10000 MMU routines.
CPU revision is: 00000926
Primary instruction cache 32kb, linesize 64 bytes
Primary data cache 32kb, linesize 32 bytes
Secondary cache sized at 1024K, linesize 128
IP27: Running on node 0.
Node 0 has a primary CPU, CPU is running.
Node 0 has no secondary CPU.
Machine is in M mode.
Cpu 0, Nasid 0x0, pcibr_setup(): found partnum= 0xc002...is bridge
CPU 0 clock is 65535MHz.
On node 0 totalpages: 294912
zone(0): 294912 pages.
zone(1): 0 pages.
zone(2): 0 pages.
Kernel command line: OSLoadOptions=INST
Entering 64-bit mode.
Calibrating delay loop... 179.81 BogoMIPS
Memory: 286120k/327680k available (1430k kernel code, 41560k reserved,
150k data, 208k init)
Dentry-cache hash table entries: 65536 (order: 8, 1048576 bytes)
Buffer-cache hash table entries: 32768 (order: 6, 262144 bytes)
Page-cache hash table entries: 131072 (order: 8, 1048576 bytes)
Inode-cache hash table entries: 32768 (order: 7, 524288 bytes)
Checking for 'wait' instruction... unavailable.
POSIX conformance testing by UNIFIX
REPLICATION: ON nasid 0, ktext from nasid 0, kdata from nasid 0
PCI: Probing PCI hardware on host bus 0.
PCI: Fixing isp1020 in [bus:slot.fn] 00:00.0
PCI: Fixing isp1020 in [bus:slot.fn] 00:01.0
PCI: Fixing base addresses for IOC3 device 00:02.0
PCI: Fixing base addresses for IOC3 device 00:05.0
Linux NET4.0 for Linux 2.4
Based upon Swansea University Computer Society NET3.039
Starting kswapd v1.8
ttyS00 at iomem 0x9200000008620178 (irq = 0) is a 16550ASHARE_IRQ
SERIAL_PCI enabled
ttyS01 at iomem 0x9200000008920178 (irq = 0) is a 16550A
Using PHY 31, vendor 0x20005c0, model 0, rev 1.
eth0: MII transceiver found at MDIO address 31, config 3100 status 786f.
IOC3 SSRAM has 128 kbyte.
Found DS1981U NIC registration number 2a:e8:02:00:70:5e, CRC b9.
Ethernet address is 08:00:69:05:77:36.
Using PHY 31, vendor 0x20005c0, model 0, rev 1.
eth1: MII transceiver found at MDIO address 31, config 3100 status 7849.
IOC3 SSRAM has 128 kbyte.
Found DS1981U NIC registration number 49:d1:01:00:70:5e, CRC dc.
Ethernet address is 08:00:69:05:45:f1.
SCSI subsystem driver Revision: 1.00
qlogicisp : new isp1020 revision ID (5)
qlogicisp : new isp1020 revision ID (5)
scsi0 : QLogic ISP1020 SCSI on PCI bus 00 device 00 irq 4 I/O base
0x8200000
scsi1 : QLogic ISP1020 SCSI on PCI bus 00 device 08 irq 5 I/O base
0x8400000
Got dbe at 0xffffffff8013f43c
Cpu 0
$0 : 0000000000000000 0000000014201ce0 a80000000028d040
a80000000028d000
$4 : a80000000028d080 0000000000000000 0000000000000040
ffffffff801ccc80
$8 : 0000000014201ce1 0000000000000000 0000000000000004
0000000000000000
$12 : 0000000000000000 a80000000028d080 ffffffffffffffff
a80000000028d014
$16 : 0000000000000040 0000000014201ce1 a80000000028d040
0000000000000002
$20 : a800000047ffcc00 a8000000002e8800 0000000000000000
a8000000002e88b8
$24 : 0000000000000040 a8000000002e8800
$28 : a800000003678000 a80000000367bb20 a800000003667c30
ffffffff800ddacc
Hi : 0000000000000000
Lo : 0000000000000040
epc : ffffffff8013f43c
badvaddr: a800000047ffde60
badvaddr: a800000047ffde60
Status : 14201ce2
Cause : 0000901c
Cause : 0000901c
Index: 0 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 1 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 2 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 3 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 4 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 5 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 6 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 7 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 8 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 9 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 10 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 11 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 12 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 13 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 14 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 15 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 16 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 17 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 18 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 19 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 20 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 21 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 22 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 23 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 24 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 25 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 26 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 27 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 28 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 29 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 30 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 31 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 32 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 33 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 34 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 35 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 36 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 37 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 38 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 39 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 40 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 41 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 42 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 43 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 44 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 45 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 46 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 47 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 48 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 49 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 50 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 51 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 52 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 53 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 54 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 55 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 56 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 57 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 58 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 59 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 60 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 61 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 62 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Index: 63 pgmask=00000000 va=c0000fff80000000 asid=00 [pa=000000 c=0 d=0
v=0 g=0] [pa=000000 c=0 d=0 v=0 g=0]
Any suggestions/ideas?
Thanks
Nick
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-25 15:55 ` [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call Florian Lohoff
2001-01-25 15:55 ` Florian Lohoff
2001-01-25 16:34 ` Origin 200 crash nick
@ 2001-01-25 18:28 ` Joe deBlaquiere
2001-01-25 19:35 ` Joe deBlaquiere
2001-02-19 13:11 ` strace sysmips support (was: Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call) Wichert Akkerman
3 siblings, 1 reply; 45+ messages in thread
From: Joe deBlaquiere @ 2001-01-25 18:28 UTC (permalink / raw)
To: Florian Lohoff; +Cc: linux-mips
I'm trying to implement MIPS_ATOMIC_SET for the Vr4181, which has no ll,
sc operations. It looks to me like the function does something like
sysmips(MIPS_ATOMIC_SET,ptr,val)
{
}
Florian Lohoff wrote:
> On Wed, Jan 24, 2001 at 04:59:19PM +0100, Florian Lohoff wrote:
>
>> Decoded this is:
>>
>> Unable to handle kernel paging request at virtual address 00000000, epc == 00000000, ra == 00000000
>> $0 : 00000000 1004fc00 fffffff2 00000001
>> $4 : fffffff2 00000000 00000001 00000000
>> $8 : 00000000 2abf3a94 8800f4a0 00000004
>> $12: 8ec09f10 7ffffaf8 8ec09f18 8ec09f18
>> $16: 8801acf8 00000000 10011510 00000002
>> $20: 10011510 7ffffdd8 7ffffdcc 00000002
>> $24: 00000000 2abf3a80
>> $28: 8ec08000 8ec09ef8 7ffffd10 00000000
>> epc : 00000000
>> Using defaults from ksymoops -t elf32-bigmips -a mips:3000
>> Status: 1004fc03
>> Cause : 30000008
>
>
> Ok - another one (sorry to spam you)
>
>>From "handle_sys" i see that system call address and no of
> args are in t2 and t3 which are 0x8800f4a0 and 4 with the register
> dump above.
>
> 8800f4a0 is sys_sysmips which i also saw in the find strace.
>
>>From the strace i find
>
> sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
>
> all the time - 0x7d1 is "MIPS_ATOMIC_SET" - Ok from the trace
> i see the call comes from handle_sys which itself would end with
> o32_ret_from_sys_call.
>
> sysmips(MIPS_ATOMIC_SET, ...)
>
> would itself return with "ret_from_sys_call".
>
> If i now apply
>
> Index: arch/mips/kernel/sysmips.c
> ===================================================================
> RCS file: /cvs/linux/arch/mips/kernel/sysmips.c,v
> retrieving revision 1.15
> diff -u -r1.15 sysmips.c
> --- arch/mips/kernel/sysmips.c 2000/11/18 01:19:35 1.15
> +++ arch/mips/kernel/sysmips.c 2001/01/25 15:48:44
> @@ -111,7 +111,7 @@
>
> __asm__ __volatile__(
> "move\t$29, %0\n\t"
> - "j\tret_from_sys_call"
> + "j\to32_ret_from_sys_call"
> : /* No outputs */
> : "r" (&cmd));
> /* Unreached */
>
> The machine now at least doesnt crash anymore - Others have to decide
> if this is correct. (Nevertheless find doesnt return but this might
> be a different problem)
>
> Flo
--
Joe deBlaquiere
Red Hat, Inc.
307 Wynn Drive
Huntsville AL, 35805
voice : (256)-704-9200
fax : (256)-837-3839
^ permalink raw reply [flat|nested] 45+ messages in thread* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-25 18:28 ` [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call Joe deBlaquiere
@ 2001-01-25 19:35 ` Joe deBlaquiere
2001-01-25 22:19 ` Ralf Baechle
0 siblings, 1 reply; 45+ messages in thread
From: Joe deBlaquiere @ 2001-01-25 19:35 UTC (permalink / raw)
To: Joe deBlaquiere; +Cc: Florian Lohoff, linux-mips
that didn't make sense, did it... ;o)
what I meant to say is that it works like
sysmips(MIPS_ATOMIC_SET,ptr,val)
{
*ptr = val ;
val 0 ;
}
but it is an atomic operation
if this correct in a pseudo-code sense?
Joe deBlaquiere wrote:
> I'm trying to implement MIPS_ATOMIC_SET for the Vr4181, which has no ll,
> sc operations. It looks to me like the function does something like
>
> sysmips(MIPS_ATOMIC_SET,ptr,val)
> {
>
> }
>
> Florian Lohoff wrote:
>
>> On Wed, Jan 24, 2001 at 04:59:19PM +0100, Florian Lohoff wrote:
>>
>>> Decoded this is:
>>>
>>> Unable to handle kernel paging request at virtual address 00000000,
>>> epc == 00000000, ra == 00000000
>>> $0 : 00000000 1004fc00 fffffff2 00000001
>>> $4 : fffffff2 00000000 00000001 00000000
>>> $8 : 00000000 2abf3a94 8800f4a0 00000004
>>> $12: 8ec09f10 7ffffaf8 8ec09f18 8ec09f18
>>> $16: 8801acf8 00000000 10011510 00000002
>>> $20: 10011510 7ffffdd8 7ffffdcc 00000002
>>> $24: 00000000 2abf3a80
>>> $28: 8ec08000 8ec09ef8 7ffffd10 00000000
>>> epc : 00000000
>>> Using defaults from ksymoops -t elf32-bigmips -a mips:3000
>>> Status: 1004fc03
>>> Cause : 30000008
>>
>>
>>
>> Ok - another one (sorry to spam you)
>>
>>> From "handle_sys" i see that system call address and no of
>>
>> args are in t2 and t3 which are 0x8800f4a0 and 4 with the register
>> dump above.
>>
>> 8800f4a0 is sys_sysmips which i also saw in the find strace.
>>
>>> From the strace i find
>>
>>
>> sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
>>
>> all the time - 0x7d1 is "MIPS_ATOMIC_SET" - Ok from the trace
>> i see the call comes from handle_sys which itself would end with
>> o32_ret_from_sys_call.
>>
>> sysmips(MIPS_ATOMIC_SET, ...)
>> would itself return with "ret_from_sys_call".
>>
>> If i now apply
>>
>> Index: arch/mips/kernel/sysmips.c
>> ===================================================================
>> RCS file: /cvs/linux/arch/mips/kernel/sysmips.c,v
>> retrieving revision 1.15
>> diff -u -r1.15 sysmips.c
>> --- arch/mips/kernel/sysmips.c 2000/11/18 01:19:35 1.15
>> +++ arch/mips/kernel/sysmips.c 2001/01/25 15:48:44
>> @@ -111,7 +111,7 @@
>>
>> __asm__ __volatile__(
>> "move\t$29, %0\n\t"
>> - "j\tret_from_sys_call"
>> + "j\to32_ret_from_sys_call"
>> : /* No outputs */
>> : "r" (&cmd));
>> /* Unreached */
>>
>> The machine now at least doesnt crash anymore - Others have to decide
>> if this is correct. (Nevertheless find doesnt return but this might
>> be a different problem)
>>
>> Flo
--
Joe deBlaquiere
Red Hat, Inc.
307 Wynn Drive
Huntsville AL, 35805
voice : (256)-704-9200
fax : (256)-837-3839
^ permalink raw reply [flat|nested] 45+ messages in thread* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-25 19:35 ` Joe deBlaquiere
@ 2001-01-25 22:19 ` Ralf Baechle
2001-01-26 0:53 ` Joe deBlaquiere
2001-04-04 22:13 ` Florian Lohoff
0 siblings, 2 replies; 45+ messages in thread
From: Ralf Baechle @ 2001-01-25 22:19 UTC (permalink / raw)
To: Joe deBlaquiere; +Cc: Florian Lohoff, linux-mips
On Thu, Jan 25, 2001 at 01:35:23PM -0600, Joe deBlaquiere wrote:
> sysmips(MIPS_ATOMIC_SET,ptr,val)
> {
> *ptr = val ;
> val 0 ;
> }
>
> but it is an atomic operation
>
> if this correct in a pseudo-code sense?
It's more:
sysmips(MIPS_ATOMIC_SET, ptr, val)
{
result = *ptr;
*ptr = val;
return result;
}
Ralf
^ permalink raw reply [flat|nested] 45+ messages in thread* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-25 22:19 ` Ralf Baechle
@ 2001-01-26 0:53 ` Joe deBlaquiere
2001-01-26 10:21 ` Maciej W. Rozycki
2001-01-26 20:01 ` Jun Sun
2001-04-04 22:13 ` Florian Lohoff
1 sibling, 2 replies; 45+ messages in thread
From: Joe deBlaquiere @ 2001-01-26 0:53 UTC (permalink / raw)
To: Ralf Baechle; +Cc: Florian Lohoff, linux-mips
Ralf,
Thanks for the help. I generally consider myself a pseudo-expert on
Linux, but at the same time I'm amazed by how much I learn on a daily basis.
So I've got the following code which seems to work... (I can't use the
ll/sc ops on the Vr41xx since they are not implemeted!)
#ifdef CONFIG_CPU_VR41XX
/* this version is inherently single processor! */
case MIPS_ATOMIC_SET: {
unsigned int tmp;
unsigned long flags;
p = (int *) arg1;
errno = verify_area(VERIFY_WRITE, p, sizeof(*p));
if (errno)
return errno;
errno = 0;
/* the Vr processors can't be SMP, so just lock ints */
save_and_cli(flags);
tmp = *p ;
*p = arg2 ;
restore_flags(flags);
return tmp;
}
#endif
The trailer in the normal call is like :
/* 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 */
Which says "no outputs" although sysmips is specified as
extern int sysmips __P ((__const cmd, __const int arg1,
__const int arg2, __const int arg3));
and the usage of this call in glibc pthreads implies that there should
be a return value. Should I be bypassing the scheduler to return also?
The end goal of this is to make pthreads work on the Vr4181...it's
certainly an interesting task so far...
Ralf Baechle wrote:
> On Thu, Jan 25, 2001 at 01:35:23PM -0600, Joe deBlaquiere wrote:
>
>
>> sysmips(MIPS_ATOMIC_SET,ptr,val)
>> {
>> *ptr = val ;
>> val 0 ;
>> }
>>
>> but it is an atomic operation
>>
>> if this correct in a pseudo-code sense?
>
>
> It's more:
>
> sysmips(MIPS_ATOMIC_SET, ptr, val)
> {
> result = *ptr;
> *ptr = val;
>
> return result;
> }
>
> Ralf
--
Joe deBlaquiere
Red Hat, Inc.
307 Wynn Drive
Huntsville AL, 35805
voice : (256)-704-9200
fax : (256)-837-3839
^ permalink raw reply [flat|nested] 45+ messages in thread* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-26 0:53 ` Joe deBlaquiere
@ 2001-01-26 10:21 ` Maciej W. Rozycki
2001-01-26 15:41 ` Joe deBlaquiere
2001-01-26 21:15 ` Ralf Baechle
2001-01-26 20:01 ` Jun Sun
1 sibling, 2 replies; 45+ messages in thread
From: Maciej W. Rozycki @ 2001-01-26 10:21 UTC (permalink / raw)
To: Ralf Baechle, Joe deBlaquiere; +Cc: Florian Lohoff, linux-mips
On Thu, 25 Jan 2001, Joe deBlaquiere wrote:
> So I've got the following code which seems to work... (I can't use the
> ll/sc ops on the Vr41xx since they are not implemeted!)
>
> #ifdef CONFIG_CPU_VR41XX
You are perfectly correct, with the exception you really want to make it:
#ifndef CONFIG_CPU_HAS_LLSC
as that's the correct option -- just undef it in arch/mips/config.in for
your CPU like it's done for others already.
Shame on me I haven't sent the patch for MIPS_ATMIC_SET for non-ll/sc
processors yet. I have it but it needs a few minor cleanups.
Ralf, BTW, what do you think if we send a segfault on a memory access
violation instead of returning an error? That would make the behaviour of
MIPS_ATMIC_SET consistent for any memory contents. Does anything actually
rely on the function to return an error in such a situation?
Maciej
--
+ Maciej W. Rozycki, Technical University of Gdansk, Poland +
+--------------------------------------------------------------+
+ e-mail: macro@ds2.pg.gda.pl, PGP key available +
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-26 10:21 ` Maciej W. Rozycki
@ 2001-01-26 15:41 ` Joe deBlaquiere
2001-01-26 21:16 ` Ralf Baechle
2001-01-27 7:20 ` Maciej W. Rozycki
2001-01-26 21:15 ` Ralf Baechle
1 sibling, 2 replies; 45+ messages in thread
From: Joe deBlaquiere @ 2001-01-26 15:41 UTC (permalink / raw)
To: Maciej W. Rozycki; +Cc: Ralf Baechle, Florian Lohoff, linux-mips
Ralf gently pointed out that there was the possibility of needing to
fault the page for *p, which couldn't occur with ints off. So here's an
updated version...
#ifndef CONFIG_CPU_HAS_LLSC
/* this version is inherently single processor! */
/* borrowed from Linux-2.4.0-test12 */
/* mlock/munlock added - jadb@redhat.com */
case MIPS_ATOMIC_SET: {
unsigned int tmp;
unsigned int flags;
p = (int *) arg1;
errno = verify_area(VERIFY_WRITE, p, sizeof(*p));
if (errno)
return errno;
errno = 0;
/* need to prevent page faults with ints off */
if (sys_mlock(p,sizeof(*p)) != 0)
{
return -EAGAIN;
}
/* actually _do_ the exchange */
save_and_cli(flags);
errno |= __get_user(tmp, p);
errno |= __put_user(arg2, p);
restore_flags(flags);
/* i don't think sys_munlock can fail here, and */
/* I wouldn't know what to do if it did, so no */
/* reason to pay attention to the return value */
sys_munlock(p,sizeof(*p));
return tmp;
}
#endif
comments anyone?
Joe
Maciej W. Rozycki wrote:
> On Thu, 25 Jan 2001, Joe deBlaquiere wrote:
>
>
>> So I've got the following code which seems to work... (I can't use the
>> ll/sc ops on the Vr41xx since they are not implemeted!)
>>
>> #ifdef CONFIG_CPU_VR41XX
>
>
> You are perfectly correct, with the exception you really want to make it:
>
> #ifndef CONFIG_CPU_HAS_LLSC
>
> as that's the correct option -- just undef it in arch/mips/config.in for
> your CPU like it's done for others already.
>
> Shame on me I haven't sent the patch for MIPS_ATMIC_SET for non-ll/sc
> processors yet. I have it but it needs a few minor cleanups.
>
> Ralf, BTW, what do you think if we send a segfault on a memory access
> violation instead of returning an error? That would make the behaviour of
> MIPS_ATMIC_SET consistent for any memory contents. Does anything actually
> rely on the function to return an error in such a situation?
>
> Maciej
--
Joe deBlaquiere
Red Hat, Inc.
307 Wynn Drive
Huntsville AL, 35805
voice : (256)-704-9200
fax : (256)-837-3839
^ permalink raw reply [flat|nested] 45+ messages in thread* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-26 15:41 ` Joe deBlaquiere
@ 2001-01-26 21:16 ` Ralf Baechle
2001-01-27 7:20 ` Maciej W. Rozycki
1 sibling, 0 replies; 45+ messages in thread
From: Ralf Baechle @ 2001-01-26 21:16 UTC (permalink / raw)
To: Joe deBlaquiere; +Cc: Maciej W. Rozycki, Florian Lohoff, linux-mips
On Fri, Jan 26, 2001 at 09:41:49AM -0600, Joe deBlaquiere wrote:
> sys_munlock(p,sizeof(*p));
>
> comments anyone?
Mlock(2) doesn't nest. So if the page was mlocked before, you just unlocked
it.
Ralf
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-26 15:41 ` Joe deBlaquiere
2001-01-26 21:16 ` Ralf Baechle
@ 2001-01-27 7:20 ` Maciej W. Rozycki
1 sibling, 0 replies; 45+ messages in thread
From: Maciej W. Rozycki @ 2001-01-27 7:20 UTC (permalink / raw)
To: Joe deBlaquiere; +Cc: Ralf Baechle, Florian Lohoff, linux-mips
On Fri, 26 Jan 2001, Joe deBlaquiere wrote:
> Ralf gently pointed out that there was the possibility of needing to
> fault the page for *p, which couldn't occur with ints off. So here's an
> updated version...
I don't think you get a page fault that would lead to an inconsistent
state. See below:
> /* actually _do_ the exchange */
> save_and_cli(flags);
> errno |= __get_user(tmp, p);
You may get a page fault on accessing *p here. Not a problem. When we
return to the faulting "lw" instruction, it will fetch the current value
of *p whether it changed before or not. Also the TLB will get filled here
if needed.
> errno |= __put_user(arg2, p);
You may get a page fault on accessing *p here. But since interrupts are
disabled since getting back from the page fault at the above "lw"
instruction, no context switch could have happened, so the page *p lies on
is already swapped in. So the only reason of the fault might be write
protection (read protection was already checked by the fault above). In
this case we don't care if *p changed meanwhile as we won't write it
anyway. TLB got already filled above so no TLB fault will happen.
> restore_flags(flags);
Remember we are running UP.
If anyone sees any other page fault scenario I would be pleased to read
it.
Maciej
--
+ Maciej W. Rozycki, Technical University of Gdansk, Poland +
+--------------------------------------------------------------+
+ e-mail: macro@ds2.pg.gda.pl, PGP key available +
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-26 10:21 ` Maciej W. Rozycki
2001-01-26 15:41 ` Joe deBlaquiere
@ 2001-01-26 21:15 ` Ralf Baechle
2001-01-27 7:28 ` Maciej W. Rozycki
1 sibling, 1 reply; 45+ messages in thread
From: Ralf Baechle @ 2001-01-26 21:15 UTC (permalink / raw)
To: Maciej W. Rozycki; +Cc: Joe deBlaquiere, Florian Lohoff, linux-mips
On Fri, Jan 26, 2001 at 11:21:43AM +0100, Maciej W. Rozycki wrote:
> Ralf, BTW, what do you think if we send a segfault on a memory access
> violation instead of returning an error? That would make the behaviour of
> MIPS_ATMIC_SET consistent for any memory contents. Does anything actually
> rely on the function to return an error in such a situation?
Afaik the only user of MIPS_ATOMIC_SET ever running on Linux/MIPS is the
Linuxthreads code you wrote, so no. Aside of that the semantics of this
syscall were defined by older MIPS operating systems such as Risc/OS and
I think we should follow their example.
Ralf
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-26 21:15 ` Ralf Baechle
@ 2001-01-27 7:28 ` Maciej W. Rozycki
2001-01-27 19:42 ` Ralf Baechle
0 siblings, 1 reply; 45+ messages in thread
From: Maciej W. Rozycki @ 2001-01-27 7:28 UTC (permalink / raw)
To: Ralf Baechle; +Cc: Joe deBlaquiere, Florian Lohoff, linux-mips
On Fri, 26 Jan 2001, Ralf Baechle wrote:
> Afaik the only user of MIPS_ATOMIC_SET ever running on Linux/MIPS is the
> Linuxthreads code you wrote, so no. Aside of that the semantics of this
> syscall were defined by older MIPS operating systems such as Risc/OS and
> I think we should follow their example.
I still haven't seen a definite spec for the call. Since you suggest the
Linuxthreads code is the only user of the code (also remember the
_test_and_set library function as specified by the ABI), we might abandon
MIPS_ATOMIC_SET and write a _test_and_set syscall instead. No
compatibility issues would be involved and the definition is clear in the
ABI (the library function would become a simple wrapper).
I'm still uncertain if wasting a syscall number is that great idea, but
we would be free from any compatibility problems. And yes, I still think
an ll/sc emulation could be done independently anyway.
Maciej
--
+ Maciej W. Rozycki, Technical University of Gdansk, Poland +
+--------------------------------------------------------------+
+ e-mail: macro@ds2.pg.gda.pl, PGP key available +
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-27 7:28 ` Maciej W. Rozycki
@ 2001-01-27 19:42 ` Ralf Baechle
2001-01-29 15:03 ` Maciej W. Rozycki
0 siblings, 1 reply; 45+ messages in thread
From: Ralf Baechle @ 2001-01-27 19:42 UTC (permalink / raw)
To: Maciej W. Rozycki; +Cc: Joe deBlaquiere, Florian Lohoff, linux-mips
On Sat, Jan 27, 2001 at 08:28:05AM +0100, Maciej W. Rozycki wrote:
> > Afaik the only user of MIPS_ATOMIC_SET ever running on Linux/MIPS is the
> > Linuxthreads code you wrote, so no. Aside of that the semantics of this
> > syscall were defined by older MIPS operating systems such as Risc/OS and
> > I think we should follow their example.
>
> I still haven't seen a definite spec for the call.
Sorry, the specs is code and docs I have access to here inside SGI and which
I cannot pass on ...
> Since you suggest the Linuxthreads code is the only user of the code
> (also remember the _test_and_set library function as specified by the ABI),
> we might abandon MIPS_ATOMIC_SET and write a _test_and_set syscall
> instead. No compatibility issues would be involved and the definition is
> clear in the ABI (the library function would become a simple wrapper).
We have an IRIX 5 emulation and if I remember right for IRIX 5
MIPS_ATOMIC_SET is still supported, so we need to also. So I fear we'll
have to keep sysmips. Which still doesn't mean we should come up with
something better.
> I'm still uncertain if wasting a syscall number is that great idea, but
> we would be free from any compatibility problems. And yes, I still think
> an ll/sc emulation could be done independently anyway.
Ralf
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-27 19:42 ` Ralf Baechle
@ 2001-01-29 15:03 ` Maciej W. Rozycki
0 siblings, 0 replies; 45+ messages in thread
From: Maciej W. Rozycki @ 2001-01-29 15:03 UTC (permalink / raw)
To: Ralf Baechle; +Cc: Joe deBlaquiere, Florian Lohoff, linux-mips
On Sat, 27 Jan 2001, Ralf Baechle wrote:
> Sorry, the specs is code and docs I have access to here inside SGI and which
> I cannot pass on ...
Hmm, weird -- I thought a manual page would be available somewhere, as
it's practised in Unix. Error conditions is what would be most
interesting.
> We have an IRIX 5 emulation and if I remember right for IRIX 5
> MIPS_ATOMIC_SET is still supported, so we need to also. So I fear we'll
> have to keep sysmips. Which still doesn't mean we should come up with
> something better.
OK, then, but still we should do it properly, even for MIPS1.
--
+ Maciej W. Rozycki, Technical University of Gdansk, Poland +
+--------------------------------------------------------------+
+ e-mail: macro@ds2.pg.gda.pl, PGP key available +
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-26 0:53 ` Joe deBlaquiere
2001-01-26 10:21 ` Maciej W. Rozycki
@ 2001-01-26 20:01 ` Jun Sun
2001-01-26 20:38 ` Joe deBlaquiere
1 sibling, 1 reply; 45+ messages in thread
From: Jun Sun @ 2001-01-26 20:01 UTC (permalink / raw)
To: Joe deBlaquiere; +Cc: Ralf Baechle, Florian Lohoff, linux-mips
On Thu, Jan 25, 2001 at 06:53:44PM -0600, Joe deBlaquiere wrote:
>
> The end goal of this is to make pthreads work on the Vr4181...it's
> certainly an interesting task so far...
>
We have got pthreads working on Vr4181 for a couple of months already.
What version of kernel are you using? The toughest problem is not
MIPS_AUTOMIC_SET. It is a kernel s0 register corruption bug, which is
already fixed in the current CVS tree.
Jun
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-26 20:01 ` Jun Sun
@ 2001-01-26 20:38 ` Joe deBlaquiere
2001-01-26 21:02 ` Jun Sun
0 siblings, 1 reply; 45+ messages in thread
From: Joe deBlaquiere @ 2001-01-26 20:38 UTC (permalink / raw)
To: Jun Sun; +Cc: Ralf Baechle, Florian Lohoff, linux-mips
Jun Sun wrote:
> On Thu, Jan 25, 2001 at 06:53:44PM -0600, Joe deBlaquiere wrote:
>
>> The end goal of this is to make pthreads work on the Vr4181...it's
>> certainly an interesting task so far...
>>
>
>
> We have got pthreads working on Vr4181 for a couple of months already.
> What version of kernel are you using? The toughest problem is not
> MIPS_AUTOMIC_SET. It is a kernel s0 register corruption bug, which is
> already fixed in the current CVS tree.
>
which current CVS tree, the linuxvr tree?
what is the s0 register corruption bug?
> Jun
--
Joe
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-26 20:38 ` Joe deBlaquiere
@ 2001-01-26 21:02 ` Jun Sun
0 siblings, 0 replies; 45+ messages in thread
From: Jun Sun @ 2001-01-26 21:02 UTC (permalink / raw)
To: Joe deBlaquiere; +Cc: linux-mips
On Fri, Jan 26, 2001 at 02:38:15PM -0600, Joe deBlaquiere wrote:
>
> Jun Sun wrote:
>
> > On Thu, Jan 25, 2001 at 06:53:44PM -0600, Joe deBlaquiere wrote:
> >
> >> The end goal of this is to make pthreads work on the Vr4181...it's
> >> certainly an interesting task so far...
> >>
> >
> >
> > We have got pthreads working on Vr4181 for a couple of months already.
> > What version of kernel are you using? The toughest problem is not
> > MIPS_AUTOMIC_SET. It is a kernel s0 register corruption bug, which is
> > already fixed in the current CVS tree.
> >
>
> which current CVS tree, the linuxvr tree?
>
What do you think "CVS tree" is on an oss.sgi.com mailing list? :-0
> what is the s0 register corruption bug?
>
Check back with the mailing list archive. There was a thread about this.
Basically, the s0 register can be corrupted during a few syscalls.
pthread_create() uses one of the syscalls and thus fails even though the
new thread is actually created.
Jun
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call
2001-01-25 22:19 ` Ralf Baechle
2001-01-26 0:53 ` Joe deBlaquiere
@ 2001-04-04 22:13 ` Florian Lohoff
1 sibling, 0 replies; 45+ messages in thread
From: Florian Lohoff @ 2001-04-04 22:13 UTC (permalink / raw)
To: Ralf Baechle; +Cc: linux-mips
On Thu, Jan 25, 2001 at 02:19:52PM -0800, Ralf Baechle wrote:
> It's more:
>
> sysmips(MIPS_ATOMIC_SET, ptr, val)
> {
> result = *ptr;
> *ptr = val;
>
> return result;
> }
If thats the case - shouldnt the attached patch fix the sysmips stuff ?
I stumbled once again over sysmips - To get a MIPS ISA I compatible
glibc 2.2.2 you need to compile it with sysmips(MIPS_ATOMIC_SET, ...)
which breaks badly with "Illegal Instruction" on current cvs kernels.
Index: arch/mips/kernel/sysmips.c
===================================================================
RCS file: /cvs/linux/arch/mips/kernel/sysmips.c,v
retrieving revision 1.17
diff -u -r1.17 sysmips.c
--- arch/mips/kernel/sysmips.c 2001/02/09 21:05:46 1.17
+++ arch/mips/kernel/sysmips.c 2001/04/04 22:09:18
@@ -75,7 +75,6 @@
}
case MIPS_ATOMIC_SET: {
- unsigned int tmp;
p = (int *) arg1;
errno = verify_area(VERIFY_WRITE, p, sizeof(*p));
@@ -98,7 +97,7 @@
".word\t1b, 3b\n\t"
".word\t2b, 3b\n\t"
".previous\n\t"
- : "=&r" (tmp), "=o" (* (u32 *) p), "=r" (errno)
+ : "=&r" (retval), "=o" (* (u32 *) p), "=r" (errno)
: "r" (arg2), "o" (* (u32 *) p), "2" (errno)
: "$1");
@@ -109,15 +108,7 @@
if (current->ptrace & PT_TRACESYS)
syscall_trace();
- ((struct pt_regs *)&cmd)->regs[2] = tmp;
- ((struct pt_regs *)&cmd)->regs[7] = 0;
-
- __asm__ __volatile__(
- "move\t$29, %0\n\t"
- "j\to32_ret_from_sys_call"
- : /* No outputs */
- : "r" (&cmd));
- /* Unreached */
+ goto out;
}
case MIPS_FIXADE:
What makes me wonder is that we try to return -EFAULT and stuff
which then limits the values for MIPS_ATOMIC_SET to positive ints.
I dont think this is correct.
Comments ?
Flo
--
Florian Lohoff flo@rfc822.org +49-5201-669912
Why is it called "common sense" when nobody seems to have any?
^ permalink raw reply [flat|nested] 45+ messages in thread
* strace sysmips support (was: Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call)
2001-01-25 15:55 ` [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call Florian Lohoff
` (2 preceding siblings ...)
2001-01-25 18:28 ` [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call Joe deBlaquiere
@ 2001-02-19 13:11 ` Wichert Akkerman
2001-02-19 19:52 ` newbie question Can Altineller
2001-02-20 20:41 ` strace sysmips support (was: Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call) Ralf Baechle
3 siblings, 2 replies; 45+ messages in thread
From: Wichert Akkerman @ 2001-02-19 13:11 UTC (permalink / raw)
To: linux-mips
Previously Florian Lohoff wrote:
> From the strace i find
>
> sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
FWIW, I've just put code in strace CVS to decode this properly. Looking
in my (stock Linus) kerneltree I noticed the sys_sysmips code assumes
it can get away with converting an int to a char*, which seems like a
wrong assumption to me..
I don't have my indy up and running at the moment, so the code is
completely untested. Feedback is welcomed :)
Wichert.
--
_________________________________________________________________
/ Nothing is fool-proof to a sufficiently talented fool \
| wichert@cistron.nl http://www.liacs.nl/~wichert/ |
| 1024D/2FA3BC2D 576E 100B 518D 2F16 36B0 2805 3CB8 9250 2FA3 BC2D |
^ permalink raw reply [flat|nested] 45+ messages in thread* newbie question.
2001-02-19 13:11 ` strace sysmips support (was: Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call) Wichert Akkerman
@ 2001-02-19 19:52 ` Can Altineller
2001-02-20 7:06 ` David Jez
2001-02-20 20:41 ` strace sysmips support (was: Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call) Ralf Baechle
1 sibling, 1 reply; 45+ messages in thread
From: Can Altineller @ 2001-02-19 19:52 UTC (permalink / raw)
To: linux-mips
Hello;
I got an Indy 4600SC with 64Megs of memory, and I dont feel like
running Irix on it. What is the status of the sgi port port of linux. Is
there a distro available? Also, I dont have a floppy in my indy, so can I
net boot? If someone point me out in the correct way, I will be very
happy.
Thanks.
-C.A.
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: newbie question.
2001-02-19 19:52 ` newbie question Can Altineller
@ 2001-02-20 7:06 ` David Jez
2001-02-20 20:26 ` Mike McDonald
0 siblings, 1 reply; 45+ messages in thread
From: David Jez @ 2001-02-20 7:06 UTC (permalink / raw)
To: Can Altineller; +Cc: linux-mips
On Mon, Feb 19, 2001 at 02:52:10PM -0500, Can Altineller wrote:
>
> Hello;
>
> I got an Indy 4600SC with 64Megs of memory, and I dont feel like
> running Irix on it. What is the status of the sgi port port of linux. Is
> there a distro available? Also, I dont have a floppy in my indy, so can I
> net boot? If someone point me out in the correct way, I will be very
> happy.
Hi,
Try download doc & faqs & tutorials & distro from:
ftp://ftp.oss.sgi.com/pub/linux/mips
or RedHat from:
ftp://ftp.oss.sgi.com/pub/linux/mips/redhat
PS: Don't worry about instalation. In directory redhat you can find Getting
started and README. Read it carefully. If you search archive of this conf. you
can find thread about netbooting Indy ( bootp():/vmlinuz ) from PROM monitor
and setting bootpd in linux boot server.
>
> Thanks.
> -C.A.
>
>
Best Regards,
Dave
--
-------------------------------------------------------
David "Dave" Jez Brno, CZ, Europe
E-mail: dave.jez@seznam.cz
PGP key: finger xjezda00@fest.stud.fee.vutbr.cz
---------=[ ~EOF ]=------------------------------------
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: newbie question.
2001-02-20 7:06 ` David Jez
@ 2001-02-20 20:26 ` Mike McDonald
2001-02-20 20:30 ` nick
2001-02-20 20:53 ` Ralf Baechle
0 siblings, 2 replies; 45+ messages in thread
From: Mike McDonald @ 2001-02-20 20:26 UTC (permalink / raw)
To: David Jez; +Cc: Can Altineller, linux-mips
>Date: Tue, 20 Feb 2001 08:06:10 +0100
>From: David Jez <dave.jez@seznam.cz>
>To: Can Altineller <altine@ee.fit.edu>
>Subject: Re: newbie question.
>
>On Mon, Feb 19, 2001 at 02:52:10PM -0500, Can Altineller wrote:
>>
>> Hello;
>>
>> I got an Indy 4600SC with 64Megs of memory, and I dont feel like
>> running Irix on it. What is the status of the sgi port port of linux. Is
>> there a distro available? Also, I dont have a floppy in my indy, so can I
>> net boot? If someone point me out in the correct way, I will be very
>> happy.
>Hi,
>
>Try download doc & faqs & tutorials & distro from:
>
>ftp://ftp.oss.sgi.com/pub/linux/mips
Actually, it's ftp://oss.sgi.com/pub/linux/mips but I can't find any
FAQs or tutorials there. http://oss.sgi.com/mips/ has some more info.
(I've heard there's a FAQ someplace but I've never found it.)
Mike McDonald
mikemac@mikemac.com
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: newbie question.
2001-02-20 20:26 ` Mike McDonald
@ 2001-02-20 20:30 ` nick
2001-02-20 20:53 ` Ralf Baechle
1 sibling, 0 replies; 45+ messages in thread
From: nick @ 2001-02-20 20:30 UTC (permalink / raw)
To: Mike McDonald; +Cc: David Jez, Can Altineller, linux-mips
www.foobazco.org is the faq I have used.
Nick
On Tue, 20 Feb 2001, Mike McDonald wrote:
>
> >Date: Tue, 20 Feb 2001 08:06:10 +0100
> >From: David Jez <dave.jez@seznam.cz>
> >To: Can Altineller <altine@ee.fit.edu>
> >Subject: Re: newbie question.
> >
> >On Mon, Feb 19, 2001 at 02:52:10PM -0500, Can Altineller wrote:
> >>
> >> Hello;
> >>
> >> I got an Indy 4600SC with 64Megs of memory, and I dont feel like
> >> running Irix on it. What is the status of the sgi port port of linux. Is
> >> there a distro available? Also, I dont have a floppy in my indy, so can I
> >> net boot? If someone point me out in the correct way, I will be very
> >> happy.
> >Hi,
> >
> >Try download doc & faqs & tutorials & distro from:
> >
> >ftp://ftp.oss.sgi.com/pub/linux/mips
>
> Actually, it's ftp://oss.sgi.com/pub/linux/mips but I can't find any
> FAQs or tutorials there. http://oss.sgi.com/mips/ has some more info.
> (I've heard there's a FAQ someplace but I've never found it.)
>
>
> Mike McDonald
> mikemac@mikemac.com
>
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: newbie question.
2001-02-20 20:26 ` Mike McDonald
2001-02-20 20:30 ` nick
@ 2001-02-20 20:53 ` Ralf Baechle
1 sibling, 0 replies; 45+ messages in thread
From: Ralf Baechle @ 2001-02-20 20:53 UTC (permalink / raw)
To: Mike McDonald; +Cc: David Jez, Can Altineller, linux-mips
On Tue, Feb 20, 2001 at 12:26:11PM -0800, Mike McDonald wrote:
> Actually, it's ftp://oss.sgi.com/pub/linux/mips but I can't find any
> FAQs or tutorials there. http://oss.sgi.com/mips/ has some more info.
> (I've heard there's a FAQ someplace but I've never found it.)
Write 100 times: http://oss.sgi.com/mips/mips-howto.html ;-)
Ralf
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: strace sysmips support (was: Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call)
2001-02-19 13:11 ` strace sysmips support (was: Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call) Wichert Akkerman
2001-02-19 19:52 ` newbie question Can Altineller
@ 2001-02-20 20:41 ` Ralf Baechle
1 sibling, 0 replies; 45+ messages in thread
From: Ralf Baechle @ 2001-02-20 20:41 UTC (permalink / raw)
To: linux-mips
On Mon, Feb 19, 2001 at 02:11:30PM +0100, Wichert Akkerman wrote:
> > sysmips(0x7d1, 0x2ac95d24, 0x1, 0) = 4149
>
> FWIW, I've just put code in strace CVS to decode this properly. Looking
> in my (stock Linus) kerneltree I noticed the sys_sysmips code assumes
> it can get away with converting an int to a char*, which seems like a
> wrong assumption to me..
>
> I don't have my indy up and running at the moment, so the code is
> completely untested. Feedback is welcomed :)
Some versions of the kernel were simply not return anything usefull, so
the the value in $v0 stayed unchanged; 4149 is the syscall number of
sysmips(2).
Ralf
^ permalink raw reply [flat|nested] 45+ messages in thread
* Newbie question...
@ 2001-06-13 13:59 Bartosch Pixa
2001-06-13 15:07 ` Mat Withers
2001-06-13 15:14 ` Keith M Wesolowski
0 siblings, 2 replies; 45+ messages in thread
From: Bartosch Pixa @ 2001-06-13 13:59 UTC (permalink / raw)
To: linux-mips
Hi
i'm quite new to the mips architecture so sorry if i ask dumb/useless
questions. i just bought a used Octane (IP30 R10K ...) and now i'm
curious if it's possible to get linux on it ;)
Any help/hints apreciated
Thx in advance
Bartosch Pixa
--
Bartosch Pixa, bartosch.pixa@infopark.de
Infopark AG
Kitzingstr. 15, D-12277 Berlin, Germany
Tel +49(0)-30-747.993.0, Fax +49(0)-30-747.993.93
http://www.infopark.de/
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: Newbie question...
2001-06-13 13:59 Newbie question Bartosch Pixa
@ 2001-06-13 15:07 ` Mat Withers
2001-06-13 15:22 ` Keith M Wesolowski
2001-06-13 15:14 ` Keith M Wesolowski
1 sibling, 1 reply; 45+ messages in thread
From: Mat Withers @ 2001-06-13 15:07 UTC (permalink / raw)
To: linux-mips
Bartosch Pixa (bartosch.pixa@infopark.de) wrote:
> Hi
>
> i'm quite new to the mips architecture so sorry if i ask dumb/useless
> questions. i just bought a used Octane (IP30 R10K ...) and now i'm
> curious if it's possible to get linux on it ;)
> Any help/hints apreciated
>
>
> Thx in advance
>
> Bartosch Pixa
>
> --
> Bartosch Pixa, bartosch.pixa@infopark.de
> Infopark AG
> Kitzingstr. 15, D-12277 Berlin, Germany
> Tel +49(0)-30-747.993.0, Fax +49(0)-30-747.993.93
> http://www.infopark.de/
>
>
>
I'm also quite interested in mips linux - I've got an Indigo 2 R4400SC with 128 Mb RAM sitting under my desk at home doing nothing. Is this a reasonable platform to run ? I understand that I would have to use a serial console at the moment - are there any plans to support a text console on the Indigo 2 gfx hardware (I don't really care about X). How easy is the install ?
Any info would be gratefully received
Cheers
Mat
--
Mat Withers
mat@minus-9.com
http://minus-9.com
phone: +44 7092 019849
"a sarcasm detector, *that's* a real useful invention."
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: Newbie question...
2001-06-13 15:07 ` Mat Withers
@ 2001-06-13 15:22 ` Keith M Wesolowski
0 siblings, 0 replies; 45+ messages in thread
From: Keith M Wesolowski @ 2001-06-13 15:22 UTC (permalink / raw)
To: Mat Withers; +Cc: linux-mips
On Wed, Jun 13, 2001 at 04:07:45PM +0100, Mat Withers wrote:
> I'm also quite interested in mips linux - I've got an Indigo 2
> R4400SC with 128 Mb RAM sitting under my desk at home doing nothing.
> Is this a reasonable platform to run ? I understand that I would
> have to use a serial console at the moment - are there any plans to
> support a text console on the Indigo 2 gfx hardware (I don't really
> care about X). How easy is the install ?
As the FAQ states, this box should work fine. Graphics hardware will
be supported when documentation is available or someone manages to
reverse-engineer it. Perhaps you'd like to volunteer?
The install is a trivial matter for experienced hackers, an annoyance
to people who've never strayed outside the chartered bounds of
commercial Linux on peecees, and a source of unending pain and grief
for newbies. Unfortunately it's getting easier all the time.
--
Keith M Wesolowski <wesolows@foobazco.org> http://foobazco.org/~wesolows
------(( Project Foobazco Coordinator and Network Administrator ))------
"Nothing motivates a man more than to see his boss put
in an honest day's work." -- The fortune file
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: Newbie question...
2001-06-13 13:59 Newbie question Bartosch Pixa
2001-06-13 15:07 ` Mat Withers
@ 2001-06-13 15:14 ` Keith M Wesolowski
2001-06-13 21:50 ` mjpento
1 sibling, 1 reply; 45+ messages in thread
From: Keith M Wesolowski @ 2001-06-13 15:14 UTC (permalink / raw)
To: Bartosch Pixa; +Cc: linux-mips
On Wed, Jun 13, 2001 at 03:59:26PM +0200, Bartosch Pixa wrote:
> i'm quite new to the mips architecture so sorry if i ask dumb/useless
> questions. i just bought a used Octane (IP30 R10K ...) and now i'm
> curious if it's possible to get linux on it ;)
Not at this time, though a few people have started to look at it. If
you have irix headers and an ability to mangle the kernel for the
better you should probably coordinate with Ralf and get started. IP30
is not very different from IP27, so the port should not be excessively
difficult.
--
Keith M Wesolowski <wesolows@foobazco.org> http://foobazco.org/~wesolows
------(( Project Foobazco Coordinator and Network Administrator ))------
"Nothing motivates a man more than to see his boss put
in an honest day's work." -- The fortune file
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: Newbie question...
2001-06-13 15:14 ` Keith M Wesolowski
@ 2001-06-13 21:50 ` mjpento
2001-06-15 12:12 ` Florian Lohoff
2001-06-15 13:31 ` Jan-Benedict Glaw
0 siblings, 2 replies; 45+ messages in thread
From: mjpento @ 2001-06-13 21:50 UTC (permalink / raw)
To: Keith M Wesolowski; +Cc: linux-mips
Hello folks,
I am actually inquiring on a similar note. I have an Indigo
R3000 under my desk that is collecting dust. Firstly, I would like to
port a linux kernel to this system. I am sort of a newbie to porting
os's. So, I have a few questions that I would like to ask:
1. Is there someone out there working on a port to the R3000's
Indigo's? If so, does someone know who it is or a link to a
website??? etc ...
2. Since I am rather new to porting, is there a resource that you
folks would suggest out there on the internet that would be a good
starting point for information or tips on the best porting methods?
Any help would be greatly appreciated,
Mike
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: Newbie question...
2001-06-13 21:50 ` mjpento
@ 2001-06-15 12:12 ` Florian Lohoff
2001-06-15 13:31 ` Jan-Benedict Glaw
1 sibling, 0 replies; 45+ messages in thread
From: Florian Lohoff @ 2001-06-15 12:12 UTC (permalink / raw)
To: mjpento; +Cc: Keith M Wesolowski, linux-mips
On Wed, Jun 13, 2001 at 05:50:06PM -0400, mjpento wrote:
> Hello folks,
>
> I am actually inquiring on a similar note. I have an Indigo
> R3000 under my desk that is collecting dust. Firstly, I would like to
> port a linux kernel to this system. I am sort of a newbie to porting
> os's. So, I have a few questions that I would like to ask:
>
> 1. Is there someone out there working on a port to the R3000's
> Indigo's? If so, does someone know who it is or a link to a
> website??? etc ...
>
> 2. Since I am rather new to porting, is there a resource that you
> folks would suggest out there on the internet that would be a good
> starting point for information or tips on the best porting methods?
R3000 is no problem - The Indigo (1 IP12 ?) is the problem - Its mostly
undocumented and i havent heard of anyone trying to do something about it.
Flo
--
Florian Lohoff flo@rfc822.org +49-5201-669912
Why is it called "common sense" when nobody seems to have any?
^ permalink raw reply [flat|nested] 45+ messages in thread* Re: Newbie question...
2001-06-13 21:50 ` mjpento
2001-06-15 12:12 ` Florian Lohoff
@ 2001-06-15 13:31 ` Jan-Benedict Glaw
1 sibling, 0 replies; 45+ messages in thread
From: Jan-Benedict Glaw @ 2001-06-15 13:31 UTC (permalink / raw)
To: linux-mips
[-- Attachment #1: Type: text/plain, Size: 1892 bytes --]
On Wed, Jun 13, 2001 at 05:50:06PM -0400, mjpento wrote:
[Indigo R3000]
> 1. Is there someone out there working on a port to the R3000's
> Indigo's? If so, does someone know who it is or a link to a
> website??? etc ...
Rumor was that Michael Engel was working on the Indigo. I've got
such a beast as well (okay, it's an OEM version build by Siemens
Nixdorf), but there's no Linux running on this box these days.
From what I've heared, the Indigo R3k is quite different to most
other supported machines (Indy, Indigo2) so a port will be
somewhat difficult. The machine isn't the fastest one (well,
mine is running wirh Irix 5.2 and the flight simulator is quite nice
to play with:-), but it *would* be more then fast enough to run
Linux.
> 2. Since I am rather new to porting, is there a resource that you
> folks would suggest out there on the internet that would be a good
> starting point for information or tips on the best porting methods?
Porting Linux to Indigo R3k is difficult. There seems to be no
hardware documentation available (except Irix header files). So
porting will be a means of reading header files, using an oscilloscope
and disassembline Irix' kernel.
> Any help would be greatly appreciated,
I'd really *love* to see Linux running on Indigo R3k, but I'm not
experienced enough to do the port. However, I'd like to help and
cooperate with more experienced programmers to make it running, but
they're more or less fixed to their bigger^Wfaster machines...
Michael, have you had any success with your Indigo R3k?
MfG, JBG
--
Fehler eingestehen, Größe zeigen: Nehmt die Rechtschreibreform zurück!!!
/* Jan-Benedict Glaw <jbglaw@lug-owl.de> -- +49-172-7608481 */
keyID=0x8399E1BB fingerprint=250D 3BCF 7127 0D8C A444 A961 1DBD 5E75 8399 E1BB
"insmod vi.o and there we go..." (Alexander Viro on linux-kernel)
[-- Attachment #2: Type: application/pgp-signature, Size: 240 bytes --]
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: Newbie question...
@ 2001-06-13 15:43 Bartosch Pixa
0 siblings, 0 replies; 45+ messages in thread
From: Bartosch Pixa @ 2001-06-13 15:43 UTC (permalink / raw)
To: linux-mips
Julien wrote:
>
> Hi...
>
> If I remember well, currently r10k are only supported on ip22 boards
> (O2, etc)... I'm quite pessimistic for your Octane (in the immediate
> futur). Are you looking for Linux to use it as a full featured os ?
> linux-mips is still in intensive development (for example, only the
> Indy
> XL graphic card is supported, all other machines need a serial console
> to use them), so if you planned to use it as an Irix replacement, it's
> to soon [;-)]
> If you feel it, and can find enough documentation about IP30 boards,
> it should be possible to do the port yourself ;-))
>
> hope this answers your question
thx, this is not exactly what i wanted to hear ;)
but i think i'll give it a try, any hint where i should start getting
into it, like i said i'm quite new to mips ...but i realy want to give
it a try :)
Bartosch Pixa
--
Bartosch Pixa, bartosch.pixa@infopark.de
Infopark AG
Kitzingstr. 15, D-12277 Berlin, Germany
Tel +49(0)-30-747.993.0, Fax +49(0)-30-747.993.93
http://www.infopark.de/
^ permalink raw reply [flat|nested] 45+ messages in thread
* Newbie Question
@ 2002-01-27 18:59 Robert Rusek
2002-01-27 18:59 ` Robert Rusek
0 siblings, 1 reply; 45+ messages in thread
From: Robert Rusek @ 2002-01-27 18:59 UTC (permalink / raw)
To: linux-mips
[-- Attachment #1: Type: text/plain, Size: 188 bytes --]
I have been out of the loop for quite a while. Is there a functional or
completed port of any of the RedHat flavors? If so how would I go about
getting them?
Thanks,
--
Robert Rusek
[-- Attachment #2: Type: text/html, Size: 838 bytes --]
^ permalink raw reply [flat|nested] 45+ messages in thread
* newbie question
@ 2005-09-21 14:43 phess.linux
2005-09-21 14:50 ` Nigel Stephens
0 siblings, 1 reply; 45+ messages in thread
From: phess.linux @ 2005-09-21 14:43 UTC (permalink / raw)
To: linux-mips
Hi there!
First I have to say that I'm a newbie without any experience with "linux
kernel". So don't blame me ;-)
I downloaded toolchains from MIPS Technologies.
I downloaded the newest version Linux 2.6.14-rc1 via CVS.
I installed the toolchain and tested some examples like "hello world" and
"minicom". They worked fine. I copied the linux kernel into a new folder of
the toolchain example directory. Then I tried to make (with command sde-make
menuconfig and then sde-make SBD=GSIM32L) the linux kernel. But all I get
are the following five lines:
CHK include/linux/version.h
CC arch/mips/kernel/asm-offsets.s
gcc: cannot specify -o with -c or -S and multiple compilations
sde-make[1]: *** [arch/mips/kernel/asm-offsets.s] Error 1
sde-make: *** [prepare0] Error 2
Now I need some help. Thx!
--
GMX DSL = Maximale Leistung zum minimalen Preis!
2000 MB nur 2,99, Flatrate ab 4,99 Euro/Monat: http://www.gmx.net/de/go/dsl
^ permalink raw reply [flat|nested] 45+ messages in thread
* Re: newbie question
2005-09-21 14:43 newbie question phess.linux
@ 2005-09-21 14:50 ` Nigel Stephens
0 siblings, 0 replies; 45+ messages in thread
From: Nigel Stephens @ 2005-09-21 14:50 UTC (permalink / raw)
To: phess.linux; +Cc: linux-mips
phess.linux@streber24.de wrote:
>Hi there!
>
>First I have to say that I'm a newbie without any experience with "linux
>kernel". So don't blame me ;-)
>
>I downloaded toolchains from MIPS Technologies.
>I downloaded the newest version Linux 2.6.14-rc1 via CVS.
>
>I installed the toolchain and tested some examples like "hello world" and
>"minicom". They worked fine. I copied the linux kernel into a new folder of
>the toolchain example directory. Then I tried to make (with command sde-make
>menuconfig and then sde-make SBD=GSIM32L) the linux kernel. But all I get
>are the following five lines:
>
>
Don't try to use the bare-iron/embedded MIPS SDE toolchain to build a
Linux kernel. Instead use the version which is configured as a Linux
native or cross compiler. See
http://www.linux-mips.org/wiki/Toolchains#MIPS_SDE
Nigel
^ permalink raw reply [flat|nested] 45+ messages in thread
end of thread, other threads:[~2005-09-21 14:51 UTC | newest]
Thread overview: 45+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2001-01-24 15:30 OOps - very obscure Florian Lohoff
2001-01-24 15:59 ` Florian Lohoff
2001-01-24 16:22 ` Florian Lohoff
2001-01-24 21:18 ` Keith Owens
2001-01-25 12:43 ` Florian Lohoff
2001-01-25 18:59 ` Jun Sun
2001-01-25 19:22 ` Florian Lohoff
2001-01-25 15:55 ` [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call Florian Lohoff
2001-01-25 15:55 ` Florian Lohoff
2001-01-25 16:34 ` Origin 200 crash nick
2001-01-25 18:28 ` [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call Joe deBlaquiere
2001-01-25 19:35 ` Joe deBlaquiere
2001-01-25 22:19 ` Ralf Baechle
2001-01-26 0:53 ` Joe deBlaquiere
2001-01-26 10:21 ` Maciej W. Rozycki
2001-01-26 15:41 ` Joe deBlaquiere
2001-01-26 21:16 ` Ralf Baechle
2001-01-27 7:20 ` Maciej W. Rozycki
2001-01-26 21:15 ` Ralf Baechle
2001-01-27 7:28 ` Maciej W. Rozycki
2001-01-27 19:42 ` Ralf Baechle
2001-01-29 15:03 ` Maciej W. Rozycki
2001-01-26 20:01 ` Jun Sun
2001-01-26 20:38 ` Joe deBlaquiere
2001-01-26 21:02 ` Jun Sun
2001-04-04 22:13 ` Florian Lohoff
2001-02-19 13:11 ` strace sysmips support (was: Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call) Wichert Akkerman
2001-02-19 19:52 ` newbie question Can Altineller
2001-02-20 7:06 ` David Jez
2001-02-20 20:26 ` Mike McDonald
2001-02-20 20:30 ` nick
2001-02-20 20:53 ` Ralf Baechle
2001-02-20 20:41 ` strace sysmips support (was: Re: [FIX] sysmips(MIPS_ATMIC_SET, ...) ret_from_sys_call vs. o32_ret_from_sys_call) Ralf Baechle
-- strict thread matches above, loose matches on Subject: below --
2001-06-13 13:59 Newbie question Bartosch Pixa
2001-06-13 15:07 ` Mat Withers
2001-06-13 15:22 ` Keith M Wesolowski
2001-06-13 15:14 ` Keith M Wesolowski
2001-06-13 21:50 ` mjpento
2001-06-15 12:12 ` Florian Lohoff
2001-06-15 13:31 ` Jan-Benedict Glaw
2001-06-13 15:43 Bartosch Pixa
2002-01-27 18:59 Newbie Question Robert Rusek
2002-01-27 18:59 ` Robert Rusek
2005-09-21 14:43 newbie question phess.linux
2005-09-21 14:50 ` Nigel Stephens
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox