[PATCH v4 2/2] mtd: mediatek: driver for MTK Smart Device Gen1 NAND
Jorge Ramirez
jorge.ramirez-ortiz at linaro.org
Tue May 10 08:18:29 PDT 2016
On 05/10/2016 10:59 AM, Boris Brezillon wrote:
> On Tue, 10 May 2016 10:45:31 -0400
> Jorge Ramirez<jorge.ramirez-ortiz at linaro.org> wrote:
>
>> >On 05/10/2016 08:13 AM, Boris Brezillon wrote:
>>>> > >>+struct mtk_ecc {
>>>>> > >> >+ struct device *dev;
>>>>> > >> >+ void __iomem *regs;
>>>>> > >> >+ struct clk *clk;
>>>>> > >> >+
>>>>> > >> >+ struct completion done;
>>>>> > >> >+ struct semaphore sem;
>>> > >You tried to explain me why you decided to go for a semaphore instead of
>>> > >a mutex, but I don't remember. Could you explain it again?
>>> > >If that's all about being interruptible, then you can use
>> >
>> >Just for flexibility, no other reason really.
>> >Neither the mutex nor the semaphore are actually needed in this driver.
>> >Not knowing how things are going to evolve in the upper layers of MTD I
>> >didn't feel comfortable taking a lock in a function and unlocking the
>> >mutex in a different function (which is the way this driver operates).
>> >with that in mind I opted for a semaphore since it can always be
>> >unlocked -if needed be- by a different thread.
> But that has nothing to do with possible evolutions in the MTD layer.
> The ECC engine resource can only have a single user at a time, hence
> the mutex approach. Sorry, but I don't understand the "flexibility"
> argument, but maybe I'm misunderstanding the different between a
> semaphore and a mutex.
mutex can only be unlocked by the same thread that locks it. if for some
reason (hypotetically speaking) the MTD wishes to unlock ecc engines and
implement an abort operation before running operations complete this
could guarantee that the ecc engine is left in an unlocked state. the
risk of having a mutex in this driver is that the lock/unlock happen in
_different_ function calls (which is always scary) with DMAs having to
complete in between so if the running thread was canceled before the
mutex protecting the resource was unlocked we would never be able to
unlock it....with a semaphore we could (any thread could unlock the
resource).
More information about the Linux-mediatek
mailing list