[U-Boot] [PATCH v3 1/4] mips: add base support for atheros ath79 based SOCs
Wills Wang
wills.wang at live.com
Sat Dec 26 16:48:57 CET 2015
On 12/26/2015 02:02 PM, Marek Vasut wrote:
> On Friday, December 25, 2015 at 12:38:39 PM, Wills Wang wrote:
>> On 12/24/2015 11:12 PM, Marek Vasut wrote:
>>> On Thursday, December 24, 2015 at 02:51:06 PM, Wills Wang wrote:
>>>
>>> [...]
>>>
>>>>>> +LEAF(lowlevel_init)
>>>>>> + /* These three WLAN_RESET will avoid original issue */
>>>>>> + li t3, 0x03
>>>>>> +1:
>>>>>> + li t0, KSEG1ADDR(AR71XX_RESET_BASE)
>>>>>> + lw t1, AR933X_RESET_REG_RESET_MODULE(t0)
>>>>>> + ori t1, t1, 0x0800
>>>>>> + sw t1, AR933X_RESET_REG_RESET_MODULE(t0)
>>>>>> + nop
>>>>>> + lw t1, AR933X_RESET_REG_RESET_MODULE(t0)
>>>>>> + li t2, 0xfffff7ff
>>>>>> + and t1, t1, t2
>>>>>> + sw t1, AR933X_RESET_REG_RESET_MODULE(t0)
>>>>>> + nop
>>>>>> + addi t3, t3, -1
>>>>>> + bnez t3, 1b
>>>>>> + nop
>>>>> This should be also easy to rewrite into C , right ?
>>>> C runtime environment is not available.
>>>> C stack is not ready before DDR has initialized.
>>> Just point the stack into a locked cacheline or some onchip RAM and there
>>> you have a C runtime. That should be pretty easy :)
>> How to lock cacheline?
> You'd have to check the MIPS core manual, I don't know the details, sorry.
>
>> My guess is that cache memory may be use to map SPI flash at 0x9f000000
>> by ROM code.
> The SPI flash is an IP block which just maps the SPI NOR into the address space,
> it doesn't use the CPU cache at all.
>
> Maybe you don't even need to lock cachelines though, the AR9331 should have some
> internal SRAM, so just use that for stack. Do you have a proper datasheet for
> the Atheros MIPS chips ? I have some 320 pages datasheet for AR9331.
I don't find any description about internal SRAM in public datasheet.
About mapping SPI flash, there is a doubt, who fetch the instruction from
the SPI Nor flash to CPU pipe line when chip boot from SPI flash?
I guess that ROM code handle cache exception and load instruction/date from
SPI flash into cache.
>>> [...]
>>>
>>>>>> +phys_size_t initdram(int board_type)
>>>>>> +{
>>>>>> + uint8_t *addr, *p;
>>>>>> + int i;
>>>>>> +
>>>>>> + ddr_tap_init();
>>>>>> + addr = (uint8_t *)KSEG1;
>>>>>> + *addr = 0x77;
>>>>>> + for (i = 0, p = addr; p < (uint8_t *)KSEG2; i++) {
>>>>>> + p += 0x1000000;
>>>>>> + *p = i;
>>>>>> + if (*addr != 0x77)
>>>>>> + break;
>>>>>> + }
>>>>> What is this and how does it work ?
>>>> Physical memory was mapped circularly for this chip.
>>> Can you please expand on that ? I am not as deep in this chip as you are,
>>> so please explain it to me in a bit more detail.
> Well ... ?
There is 64MB DDR on my board, the 64MB memory was mapped circularly into
0x00000000-0x03ffffff, 0x04000000-0x07ffffff, 0x08000000-0x0bffffff,...
the address 0x00000000, 0x04000000 and 0x08000000 was mapped to the same
physical memory. their corresponding KSEG1 address is 0xA0000000,
0xA4000000,
0xA8000000, when write a value into 0xA0000000, we can read the same value
from address 0xA4000000 and 0xA8000000.
>
>>>>>> + return (phys_size_t)(p - addr);
>>>>>> +}
>>> [...]
>>>
>>>>>> + if (reg) {
>>>>>> + val = RST_READ(reg);
>>>>>> + val |= AR71XX_RESET_FULL_CHIP;
>>>>>> + RST_WRITE(reg, val);
>>>>> setbits_le32() please.
>>>> Macro setbits_le32() is not available for MIPS architecture.
>>> You can always add them :)
>>>
>>>> Other, I don't think there is better in being so explicit and using
>>>> little-endian.
>>> I believe your register accesses should have correct endianness exactly
>>> beause mips can be both endian.
>> What is the advantage of using setbits_le32()?
> You don't have these constant repeating patterns of:
>
> var = read()
> var |= BIT
> write(var)
>
> It makes things a bit less confusing.
ok, AR9331 use big-endian.
> Best regards,
> Marek Vasut
>
>
More information about the U-Boot
mailing list