diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2018-06-05 19:20:22 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2018-06-05 19:20:22 -0400 |
commit | abf7dba7c4f77d781f6df50fefb19a64c5dc331f (patch) | |
tree | 38648731b502d5aec508f3b33f6616190e598eb6 /drivers/fpga/xilinx-spi.c | |
parent | 07c4dd3435aa387d3b58f4e941dc516513f14507 (diff) | |
parent | b23220fe054e92f616b82450fae8cd3ab176cc60 (diff) |
Merge tag 'char-misc-4.18-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc
Pull char/misc driver updates from Greg KH:
"Here is the "big" char and misc driver patches for 4.18-rc1.
It's not a lot of stuff here, but there are some highlights:
- coreboot driver updates
- soundwire driver updates
- android binder updates
- fpga big sync, mostly documentation
- lots of minor driver updates
All of these have been in linux-next for a while with no reported
issues"
* tag 'char-misc-4.18-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc: (81 commits)
vmw_balloon: fixing double free when batching mode is off
MAINTAINERS: Add driver-api/fpga path
fpga: clarify that unregister functions also free
documentation: fpga: move fpga-region.txt to driver-api
documentation: fpga: add bridge document to driver-api
documentation: fpga: move fpga-mgr.txt to driver-api
Documentation: fpga: move fpga overview to driver-api
fpga: region: kernel-doc fixes
fpga: bridge: kernel-doc fixes
fpga: mgr: kernel-doc fixes
fpga: use SPDX
fpga: region: change api, add fpga_region_create/free
fpga: bridge: change api, don't use drvdata
fpga: manager: change api, don't use drvdata
fpga: region: don't use drvdata in common fpga code
Drivers: hv: vmbus: Removed an unnecessary cast from void *
ver_linux: Drop redundant calls to system() to test if file is readable
ver_linux: Move stderr redirection from function parameter to function body
misc: IBM Virtual Management Channel Driver (VMC)
rpmsg: Correct support for MODULE_DEVICE_TABLE()
...
Diffstat (limited to 'drivers/fpga/xilinx-spi.c')
-rw-r--r-- | drivers/fpga/xilinx-spi.c | 20 |
1 files changed, 17 insertions, 3 deletions
diff --git a/drivers/fpga/xilinx-spi.c b/drivers/fpga/xilinx-spi.c index 9b62a4c2a3df..8d1945966533 100644 --- a/drivers/fpga/xilinx-spi.c +++ b/drivers/fpga/xilinx-spi.c | |||
@@ -143,6 +143,8 @@ static const struct fpga_manager_ops xilinx_spi_ops = { | |||
143 | static int xilinx_spi_probe(struct spi_device *spi) | 143 | static int xilinx_spi_probe(struct spi_device *spi) |
144 | { | 144 | { |
145 | struct xilinx_spi_conf *conf; | 145 | struct xilinx_spi_conf *conf; |
146 | struct fpga_manager *mgr; | ||
147 | int ret; | ||
146 | 148 | ||
147 | conf = devm_kzalloc(&spi->dev, sizeof(*conf), GFP_KERNEL); | 149 | conf = devm_kzalloc(&spi->dev, sizeof(*conf), GFP_KERNEL); |
148 | if (!conf) | 150 | if (!conf) |
@@ -165,13 +167,25 @@ static int xilinx_spi_probe(struct spi_device *spi) | |||
165 | return PTR_ERR(conf->done); | 167 | return PTR_ERR(conf->done); |
166 | } | 168 | } |
167 | 169 | ||
168 | return fpga_mgr_register(&spi->dev, "Xilinx Slave Serial FPGA Manager", | 170 | mgr = fpga_mgr_create(&spi->dev, "Xilinx Slave Serial FPGA Manager", |
169 | &xilinx_spi_ops, conf); | 171 | &xilinx_spi_ops, conf); |
172 | if (!mgr) | ||
173 | return -ENOMEM; | ||
174 | |||
175 | spi_set_drvdata(spi, mgr); | ||
176 | |||
177 | ret = fpga_mgr_register(mgr); | ||
178 | if (ret) | ||
179 | fpga_mgr_free(mgr); | ||
180 | |||
181 | return ret; | ||
170 | } | 182 | } |
171 | 183 | ||
172 | static int xilinx_spi_remove(struct spi_device *spi) | 184 | static int xilinx_spi_remove(struct spi_device *spi) |
173 | { | 185 | { |
174 | fpga_mgr_unregister(&spi->dev); | 186 | struct fpga_manager *mgr = spi_get_drvdata(spi); |
187 | |||
188 | fpga_mgr_unregister(mgr); | ||
175 | 189 | ||
176 | return 0; | 190 | return 0; |
177 | } | 191 | } |