2 * Cavium ThunderX SPI driver.
4 * Copyright (C) 2016 Cavium Inc.
5 * Authors: Jan Glauber <jglauber@cavium.com>
8 #include <linux/module.h>
10 #include <linux/spi/spi.h>
12 #include "spi-cavium.h"
14 #define DRV_NAME "spi-thunderx"
16 #define SYS_FREQ_DEFAULT 700000000 /* 700 Mhz */
18 static int thunderx_spi_probe(struct pci_dev
*pdev
,
19 const struct pci_device_id
*ent
)
21 struct device
*dev
= &pdev
->dev
;
22 struct spi_master
*master
;
26 master
= spi_alloc_master(dev
, sizeof(struct octeon_spi
));
30 p
= spi_master_get_devdata(master
);
32 ret
= pcim_enable_device(pdev
);
36 ret
= pci_request_regions(pdev
, DRV_NAME
);
40 p
->register_base
= pcim_iomap(pdev
, 0, pci_resource_len(pdev
, 0));
41 if (!p
->register_base
) {
46 p
->regs
.config
= 0x1000;
47 p
->regs
.status
= 0x1008;
49 p
->regs
.data
= 0x1080;
51 p
->clk
= devm_clk_get(dev
, NULL
);
53 ret
= PTR_ERR(p
->clk
);
57 ret
= clk_prepare_enable(p
->clk
);
61 p
->sys_freq
= clk_get_rate(p
->clk
);
63 p
->sys_freq
= SYS_FREQ_DEFAULT
;
64 dev_info(dev
, "Set system clock to %u\n", p
->sys_freq
);
66 master
->num_chipselect
= 4;
67 master
->mode_bits
= SPI_CPHA
| SPI_CPOL
| SPI_CS_HIGH
|
68 SPI_LSB_FIRST
| SPI_3WIRE
;
69 master
->transfer_one_message
= octeon_spi_transfer_one_message
;
70 master
->bits_per_word_mask
= SPI_BPW_MASK(8);
71 master
->max_speed_hz
= OCTEON_SPI_MAX_CLOCK_HZ
;
72 master
->dev
.of_node
= pdev
->dev
.of_node
;
74 pci_set_drvdata(pdev
, master
);
76 ret
= devm_spi_register_master(dev
, master
);
83 clk_disable_unprepare(p
->clk
);
84 pci_release_regions(pdev
);
85 spi_master_put(master
);
89 static void thunderx_spi_remove(struct pci_dev
*pdev
)
91 struct spi_master
*master
= pci_get_drvdata(pdev
);
94 p
= spi_master_get_devdata(master
);
98 clk_disable_unprepare(p
->clk
);
99 pci_release_regions(pdev
);
100 /* Put everything in a known state. */
101 writeq(0, p
->register_base
+ OCTEON_SPI_CFG(p
));
104 static const struct pci_device_id thunderx_spi_pci_id_table
[] = {
105 { PCI_DEVICE(PCI_VENDOR_ID_CAVIUM
, 0xa00b) },
109 MODULE_DEVICE_TABLE(pci
, thunderx_spi_pci_id_table
);
111 static struct pci_driver thunderx_spi_driver
= {
113 .id_table
= thunderx_spi_pci_id_table
,
114 .probe
= thunderx_spi_probe
,
115 .remove
= thunderx_spi_remove
,
118 module_pci_driver(thunderx_spi_driver
);
120 MODULE_DESCRIPTION("Cavium, Inc. ThunderX SPI bus driver");
121 MODULE_AUTHOR("Jan Glauber");
122 MODULE_LICENSE("GPL");