Re: [PATCH v5 1/4] mfd: mxs-lradc: Add support for mxs-lradc MFD
From: Lee Jones <hidden>
Date: 2016-09-28 23:58:17
Also in:
linux-iio, lkml
On Tue, 27 Sep 2016, Dmitry Torokhov wrote:
On September 27, 2016 11:50:00 AM PDT, Lee Jones [off-list ref] wrote:quoted
On Sat, 17 Sep 2016, Ksenija Stanojević wrote:quoted
On Wed, Aug 31, 2016 at 2:05 PM, Lee Jones [off-list ref]wrote:quoted
quoted
On Thu, 18 Aug 2016, Ksenija Stanojevic wrote:quoted
Add core files for mxs-lradc MFD driver. Note: this patch won't compile in iio/testing without thispatch:quoted
quoted
quoted
a8f447be8056 ("mfd: Add resource managed APIs formfd_add_devices")quoted
quoted
quoted
Signed-off-by: Ksenija Stanojevic <redacted> --- Changes in v5: - use DEFINE_RES_MEM - don't pass ioreammaped adress to platform cells - move comment outside of struct mxs_lradc - change type of argument in mxs_lradc_reg_set,mxs_lradc_reg_clear,quoted
quoted
quoted
mxs_lradc_reg_wrt (struct mxs_lradc * -> void __iomem *) Changes in v4: - update copyright - use DEFINE_RES_IRQ_NAMED - remove mxs_lradc_add_device function - use struct mfd_cell in static form - improve spacing - remove unnecessary comment - remove platform_get_irq - remove touch_ret and use ret instead - rename use_touchscreen to touchscreen_wire - use goto statements - remove irq[13], irq_count and irq_name from struct mxs_lradc - remove all defines from inside the struct definition Changes in v3: - add note to commit message - move switch statement into if(touch_ret == 0) branch - add MODULE_AUTHOR Changes in v2: - do not change spacing in Kconfig - make struct mfd_cell part of struct mxs_lradc - use switch instead of if in mxs_lradc_irq_mask - use only necessary header files in mxs_lradc.h - use devm_mfd_add_device - use separate function to register mfd device - change licence to GPL - add copyright drivers/mfd/Kconfig | 17 +++ drivers/mfd/Makefile | 1 + drivers/mfd/mxs-lradc.c | 255++++++++++++++++++++++++++++++++++++++++++quoted
quoted
quoted
include/linux/mfd/mxs-lradc.h | 194++++++++++++++++++++++++++++++++quoted
quoted
quoted
4 files changed, 467 insertions(+) create mode 100644 drivers/mfd/mxs-lradc.c create mode 100644 include/linux/mfd/mxs-lradc.h[...]quoted
quoted
quoted
+static int mxs_lradc_probe(struct platform_device *pdev) +{ + const struct of_device_id *of_id; + struct device *dev = &pdev->dev; + struct device_node *node = dev->of_node; + struct mxs_lradc *lradc; + struct mfd_cell *cells = NULL; + int ret = 0; + u32 ts_wires = 0; + + lradc = devm_kzalloc(&pdev->dev, sizeof(*lradc),GFP_KERNEL);quoted
quoted
quoted
+ if (!lradc) + return -ENOMEM; + + of_id = of_match_device(mxs_lradc_dt_ids, &pdev->dev); + lradc->soc = (enum mxs_lradc_id)of_id->data;Unnecessary cast.If I remove the cast I get this error: drivers/mfd/mxs-lradc.c:148:13: error: incompatible types when assigning to type ‘enum mxs_lradc_id’ from type ‘const void * const’Ah, because it's a const. Fair enough.No, it's because void * has to be cast to a non-pointer data type explicitly.
You're right. My bad! I was getting confused by the fact that you don't need to cast when you allocate a value *to* a void *. Senior moment, please ignore! -- Lee Jones Linaro STMicroelectronics Landing Team Lead Linaro.org │ Open source software for ARM SoCs Follow Linaro: Facebook | Twitter | Blog