lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20110224031528.GB12139@angua.secretlab.ca>
Date:	Wed, 23 Feb 2011 20:15:28 -0700
From:	Grant Likely <grant.likely@...retlab.ca>
To:	Rob Herring <robherring2@...il.com>
Cc:	devicetree-discuss@...ts.ozlabs.org, linux-kernel@...r.kernel.org
Subject: Re: [RFC PATCH] ipmi: convert OF driver to platform driver

On Wed, Feb 23, 2011 at 03:37:59PM -0600, Rob Herring wrote:
> From: Rob Herring <rob.herring@...xeda.com>
> 
> of_bus is deprecated in favor of the plain platform bus. This patch
> merges the ipmi OF driver with the existing platform driver.
> 
> CONFIG_PPC_OF occurrances are removed or replaced with CONFIG_OF.
> 
> Compile tested with and without CONFIG_OF. Tested OF probe and
> default probe cases.
> 
> Signed-off-by: Rob Herring <rob.herring@...xeda.com>

Wow.  That driver does some weird things with the driver model that
really should be cleaned up.  That said, this change looks correct.
I'll add it to my tree and see how it goes.

I'm going to wait another day or so for comments, and then I'll push
my branch out to linux-next for testing.

g.

> 
> ---
>  drivers/char/ipmi/ipmi_si_intf.c |   70 ++++++++++++-------------------------
>  1 files changed, 23 insertions(+), 47 deletions(-)
> 
> diff --git a/drivers/char/ipmi/ipmi_si_intf.c b/drivers/char/ipmi/ipmi_si_intf.c
> index 7855f9f..dcfc39c 100644
> --- a/drivers/char/ipmi/ipmi_si_intf.c
> +++ b/drivers/char/ipmi/ipmi_si_intf.c
> @@ -66,13 +66,10 @@
>  #include <linux/string.h>
>  #include <linux/ctype.h>
>  #include <linux/pnp.h>
> -
> -#ifdef CONFIG_PPC_OF
>  #include <linux/of_device.h>
>  #include <linux/of_platform.h>
>  #include <linux/of_address.h>
>  #include <linux/of_irq.h>
> -#endif
>  
>  #define PFX "ipmi_si: "
>  
> @@ -116,13 +113,7 @@ static char *ipmi_addr_src_to_str[] = { NULL, "hotmod", "hardcoded", "SPMI",
>  
>  #define DEVICE_NAME "ipmi_si"
>  
> -static struct platform_driver ipmi_driver = {
> -	.driver = {
> -		.name = DEVICE_NAME,
> -		.bus = &platform_bus_type
> -	}
> -};
> -
> +static struct platform_driver ipmi_driver;
>  
>  /*
>   * Indexes into stats[] in smi_info below.
> @@ -308,9 +299,6 @@ static int pci_registered;
>  #ifdef CONFIG_ACPI
>  static int pnp_registered;
>  #endif
> -#ifdef CONFIG_PPC_OF
> -static int of_registered;
> -#endif
>  
>  static unsigned int kipmid_max_busy_us[SI_MAX_PARMS];
>  static int num_max_busy_us;
> @@ -1860,8 +1848,9 @@ static int hotmod_handler(const char *val, struct kernel_param *kp)
>  	return rv;
>  }
>  
> -static void __devinit hardcode_find_bmc(void)
> +static int __devinit hardcode_find_bmc(void)
>  {
> +	int ret = -ENODEV;
>  	int             i;
>  	struct smi_info *info;
>  
> @@ -1871,7 +1860,7 @@ static void __devinit hardcode_find_bmc(void)
>  
>  		info = smi_info_alloc();
>  		if (!info)
> -			return;
> +			return -ENOMEM;
>  
>  		info->addr_source = SI_HARDCODED;
>  		printk(KERN_INFO PFX "probing via hardcoded address\n");
> @@ -1924,10 +1913,12 @@ static void __devinit hardcode_find_bmc(void)
>  		if (!add_smi(info)) {
>  			if (try_smi_init(info))
>  				cleanup_one_si(info);
> +			ret = 0;
>  		} else {
>  			kfree(info);
>  		}
>  	}
> +	return ret;
>  }
>  
>  #ifdef CONFIG_ACPI
> @@ -2555,11 +2546,9 @@ static struct pci_driver ipmi_pci_driver = {
>  };
>  #endif /* CONFIG_PCI */
>  
> -
> -#ifdef CONFIG_PPC_OF
> -static int __devinit ipmi_of_probe(struct platform_device *dev,
> -			 const struct of_device_id *match)
> +static int __devinit ipmi_probe(struct platform_device *dev)
>  {
> +#ifdef CONFIG_OF
>  	struct smi_info *info;
>  	struct resource resource;
>  	const __be32 *regsize, *regspacing, *regshift;
> @@ -2569,6 +2558,9 @@ static int __devinit ipmi_of_probe(struct platform_device *dev,
>  
>  	dev_info(&dev->dev, "probing via device tree\n");
>  
> +	if (!dev->dev.of_match)
> +		return -EINVAL;
> +
>  	ret = of_address_to_resource(np, 0, &resource);
>  	if (ret) {
>  		dev_warn(&dev->dev, PFX "invalid address from OF\n");
> @@ -2601,7 +2593,7 @@ static int __devinit ipmi_of_probe(struct platform_device *dev,
>  		return -ENOMEM;
>  	}
>  
> -	info->si_type		= (enum si_type) match->data;
> +	info->si_type		= (enum si_type) dev->dev.of_match->data;
>  	info->addr_source	= SI_DEVICETREE;
>  	info->irq_setup		= std_irq_setup;
>  
> @@ -2632,13 +2624,15 @@ static int __devinit ipmi_of_probe(struct platform_device *dev,
>  		kfree(info);
>  		return -EBUSY;
>  	}
> -
> +#endif
>  	return 0;
>  }
>  
> -static int __devexit ipmi_of_remove(struct platform_device *dev)
> +static int __devexit ipmi_remove(struct platform_device *dev)
>  {
> +#ifdef CONFIG_OF
>  	cleanup_one_si(dev_get_drvdata(&dev->dev));
> +#endif
>  	return 0;
>  }
>  
> @@ -2653,16 +2647,15 @@ static struct of_device_id ipmi_match[] =
>  	{},
>  };
>  
> -static struct of_platform_driver ipmi_of_platform_driver = {
> +static struct platform_driver ipmi_driver = {
>  	.driver = {
> -		.name = "ipmi",
> +		.name = DEVICE_NAME,
>  		.owner = THIS_MODULE,
>  		.of_match_table = ipmi_match,
>  	},
> -	.probe		= ipmi_of_probe,
> -	.remove		= __devexit_p(ipmi_of_remove),
> +	.probe		= ipmi_probe,
> +	.remove		= __devexit_p(ipmi_remove),
>  };
> -#endif /* CONFIG_PPC_OF */
>  
>  static int wait_for_msg_done(struct smi_info *smi_info)
>  {
> @@ -3340,8 +3333,7 @@ static int __devinit init_ipmi_si(void)
>  		return 0;
>  	initialized = 1;
>  
> -	/* Register the device drivers. */
> -	rv = driver_register(&ipmi_driver.driver);
> +	rv = platform_driver_register(&ipmi_driver);
>  	if (rv) {
>  		printk(KERN_ERR PFX "Unable to register driver: %d\n", rv);
>  		return rv;
> @@ -3365,15 +3357,9 @@ static int __devinit init_ipmi_si(void)
>  
>  	printk(KERN_INFO "IPMI System Interface driver.\n");
>  
> -	hardcode_find_bmc();
> -
>  	/* If the user gave us a device, they presumably want us to use it */
> -	mutex_lock(&smi_infos_lock);
> -	if (!list_empty(&smi_infos)) {
> -		mutex_unlock(&smi_infos_lock);
> +	if (!hardcode_find_bmc())
>  		return 0;
> -	}
> -	mutex_unlock(&smi_infos_lock);
>  
>  #ifdef CONFIG_PCI
>  	rv = pci_register_driver(&ipmi_pci_driver);
> @@ -3396,11 +3382,6 @@ static int __devinit init_ipmi_si(void)
>  	spmi_find_bmc();
>  #endif
>  
> -#ifdef CONFIG_PPC_OF
> -	of_register_platform_driver(&ipmi_of_platform_driver);
> -	of_registered = 1;
> -#endif
> -
>  	/* We prefer devices with interrupts, but in the case of a machine
>  	   with multiple BMCs we assume that there will be several instances
>  	   of a given type so if we succeed in registering a type then also
> @@ -3548,17 +3529,12 @@ static void __exit cleanup_ipmi_si(void)
>  		pnp_unregister_driver(&ipmi_pnp_driver);
>  #endif
>  
> -#ifdef CONFIG_PPC_OF
> -	if (of_registered)
> -		of_unregister_platform_driver(&ipmi_of_platform_driver);
> -#endif
> +	platform_driver_unregister(&ipmi_driver);
>  
>  	mutex_lock(&smi_infos_lock);
>  	list_for_each_entry_safe(e, tmp_e, &smi_infos, link)
>  		cleanup_one_si(e);
>  	mutex_unlock(&smi_infos_lock);
> -
> -	driver_unregister(&ipmi_driver.driver);
>  }
>  module_exit(cleanup_ipmi_si);
>  
> -- 
> 1.7.1
> 
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ