mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 386a966f5c
			
		
	
	
		386a966f5c
		
	
	
	
	
		
			
			The driver core ignores the return value of struct bus_type::remove() because there is only little that can be done. To simplify the quest to make this function return void, let struct vio_driver::remove() return void, too. All users already unconditionally return 0, this commit makes it obvious that returning an error code is a bad idea. Note there are two nominally different implementations for a vio bus: one in arch/sparc/kernel/vio.c and the other in arch/powerpc/platforms/pseries/vio.c. This patch only adapts the powerpc one. Before this patch for a device that was bound to a driver without a remove callback vio_cmo_bus_remove(viodev) wasn't called. As the device core still considers the device unbound after vio_bus_remove() returns calling this unconditionally is the consistent behaviour which is implemented here. Signed-off-by: Uwe Kleine-König <uwe@kleine-koenig.org> Reviewed-by: Tyrel Datwyler <tyreld@linux.ibm.com> Acked-by: Lijun Pan <ljp@linux.ibm.com> Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> [mpe: Drop unneeded hvcs_remove() forward declaration, squash in change from sfr to drop ibmvnic_remove() forward declaration] Signed-off-by: Michael Ellerman <mpe@ellerman.id.au> Link: https://lore.kernel.org/r/20210225221834.160083-1-uwe@kleine-koenig.org
		
			
				
	
	
		
			93 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0-only
 | |
| /*
 | |
|  * Copyright (C) 2010 Michael Neuling IBM Corporation
 | |
|  *
 | |
|  * Driver for the pseries hardware RNG for POWER7+ and above
 | |
|  */
 | |
| 
 | |
| #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
 | |
| 
 | |
| #include <linux/kernel.h>
 | |
| #include <linux/module.h>
 | |
| #include <linux/hw_random.h>
 | |
| #include <asm/vio.h>
 | |
| 
 | |
| 
 | |
| static int pseries_rng_read(struct hwrng *rng, void *data, size_t max, bool wait)
 | |
| {
 | |
| 	u64 buffer[PLPAR_HCALL_BUFSIZE];
 | |
| 	int rc;
 | |
| 
 | |
| 	rc = plpar_hcall(H_RANDOM, (unsigned long *)buffer);
 | |
| 	if (rc != H_SUCCESS) {
 | |
| 		pr_err_ratelimited("H_RANDOM call failed %d\n", rc);
 | |
| 		return -EIO;
 | |
| 	}
 | |
| 	memcpy(data, buffer, 8);
 | |
| 
 | |
| 	/* The hypervisor interface returns 64 bits */
 | |
| 	return 8;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * pseries_rng_get_desired_dma - Return desired DMA allocate for CMO operations
 | |
|  *
 | |
|  * This is a required function for a driver to operate in a CMO environment
 | |
|  * but this device does not make use of DMA allocations, return 0.
 | |
|  *
 | |
|  * Return value:
 | |
|  *	Number of bytes of IO data the driver will need to perform well -> 0
 | |
|  */
 | |
| static unsigned long pseries_rng_get_desired_dma(struct vio_dev *vdev)
 | |
| {
 | |
| 	return 0;
 | |
| };
 | |
| 
 | |
| static struct hwrng pseries_rng = {
 | |
| 	.name		= KBUILD_MODNAME,
 | |
| 	.read		= pseries_rng_read,
 | |
| };
 | |
| 
 | |
| static int pseries_rng_probe(struct vio_dev *dev,
 | |
| 		const struct vio_device_id *id)
 | |
| {
 | |
| 	return hwrng_register(&pseries_rng);
 | |
| }
 | |
| 
 | |
| static void pseries_rng_remove(struct vio_dev *dev)
 | |
| {
 | |
| 	hwrng_unregister(&pseries_rng);
 | |
| }
 | |
| 
 | |
| static const struct vio_device_id pseries_rng_driver_ids[] = {
 | |
| 	{ "ibm,random-v1", "ibm,random"},
 | |
| 	{ "", "" }
 | |
| };
 | |
| MODULE_DEVICE_TABLE(vio, pseries_rng_driver_ids);
 | |
| 
 | |
| static struct vio_driver pseries_rng_driver = {
 | |
| 	.name = KBUILD_MODNAME,
 | |
| 	.probe = pseries_rng_probe,
 | |
| 	.remove = pseries_rng_remove,
 | |
| 	.get_desired_dma = pseries_rng_get_desired_dma,
 | |
| 	.id_table = pseries_rng_driver_ids
 | |
| };
 | |
| 
 | |
| static int __init rng_init(void)
 | |
| {
 | |
| 	pr_info("Registering IBM pSeries RNG driver\n");
 | |
| 	return vio_register_driver(&pseries_rng_driver);
 | |
| }
 | |
| 
 | |
| module_init(rng_init);
 | |
| 
 | |
| static void __exit rng_exit(void)
 | |
| {
 | |
| 	vio_unregister_driver(&pseries_rng_driver);
 | |
| }
 | |
| module_exit(rng_exit);
 | |
| 
 | |
| MODULE_LICENSE("GPL");
 | |
| MODULE_AUTHOR("Michael Neuling <mikey@neuling.org>");
 | |
| MODULE_DESCRIPTION("H/W RNG driver for IBM pSeries processors");
 |