Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp721718pxb; Tue, 2 Feb 2021 16:41:32 -0800 (PST) X-Google-Smtp-Source: ABdhPJwm8hR/mBDMPbng8eGgxSgjCFfIW/77GiMS0ZRJPH7uuz2tos/mQ2Fe1f+HiCHTLfvjTk4o X-Received: by 2002:a17:906:19c3:: with SMTP id h3mr560590ejd.429.1612312891909; Tue, 02 Feb 2021 16:41:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612312891; cv=none; d=google.com; s=arc-20160816; b=vu1guHkec9P1Sf3VE8gaSZSxZPzv78t35Lb0SV4pZXj5LweLPch6Zw5IRy0a5bKH2Z 9qLb5kdJNzkWqI5hZNDVa4+Pcu5Do5nrT5Syzv+ZV8nTJTZkr0XEaT5t6gLil/Kve3eL 5iYSo9g6pUfPrYF7wbi/oTHf3FqTGW8jzbCPJPmxpelkcBu6yxkMhsTH9ko5+pgX3t0p pAL5eedEQ6QO0IAa0URvH/T/Ei9WYOnp0bZZtwKhE3nuf5NgoKBUBJ1UoFlbTqmYSpfb VY5osGHEAlz0/dw62wqUc9RZigwppdBAO3GAAdj8z6uHAekLSpgGygGzczxjZcnE5EpT oaCA== 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=pqYAJ+nDIkVEKnS+v7ZhHGM7/OU8LF5OYhbV8HTOckE=; b=e+LgTAZBgL7F9xdCltu0tUFxRwWq83vI4v8tr8VP88YoPnyBQpuc3noqzwois4nbyt 2TrKcir3SsnUwXr/7T5YIP4ReawgYJKldUFr5CsfRxNd644kFsp4K5wGVXKN9xUeOHc2 KY2CJIK1HlH/62jHV3MIkX91Dpe1pyP3x9dmezKTZCJtiQgpWClCpkH6W0yrI8g7BwEs OcGjzrfcqFf4lqlnrC9CLheF5CV8u7NzyryvrHpYnNB+CfjmWAuiDkx4s2vJbT0SUHEY kcQSObeSdZsWHWMPCRFvZnxvn8w/dYdUEwcvWcfeiJYVUTZO2meYjb3K0vZ6yxC1pjdc tRUg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=EbqJ0Eur; 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 k17si304445ejg.72.2021.02.02.16.41.07; Tue, 02 Feb 2021 16:41:31 -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=EbqJ0Eur; 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 S238984AbhBBSr5 (ORCPT + 99 others); Tue, 2 Feb 2021 13:47:57 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54406 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238928AbhBBSpR (ORCPT ); Tue, 2 Feb 2021 13:45:17 -0500 Received: from mail-pg1-x532.google.com (mail-pg1-x532.google.com [IPv6:2607:f8b0:4864:20::532]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AE746C06174A for ; Tue, 2 Feb 2021 10:44:36 -0800 (PST) Received: by mail-pg1-x532.google.com with SMTP id n10so15450505pgl.10 for ; Tue, 02 Feb 2021 10:44:36 -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=pqYAJ+nDIkVEKnS+v7ZhHGM7/OU8LF5OYhbV8HTOckE=; b=EbqJ0Eurb13i9Kw7vv82CpFT7VlQSyoOtUH5W4u37wAbfax4UUXya1SmKJ0iwKaSfl VxqsOSzQDWUmkiJI4xt6F6HBcRKZy5gKku7bXr0dp7tUWLHFYIvMJDmUXHVs0bRIGASq qFzeb8ioYMyL4PqV4ZhFRHd8THUyK4izEz8XY= 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=pqYAJ+nDIkVEKnS+v7ZhHGM7/OU8LF5OYhbV8HTOckE=; b=RJDeTPvvChbUf7Hp9C5Mb6jh1VpyMNjstKbCo1QuxIV7UbC/cp+NYL+GKTNlCacOes aZoeOwJ77HnB7sJdkd8nTMXeANhPFj29HmRW+HMA/MzBOR42GqdQS5b9urfjERp2Kh/l wI8kQFdDVnGas30qQQBeyfh20SsMbWxJGakBRne1b+saG/MPCnJdAI6SwA5m/oYwZgtB rNhj0vV/vTyeo+tNxpreSy/gQj6hks3GoV487GDsrnb40nkNg3w+uoVxPPNVrPLtMsiD lCL1Umfer0IQD2xMKhTWD550O3W668W2eaLpwXLN5cZkAPF9g3MxUnUweQBrU3oiUs7F 4xpA== X-Gm-Message-State: AOAM533FkiyA0sAQCyhK1l78dZs46D3+I4wVb5XfRtg+NIaSryaMS3Iq XWwMyl8MLRMjFu8XaEF5sOds5+jR6nJKQQ== X-Received: by 2002:a63:2009:: with SMTP id g9mr23088703pgg.219.1612291476245; Tue, 02 Feb 2021 10:44:36 -0800 (PST) Received: from smtp.gmail.com ([2620:15c:202:201:3571:bd6e:ee19:b59f]) by smtp.gmail.com with ESMTPSA id b21sm23159859pfb.45.2021.02.02.10.44.34 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 02 Feb 2021 10:44:35 -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: [PATCHv4 0/3] iio: Add a ChromeOS EC MKBP proximity driver Date: Tue, 2 Feb 2021 10:44:31 -0800 Message-Id: <20210202184434.42644-1-swboyd@chromium.org> X-Mailer: git-send-email 2.30.0.365.g02bc693789-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 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 | 46 ++++ .../bindings/mfd/google,cros-ec.yaml | 3 + drivers/iio/proximity/Kconfig | 11 + drivers/iio/proximity/Makefile | 1 + .../iio/proximity/cros_ec_mkbp_proximity.c | 242 ++++++++++++++++++ .../linux/platform_data/cros_ec_commands.h | 1 + 6 files changed, 304 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