Hi Dmitry, On 2/2/2011 2:03 PM, Dmitry Torokhov wrote: > Hi Anirudh, > > On Tue, Feb 01, 2011 at 07:17:43PM +0530, Anirudh Ghayal wrote: >> + >> +#include <linux/mfd/pmic8058.h> >> +#include <linux/input/pmic8058-vibrator.h> > > Where is this header file? Shouldn't it be part of this patch?
Looks like someone forgot "git add" on it. We will fix this in v3. > >> + >> +#define VIB_DRV 0x4A >> + >> +#define VIB_DRV_SEL_MASK 0xf8 >> +#define VIB_DRV_SEL_SHIFT 0x03 >> +#define VIB_DRV_EN_MANUAL_MASK 0xfc >> + >> +#define VIB_MAX_LEVEL_mV (3100) >> +#define VIB_MIN_LEVEL_mV (1200) >> +#define VIB_MAX_LEVELS (VIB_MAX_LEVEL_mV - VIB_MIN_LEVEL_mV) >> + >> +#define MAX_FF_SPEED 0xff >> + >> +/* >> + * struct pmic8058_vib - structure to hold vibrator data >> + * vib_input_dev: input device supporting force feedback >> + * work: work structure to set the vibration parameters >> + * dev: device supporting force feedback >> + * pdata: platform data >> + * pm_chip: reference to pmic chip to carry out read/write operations >> + * speed: speed of vibration set from userland >> + * state: state of vibrator >> + * level: level of vibration to set in the chip >> + * reg_vib_drv: VIB_DRV register value > > Hmm, this is kind of kerneldoc but not quite (kerneldoc's arguments > start with '@'). Ack. It will be fixed. >> + >> +static int __devinit pmic8058_vib_probe(struct platform_device *pdev) >> + >> +{ >> + struct pm8058_chip *pm_chip; >> + struct pmic8058_vib *vib; >> + const struct pmic8058_vibrator_pdata *pdata = pdev->dev.platform_data; >> + int rc; >> + u8 val; >> + >> + pm_chip = platform_get_drvdata(pdev); > > The parent should not abuse platform data of _this_ device, it belongs > to this driver. In fact you overwrite it with pmic8058_vib below, which > means that you can't unbind the driver and bind it again. > > Please find other way to pass pm_chip. This will be fixed through pmic8058 core driver, when we submit. We are aware of it, and the all the sub-device driver will be changed to do it properly once we release them again with pmic core driver submission. >> + >> + platform_set_drvdata(pdev, vib); >> + >> + rc = input_register_device(vib->vib_input_dev); >> + if (rc < 0) { >> + dev_dbg(&pdev->dev, "couldn't register input device\n"); >> + goto err_reg_input_dev; >> + } > > platform_set_drvdata(pdev, vib) should go here so you do not need to > clean it if input_register_device() fails. Ack >> + >> +static int __devexit pmic8058_vib_remove(struct platform_device *pdev) >> +{ >> + struct pmic8058_vib *vib = platform_get_drvdata(pdev); >> + >> + cancel_work_sync(&vib->work); >> + if (vib->state) >> + pmic8058_vib_set(vib, 0); > > This should probably be part of pmic8058_vib_close() method. > Ok. We will check and fix. >> + >> + input_unregister_device(vib->vib_input_dev); >> + kfree(vib); > > Need to call platform_set_drvdata(pdev, NULL); Ack. > > What about PM? Do you need to shut off vibration if device goes to sleep? Yes. Let me check and add it to v3 patch series. I will drop the PMIC8058 OTHC from v3 series, as Mark suggested to explore ASoC way of doing it. ---Trilok Soni -- Sent by a consultant of the Qualcomm Innovation Center, Inc. The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum. -- To unsubscribe from this list: send the line "unsubscribe linux-arm-msm" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html