Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp759201pxf; Wed, 7 Apr 2021 10:48:29 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyuCeFXktQsCiL/OPqTbDprmMIFeMwsghBqdgYOjlhmYSU9/NxHQvbYOGu+zQ7HVxKyE7Ei X-Received: by 2002:a02:a483:: with SMTP id d3mr2616756jam.3.1617817709720; Wed, 07 Apr 2021 10:48:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617817709; cv=none; d=google.com; s=arc-20160816; b=sQcZXWVdr8VabBkR0gCjlnnu23GnX0yrZeaO/wIPgtgj6AbyKtFAr9TQJwjkbYBH6Y lh4hItlXI9C6+bp49+QCH312JUZXdh+tKOF/fjbe+9yNveCzyZV2BU7/pdfNtv/yFe9i jXYRXARDMOhGgPWkDiF7btpnKTjBUPJf2JqzL3KC2jZvEDfOM1mkwz1qLp0IZQJmUMU/ 8L4ljYU5dihTJO1jTOxeDxdgIkLmKtxxwzkL1UfmoJ17fwisJrxiElrNrGz4bSNx6gev R6IbDI4ddxrLKtSF9qV79XVWQbZSrULeHNj4h5DY+Awv2frFmRHOZpjAOsduGfToHAFG 4ehw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:references:mime-version :message-id:in-reply-to:date:dkim-signature; bh=iAoCwns4tGDUg+Uupy+j5nADfE99sMComaQjSmba07U=; b=xfyUsTrW3JcVT9TqlF9fPP4XV5GwwJn6wpht84SKKMNRHpOzL16gJucwps5FpheZ32 QFSZz5mza1l18xDlJKUi9dPq/0AeLdhppIVFSdA9NidSO9xkYPpdnbVW0MPUGJqut4cl hedr1Uz5agwxKfWwXDxoCzEsiZOQJapHr6j2MRRykMfsZmZbpwXeKbx4rRTowxbmKl92 YQKD+3wUEXJ4CrP5LdWA0fK8gUcemXec/Xgn2lOylxaEvTQZ3sicqVnjLuj2wqGMfxbK XZ5c2SA690Cruil07UtAr+tZqmzqT1ec5GpCVbK+qO7QgwRjq1as0oPqhHGiHOU/Ocnq fGXg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b="RiWn/u2m"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y14si21980505ilu.81.2021.04.07.10.48.17; Wed, 07 Apr 2021 10:48:29 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b="RiWn/u2m"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1344546AbhDGDpM (ORCPT + 99 others); Tue, 6 Apr 2021 23:45:12 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47382 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1344439AbhDGDpL (ORCPT ); Tue, 6 Apr 2021 23:45:11 -0400 Received: from mail-yb1-xb4a.google.com (mail-yb1-xb4a.google.com [IPv6:2607:f8b0:4864:20::b4a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C468AC061756 for ; Tue, 6 Apr 2021 20:45:02 -0700 (PDT) Received: by mail-yb1-xb4a.google.com with SMTP id 125so19601734ybd.17 for ; Tue, 06 Apr 2021 20:45:02 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc; bh=iAoCwns4tGDUg+Uupy+j5nADfE99sMComaQjSmba07U=; b=RiWn/u2mZTBsRW/4i84DxQpGr9bI9wMIqSGA26L4TryZfHh2/SzOuISYwZZCiyTDCC N+cS/VK4cdvRl+f/QSKveQLdCa4g672T+pazc0IkCR31ZLwrRbZzlx2/4K/oMahavy2u 53O6fQYl9RTexvci0kG2f4c80VB5atBISmioOHhVi+KSYLj6XOjXC8jjxYUfiv/OzVeU uytuu5ytliEKP3WVGToSTDFyKxH/iTJR3RMjcPQGaNjXbpXpjeZKcEFdnl2SEf/2l8df ICGaAJngl6pC0VFmnnIPg0asiNDFH203XevwFGtHIe1Jl9O1NdoFgWzQaBtS6arZkJEo 0oJg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=iAoCwns4tGDUg+Uupy+j5nADfE99sMComaQjSmba07U=; b=DPPi+RVLBaZnU8ssBeyqTigPfqd1vzKUROKohJAaMDpgKT+IiaDl66XPMtiJEogetm VFrQymMmMUrcjdlQTs8ehP1D86sl8acNY98GoJfE6e7bjWdgo06tybvc2ZM3idfBA+yu 3Mwd2NLTCVE40sxkh5j4GYXnGqhjRQdUPcIgGcxWtMeFOGx+6BQhTVdfAl0fbi9KowVs 4JMMVSqV9a2NOvEsKC/DfWzU4X7yEOLQYKhd5I7oYcMk9JXfgL4XLUj932izjTT7N6xj 9WQQYV8voQDeMitIGT83KNyqaJtaEmYOkwgt6lYxcecNm4sk6zp6aB/B69q+8cGpda4G BNeg== X-Gm-Message-State: AOAM530EJqjqHBF2U+G6ERGY8IpCvDMw+4My8DNqLXobLYsjrUbnCcb+ aTQCfjRpMxF97PsoYrU33UIkP+b/lT3Ja4s= X-Received: from saravanak.san.corp.google.com ([2620:15c:2d:3:2dae:f92:7d76:4244]) (user=saravanak job=sendgmr) by 2002:a25:ab2f:: with SMTP id u44mr1756605ybi.158.1617767101994; Tue, 06 Apr 2021 20:45:01 -0700 (PDT) Date: Tue, 6 Apr 2021 20:44:54 -0700 In-Reply-To: <20210407034456.516204-1-saravanak@google.com> Message-Id: <20210407034456.516204-2-saravanak@google.com> Mime-Version: 1.0 References: <20210407034456.516204-1-saravanak@google.com> X-Mailer: git-send-email 2.31.1.295.g9ea45b61b8-goog Subject: [PATCH v1 1/2] driver core: Add dev_set_drv_sync_state() From: Saravana Kannan To: Greg Kroah-Hartman , Michael Turquette , Stephen Boyd Cc: Saravana Kannan , kernel-team@android.com, linux-clk@vger.kernel.org, linux-kernel@vger.kernel.org Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This can be used by frameworks to set the sync_state() helper functions for drivers that don't already have them set. Signed-off-by: Saravana Kannan --- include/linux/device.h | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/include/linux/device.h b/include/linux/device.h index ba660731bd25..35e8833ca16b 100644 --- a/include/linux/device.h +++ b/include/linux/device.h @@ -778,6 +778,18 @@ static inline bool dev_has_sync_state(struct device *dev) return false; } +static inline int dev_set_drv_sync_state(struct device *dev, + void (*fn)(struct device *dev)) +{ + if (!dev || !dev->driver) + return 0; + if (dev->driver->sync_state && dev->driver->sync_state != fn) + return -EBUSY; + if (!dev->driver->sync_state) + dev->driver->sync_state = fn; + return 0; +} + /* * High level routines for use by the bus drivers */ -- 2.31.1.295.g9ea45b61b8-goog