Re: [PATCH] net/macb: fix ISR clear-on-write behavior only for someSoC
From: Michal Simek
Date: Tue May 14 2013 - 07:38:58 EST
On 05/14/2013 11:16 AM, Nicolas Ferre wrote:
> On 13/05/2013 18:05, Jean-Christophe PLAGNIOL-VILLARD :
>>
>> On May 14, 2013, at 12:05 AM, Nicolas Ferre <nicolas.ferre@xxxxxxxxx> wrote:
>>
>>> Commit 749a2b6 (net/macb: clear tx/rx completion flags in ISR)
>>> introduces clear-on-write on ISR register. This behavior is not always
>>> implemented when using Cadence MACB/GEM and is breaking other platforms.
>>> We are using a new Device Tree compatibility string and a capability
>>> property to actually activate this clear-on-write behavior on ISR.
>>>
>>> Reported-by: Hein Tibosch <hein_tibosch@xxxxxxxx>
>>> Signed-off-by: Nicolas Ferre <nicolas.ferre@xxxxxxxxx>
>>
>> can we detect it via the IP?
>
> As said by Hein, we cannot use the IP revision number. *But* we may have the opportunity to read this integration configuration in the Design Configuration Register 1 (DCFG1 already used for determining data bus width).
>
> So, Michal or Steffen, can you please tell me the value of:
> -> bit 23 at register address 0x280: mine is "1" which should mean "IRQ read clear", yours should be "0".
here is the whole reg map for zynq.
Reg 0x280 is undocumented in our TRM.
Please decode it not sure if bit 0 is LSB or MSB.
U-Boot-PetaLinux> md e000b000
e000b000: 0000001c 000e0013 00000006 00000000 ................
e000b010: 00180704 00000021 3ffba2e4 3ffbd32c ....!......?,..?
e000b020: 00000003 00000000 00000000 00000000 ................
e000b030: 07ffffff 63c66f08 00000000 0000ffff .....o.c........
e000b040: 000003ff 000003ff 00000000 00000000 ................
e000b050: 00000000 00000000 00000000 00000000 ................
e000b060: 00000000 00000000 00000000 00000000 ................
e000b070: 00000000 00000000 00000000 00000000 ................
e000b080: 00000000 00000000 00350a00 00001c48 ..........5.H...
e000b090: 00000000 00000000 00000000 00000000 ................
e000b0a0: 00000000 00000000 00000000 00000000 ................
e000b0b0: 00000000 00000000 00000000 00000000 ................
e000b0c0: 00000000 00000000 00000000 00000000 ................
e000b0d0: 00000000 00000000 00000000 00000000 ................
e000b0e0: 00000000 00000000 00000000 00000000 ................
e000b0f0: 00000000 00000000 00000000 00020118 ................
U-Boot-PetaLinux>
e000b100: 00014796 00000000 0000051e 00000001 .G..............
e000b110: 00000000 00000000 0000051d 00000001 ................
e000b120: 00000000 00000000 00000000 00000000 ................
e000b130: 00000000 00000000 00000000 00000000 ................
e000b140: 00000000 00000000 00000000 00000000 ................
e000b150: 001e58b6 00000000 00000526 00000000 .X......&.......
e000b160: 00000004 00000000 00000004 00000001 ................
e000b170: 00000000 00000004 00000000 0000051d ................
e000b180: 00000000 00000000 00000000 00000000 ................
e000b190: 00000000 00000000 00000000 00000000 ................
e000b1a0: 00000038 00000000 00000000 00000000 8...............
e000b1b0: 00000000 00000000 00000000 00000000 ................
e000b1c0: 00000000 00000000 00000000 00000000 ................
e000b1d0: 00000000 00000000 00000000 00000000 ................
e000b1e0: 00000000 00000000 00000000 00000000 ................
e000b1f0: 00000000 00000000 00000000 00000000 ................
U-Boot-PetaLinux>
e000b200: 00000000 00000000 00000000 00000000 ................
e000b210: 00000000 00000000 00000000 00000000 ................
e000b220: 00000000 00000000 00000000 00000000 ................
e000b230: 00000000 00000000 00000000 00000000 ................
e000b240: 00000000 00000000 00000000 00000000 ................
e000b250: 00000000 00000000 00000000 00000000 ................
e000b260: 00000000 00000000 00000000 00000000 ................
e000b270: 00000000 00000000 00000000 00000000 ................
e000b280: 02500111 2ab13fff 00000000 00000000 ..P..?.*........
e000b290: 002f2145 00000200 00000000 00000000 E!/.............
e000b2a0: 00000000 00000000 00000000 00000000 ................
e000b2b0: 00000000 00000000 00000000 00000000 ................
e000b2c0: 00000000 00000000 00000000 00000000 ................
e000b2d0: 00000000 00000000 00000000 00000000 ................
e000b2e0: 00000000 00000000 00000000 00000000 ................
e000b2f0: 00000000 00000000 00000000 00000000 ................
U-Boot-PetaLinux>
>
> Hein, in case of use of the MACB, we do not have this register included, so I will avoid to run the test when using MACB (we already have this information).
>
> If it works, I plan to rewrite the patch but taking this information instead of the device tree compatibility string.
yep. Will be good to detect it instead of new compatible string.
Also is there an option to remove "CONFIG_ARCH_AT91"?
Thanks,
Michal
--
Michal Simek, Ing. (M.Eng), OpenPGP -> KeyID: FE3D1F91
w: www.monstr.eu p: +42-0-721842854
Maintainer of Linux kernel - Microblaze cpu - http://www.monstr.eu/fdt/
Maintainer of Linux kernel - Xilinx Zynq ARM architecture
Microblaze U-BOOT custodian and responsible for u-boot arm zynq platform
Attachment:
signature.asc
Description: OpenPGP digital signature