{"id":809878,"url":"http://patchwork.ozlabs.org/api/1.0/patches/809878/?format=json","project":{"id":7,"url":"http://patchwork.ozlabs.org/api/1.0/projects/7/?format=json","name":"Linux network development","link_name":"netdev","list_id":"netdev.vger.kernel.org","list_email":"netdev@vger.kernel.org","web_url":null,"scm_url":null,"webscm_url":null},"msgid":"<aee6f9e51843216733ebfb1072748eca21544cf6.1504570627.git.daniel@iogearbox.net>","date":"2017-09-05T00:24:31","name":"[iproute2,master,1/2] bpf: minor cleanups for bpf_trace_pipe","commit_ref":null,"pull_url":null,"state":"accepted","archived":true,"hash":"3cf96417b376dd8efb768b1045a9103db2c22d86","submitter":{"id":65705,"url":"http://patchwork.ozlabs.org/api/1.0/people/65705/?format=json","name":"Daniel Borkmann","email":"daniel@iogearbox.net"},"delegate":{"id":389,"url":"http://patchwork.ozlabs.org/api/1.0/users/389/?format=json","username":"shemminger","first_name":"stephen","last_name":"hemminger","email":"shemminger@vyatta.com"},"mbox":"http://patchwork.ozlabs.org/project/netdev/patch/aee6f9e51843216733ebfb1072748eca21544cf6.1504570627.git.daniel@iogearbox.net/mbox/","series":[{"id":1470,"url":"http://patchwork.ozlabs.org/api/1.0/series/1470/?format=json","date":"2017-09-05T00:24:30","name":"Two minor BPF updates","version":1,"mbox":"http://patchwork.ozlabs.org/series/1470/mbox/"}],"check":"pending","checks":"http://patchwork.ozlabs.org/api/patches/809878/checks/","tags":{},"headers":{"Return-Path":"<netdev-owner@vger.kernel.org>","X-Original-To":"patchwork-incoming@ozlabs.org","Delivered-To":"patchwork-incoming@ozlabs.org","Authentication-Results":"ozlabs.org;\n\tspf=none (mailfrom) smtp.mailfrom=vger.kernel.org\n\t(client-ip=209.132.180.67; helo=vger.kernel.org;\n\tenvelope-from=netdev-owner@vger.kernel.org;\n\treceiver=<UNKNOWN>)","Received":["from vger.kernel.org (vger.kernel.org [209.132.180.67])\n\tby ozlabs.org (Postfix) with ESMTP id 3xmSCW57MTz9sPs\n\tfor <patchwork-incoming@ozlabs.org>;\n\tTue,  5 Sep 2017 10:24:55 +1000 (AEST)","(majordomo@vger.kernel.org) by vger.kernel.org via listexpand\n\tid S1754070AbdIEAYt (ORCPT <rfc822;patchwork-incoming@ozlabs.org>);\n\tMon, 4 Sep 2017 20:24:49 -0400","from www62.your-server.de ([213.133.104.62]:49479 \"EHLO\n\twww62.your-server.de\" rhost-flags-OK-OK-OK-OK) by vger.kernel.org\n\twith ESMTP id S1754046AbdIEAYq (ORCPT\n\t<rfc822;netdev@vger.kernel.org>); Mon, 4 Sep 2017 20:24:46 -0400","from [92.105.166.74] (helo=localhost)\n\tby www62.your-server.de with esmtpsa\n\t(TLSv1.2:DHE-RSA-AES128-GCM-SHA256:128) (Exim 4.85_2)\n\t(envelope-from <daniel@iogearbox.net>)\n\tid 1dp1fZ-0008G3-HF; Tue, 05 Sep 2017 02:24:45 +0200"],"From":"Daniel Borkmann <daniel@iogearbox.net>","To":"stephen@networkplumber.org","Cc":"ast@fb.com, netdev@vger.kernel.org,\n\tDaniel Borkmann <daniel@iogearbox.net>","Subject":"[PATCH iproute2 master 1/2] bpf: minor cleanups for bpf_trace_pipe","Date":"Tue,  5 Sep 2017 02:24:31 +0200","Message-Id":"<aee6f9e51843216733ebfb1072748eca21544cf6.1504570627.git.daniel@iogearbox.net>","X-Mailer":"git-send-email 1.9.3","In-Reply-To":["<cover.1504570627.git.daniel@iogearbox.net>","<cover.1504570627.git.daniel@iogearbox.net>"],"References":["<cover.1504570627.git.daniel@iogearbox.net>","<cover.1504570627.git.daniel@iogearbox.net>"],"X-Authenticated-Sender":"daniel@iogearbox.net","X-Virus-Scanned":"Clear (ClamAV 0.99.2/23772/Mon Sep  4 22:37:02 2017)","Sender":"netdev-owner@vger.kernel.org","Precedence":"bulk","List-ID":"<netdev.vger.kernel.org>","X-Mailing-List":"netdev@vger.kernel.org"},"content":"Just minor nits, e.g. no need to fflush() and instead of returning\nright away, just break and close the fd.\n\nSigned-off-by: Daniel Borkmann <daniel@iogearbox.net>\n---\n lib/bpf.c | 19 +++++++++----------\n 1 file changed, 9 insertions(+), 10 deletions(-)","diff":"diff --git a/lib/bpf.c b/lib/bpf.c\nindex 5fd4928..7463fdc 100644\n--- a/lib/bpf.c\n+++ b/lib/bpf.c\n@@ -569,9 +569,9 @@ int bpf_trace_pipe(void)\n \t\t\"/trace\",\n \t\t0,\n \t};\n+\tint fd_in, fd_out = STDERR_FILENO;\n \tchar tpipe[PATH_MAX];\n \tconst char *mnt;\n-\tint fd;\n \n \tmnt = bpf_find_mntpt(\"tracefs\", TRACEFS_MAGIC, tracefs_mnt,\n \t\t\t     sizeof(tracefs_mnt), tracefs_known_mnts);\n@@ -582,8 +582,8 @@ int bpf_trace_pipe(void)\n \n \tsnprintf(tpipe, sizeof(tpipe), \"%s/trace_pipe\", mnt);\n \n-\tfd = open(tpipe, O_RDONLY);\n-\tif (fd < 0)\n+\tfd_in = open(tpipe, O_RDONLY);\n+\tif (fd_in < 0)\n \t\treturn -1;\n \n \tfprintf(stderr, \"Running! Hang up with ^C!\\n\\n\");\n@@ -591,15 +591,14 @@ int bpf_trace_pipe(void)\n \t\tstatic char buff[4096];\n \t\tssize_t ret;\n \n-\t\tret = read(fd, buff, sizeof(buff) - 1);\n-\t\tif (ret > 0) {\n-\t\t\tif (write(STDERR_FILENO, buff, ret) != ret)\n-\t\t\t\treturn -1;\n-\t\t\tfflush(stderr);\n-\t\t}\n+\t\tret = read(fd_in, buff, sizeof(buff));\n+\t\tif (ret > 0 && write(fd_out, buff, ret) == ret)\n+\t\t\tcontinue;\n+\t\tbreak;\n \t}\n \n-\treturn 0;\n+\tclose(fd_in);\n+\treturn -1;\n }\n \n static int bpf_gen_global(const char *bpf_sub_dir)\n","prefixes":["iproute2","master","1/2"]}