Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp5427393imm; Wed, 12 Sep 2018 06:01:32 -0700 (PDT) X-Google-Smtp-Source: ANB0VdbS8D1Nh5CvLlacbFPuABpVQwlCGU3nBbzBzDhOj8+GcXwDs85rwObjpIOarl1oV6ynRrxI X-Received: by 2002:a17:902:8e81:: with SMTP id bg1-v6mr2166347plb.129.1536757292593; Wed, 12 Sep 2018 06:01:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1536757292; cv=none; d=google.com; s=arc-20160816; b=dvn6A9FA6vB/KMvmtceGMK2Mkfo9g5scU/v+LJu1ozjU6BtZm70LsN3D0djAb2DLji olVpQfykspUDU76WAt9hdmGofcNoUd8d5z09FjnmPk/5KHBpO09wZTNOkmpq7BcH+QvQ 9N6JprgFmfqpq9MyOyw2ywOXTbQUb7BDecFLWNBqerYbvDGlEPFpwP2GOu3RwqLfTJWA lya0MRUGiKv9sbxsh180E/dwSGulUKRj4UvRKQiQb5lqfqltkh6bQo0VtJ/W9CZyv9/3 SVru/TeV1RKiF/9pDEraDjAEbPVQFsVxupSDn+Vl5atnZYJzP+xSGp3Q93ya/Ud+DueM GYjw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=doOt6MvCFxEjQ6amDN7VFxjMhw7Rb31g6Fp2XG3fVJE=; b=qzUcZuE/Mx5pJjwjSv4xt6aLSzyqsHqTyjWz6hCfiNki1S4kl9ImRzWdqfpzjYuMOa GFG061Ita0ymEYZCJ4OvpHBAFkMOmgG3RDebQEK1+yhkCVZAUfNrIrZdDSYAFn0DjBQn Mh6Wlpss6Wgyo4tNaSX5Vnoiy3lYCsyzg4XnC0c3456M29xOxX8h+bqBUzG4WGMzBA70 ov9IyRwsijeLprFiYofNpZ9Y7dMQKsOcZYcduMqYtS0EblegKzvlkeneZk+zd2EflrnZ MYKxUjPWQVtynGZmUEQn4dhx8kZ/3bEDpyIuAEiqOBHNaIcg5kpIwdDgAPuVmXNJCIR9 XSbw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@lunn.ch header.s=20171124 header.b=hvvScPVY; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l64-v6si881721pge.420.2018.09.12.06.01.11; Wed, 12 Sep 2018 06:01:32 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@lunn.ch header.s=20171124 header.b=hvvScPVY; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726818AbeILSFa (ORCPT + 99 others); Wed, 12 Sep 2018 14:05:30 -0400 Received: from vps0.lunn.ch ([185.16.172.187]:60332 "EHLO vps0.lunn.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726359AbeILSFa (ORCPT ); Wed, 12 Sep 2018 14:05:30 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lunn.ch; s=20171124; h=In-Reply-To:Content-Type:MIME-Version:References:Message-ID:Subject:Cc:To:From:Date; bh=doOt6MvCFxEjQ6amDN7VFxjMhw7Rb31g6Fp2XG3fVJE=; b=hvvScPVYsnh87eLRHtklb39tL1HghPoqNtotgKxKvi82+6TxQ9h0bhAB/Saoq5mROS/sfBNaeiJ0Hyrpnb8bOyyYi0HE1DssrSVZTdlUUPKV29guekFtLAVzXAvYClR36TJdC+WBMMHyZJHdFm65MEb1Q1I5FTtUpFCv7adavhg=; Received: from andrew by vps0.lunn.ch with local (Exim 4.84_2) (envelope-from ) id 1g04lS-0006k4-K3; Wed, 12 Sep 2018 15:01:02 +0200 Date: Wed, 12 Sep 2018 15:01:02 +0200 From: Andrew Lunn To: Aditya Prayoga Cc: linux-gpio@vger.kernel.org, Thierry Reding , Linus Walleij , linux-pwm@vger.kernel.org, linux-kernel@vger.kernel.org, Richard Genoud , Ralph Sennhauser , Gregory CLEMENT , Gauthier Provost , Dennis Gilmore Subject: Re: [PATCH v2 1/1] gpio: mvebu: Add support for multiple PWM lines per GPIO chip Message-ID: <20180912130102.GB24595@lunn.ch> References: <1536727915-113932-1-git-send-email-aditya@kobol.io> <1536727915-113932-2-git-send-email-aditya@kobol.io> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1536727915-113932-2-git-send-email-aditya@kobol.io> User-Agent: Mutt/1.5.23 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org > static int mvebu_pwm_request(struct pwm_chip *chip, struct pwm_device *pwm) > { > struct mvebu_pwm *mvpwm = to_mvebu_pwm(chip); > struct mvebu_gpio_chip *mvchip = mvpwm->mvchip; > struct gpio_desc *desc; > + struct mvebu_pwm *counter; > unsigned long flags; > int ret = 0; > > spin_lock_irqsave(&mvpwm->lock, flags); > > - if (mvpwm->gpiod) { > - ret = -EBUSY; > - } else { > - desc = gpiochip_request_own_desc(&mvchip->chip, > - pwm->hwpwm, "mvebu-pwm"); > - if (IS_ERR(desc)) { > - ret = PTR_ERR(desc); > + counter = mvpwm; > + if (counter->gpiod) { > + counter = mvebu_pwm_get_avail_counter(); > + if (!counter) { > + ret = -EBUSY; I don't understand this bit of code. Please could you explain what is going on. > goto out; > } > > - ret = gpiod_direction_output(desc, 0); > - if (ret) { > - gpiochip_free_own_desc(desc); > - goto out; > - } > + pwm->chip_data = counter; > + } > > - mvpwm->gpiod = desc; > + desc = gpiochip_request_own_desc(&mvchip->chip, > + pwm->hwpwm, "mvebu-pwm"); > + if (IS_ERR(desc)) { > + ret = PTR_ERR(desc); > + goto out; > } > + > + ret = gpiod_direction_output(desc, 0); > + if (ret) { > + gpiochip_free_own_desc(desc); > + goto out; > + } > + > + regmap_update_bits(mvchip->regs, GPIO_BLINK_CNT_SELECT_OFF + > + mvchip->offset, BIT(pwm->hwpwm), > + counter->id ? BIT(pwm->hwpwm) : 0); > + regmap_read(mvchip->regs, GPIO_BLINK_CNT_SELECT_OFF + > + mvchip->offset, &counter->blink_select); > + > + counter->gpiod = desc; > out: > spin_unlock_irqrestore(&mvpwm->lock, flags); > return ret; > @@ -632,6 +666,11 @@ static void mvebu_pwm_free(struct pwm_chip *chip, struct pwm_device *pwm) > struct mvebu_pwm *mvpwm = to_mvebu_pwm(chip); > unsigned long flags; > > + if (pwm->chip_data) { > + mvpwm = (struct mvebu_pwm *) pwm->chip_data; > + pwm->chip_data = NULL; > + } > + > spin_lock_irqsave(&mvpwm->lock, flags); > gpiochip_free_own_desc(mvpwm->gpiod); > mvpwm->gpiod = NULL; > @@ -648,6 +687,9 @@ static void mvebu_pwm_get_state(struct pwm_chip *chip, > unsigned long flags; > u32 u; > > + if (pwm->chip_data) > + mvpwm = (struct mvebu_pwm *) pwm->chip_data; > + You should not need a cast here, if chip_data is a void *. What is pwm->chip_data is a NULL? Don't you then use an uninitialized mvpwm? Andrew