Commit b55a0ff8 authored by Linus Torvalds's avatar Linus Torvalds

Merge branch 'for-next' of git://git.kernel.org/pub/scm/linux/kernel/git/gerg/m68knommu into next

Pull m68knommu updates from Greg Ungerer:
 "Nothing too big, just a handfull of small changes.

  A couple of dragonball fixes, coldfire qspi cleanup and fixes, and
  some coldfire gpio cleanup, fixes and extensions"

* 'for-next' of git://git.kernel.org/pub/scm/linux/kernel/git/gerg/m68knommu:
  m68knommu: Implement gpio support for m54xx.
  m68knommu: Make everything thats not exported, static.
  m68knommu: setting the gpio data direction register to output doesn't dependent upon the value to output!
  m68knommu: add to_irq function so we can map gpios to external interrupts.
  m68knommu: qspi declutter.
  m68knommu: Fix the 5249/525x qspi base address.
  m68knommu: Add qspi clk for Coldfire SoCs without real clks.
  m68k: fix a compiler warning when building for DragonBall
  m68knommu: Fix mach_sched_init for EZ and VZ DragonBall chips
parents a727eaf6 83c6bdb8
...@@ -105,7 +105,7 @@ ...@@ -105,7 +105,7 @@
/* /*
* QSPI module. * QSPI module.
*/ */
#define MCFQSPI_BASE (MCF_MBAR + 0x300) /* Base address QSPI */ #define MCFQSPI_BASE (MCF_MBAR + 0x400) /* Base address QSPI */
#define MCFQSPI_SIZE 0x40 /* Register set size */ #define MCFQSPI_SIZE 0x40 /* Register set size */
#ifdef CONFIG_M5249 #ifdef CONFIG_M5249
......
...@@ -55,9 +55,15 @@ ...@@ -55,9 +55,15 @@
/* /*
* Generic GPIO support * Generic GPIO support
*/ */
#define MCFGPIO_PIN_MAX 0 /* I am too lazy to count */ #define MCFGPIO_PODR (MCF_MBAR + 0xA00)
#define MCFGPIO_IRQ_MAX -1 #define MCFGPIO_PDDR (MCF_MBAR + 0xA10)
#define MCFGPIO_IRQ_VECBASE -1 #define MCFGPIO_PPDR (MCF_MBAR + 0xA20)
#define MCFGPIO_SETR (MCF_MBAR + 0xA20)
#define MCFGPIO_CLRR (MCF_MBAR + 0xA30)
#define MCFGPIO_PIN_MAX 136 /* 128 gpio + 8 eport */
#define MCFGPIO_IRQ_MAX 8
#define MCFGPIO_IRQ_VECBASE MCFINT_VECBASE
/* /*
* EDGE Port support. * EDGE Port support.
......
...@@ -139,7 +139,8 @@ static inline void gpio_free(unsigned gpio) ...@@ -139,7 +139,8 @@ static inline void gpio_free(unsigned gpio)
#if defined(CONFIG_M520x) || defined(CONFIG_M523x) || \ #if defined(CONFIG_M520x) || defined(CONFIG_M523x) || \
defined(CONFIG_M527x) || defined(CONFIG_M528x) || \ defined(CONFIG_M527x) || defined(CONFIG_M528x) || \
defined(CONFIG_M53xx) || defined(CONFIG_M5441x) defined(CONFIG_M53xx) || defined(CONFIG_M54xx) || \
defined(CONFIG_M5441x)
/* /*
* These parts have an 'Edge' Port module (external interrupt/GPIO) which uses * These parts have an 'Edge' Port module (external interrupt/GPIO) which uses
* read-modify-write to change an output and a GPIO module which has separate * read-modify-write to change an output and a GPIO module which has separate
...@@ -195,7 +196,8 @@ static inline u32 __mcfgpio_ppdr(unsigned gpio) ...@@ -195,7 +196,8 @@ static inline u32 __mcfgpio_ppdr(unsigned gpio)
return MCFSIM2_GPIO1READ; return MCFSIM2_GPIO1READ;
#elif defined(CONFIG_M520x) || defined(CONFIG_M523x) || \ #elif defined(CONFIG_M520x) || defined(CONFIG_M523x) || \
defined(CONFIG_M527x) || defined(CONFIG_M528x) || \ defined(CONFIG_M527x) || defined(CONFIG_M528x) || \
defined(CONFIG_M53xx) || defined(CONFIG_M5441x) defined(CONFIG_M53xx) || defined(CONFIG_M54xx) || \
defined(CONFIG_M5441x)
#if !defined(CONFIG_M5441x) #if !defined(CONFIG_M5441x)
if (gpio < 8) if (gpio < 8)
return MCFEPORT_EPPDR; return MCFEPORT_EPPDR;
...@@ -237,7 +239,8 @@ static inline u32 __mcfgpio_podr(unsigned gpio) ...@@ -237,7 +239,8 @@ static inline u32 __mcfgpio_podr(unsigned gpio)
return MCFSIM2_GPIO1WRITE; return MCFSIM2_GPIO1WRITE;
#elif defined(CONFIG_M520x) || defined(CONFIG_M523x) || \ #elif defined(CONFIG_M520x) || defined(CONFIG_M523x) || \
defined(CONFIG_M527x) || defined(CONFIG_M528x) || \ defined(CONFIG_M527x) || defined(CONFIG_M528x) || \
defined(CONFIG_M53xx) || defined(CONFIG_M5441x) defined(CONFIG_M53xx) || defined(CONFIG_M54xx) || \
defined(CONFIG_M5441x)
#if !defined(CONFIG_M5441x) #if !defined(CONFIG_M5441x)
if (gpio < 8) if (gpio < 8)
return MCFEPORT_EPDR; return MCFEPORT_EPDR;
...@@ -279,7 +282,8 @@ static inline u32 __mcfgpio_pddr(unsigned gpio) ...@@ -279,7 +282,8 @@ static inline u32 __mcfgpio_pddr(unsigned gpio)
return MCFSIM2_GPIO1ENABLE; return MCFSIM2_GPIO1ENABLE;
#elif defined(CONFIG_M520x) || defined(CONFIG_M523x) || \ #elif defined(CONFIG_M520x) || defined(CONFIG_M523x) || \
defined(CONFIG_M527x) || defined(CONFIG_M528x) || \ defined(CONFIG_M527x) || defined(CONFIG_M528x) || \
defined(CONFIG_M53xx) || defined(CONFIG_M5441x) defined(CONFIG_M53xx) || defined(CONFIG_M54xx) || \
defined(CONFIG_M5441x)
#if !defined(CONFIG_M5441x) #if !defined(CONFIG_M5441x)
if (gpio < 8) if (gpio < 8)
return MCFEPORT_EPDDR; return MCFEPORT_EPDDR;
......
...@@ -58,17 +58,16 @@ void (*mach_halt)(void); ...@@ -58,17 +58,16 @@ void (*mach_halt)(void);
void (*mach_power_off)(void); void (*mach_power_off)(void);
#ifdef CONFIG_M68000 #ifdef CONFIG_M68000
#define CPU_NAME "MC68000" #if defined(CONFIG_M68328)
#endif
#ifdef CONFIG_M68328
#define CPU_NAME "MC68328" #define CPU_NAME "MC68328"
#endif #elif defined(CONFIG_M68EZ328)
#ifdef CONFIG_M68EZ328
#define CPU_NAME "MC68EZ328" #define CPU_NAME "MC68EZ328"
#endif #elif defined(CONFIG_M68VZ328)
#ifdef CONFIG_M68VZ328
#define CPU_NAME "MC68VZ328" #define CPU_NAME "MC68VZ328"
#else
#define CPU_NAME "MC68000"
#endif #endif
#endif /* CONFIG_M68000 */
#ifdef CONFIG_M68360 #ifdef CONFIG_M68360
#define CPU_NAME "MC68360" #define CPU_NAME "MC68360"
#endif #endif
......
...@@ -70,6 +70,7 @@ void __init config_BSP(char *command, int len) ...@@ -70,6 +70,7 @@ void __init config_BSP(char *command, int len)
else command[0] = 0; else command[0] = 0;
#endif #endif
mach_sched_init = hw_timer_init;
mach_hwclk = m68328_hwclk; mach_hwclk = m68328_hwclk;
mach_reset = m68ez328_reset; mach_reset = m68ez328_reset;
} }
......
...@@ -182,6 +182,7 @@ void __init config_BSP(char *command, int size) ...@@ -182,6 +182,7 @@ void __init config_BSP(char *command, int size)
init_hardware(command, size); init_hardware(command, size);
mach_sched_init = hw_timer_init;
mach_hwclk = m68328_hwclk; mach_hwclk = m68328_hwclk;
mach_reset = m68vz328_reset; mach_reset = m68vz328_reset;
} }
......
...@@ -76,10 +76,7 @@ int __mcfgpio_direction_output(unsigned gpio, int value) ...@@ -76,10 +76,7 @@ int __mcfgpio_direction_output(unsigned gpio, int value)
local_irq_save(flags); local_irq_save(flags);
data = mcfgpio_read(__mcfgpio_pddr(gpio)); data = mcfgpio_read(__mcfgpio_pddr(gpio));
if (value)
data |= mcfgpio_bit(gpio); data |= mcfgpio_bit(gpio);
else
data &= mcfgpio_bit(gpio);
mcfgpio_write(data, __mcfgpio_pddr(gpio)); mcfgpio_write(data, __mcfgpio_pddr(gpio));
/* now set the data to output */ /* now set the data to output */
...@@ -117,37 +114,51 @@ EXPORT_SYMBOL(__mcfgpio_free); ...@@ -117,37 +114,51 @@ EXPORT_SYMBOL(__mcfgpio_free);
#ifdef CONFIG_GPIOLIB #ifdef CONFIG_GPIOLIB
int mcfgpio_direction_input(struct gpio_chip *chip, unsigned offset) static int mcfgpio_direction_input(struct gpio_chip *chip, unsigned offset)
{ {
return __mcfgpio_direction_input(offset); return __mcfgpio_direction_input(offset);
} }
int mcfgpio_get_value(struct gpio_chip *chip, unsigned offset) static int mcfgpio_get_value(struct gpio_chip *chip, unsigned offset)
{ {
return __mcfgpio_get_value(offset); return __mcfgpio_get_value(offset);
} }
int mcfgpio_direction_output(struct gpio_chip *chip, unsigned offset, int value) static int mcfgpio_direction_output(struct gpio_chip *chip, unsigned offset,
int value)
{ {
return __mcfgpio_direction_output(offset, value); return __mcfgpio_direction_output(offset, value);
} }
void mcfgpio_set_value(struct gpio_chip *chip, unsigned offset, int value) static void mcfgpio_set_value(struct gpio_chip *chip, unsigned offset,
int value)
{ {
__mcfgpio_set_value(offset, value); __mcfgpio_set_value(offset, value);
} }
int mcfgpio_request(struct gpio_chip *chip, unsigned offset) static int mcfgpio_request(struct gpio_chip *chip, unsigned offset)
{ {
return __mcfgpio_request(offset); return __mcfgpio_request(offset);
} }
void mcfgpio_free(struct gpio_chip *chip, unsigned offset) static void mcfgpio_free(struct gpio_chip *chip, unsigned offset)
{ {
__mcfgpio_free(offset); __mcfgpio_free(offset);
} }
struct bus_type mcfgpio_subsys = { static int mcfgpio_to_irq(struct gpio_chip *chip, unsigned offset)
{
#if defined(MCFGPIO_IRQ_MIN)
if ((offset >= MCFGPIO_IRQ_MIN) && (offset < MCFGPIO_IRQ_MAX))
#else
if (offset < MCFGPIO_IRQ_MAX)
#endif
return MCFGPIO_IRQ_VECBASE + offset;
else
return -EINVAL;
}
static struct bus_type mcfgpio_subsys = {
.name = "gpio", .name = "gpio",
.dev_name = "gpio", .dev_name = "gpio",
}; };
...@@ -160,6 +171,7 @@ static struct gpio_chip mcfgpio_chip = { ...@@ -160,6 +171,7 @@ static struct gpio_chip mcfgpio_chip = {
.direction_output = mcfgpio_direction_output, .direction_output = mcfgpio_direction_output,
.get = mcfgpio_get_value, .get = mcfgpio_get_value,
.set = mcfgpio_set_value, .set = mcfgpio_set_value,
.to_irq = mcfgpio_to_irq,
.base = 0, .base = 0,
.ngpio = MCFGPIO_PIN_MAX, .ngpio = MCFGPIO_PIN_MAX,
}; };
......
...@@ -118,10 +118,9 @@ static void __init m520x_clk_init(void) ...@@ -118,10 +118,9 @@ static void __init m520x_clk_init(void)
/***************************************************************************/ /***************************************************************************/
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
static void __init m520x_qspi_init(void) static void __init m520x_qspi_init(void)
{ {
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
u16 par; u16 par;
/* setup Port QS for QSPI with gpio CS control */ /* setup Port QS for QSPI with gpio CS control */
writeb(0x3f, MCF_GPIO_PAR_QSPI); writeb(0x3f, MCF_GPIO_PAR_QSPI);
...@@ -129,9 +128,8 @@ static void __init m520x_qspi_init(void) ...@@ -129,9 +128,8 @@ static void __init m520x_qspi_init(void)
par = readw(MCF_GPIO_PAR_UART); par = readw(MCF_GPIO_PAR_UART);
par &= 0x00ff; par &= 0x00ff;
writew(par, MCF_GPIO_PAR_UART); writew(par, MCF_GPIO_PAR_UART);
}
#endif /* IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI) */ #endif /* IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI) */
}
/***************************************************************************/ /***************************************************************************/
...@@ -176,9 +174,7 @@ void __init config_BSP(char *commandp, int size) ...@@ -176,9 +174,7 @@ void __init config_BSP(char *commandp, int size)
m520x_clk_init(); m520x_clk_init();
m520x_uarts_init(); m520x_uarts_init();
m520x_fec_init(); m520x_fec_init();
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
m520x_qspi_init(); m520x_qspi_init();
#endif
} }
/***************************************************************************/ /***************************************************************************/
...@@ -32,6 +32,7 @@ DEFINE_CLK(mcfpit3, "mcfpit.3", MCF_CLK); ...@@ -32,6 +32,7 @@ DEFINE_CLK(mcfpit3, "mcfpit.3", MCF_CLK);
DEFINE_CLK(mcfuart0, "mcfuart.0", MCF_BUSCLK); DEFINE_CLK(mcfuart0, "mcfuart.0", MCF_BUSCLK);
DEFINE_CLK(mcfuart1, "mcfuart.1", MCF_BUSCLK); DEFINE_CLK(mcfuart1, "mcfuart.1", MCF_BUSCLK);
DEFINE_CLK(mcfuart2, "mcfuart.2", MCF_BUSCLK); DEFINE_CLK(mcfuart2, "mcfuart.2", MCF_BUSCLK);
DEFINE_CLK(mcfqspi0, "mcfqspi.0", MCF_BUSCLK);
DEFINE_CLK(fec0, "fec.0", MCF_BUSCLK); DEFINE_CLK(fec0, "fec.0", MCF_BUSCLK);
struct clk *mcf_clks[] = { struct clk *mcf_clks[] = {
...@@ -44,16 +45,16 @@ struct clk *mcf_clks[] = { ...@@ -44,16 +45,16 @@ struct clk *mcf_clks[] = {
&clk_mcfuart0, &clk_mcfuart0,
&clk_mcfuart1, &clk_mcfuart1,
&clk_mcfuart2, &clk_mcfuart2,
&clk_mcfqspi0,
&clk_fec0, &clk_fec0,
NULL NULL
}; };
/***************************************************************************/ /***************************************************************************/
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
static void __init m523x_qspi_init(void) static void __init m523x_qspi_init(void)
{ {
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
u16 par; u16 par;
/* setup QSPS pins for QSPI with gpio CS control */ /* setup QSPS pins for QSPI with gpio CS control */
...@@ -62,9 +63,8 @@ static void __init m523x_qspi_init(void) ...@@ -62,9 +63,8 @@ static void __init m523x_qspi_init(void)
par = readw(MCFGPIO_PAR_TIMER); par = readw(MCFGPIO_PAR_TIMER);
par &= 0x3f3f; par &= 0x3f3f;
writew(par, MCFGPIO_PAR_TIMER); writew(par, MCFGPIO_PAR_TIMER);
}
#endif /* IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI) */ #endif /* IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI) */
}
/***************************************************************************/ /***************************************************************************/
...@@ -80,9 +80,7 @@ void __init config_BSP(char *commandp, int size) ...@@ -80,9 +80,7 @@ void __init config_BSP(char *commandp, int size)
{ {
mach_sched_init = hw_timer_init; mach_sched_init = hw_timer_init;
m523x_fec_init(); m523x_fec_init();
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
m523x_qspi_init(); m523x_qspi_init();
#endif
} }
/***************************************************************************/ /***************************************************************************/
...@@ -26,6 +26,7 @@ DEFINE_CLK(mcftmr0, "mcftmr.0", MCF_BUSCLK); ...@@ -26,6 +26,7 @@ DEFINE_CLK(mcftmr0, "mcftmr.0", MCF_BUSCLK);
DEFINE_CLK(mcftmr1, "mcftmr.1", MCF_BUSCLK); DEFINE_CLK(mcftmr1, "mcftmr.1", MCF_BUSCLK);
DEFINE_CLK(mcfuart0, "mcfuart.0", MCF_BUSCLK); DEFINE_CLK(mcfuart0, "mcfuart.0", MCF_BUSCLK);
DEFINE_CLK(mcfuart1, "mcfuart.1", MCF_BUSCLK); DEFINE_CLK(mcfuart1, "mcfuart.1", MCF_BUSCLK);
DEFINE_CLK(mcfqspi0, "mcfqspi.0", MCF_BUSCLK);
struct clk *mcf_clks[] = { struct clk *mcf_clks[] = {
&clk_pll, &clk_pll,
...@@ -34,6 +35,7 @@ struct clk *mcf_clks[] = { ...@@ -34,6 +35,7 @@ struct clk *mcf_clks[] = {
&clk_mcftmr1, &clk_mcftmr1,
&clk_mcfuart0, &clk_mcfuart0,
&clk_mcfuart1, &clk_mcfuart1,
&clk_mcfqspi0,
NULL NULL
}; };
...@@ -71,17 +73,15 @@ static struct platform_device *m5249_devices[] __initdata = { ...@@ -71,17 +73,15 @@ static struct platform_device *m5249_devices[] __initdata = {
/***************************************************************************/ /***************************************************************************/
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
static void __init m5249_qspi_init(void) static void __init m5249_qspi_init(void)
{ {
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
/* QSPI irq setup */ /* QSPI irq setup */
writeb(MCFSIM_ICR_AUTOVEC | MCFSIM_ICR_LEVEL4 | MCFSIM_ICR_PRI0, writeb(MCFSIM_ICR_AUTOVEC | MCFSIM_ICR_LEVEL4 | MCFSIM_ICR_PRI0,
MCFSIM_QSPIICR); MCFSIM_QSPIICR);
mcf_mapirq2imr(MCF_IRQ_QSPI, MCFINTC_QSPI); mcf_mapirq2imr(MCF_IRQ_QSPI, MCFINTC_QSPI);
}
#endif /* IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI) */ #endif /* IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI) */
}
/***************************************************************************/ /***************************************************************************/
...@@ -110,9 +110,7 @@ void __init config_BSP(char *commandp, int size) ...@@ -110,9 +110,7 @@ void __init config_BSP(char *commandp, int size)
#ifdef CONFIG_M5249C3 #ifdef CONFIG_M5249C3
m5249_smc91x_init(); m5249_smc91x_init();
#endif #endif
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
m5249_qspi_init(); m5249_qspi_init();
#endif
} }
/***************************************************************************/ /***************************************************************************/
......
...@@ -26,6 +26,7 @@ DEFINE_CLK(mcftmr0, "mcftmr.0", MCF_BUSCLK); ...@@ -26,6 +26,7 @@ DEFINE_CLK(mcftmr0, "mcftmr.0", MCF_BUSCLK);
DEFINE_CLK(mcftmr1, "mcftmr.1", MCF_BUSCLK); DEFINE_CLK(mcftmr1, "mcftmr.1", MCF_BUSCLK);
DEFINE_CLK(mcfuart0, "mcfuart.0", MCF_BUSCLK); DEFINE_CLK(mcfuart0, "mcfuart.0", MCF_BUSCLK);
DEFINE_CLK(mcfuart1, "mcfuart.1", MCF_BUSCLK); DEFINE_CLK(mcfuart1, "mcfuart.1", MCF_BUSCLK);
DEFINE_CLK(mcfqspi0, "mcfqspi.0", MCF_BUSCLK);
struct clk *mcf_clks[] = { struct clk *mcf_clks[] = {
&clk_pll, &clk_pll,
...@@ -34,6 +35,7 @@ struct clk *mcf_clks[] = { ...@@ -34,6 +35,7 @@ struct clk *mcf_clks[] = {
&clk_mcftmr1, &clk_mcftmr1,
&clk_mcfuart0, &clk_mcfuart0,
&clk_mcfuart1, &clk_mcfuart1,
&clk_mcfqspi0,
NULL NULL
}; };
......
...@@ -39,6 +39,7 @@ DEFINE_CLK(mcftmr2, "mcftmr.2", MCF_BUSCLK); ...@@ -39,6 +39,7 @@ DEFINE_CLK(mcftmr2, "mcftmr.2", MCF_BUSCLK);
DEFINE_CLK(mcftmr3, "mcftmr.3", MCF_BUSCLK); DEFINE_CLK(mcftmr3, "mcftmr.3", MCF_BUSCLK);
DEFINE_CLK(mcfuart0, "mcfuart.0", MCF_BUSCLK); DEFINE_CLK(mcfuart0, "mcfuart.0", MCF_BUSCLK);
DEFINE_CLK(mcfuart1, "mcfuart.1", MCF_BUSCLK); DEFINE_CLK(mcfuart1, "mcfuart.1", MCF_BUSCLK);
DEFINE_CLK(mcfqspi0, "mcfqspi.0", MCF_BUSCLK);
DEFINE_CLK(fec0, "fec.0", MCF_BUSCLK); DEFINE_CLK(fec0, "fec.0", MCF_BUSCLK);
struct clk *mcf_clks[] = { struct clk *mcf_clks[] = {
...@@ -50,6 +51,7 @@ struct clk *mcf_clks[] = { ...@@ -50,6 +51,7 @@ struct clk *mcf_clks[] = {
&clk_mcftmr3, &clk_mcftmr3,
&clk_mcfuart0, &clk_mcfuart0,
&clk_mcfuart1, &clk_mcfuart1,
&clk_mcfqspi0,
&clk_fec0, &clk_fec0,
NULL NULL
}; };
......
...@@ -33,6 +33,7 @@ DEFINE_CLK(mcfpit3, "mcfpit.3", MCF_CLK); ...@@ -33,6 +33,7 @@ DEFINE_CLK(mcfpit3, "mcfpit.3", MCF_CLK);
DEFINE_CLK(mcfuart0, "mcfuart.0", MCF_BUSCLK); DEFINE_CLK(mcfuart0, "mcfuart.0", MCF_BUSCLK);
DEFINE_CLK(mcfuart1, "mcfuart.1", MCF_BUSCLK); DEFINE_CLK(mcfuart1, "mcfuart.1", MCF_BUSCLK);
DEFINE_CLK(mcfuart2, "mcfuart.2", MCF_BUSCLK); DEFINE_CLK(mcfuart2, "mcfuart.2", MCF_BUSCLK);
DEFINE_CLK(mcfqspi0, "mcfqspi.0", MCF_BUSCLK);
DEFINE_CLK(fec0, "fec.0", MCF_BUSCLK); DEFINE_CLK(fec0, "fec.0", MCF_BUSCLK);
DEFINE_CLK(fec1, "fec.1", MCF_BUSCLK); DEFINE_CLK(fec1, "fec.1", MCF_BUSCLK);
...@@ -46,6 +47,7 @@ struct clk *mcf_clks[] = { ...@@ -46,6 +47,7 @@ struct clk *mcf_clks[] = {
&clk_mcfuart0, &clk_mcfuart0,
&clk_mcfuart1, &clk_mcfuart1,
&clk_mcfuart2, &clk_mcfuart2,
&clk_mcfqspi0,
&clk_fec0, &clk_fec0,
&clk_fec1, &clk_fec1,
NULL NULL
...@@ -53,10 +55,9 @@ struct clk *mcf_clks[] = { ...@@ -53,10 +55,9 @@ struct clk *mcf_clks[] = {
/***************************************************************************/ /***************************************************************************/
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
static void __init m527x_qspi_init(void) static void __init m527x_qspi_init(void)
{ {
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
#if defined(CONFIG_M5271) #if defined(CONFIG_M5271)
u16 par; u16 par;
...@@ -70,9 +71,8 @@ static void __init m527x_qspi_init(void) ...@@ -70,9 +71,8 @@ static void __init m527x_qspi_init(void)
/* setup QSPS pins for QSPI with gpio CS control */ /* setup QSPS pins for QSPI with gpio CS control */
writew(0x003e, MCFGPIO_PAR_QSPI); writew(0x003e, MCFGPIO_PAR_QSPI);
#endif #endif
}
#endif /* IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI) */ #endif /* IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI) */
}
/***************************************************************************/ /***************************************************************************/
...@@ -120,9 +120,7 @@ void __init config_BSP(char *commandp, int size) ...@@ -120,9 +120,7 @@ void __init config_BSP(char *commandp, int size)
mach_sched_init = hw_timer_init; mach_sched_init = hw_timer_init;
m527x_uarts_init(); m527x_uarts_init();
m527x_fec_init(); m527x_fec_init();
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
m527x_qspi_init(); m527x_qspi_init();
#endif
} }
/***************************************************************************/ /***************************************************************************/
...@@ -34,6 +34,7 @@ DEFINE_CLK(mcfpit3, "mcfpit.3", MCF_CLK); ...@@ -34,6 +34,7 @@ DEFINE_CLK(mcfpit3, "mcfpit.3", MCF_CLK);
DEFINE_CLK(mcfuart0, "mcfuart.0", MCF_BUSCLK); DEFINE_CLK(mcfuart0, "mcfuart.0", MCF_BUSCLK);
DEFINE_CLK(mcfuart1, "mcfuart.1", MCF_BUSCLK); DEFINE_CLK(mcfuart1, "mcfuart.1", MCF_BUSCLK);
DEFINE_CLK(mcfuart2, "mcfuart.2", MCF_BUSCLK); DEFINE_CLK(mcfuart2, "mcfuart.2", MCF_BUSCLK);
DEFINE_CLK(mcfqspi0, "mcfqspi.0", MCF_BUSCLK);
DEFINE_CLK(fec0, "fec.0", MCF_BUSCLK); DEFINE_CLK(fec0, "fec.0", MCF_BUSCLK);
struct clk *mcf_clks[] = { struct clk *mcf_clks[] = {
...@@ -46,21 +47,20 @@ struct clk *mcf_clks[] = { ...@@ -46,21 +47,20 @@ struct clk *mcf_clks[] = {
&clk_mcfuart0, &clk_mcfuart0,
&clk_mcfuart1, &clk_mcfuart1,
&clk_mcfuart2, &clk_mcfuart2,
&clk_mcfqspi0,
&clk_fec0, &clk_fec0,
NULL NULL
}; };
/***************************************************************************/ /***************************************************************************/
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
static void __init m528x_qspi_init(void) static void __init m528x_qspi_init(void)
{ {
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
/* setup Port QS for QSPI with gpio CS control */ /* setup Port QS for QSPI with gpio CS control */
__raw_writeb(0x07, MCFGPIO_PQSPAR); __raw_writeb(0x07, MCFGPIO_PQSPAR);
}
#endif /* IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI) */ #endif /* IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI) */
}
/***************************************************************************/ /***************************************************************************/
...@@ -126,9 +126,7 @@ void __init config_BSP(char *commandp, int size) ...@@ -126,9 +126,7 @@ void __init config_BSP(char *commandp, int size)
mach_sched_init = hw_timer_init; mach_sched_init = hw_timer_init;
m528x_uarts_init(); m528x_uarts_init();
m528x_fec_init(); m528x_fec_init();
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
m528x_qspi_init(); m528x_qspi_init();
#endif
} }
/***************************************************************************/ /***************************************************************************/
...@@ -166,15 +166,13 @@ static void __init m53xx_clk_init(void) ...@@ -166,15 +166,13 @@ static void __init m53xx_clk_init(void)
/***************************************************************************/ /***************************************************************************/
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
static void __init m53xx_qspi_init(void) static void __init m53xx_qspi_init(void)
{ {
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
/* setup QSPS pins for QSPI with gpio CS control */ /* setup QSPS pins for QSPI with gpio CS control */
writew(0x01f0, MCFGPIO_PAR_QSPI); writew(0x01f0, MCFGPIO_PAR_QSPI);
}
#endif /* IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI) */ #endif /* IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI) */
}
/***************************************************************************/ /***************************************************************************/
...@@ -219,9 +217,7 @@ void __init config_BSP(char *commandp, int size) ...@@ -219,9 +217,7 @@ void __init config_BSP(char *commandp, int size)
m53xx_clk_init(); m53xx_clk_init();
m53xx_uarts_init(); m53xx_uarts_init();
m53xx_fec_init(); m53xx_fec_init();
#if IS_ENABLED(CONFIG_SPI_COLDFIRE_QSPI)
m53xx_qspi_init(); m53xx_qspi_init();
#endif
#ifdef CONFIG_BDM_DISABLE #ifdef CONFIG_BDM_DISABLE
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment