Commit d75a40e9 authored by Atsushi Nemoto's avatar Atsushi Nemoto Committed by Ralf Baechle

MIPS: TXx9: Make spi_eeprom.c more generic

Helper routines in txx9/rbtx4938/spi_eeprom.c is not TX4938 specific.
Move it to txx9/generic/ directory and make it works with SPI bus
number other than 0.
Signed-off-by: default avatarAtsushi Nemoto <anemo@mba.ocn.ne.jp>
Signed-off-by: default avatarRalf Baechle <ralf@linux-mips.org>

 create mode 100644 arch/mips/txx9/generic/spi_eeprom.c
 delete mode 100644 arch/mips/txx9/rbtx4938/spi_eeprom.c
parent e6332374
...@@ -8,5 +8,6 @@ obj-$(CONFIG_SOC_TX3927) += setup_tx3927.o irq_tx3927.o ...@@ -8,5 +8,6 @@ obj-$(CONFIG_SOC_TX3927) += setup_tx3927.o irq_tx3927.o
obj-$(CONFIG_SOC_TX4927) += mem_tx4927.o setup_tx4927.o irq_tx4927.o obj-$(CONFIG_SOC_TX4927) += mem_tx4927.o setup_tx4927.o irq_tx4927.o
obj-$(CONFIG_SOC_TX4938) += mem_tx4927.o setup_tx4938.o irq_tx4938.o obj-$(CONFIG_SOC_TX4938) += mem_tx4927.o setup_tx4938.o irq_tx4938.o
obj-$(CONFIG_TOSHIBA_FPCIB0) += smsc_fdc37m81x.o obj-$(CONFIG_TOSHIBA_FPCIB0) += smsc_fdc37m81x.o
obj-$(CONFIG_SPI) += spi_eeprom.o
EXTRA_CFLAGS += -Werror EXTRA_CFLAGS += -Werror
...@@ -18,29 +18,31 @@ ...@@ -18,29 +18,31 @@
#define AT250X0_PAGE_SIZE 8 #define AT250X0_PAGE_SIZE 8
/* register board information for at25 driver */ /* register board information for at25 driver */
int __init spi_eeprom_register(int chipid) int __init spi_eeprom_register(int busid, int chipid, int size)
{ {
static struct spi_eeprom eeprom = {
.name = "at250x0",
.byte_len = 128,
.page_size = AT250X0_PAGE_SIZE,
.flags = EE_ADDR1,
};
struct spi_board_info info = { struct spi_board_info info = {
.modalias = "at25", .modalias = "at25",
.max_speed_hz = 1500000, /* 1.5Mbps */ .max_speed_hz = 1500000, /* 1.5Mbps */
.bus_num = 0, .bus_num = busid,
.chip_select = chipid, .chip_select = chipid,
.platform_data = &eeprom,
/* Mode 0: High-Active, Sample-Then-Shift */ /* Mode 0: High-Active, Sample-Then-Shift */
}; };
struct spi_eeprom *eeprom;
eeprom = kzalloc(sizeof(*eeprom), GFP_KERNEL);
if (!eeprom)
return -ENOMEM;
strcpy(eeprom->name, "at250x0");
eeprom->byte_len = size;
eeprom->page_size = AT250X0_PAGE_SIZE;
eeprom->flags = EE_ADDR1;
info.platform_data = eeprom;
return spi_register_board_info(&info, 1); return spi_register_board_info(&info, 1);
} }
/* simple temporary spi driver to provide early access to seeprom. */ /* simple temporary spi driver to provide early access to seeprom. */
static struct read_param { static struct read_param {
int busid;
int chipid; int chipid;
int address; int address;
unsigned char *buf; unsigned char *buf;
...@@ -57,7 +59,8 @@ static int __init early_seeprom_probe(struct spi_device *spi) ...@@ -57,7 +59,8 @@ static int __init early_seeprom_probe(struct spi_device *spi)
dev_info(&spi->dev, "spiclk %u KHz.\n", dev_info(&spi->dev, "spiclk %u KHz.\n",
(spi->max_speed_hz + 500) / 1000); (spi->max_speed_hz + 500) / 1000);
if (read_param->chipid != spi->chip_select) if (read_param->busid != spi->master->bus_num ||
read_param->chipid != spi->chip_select)
return -ENODEV; return -ENODEV;
while (len > 0) { while (len > 0) {
/* spi_write_then_read can only work with small chunk */ /* spi_write_then_read can only work with small chunk */
...@@ -80,11 +83,12 @@ static struct spi_driver early_seeprom_driver __initdata = { ...@@ -80,11 +83,12 @@ static struct spi_driver early_seeprom_driver __initdata = {
.probe = early_seeprom_probe, .probe = early_seeprom_probe,
}; };
int __init spi_eeprom_read(int chipid, int address, int __init spi_eeprom_read(int busid, int chipid, int address,
unsigned char *buf, int len) unsigned char *buf, int len)
{ {
int ret; int ret;
struct read_param param = { struct read_param param = {
.busid = busid,
.chipid = chipid, .chipid = chipid,
.address = address, .address = address,
.buf = buf, .buf = buf,
......
obj-y += prom.o setup.o irq.o spi_eeprom.o obj-y += prom.o setup.o irq.o
EXTRA_CFLAGS += -Werror EXTRA_CFLAGS += -Werror
...@@ -111,6 +111,7 @@ static void __init rbtx4938_pci_setup(void) ...@@ -111,6 +111,7 @@ static void __init rbtx4938_pci_setup(void)
#define SEEPROM2_CS 0 /* IOC */ #define SEEPROM2_CS 0 /* IOC */
#define SEEPROM3_CS 1 /* IOC */ #define SEEPROM3_CS 1 /* IOC */
#define SRTC_CS 2 /* IOC */ #define SRTC_CS 2 /* IOC */
#define SPI_BUSNO 0
static int __init rbtx4938_ethaddr_init(void) static int __init rbtx4938_ethaddr_init(void)
{ {
...@@ -120,7 +121,7 @@ static int __init rbtx4938_ethaddr_init(void) ...@@ -120,7 +121,7 @@ static int __init rbtx4938_ethaddr_init(void)
int i; int i;
/* 0-3: "MAC\0", 4-9:eth0, 10-15:eth1, 16:sum */ /* 0-3: "MAC\0", 4-9:eth0, 10-15:eth1, 16:sum */
if (spi_eeprom_read(SEEPROM1_CS, 0, dat, sizeof(dat))) { if (spi_eeprom_read(SPI_BUSNO, SEEPROM1_CS, 0, dat, sizeof(dat))) {
printk(KERN_ERR "seeprom: read error.\n"); printk(KERN_ERR "seeprom: read error.\n");
return -ENODEV; return -ENODEV;
} else { } else {
...@@ -287,9 +288,9 @@ static int __init rbtx4938_spi_init(void) ...@@ -287,9 +288,9 @@ static int __init rbtx4938_spi_init(void)
.mode = SPI_MODE_1 | SPI_CS_HIGH, .mode = SPI_MODE_1 | SPI_CS_HIGH,
}; };
spi_register_board_info(&srtc_info, 1); spi_register_board_info(&srtc_info, 1);
spi_eeprom_register(SEEPROM1_CS); spi_eeprom_register(SPI_BUSNO, SEEPROM1_CS, 128);
spi_eeprom_register(16 + SEEPROM2_CS); spi_eeprom_register(SPI_BUSNO, 16 + SEEPROM2_CS, 128);
spi_eeprom_register(16 + SEEPROM3_CS); spi_eeprom_register(SPI_BUSNO, 16 + SEEPROM3_CS, 128);
gpio_request(16 + SRTC_CS, "rtc-rs5c348"); gpio_request(16 + SRTC_CS, "rtc-rs5c348");
gpio_direction_output(16 + SRTC_CS, 0); gpio_direction_output(16 + SRTC_CS, 0);
gpio_request(SEEPROM1_CS, "seeprom1"); gpio_request(SEEPROM1_CS, "seeprom1");
...@@ -298,7 +299,7 @@ static int __init rbtx4938_spi_init(void) ...@@ -298,7 +299,7 @@ static int __init rbtx4938_spi_init(void)
gpio_direction_output(16 + SEEPROM2_CS, 1); gpio_direction_output(16 + SEEPROM2_CS, 1);
gpio_request(16 + SEEPROM3_CS, "seeprom3"); gpio_request(16 + SEEPROM3_CS, "seeprom3");
gpio_direction_output(16 + SEEPROM3_CS, 1); gpio_direction_output(16 + SEEPROM3_CS, 1);
tx4938_spi_init(0); tx4938_spi_init(SPI_BUSNO);
return 0; return 0;
} }
......
...@@ -13,7 +13,22 @@ ...@@ -13,7 +13,22 @@
#ifndef __ASM_TXX9_SPI_H #ifndef __ASM_TXX9_SPI_H
#define __ASM_TXX9_SPI_H #define __ASM_TXX9_SPI_H
extern int spi_eeprom_register(int chipid); #include <linux/errno.h>
extern int spi_eeprom_read(int chipid, int address, unsigned char *buf, int len);
#ifdef CONFIG_SPI
int spi_eeprom_register(int busid, int chipid, int size);
int spi_eeprom_read(int busid, int chipid,
int address, unsigned char *buf, int len);
#else
static inline int spi_eeprom_register(int busid, int chipid, int size)
{
return -ENODEV;
}
static inline int spi_eeprom_read(int busid, int chipid,
int address, unsigned char *buf, int len)
{
return -ENODEV;
}
#endif
#endif /* __ASM_TXX9_SPI_H */ #endif /* __ASM_TXX9_SPI_H */
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