Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1823938pxb; Wed, 10 Feb 2021 18:47:59 -0800 (PST) X-Google-Smtp-Source: ABdhPJw9FlllqG3jGkjSOt9EGgsSt5UDrbi+ojWqSReCU80kOPypVw6FS4T3PQ/E5W3Cah+UW4cM X-Received: by 2002:a17:906:a0c:: with SMTP id w12mr5897840ejf.211.1613011679429; Wed, 10 Feb 2021 18:47:59 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1613011679; cv=none; d=google.com; s=arc-20160816; b=PE1SywTR0sm2YGyrIAg1wXylZoN47Wg0IPe95tFSFVtP7s5+h+DtGtjBrb3U7CPW9s x9JaYcvlwHIV5Guw9XAkjph9EZdxzzujqzivAKlsf/YXy79e2wOagV1CbJGwpn4SovM+ qn3WPfdtgrKRO6e73x7KckrHQwsd6UXQZBtIfoYsfsyKORys7ZyDMHct1mqjd4/4ghR0 uBXb9XTnV71P5qOcX8DdGig69c3OVZBUcfZmzwNgVz6lAHucu6yTwJR+SmczZvks8/+7 YDIJw+3ua1ixS1WP6zV4u5P7dNbOq0nxPqXFjsyC7+wXP7y28EDIh5v4aKHNyfAvdCgv w2qw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=behYvwONvNWFO0BGED30xvXT529p8IBkLrJcULUF2I0=; b=NvcBfj7esBkqc+Bk+yf3W2ft+WbSQQF9QyACxn3L/EtteArWZzZzu61vsapKAloqrW U79mnrVdUCJeQ0DFc1xNZQWPvIHj575pyxiubrLRZsOwhxmSszPIgqf6PunsrMPGHqol FML6Omqt4u768qEzGyuOq3zUjUkvKOBtrjFjAL0zlOZc4BtN4EEIdby73GHtPI+6Nwer NaSyZU6mFQzGxIMzcs33g4AAm4XG0kRAikxGtMaTlWqV5t2k9YmOorkn9yvuKedSPKLs Wjypimfxe5134sqPqQZvsQaG9GwO8Z/WsZK9iGfv6rGmITIbGVUjnaOAs9ulbgyMUzA+ di5Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=gTovJbGO; 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=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i13si2528840ejy.297.2021.02.10.18.47.32; Wed, 10 Feb 2021 18:47:59 -0800 (PST) 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=@chromium.org header.s=google header.b=gTovJbGO; 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=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229575AbhBKCqq (ORCPT + 99 others); Wed, 10 Feb 2021 21:46:46 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59452 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229452AbhBKCqo (ORCPT ); Wed, 10 Feb 2021 21:46:44 -0500 Received: from mail-pg1-x530.google.com (mail-pg1-x530.google.com [IPv6:2607:f8b0:4864:20::530]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7C12DC06174A for ; Wed, 10 Feb 2021 18:46:04 -0800 (PST) Received: by mail-pg1-x530.google.com with SMTP id n10so2727804pgl.10 for ; Wed, 10 Feb 2021 18:46:04 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=behYvwONvNWFO0BGED30xvXT529p8IBkLrJcULUF2I0=; b=gTovJbGO32f9reHLqsnZKKg+eJsr1qnXr4h8Spqcjj2Qu9kXB7vdRUcX+3tSERCuos Lgvzv2qSOgEn2z9jv9HMIgTpKHXSZzrb7rRiny27qbLzn3r3ZyXsKP0pnYPjabRXi6k/ LBRKsHbyShsmzFtbLEvqVkDfc889+VTeqWKbs= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=behYvwONvNWFO0BGED30xvXT529p8IBkLrJcULUF2I0=; b=IBKz2tikQYVF1pC8H3jVcvbRZ8HOTE0jSVcG6tM98lr+z7BRvj3Qr2I3783UCP0jNZ P60Y0p0UsLAdpeiyRBHzxFYEFgQE3qT6hZa0djRQueadyHLau6VcsDQMK6cs2dLgRuux ab+1224O9ArnNuaiP+4+J/cp3eUHrVJREZF489GLqLoIg0B73MwrO7VrBRJlR7HO8wc0 CNI02Nc+EyN2PabsRVU1Ncd4tIRCvj6rpfQ4AzY7N7hSx1/KcCp2x+SbEi9kpWqnXU3B +UUcVovZItLdZebr/UTQunyHiKCPq+QbuZFKDynpE2rVfISACrP9vb0ncLDqHnY/z7j6 qSIg== X-Gm-Message-State: AOAM530oxKRpgIOI+1NHFGyZZrRKea5rq7FlaRCF/SFjArhXIR+0yYWP eUOrU3KZf282ao+SUdwwlNgxmw== X-Received: by 2002:a63:4f1e:: with SMTP id d30mr5888611pgb.203.1613011563990; Wed, 10 Feb 2021 18:46:03 -0800 (PST) Received: from smtp.gmail.com ([2620:15c:202:201:5533:1106:2710:3ce]) by smtp.gmail.com with ESMTPSA id o185sm2615920pfb.196.2021.02.10.18.46.02 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 10 Feb 2021 18:46:03 -0800 (PST) From: Stephen Boyd To: Jonathan Cameron Cc: linux-kernel@vger.kernel.org, linux-iio@vger.kernel.org, Dmitry Torokhov , Benson Leung , Guenter Roeck , Douglas Anderson , Gwendal Grignou , devicetree@vger.kernel.org, Rob Herring , Enric Balletbo i Serra Subject: [PATCH v6 0/3] iio: Add a ChromeOS EC MKBP proximity driver Date: Wed, 10 Feb 2021 18:45:58 -0800 Message-Id: <20210211024601.1963379-1-swboyd@chromium.org> X-Mailer: git-send-email 2.30.0.478.g8a0d178c01-goog MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This is a different approach to [1] where I tried to add this proximity sensor logic to the input subsystem. Instead, we'll take the approach of making a small IIO proximity driver that parses the EC switch bitmap to find out if the front proximity sensor is detecting something or not. This allows us to treat proximity sensors as IIO devices all the time in userspace instead of handling this switch on the EC via the input subsystem and then other proximity sensors via IIO. I propose this is all merged through IIO subsystem. Please ack the first patch so it can be merged that way. Changes from v5: * Picked up RB tag from Rob * Track state of switch and only push event if it's different Changes from v4: * Reduced binding and moved proximity node to mfd spi example * Dropped of_match_ptr() Changes from v3: * Added SPI and cros-ec wrapper nodes to yaml example * Ignore notifier registration return code that is always zero Changes from v2: * Check iio clock and use IIO time if not boottime Changes from v1: * Driver moved location * Put mkbp everywhere * Fixed up DT binding to not fail and make sure is a child of cros-ec * Simplified logic for sending a message * Dropped CONFIG_OF usage * Sorted includes [1] https://lore.kernel.org/r/20201205004709.3126266-1-swboyd@chromium.org Cc: Dmitry Torokhov Cc: Benson Leung Cc: Guenter Roeck Cc: Douglas Anderson Cc: Gwendal Grignou Cc: Cc: Rob Herring Cc: Enric Balletbo i Serra Stephen Boyd (3): platform/chrome: cros_ec: Add SW_FRONT_PROXIMITY MKBP define dt-bindings: iio: Add cros ec proximity yaml doc iio: proximity: Add a ChromeOS EC MKBP proximity driver .../google,cros-ec-mkbp-proximity.yaml | 37 +++ .../bindings/mfd/google,cros-ec.yaml | 7 + drivers/iio/proximity/Kconfig | 11 + drivers/iio/proximity/Makefile | 1 + .../iio/proximity/cros_ec_mkbp_proximity.c | 271 ++++++++++++++++++ .../linux/platform_data/cros_ec_commands.h | 1 + 6 files changed, 328 insertions(+) create mode 100644 Documentation/devicetree/bindings/iio/proximity/google,cros-ec-mkbp-proximity.yaml create mode 100644 drivers/iio/proximity/cros_ec_mkbp_proximity.c base-commit: 19c329f6808995b142b3966301f217c831e7cf31 -- https://chromeos.dev