From: Till Straumann <strauman@slac.stanford.edu>
To: Dan Malek <dan@embeddededge.com>
Cc: joakim.tjernlund@lumentis.se,
Tom Rini <trini@kernel.crashing.org>,
"Linuxppc-Embedded@Lists. Linuxppc. Org"
<linuxppc-embedded@lists.linuxppc.org>
Subject: Re: dcbz works on 862 everywhere!
Date: Wed, 26 Mar 2003 10:11:34 -0800 [thread overview]
Message-ID: <3E81ED56.7050105@slac.stanford.edu> (raw)
In-Reply-To: 3E81C4B3.2080006@embeddededge.com
Dan Malek wrote:
> Till Straumann wrote:
>
>> I found that 'dcbz' (while failing to set DAR)
>> indeed sets MD_EPN correctly. Hence, Jocke's fix
>> (copy EPN[0:19]->DAR) would handle that.
>
>
>
> After sleeping for a couple of days and consuming large
> amounts of medicine to cure a cold, I think I understand
> why copying these bits around seems to "fix" problems.
>
> It's all related to the sequence of TLB miss/error exceptions
> that I had been describing all along. The first thing that
> is going to most likely happen is you will get a TLB miss to
> load a PTE into the TLB. It will be marked valid but not
> dirty (not writable). Immediately upon performing the rfi
> you will get a TLB Error to handle the dirty PTE update.
> By copying the bits from MD_EPN to the DAR in the miss handler,
> the Error handler will have at least a 4K boundary aligned DAR
> and it will execute correctly to update the dirty state. At
> this point, it will appear to "work" properly (even though
> it is likely the dcbz didn't execute) because the system will
> at least keep running (for a while).
I'm not sure whether to agree with this analysis. I thought
you said that TLB Error correctly set DAR? Hence you would
get
- TLB Miss, copy EPN to DAR (DAR is semi-correct, i.e. to
a page boundary).
- RFI, dcbz is restarted
--- here, task switching could occur ---
- TLB Error because the page was not writable (but, according
to your earlier mail, DAR should be correct now).
- copy DAR-> EPN, lookup PTE, replace TLB
- RFI, dcbz is restarted and eventually executed.
Under the premise that TLB Miss always sets EPN correctly
and TLB Error always sets DAR correctly, this should work
even if a task switch (or IRQ) sneaks in.
>
> If you have a situation where you get a TLB Error without
> a matching TLB miss (very rare, but they can happen as the
> result of swapping, copy on write, certain other page table
> updates), then you are hosed.
Again: I thought you said that TLB Error _does_ set DAR?
> The DAR will contain some information
> from a previous exception, we will likely end up on a "hung"
> system continually taking TLB Error exceptions because we
> can't fix them properly. This is basically what happens
> without the bit copying "fix".
>
>
>> My older idea (fixing up MD_EPN and DAR based
>> on the faulting instruction opcode and the involved
>> GPR contents) should work even if we have neither
>> a valid MD_EPN nor DAR.
>
>
> All of the TLB exception handlers must have minimal instructions.
> The ones in Linux are too big already. The very little you would
> gain from making a dcbz/dcbt work correctly would be lost many,
> many, many times over in a more complex TLB exception handler.
From a performance standpoint, perhaps (although I believe that
working around the problem is more of a 'size' than execution path
length increase). But you gain the huge advantage that you don't
have to carefully screen any software you intend to port for cache
instructions.
>
> Copying bits from MD_EPN to DAR doesn't set the DAR "correctly",
> it only gives you the page boundary. This is going to further
> confuse debuggers or signal handlers if you actually have an
> addressing bug that is detected by one of these instructions.
The 'fixup' workaround would provide a correct DAR, however.
-- Till
>
>
> The only update I would like to see to TLB exception handlers is
> the removal of code due to streamlining of the page table organization.
>
> Thanks.
>
>
> -- Dan
>
** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/
next prev parent reply other threads:[~2003-03-26 18:11 UTC|newest]
Thread overview: 51+ messages / expand[flat|nested] mbox.gz Atom feed top
2003-03-24 10:19 dcbz works on 862 everywhere! Joakim Tjernlund
2003-03-24 11:01 ` Joakim Tjernlund
2003-03-24 12:25 ` Joakim Tjernlund
2003-03-24 14:20 ` Joakim Tjernlund
2003-03-24 17:09 ` Till Straumann
2003-03-24 17:42 ` Joakim Tjernlund
2003-03-24 20:15 ` Tom Rini
2003-03-24 20:57 ` Joakim Tjernlund
2003-03-24 21:07 ` Tom Rini
2003-03-24 21:54 ` Joakim Tjernlund
2003-03-24 22:59 ` Dan Malek
2003-03-25 0:33 ` Joakim Tjernlund
2003-03-24 21:42 ` Dan Malek
2003-03-24 21:51 ` Joakim Tjernlund
2003-03-24 22:44 ` Joakim Tjernlund
2003-03-24 23:09 ` Dan Malek
2003-03-24 23:57 ` Joakim Tjernlund
2003-03-25 0:48 ` Dan Malek
2003-03-25 1:22 ` Dan Malek
2003-03-25 14:02 ` Joakim Tjernlund
2003-03-26 2:17 ` Till Straumann
2003-03-26 7:57 ` Joakim Tjernlund
2003-03-26 15:18 ` Dan Malek
2003-03-26 17:04 ` Joakim Tjernlund
2003-03-26 18:52 ` Dan Malek
2003-03-27 21:49 ` Joakim Tjernlund
2003-03-26 18:11 ` Till Straumann [this message]
2003-03-26 19:06 ` Dan Malek
2003-03-26 22:42 ` mpc8xx DCBZ (&friends) hw bug. Tests, analysis + conclusions Till Straumann
2003-03-27 1:25 ` Till Straumann
2003-03-27 14:01 ` Joakim Tjernlund
2003-04-03 12:50 ` Joakim Tjernlund
2003-04-08 10:47 ` Joakim Tjernlund
2003-04-08 16:25 ` Till Straumann
2003-04-08 16:42 ` Joakim Tjernlund
2003-04-08 16:52 ` Joakim Tjernlund
2003-04-08 21:01 ` Dan Malek
2003-04-08 17:25 ` Joakim Tjernlund
2003-04-08 18:14 ` Tom Rini
2003-04-08 21:07 ` Joakim Tjernlund
2003-05-09 12:37 ` Joakim Tjernlund
2003-04-01 9:37 ` dcbz works on 862 everywhere! Joakim Tjernlund
2003-04-04 15:09 ` Joakim Tjernlund
2003-04-04 15:43 ` Dan Malek
2003-04-04 16:37 ` Joakim Tjernlund
2003-04-09 14:32 ` Joakim Tjernlund
2003-03-26 18:52 ` Till Straumann
2003-03-25 1:57 ` Joakim Tjernlund
2003-03-25 17:37 ` Joakim Tjernlund
2003-03-26 15:22 ` Dan Malek
2003-03-26 17:09 ` Joakim Tjernlund
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=3E81ED56.7050105@slac.stanford.edu \
--to=strauman@slac.stanford.edu \
--cc=dan@embeddededge.com \
--cc=joakim.tjernlund@lumentis.se \
--cc=linuxppc-embedded@lists.linuxppc.org \
--cc=trini@kernel.crashing.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).