From: Scott Wood <scottwood@freescale.com>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH 3/4][v2] powerpc/85xx:Make debug exception vector accessible
Date: Thu, 22 Mar 2012 14:43:49 -0500 [thread overview]
Message-ID: <4F6B80F5.6070700@freescale.com> (raw)
In-Reply-To: <4F6ABE2E.5000502@freescale.com>
On 03/22/2012 12:52 AM, Prabhakar Kushwaha wrote:
> Hi Scott,
>
> Please find my reply in-lined
>
> On Thursday 22 March 2012 01:22 AM, Scott Wood wrote:
>> On 03/20/2012 11:43 PM, Prabhakar Kushwaha wrote:
>>> Debugging of e500 and e500v1 processer requires debug exception
>>> vecter (IVPR +
>>> IVOR15) to have valid and fetchable OP code.
>>>
>>> While executing in translated space (AS=1), whenever a debug
>>> exception is
>>> generated, the MSR[DS/IS] gets cleared i.e. AS=0 and the processor
>>> tries to
>>> fetch an instruction from the debug exception vector (IVPR + IVOR15);
>>> since now
>>> we are in AS=0, the application needs to ensure the proper TLB
>>> configuration to
>>> have (IVOR + IVOR15) accessible from AS=0 also.
>>>
>>> Create a temporary TLB in AS0 to make sure debug exception verctor is
>>> accessible on debug exception.
>>>
>>> Signed-off-by: Radu Lazarescu<radu.lazarescu@freescale.com>
>>> Signed-off-by: Marius Grigoras<marius.grigoras@freescale.com>
>>> Signed-off-by: Prabhakar Kushwaha<prabhakar@freescale.com>
>> Can you document the flow of exactly what TLB entries are present at
>> various points of the boot flow, for all the various configurations (NOR
>> boot, NAND SPL, RAMBOOT, IFC versus non-IFC, etc).
>
> Sure. May be separate patch will be send.
Let's start with just an e-mail thoroughly describing your understanding
of this. It will provide necessary context for review.
We can clean it up for permanent documentation once it's clear to
everyone what's going on.
>> In the ramboot case is this really supposed to be I+G?
>
> I am not sure. But same is done under label "create_init_ram_area" for
> TLB entry 15.
> what you suggest.
I suggest as part of the request to document all of this, you figure out
what should actually be mapped in each configuration. The existing code
might be wrong for some of them, but we shouldn't proceed ahead blindly
and make an even bigger mess.
>> Which path will NAND SPL go through (not the payload, but the SPL
>> itself)? That will be only a 4K window mapped, and guarded doesn't stop
>> speculative instruction fetches, so we don't want to map more than is
>> backed up by something.
>
> NAND SPL go via !defined(CONFIG_SYS_RAMBOOT) path.
>
> i think NAND_SPL does not require temporary TLB as NAND SPL even does
> not have any interrupt vector.
So there's no plan to support using breakpoints or single step during
the SPL? That's fine with me, but should be documented, and we should
make sure this code does not run in that case.
>>> + lis r10,0xffc00000 at h
>>> + ori r10,r10,0xffc00000 at l
>> Don't waste instructions -- this could be in an SPL. That ori is a
>> no-op.
>
> Please refer above response. May be this piece of code is not required
> for NAND SPL
Still, I'd like to know why you're writing 0xffc00000 to MAS7. Only the
low 4 bits of MAS7 are valid on current e500.
>>> + mtspr MAS0,r6
>>> + mtspr MAS1,r7
>>> + mtspr MAS2,r8
>>> + mtspr MAS3,r9
>>> + mtspr MAS7,r10
>> Why are you writing 0xffc00000 into MAS7?
>>
>> Access to MAS7 needs to be conditional on CONFIG_ENABLE_36BIT_PHYS
>> (misnamed, should be something like CONFIG_SYS_PPC_HAS_MAS7).
>
> i will put this code under #define CONFIG_ENABLE_36BIT_PHYS
>
> For your kind information : in start.S, label label
> "create_ccsr_new_tlb", "create_ccsr_old_tlb" uses MAS7 without
> CONFIG_ENABLE_36BIT_PHYS #define.
> It should be fixed ??
Yes, it should be fixed. That was a fairly recent change and perhaps
e500v1 has not been tested since then -- Timur, could you look at this?
>>> diff --git a/arch/powerpc/include/asm/config_mpc85xx.h
>>> b/arch/powerpc/include/asm/config_mpc85xx.h
>>> index 8654625..268c56e 100644
>>> --- a/arch/powerpc/include/asm/config_mpc85xx.h
>>> +++ b/arch/powerpc/include/asm/config_mpc85xx.h
>>> @@ -1,5 +1,5 @@
>>> /*
>>> - * Copyright 2011 Freescale Semiconductor, Inc.
>>> + * Copyright 2011-2012 Freescale Semiconductor, Inc.
>>> *
>>> * This program is free software; you can redistribute it and/or
>>> * modify it under the terms of the GNU General Public License as
>>> @@ -107,6 +107,7 @@
>>> #define CONFIG_MAX_CPUS 1
>>> #define CONFIG_FSL_SDHC_V2_3
>>> #define CONFIG_SYS_FSL_NUM_LAWS 12
>>> +#define CONFIG_SYS_PPC_E500_DEBUG_TLB 3
>>> #define CONFIG_TSECV2
>>> #define CONFIG_SYS_FSL_SEC_COMPAT 4
>>> #define CONFIG_FSL_SATA_V2
>> It would be nice if we could have one place where all the fixed TLB
>> entries are assigned.
>>
>
> Am i supposed to send separate patch having TLB entry defined for all
> e500 v1/v2 SoC ?
That's a different issue, I just mean having one central place where
each hardcoded TLB entry gets a symbolic name, as well as a #define for
where programmatic TLB entry allocation can begin.
The decision to actually make use of the TLB entry would be a different
symbol, if you don't want it to be unconditional (relative to the
surrounding code).
-Scott
next prev parent reply other threads:[~2012-03-22 19:43 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-03-21 4:43 [U-Boot] [PATCH 3/4][v2] powerpc/85xx:Make debug exception vector accessible Prabhakar Kushwaha
2012-03-21 16:34 ` Scott Wood
2012-03-21 17:04 ` Prabhakar Kushwaha
2012-03-21 17:08 ` Scott Wood
2012-03-21 19:52 ` Scott Wood
2012-03-22 5:52 ` Prabhakar Kushwaha
2012-03-22 19:43 ` Scott Wood [this message]
2012-03-22 19:51 ` Timur Tabi
2012-03-22 19:53 ` Scott Wood
2012-03-22 19:56 ` Timur Tabi
2012-03-22 19:59 ` Scott Wood
2012-03-23 11:44 ` Prabhakar Kushwaha
2012-03-23 18:14 ` Scott Wood
2012-03-24 2:24 ` Prabhakar Kushwaha
2012-03-26 18:14 ` Scott Wood
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=4F6B80F5.6070700@freescale.com \
--to=scottwood@freescale.com \
--cc=u-boot@lists.denx.de \
/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