Skip to content
Snippets Groups Projects
Commit 9be659ac authored by Matthias Fuchs's avatar Matthias Fuchs Committed by Stefan Roese
Browse files

ppc4xx: Make USB working with CONFIG_4xx_DCACHE defined


This patch disables the 44x d-cache on 'usb start' and
reenables it on 'usb stop'. This should be seen as a
temporary fix until the generic usb-ohci driver can
life with d-cache enabled.

Signed-off-by: default avatarMatthias Fuchs <matthias.fuchs@esd-electronics.com>
Signed-off-by: default avatarStefan Roese <sr@denx.de>
parent fbde2169
No related branches found
No related tags found
No related merge requests found
...@@ -25,25 +25,41 @@ ...@@ -25,25 +25,41 @@
#if defined(CONFIG_USB_OHCI_NEW) && defined(CFG_USB_OHCI_CPU_INIT) #if defined(CONFIG_USB_OHCI_NEW) && defined(CFG_USB_OHCI_CPU_INIT)
#ifdef CONFIG_4xx_DCACHE
#include <asm/mmu.h>
DECLARE_GLOBAL_DATA_PTR;
#endif
#include "usbdev.h" #include "usbdev.h"
int usb_cpu_init(void) int usb_cpu_init(void)
{ {
#ifdef CONFIG_4xx_DCACHE
/* disable cache */
change_tlb(gd->bd->bi_memstart, gd->bd->bi_memsize, TLB_WORD2_I_ENABLE);
#endif
#if defined(CONFIG_440EP) || defined(CONFIG_440EPX) #if defined(CONFIG_440EP) || defined(CONFIG_440EPX)
usb_dev_init(); usb_dev_init();
#endif #endif
return 0; return 0;
} }
int usb_cpu_stop(void) int usb_cpu_stop(void)
{ {
#ifdef CONFIG_4xx_DCACHE
/* enable cache */
change_tlb(gd->bd->bi_memstart, gd->bd->bi_memsize, 0);
#endif
return 0; return 0;
} }
int usb_cpu_init_fail(void) int usb_cpu_init_fail(void)
{ {
#ifdef CONFIG_4xx_DCACHE
/* enable cache */
change_tlb(gd->bd->bi_memstart, gd->bd->bi_memsize, 0);
#endif
return 0; return 0;
} }
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment