Thread (14 messages) 14 messages, 6 authors, 2016-09-28

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 this
patch:
quoted
quoted
quoted
a8f447be8056 ("mfd: Add resource managed APIs for
mfd_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
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help