Interesting, in that the 4Kc has write-through caches,
which make it a good deal more difficult to get into
the kind of trouble you describe. Are you running one
of the 4Kc "lead vehicle" chips, or some other part?
Which version of the kernel are you running, and are
the CPU type and cache organization being reported
correctly during boot-up?
The output you report from dumping the command line
sounds is interesting. The corruption seems to be in
8-byte chunks - the first 8 have disappeared, as has
the third 8. Lord knows where the "0" in "ra0" comes
from. Can you confirm that (a) the command line string
is stored at an 8-byte aligned boundary, and (b) whether
the data is actually being moved, or if the missing
characters are simply being replaced with nulls or other
non-printable characters? I know it's not pretty, but
can you dump the same memory addresses as seen
through non-cacheable kseg1 (0xa0000000-0xbfffffff),
and are the cache and memory consistent?
If the failure is happening on 8-byte, doubleword aligned
chunks, I suspect a hardware problem more than a
kernel bug. If it were my system, I'd re-seat the RAM
and CPU modules to make sure I'm not simply getting
screwed by a bad connection when the memory interface
suddenly gets hit with a lot of traffic following the flush.
----- Original Message -----
From: "Ian Thompson" <firstname.lastname@example.org>
To: "Kevin D. Kissell" <email@example.com>
Sent: Monday, June 04, 2001 10:27 PM
Subject: Re: dcache_blast() bug?
> oops sorry i meant to mention that. running a mips 4kc.
> "Kevin D. Kissell" wrote:
> > What processor are you running?
> > Kevin K.
> > ----- Original Message -----
> > From: "Ian Thompson" <firstname.lastname@example.org>
> > To: <email@example.com>
> > Sent: Monday, June 04, 2001 7:34 PM
> > Subject: dcache_blast() bug?
> > >
> > > Hi all,
> > >
> > > I'm seeing some odd memory behavior around the time when
> > > is called, leading me to think that the method may be a little buggy.
> > > It appears that memory is being corrupted (consistently so) over the
> > > course of flushing the dcache. This happens to my command line
> > > string - arcs_cmdline. Before the blast_dcache() call, it is
> > > "console=ttyS0 ramdisk_start=0x9fcf0000 load_ramdisk=1", and after the
> > > call, the corrupted data is "ttyS0 ra0". I take it this isn't
> > > to happen? any ideas of why the writeback_invalidate_d cache
> > > may be losing data?
> > >
> > > thanks,
> > > -ian
> > >
> > >
> > > --
> > > ----------------------------------------
> > > Ian Thompson tel: 408.952.2023
> > > Firmware Engineer fax: 408.570.0910
> > > Palmchip Corporation www.palmchip.com
> Ian Thompson tel: 408.952.2023
> Firmware Engineer fax: 408.570.0910
> Palmchip Corporation www.palmchip.com