Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp75579pxa; Thu, 13 Aug 2020 20:09:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz0LlXUHy/AvbnDOldcm2kbfnWmFsR5J0xWuWDvOCvFCA0SNy4STfbX/IfbOLeBMJRyDgFZ X-Received: by 2002:a17:906:6b87:: with SMTP id l7mr492251ejr.198.1597374555030; Thu, 13 Aug 2020 20:09:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1597374555; cv=none; d=google.com; s=arc-20160816; b=HvC5Vt3mnRe0ggV22dXDHUrQNO3NynbuOa8bHJJnmxhKdIrNxmaPA97bR762k8860k frJCkyW/6UFBVYz7yw/dZVBN0rdYJjBog1h2p2Azvv8MRTEapU0zjF5dbKszS3LuaZsE z96PRvkgjPTth+Vo/34tQovphKPmOBPsXum51qYfPYEkijEvv53eXAAhMNuwxW/Bwv/W 084Zu2ZCaWBBmc3X9F11G20YcK0WdatblUY+cAv1uccBSPsiMBa6Txlh6y1RFxQsSExZ FO+W9vADfUCar4wIRYAFgpsgGQBNvfEPneZIbDefgy76R8RHJToM2W/vzJqDwwi6f6tX QcAA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=NHFesHMh8urOzDGLF3BG3WK3USIsA8bYlNdGJPsk5Ng=; b=mXOPy6mrffyqIfNq6gTByQHxRUwt7lIO3TJh40p4utFuSQW3vHPlc6vyu24Z0HUiDH s929vipBGbp4qz9Lo/lzqaQCSCeVuxjNmng+mvGyfRY020unsWunTkqJe24E/EAKzyaT ORvW+lxR3jqHJZpqq5lzcfTZiFzw50bk3QWzm04fnmA00tWtvgTY86yT5VPPF+v6HwgF pCHMG8oUBKnAD7HgdAgNTXW4wDKLQzY5Fcw5D4wPVStDcmDR21q1nd9QkNKhgG//EKl3 6tU71E6tkzIzEO+ZiyeLUFnuQV2eR5s6Yv9RWrLGbXX4fHbKkgaMiuY96l7y8nna+5OR v1sg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b="rh3ATi/J"; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id l9si5078685ejq.65.2020.08.13.20.08.52; Thu, 13 Aug 2020 20:09:15 -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=@gmail.com header.s=20161025 header.b="rh3ATi/J"; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726995AbgHNDF4 (ORCPT + 99 others); Thu, 13 Aug 2020 23:05:56 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45900 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726567AbgHNDF4 (ORCPT ); Thu, 13 Aug 2020 23:05:56 -0400 Received: from mail-pf1-x443.google.com (mail-pf1-x443.google.com [IPv6:2607:f8b0:4864:20::443]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 43AF5C061757; Thu, 13 Aug 2020 20:05:56 -0700 (PDT) Received: by mail-pf1-x443.google.com with SMTP id d188so3868329pfd.2; Thu, 13 Aug 2020 20:05:56 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=NHFesHMh8urOzDGLF3BG3WK3USIsA8bYlNdGJPsk5Ng=; b=rh3ATi/Jsrq1HxJBRguZO4kmqL2V/TdhJk5favgLPL7HWvNQUmR2Ni0y3IVZwJrfAX ejo33Bk7e/UdSPuHFHYM+o6cbwJI7tyUbdS6mYzLuB0/3qRQ4gJ2gpE2NXvUwtMz3+Xc dmxZg5cgQLpWWFR5IVqTCAFyRM+tvNdw2zV5Pa9+4cBG6rcjMs6HXbqM96z2ULIH0fHC REdG7ln3zGff2azyxYnauJN1oYvId9w2fXidz4Yf8joXQWI5bx8o083sLBi5X0Zl+mqe ZeswtBmxzIT2IwVmSK954hkoGsg37eVw1xYa5Vo4d5mt9nEYhWB9lBr1p+S8R6J3v8Ii FDAQ== 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:in-reply-to :references:mime-version:content-transfer-encoding; bh=NHFesHMh8urOzDGLF3BG3WK3USIsA8bYlNdGJPsk5Ng=; b=hod3Wq+FyhwYPktMfCnFRMsbDBwoKs8lS4kIcPG3iGEMrJRugazZHG5oQWHNhExMx1 16Zx8PIRzkrHkvhAv8c6qcwUKzor7owrGf+82UZfemCNZZDHXiL04ISd5Nsi01G9Ina5 YI64McT1mTS/jFhR19BeWO/0jn6vBjrhv61flGv+34jhqGWLzqdsUs7spABceOSfEVcG 1keEJC6vienjXAScMdZ/jPs8TugPlMb5oBxvsNLcbvtiIivWdVlv6ojp7jZszaBcP9jz XWRKzimM1+l1WEiPWoDzfsM+ZNkcXForrLYPoFqAkrcFOJGKoHRWjBx+U+oLhiR/iThI n0wQ== X-Gm-Message-State: AOAM532UHIteOfTB9cvswqtKwwOizDYDLCnIqxOrW+h84InFcKVOvV04 hKBiKxMmQ2/g7RlCfD6UmcE/2d2P X-Received: by 2002:a63:1d23:: with SMTP id d35mr406907pgd.291.1597374355314; Thu, 13 Aug 2020 20:05:55 -0700 (PDT) Received: from sol.lan (106-69-161-64.dyn.iinet.net.au. [106.69.161.64]) by smtp.gmail.com with ESMTPSA id z3sm6522231pgk.49.2020.08.13.20.05.52 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 13 Aug 2020 20:05:54 -0700 (PDT) From: Kent Gibson To: linux-kernel@vger.kernel.org, linux-gpio@vger.kernel.org, bgolaszewski@baylibre.com, linus.walleij@linaro.org Cc: Kent Gibson Subject: [PATCH v4 18/20] tools: gpio: port gpio-event-mon to v2 uAPI Date: Fri, 14 Aug 2020 11:02:55 +0800 Message-Id: <20200814030257.135463-19-warthog618@gmail.com> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20200814030257.135463-1-warthog618@gmail.com> References: <20200814030257.135463-1-warthog618@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Port the gpio-event-mon tool to the latest GPIO uAPI. Signed-off-by: Kent Gibson --- tools/gpio/gpio-event-mon.c | 91 +++++++++++++++++++------------------ 1 file changed, 47 insertions(+), 44 deletions(-) diff --git a/tools/gpio/gpio-event-mon.c b/tools/gpio/gpio-event-mon.c index 1a303a81aeef..d6a831200c18 100644 --- a/tools/gpio/gpio-event-mon.c +++ b/tools/gpio/gpio-event-mon.c @@ -23,17 +23,16 @@ #include #include #include +#include "gpio-utils.h" int monitor_device(const char *device_name, unsigned int line, - uint32_t handleflags, - uint32_t eventflags, + struct gpio_v2_line_config *config, unsigned int loops) { - struct gpioevent_request req; - struct gpiohandle_data data; + struct gpio_v2_line_values values; char *chrdev_name; - int fd; + int cfd, lfd; int ret; int i = 0; @@ -41,44 +40,39 @@ int monitor_device(const char *device_name, if (ret < 0) return -ENOMEM; - fd = open(chrdev_name, 0); - if (fd == -1) { + cfd = open(chrdev_name, 0); + if (cfd == -1) { ret = -errno; fprintf(stderr, "Failed to open %s\n", chrdev_name); goto exit_free_name; } - req.lineoffset = line; - req.handleflags = handleflags; - req.eventflags = eventflags; - strcpy(req.consumer_label, "gpio-event-mon"); - - ret = ioctl(fd, GPIO_GET_LINEEVENT_IOCTL, &req); - if (ret == -1) { - ret = -errno; - fprintf(stderr, "Failed to issue GET EVENT " - "IOCTL (%d)\n", - ret); - goto exit_close_error; - } + ret = gpiotools_request_line(device_name, &line, 1, config, + "gpio-event-mon"); + if (ret < 0) + goto exit_device_close; + else + lfd = ret; /* Read initial states */ - ret = ioctl(req.fd, GPIOHANDLE_GET_LINE_VALUES_IOCTL, &data); - if (ret == -1) { - ret = -errno; - fprintf(stderr, "Failed to issue GPIOHANDLE GET LINE " - "VALUES IOCTL (%d)\n", + values.mask = 1; + values.bits = 0; + ret = gpiotools_get_values(lfd, &values); + if (ret < 0) { + fprintf(stderr, + "Failed to issue GPIO LINE GET VALUES IOCTL (%d)\n", ret); - goto exit_close_error; + goto exit_line_close; } fprintf(stdout, "Monitoring line %d on %s\n", line, device_name); - fprintf(stdout, "Initial line value: %d\n", data.values[0]); + fprintf(stdout, "Initial line value: %d\n", + gpiotools_test_bit(values.bits, 0)); while (1) { - struct gpioevent_data event; + struct gpio_v2_line_event event; - ret = read(req.fd, &event, sizeof(event)); + ret = read(lfd, &event, sizeof(event)); if (ret == -1) { if (errno == -EAGAIN) { fprintf(stderr, "nothing available\n"); @@ -96,12 +90,14 @@ int monitor_device(const char *device_name, ret = -EIO; break; } - fprintf(stdout, "GPIO EVENT %llu: ", event.timestamp); + fprintf(stdout, "GPIO EVENT at %llu on line %d (%d|%d) ", + event.timestamp, event.offset, event.line_seqno, + event.seqno); switch (event.id) { - case GPIOEVENT_EVENT_RISING_EDGE: + case GPIO_V2_LINE_EVENT_RISING_EDGE: fprintf(stdout, "rising edge"); break; - case GPIOEVENT_EVENT_FALLING_EDGE: + case GPIO_V2_LINE_EVENT_FALLING_EDGE: fprintf(stdout, "falling edge"); break; default: @@ -114,8 +110,11 @@ int monitor_device(const char *device_name, break; } -exit_close_error: - if (close(fd) == -1) +exit_line_close: + if (close(lfd) == -1) + perror("Failed to close line file"); +exit_device_close: + if (close(cfd) == -1) perror("Failed to close GPIO character device file"); exit_free_name: free(chrdev_name); @@ -140,15 +139,20 @@ void print_usage(void) ); } +#define EDGE_FLAGS \ + (GPIO_V2_LINE_FLAG_EDGE_RISING | \ + GPIO_V2_LINE_FLAG_EDGE_FALLING) + int main(int argc, char **argv) { const char *device_name = NULL; unsigned int line = -1; unsigned int loops = 0; - uint32_t handleflags = GPIOHANDLE_REQUEST_INPUT; - uint32_t eventflags = 0; + struct gpio_v2_line_config config; int c; + memset(&config, 0, sizeof(config)); + config.flags = GPIO_V2_LINE_FLAG_INPUT; while ((c = getopt(argc, argv, "c:n:o:dsrf?")) != -1) { switch (c) { case 'c': @@ -161,16 +165,16 @@ int main(int argc, char **argv) line = strtoul(optarg, NULL, 10); break; case 'd': - handleflags |= GPIOHANDLE_REQUEST_OPEN_DRAIN; + config.flags |= GPIO_V2_LINE_FLAG_OPEN_DRAIN; break; case 's': - handleflags |= GPIOHANDLE_REQUEST_OPEN_SOURCE; + config.flags |= GPIO_V2_LINE_FLAG_OPEN_SOURCE; break; case 'r': - eventflags |= GPIOEVENT_REQUEST_RISING_EDGE; + config.flags |= GPIO_V2_LINE_FLAG_EDGE_RISING; break; case 'f': - eventflags |= GPIOEVENT_REQUEST_FALLING_EDGE; + config.flags |= GPIO_V2_LINE_FLAG_EDGE_FALLING; break; case '?': print_usage(); @@ -182,11 +186,10 @@ int main(int argc, char **argv) print_usage(); return -1; } - if (!eventflags) { + if (!(config.flags & EDGE_FLAGS)) { printf("No flags specified, listening on both rising and " "falling edges\n"); - eventflags = GPIOEVENT_REQUEST_BOTH_EDGES; + config.flags |= EDGE_FLAGS; } - return monitor_device(device_name, line, handleflags, - eventflags, loops); + return monitor_device(device_name, line, &config, loops); } -- 2.28.0