Re: [PATCH] mfd: ab8500-gpadc Add new GPADC driver

From: Mattias Wallin
Date: Wed Feb 02 2011 - 03:15:37 EST


On 02/01/2011 12:36 PM, Samuel Ortiz wrote:
As subdevices, I expect users to have an ab8500 pointer. So it would just be
one dereference.
I do not want users to have or use the ab8500 pointer at all. I would like to move it from the .h file into the ab8500-core.c eventually.

As I'm not familiar with your HW architecture, could you please describe how
those accessories would wire into the ab8500 core ?
The accessories can for example be a simple phone headset, a carkit and so on. A headset wire into the 3.5mm plug and gpadc can be used to understand whats plugged in. Our analog baseband chip ab8500 is a container of subfunctionality like audio codec, digital encoder, voltage regulators and so on.
The idea behind ab8500-core driver is to provide register access and interrupt management to the subdrivers implementing the subfunctionality. The gpadc driver is one these subdrivers. A headset driver becomes a subdriver of the gpadc wich is a subdriver to ab8500-core so the question is how far we should enforce these hierarchy of drivers.
In my opinion the line goes here. The gpadc provides a service to convert. Open for not only subdrivers and the rational is to reduce complexity.
If those devices really are independent drivers (i.e. not subdevices) needing
to get an A/D conversion from the ab8500 adc (I don't see how that can happen,
hence my above question), then it might make sense to use a conversion API
independent from any ab8500 pointer. But otherwise, I prefer this API rather
than the one in v2 of this patch.
You are absolutely right that really independent drivers of ab8500 will probably not be found and I understand your argument. But many parts in our platform have connections to ab8500 via regulators, clocks or other wires. The decision is instead based on design to reduce complexity. If a driver uses direct register access to ab8500 then it should be a subdriver (to enforce startup order for example) otherwise is is not required (in my oppinion). An accessory driver should easily be ported from other platforms and not be tied to ab8500.

Me and Arun got some feedback to keep our discussion internal first so sorry for keeping you out the last mails but the result is patch v2.

Thanks and regards,
Mattias Wallin
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/