Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp3648033imm; Mon, 2 Jul 2018 03:04:06 -0700 (PDT) X-Google-Smtp-Source: ADUXVKI9GrKTxewryhTbGJV2LHqqKfekVTCiq4w0oDPRrHoUVR56Yu16z67i5tfFXOXlyfORVWCA X-Received: by 2002:a17:902:ba97:: with SMTP id k23-v6mr25296661pls.259.1530525846336; Mon, 02 Jul 2018 03:04:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530525846; cv=none; d=google.com; s=arc-20160816; b=YjLWz4VkyxaJnxtRt1y62WyrsqLkpLWZePEl7vMYNH1L+FIpKj/lxhzGXW14sLh2Ha 6ed4i+bQEetxknz9p4ipJrq5tVdovTetDRYdJStVxUkJvRSf5jqzaF61Flg7aBMV5Jsq 2z+MGKzP3ZD/TC8uHXLYSdrf/hHhmGdM0etKG9VE9K1o0+D5ihTyAHsgUgRWdmy7pmcJ ZM07WMCnQFrwPnWje1ggda3w7zUrng7gS0zyjXI3gKLLWY3Fba4xWwj8gittL7yqVd1W cY3Zdry17+aVXz4Q2H9OVbuhY0Z6OUdCIMbdekVT+ys989dp50VjHAMQ+jb7dEqfOb9s IQaQ== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature :arc-authentication-results; bh=9ZFvG/lInhfPQWu5nPdz4fsjEiRt4NHAVL7HPyOBNUg=; b=c8EaJLyaf68GZJV2DyD3RfvvPjIt5Ac/ES0BGzi4HU7uTQrybxkKchNnlKlkzCDlb7 zqIsUOHsgqW3XqBXppR7mNAbUEW89htjUuv+7HC45mck+xzfEEOA43iF0kwrjHAxWFvK 7uDGTDx8c75/nGDh31hdRtyiRi3BxRloJ/mszGgxA/RQIsmGMeptipbtwOgwdBXQoYvB YVwgLVBAI3rqS41kTb8djG+8YmMgV9FVqX3bnk/8ksNQ23jEiX6JJmZBydIKSFgcGND7 c8+wvncr1UjgEg7ckUnp4qaVZqtvaY1DX67DaSqq2Ro7LU6i+0miq93LP+FPzSy3nGIS jn8g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=JPLi2aE7; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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. [209.132.180.67]) by mx.google.com with ESMTP id b135-v6si11958504pga.51.2018.07.02.03.03.22; Mon, 02 Jul 2018 03:04:06 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=JPLi2aE7; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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 S1754000AbeGBJrp (ORCPT + 99 others); Mon, 2 Jul 2018 05:47:45 -0400 Received: from mail-pf0-f182.google.com ([209.85.192.182]:39506 "EHLO mail-pf0-f182.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753942AbeGBJrk (ORCPT ); Mon, 2 Jul 2018 05:47:40 -0400 Received: by mail-pf0-f182.google.com with SMTP id s21-v6so7260319pfm.6; Mon, 02 Jul 2018 02:47:40 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=9ZFvG/lInhfPQWu5nPdz4fsjEiRt4NHAVL7HPyOBNUg=; b=JPLi2aE7M+ZoiQfUpAyZbbn911X0Gm/3CsSLxpYAWM+kv5dmGr7ytNM7lUPZ8D0Cdq GSvriJ3aInUJyPfHcASKJiCzitFs9t7+z5vFXC3ti9hhtYLr/ZiCCS6zw3R+oqKMtRw9 BUeA5SBN5F8py7Lxqtbxp/fp9sJebZy+n0NkUW5+UI+5OTfsb+Ng5Cedwjehfni7VHxu +Y3kxfh64+UVtnSVwDwG5axFrweDK8EKlkLboohHEI59R1XPnPWwMjE0mUEH8WJXM3Hf vWKrPCSuC3Y8i2qBzkN+Kh6eQpz5cM96KGjcELJS25LTAYUKI0lZAPWSrC/4kR1nM6V6 0Zjg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=9ZFvG/lInhfPQWu5nPdz4fsjEiRt4NHAVL7HPyOBNUg=; b=L0Yx1ibP8ZSlTAVz8bRck8Pqq33ckPMwyOKtx4StzOmVJnbHpYvZuBKz0x21uIf1yW 8no6C7JhxQvu2YVAtynMvlzlHVIEPdSctivJ/Y24d4fWoR/RJoL2fV20TMrVSZw1IYKY HBK/viFLWZQh7TQOLYicAxR0oWTrufxRAMTrwTQ53S1AFP4rNxKow+ao9ufOYePmJl2V Qz6f2Po5fzqnNIvlV/EkoMvL5xIh6vmLGDlgzz0/nXLwvpjJ0XZQyNsb1uSTIjGFRNZ2 NlWvgK80UpsUk2TQTvjP9kq2vfjHaKqyKC/lf8BOal6MkqJHZYBiLzYfrK76uOZqFCGR z3lw== X-Gm-Message-State: APt69E1yehcrVlwpQ2+jX/BcLKx3bwEQxW4KeD3pug0ElNqEWYQzS4Dv iSKUEEc71ozKtXMSbGUu+67Oyp05 X-Received: by 2002:a62:e00a:: with SMTP id f10-v6mr6723350pfh.208.1530524859598; Mon, 02 Jul 2018 02:47:39 -0700 (PDT) Received: from [192.168.0.77] ([211.196.191.92]) by smtp.gmail.com with ESMTPSA id y81-v6sm41381364pfd.178.2018.07.02.02.47.37 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 02 Jul 2018 02:47:38 -0700 (PDT) Subject: Re: [PATCH 3/4] samples/bpf: Check the error of write() and read() To: David Laight , Alexei Starovoitov , Daniel Borkmann Cc: Teng Qin , "netdev@vger.kernel.org" , "linux-kernel@vger.kernel.org" References: <1530522893-8961-1-git-send-email-treeze.taeung@gmail.com> <1530522893-8961-4-git-send-email-treeze.taeung@gmail.com> From: Taeung Song Message-ID: Date: Mon, 2 Jul 2018 18:47:35 +0900 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi David Laight, On 07/02/2018 06:25 PM, David Laight wrote: > From: Taeung Song >> Sent: 02 July 2018 10:15 >> test_task_rename() and test_urandom_read() >> can be failed during write() and read(), >> So check the result of them. >> >> Signed-off-by: Taeung Song >> --- >> samples/bpf/test_overhead_user.c | 20 +++++++++++++++----- >> 1 file changed, 15 insertions(+), 5 deletions(-) >> >> diff --git a/samples/bpf/test_overhead_user.c b/samples/bpf/test_overhead_user.c >> index 6caf47a..8a88d9c 100644 >> --- a/samples/bpf/test_overhead_user.c >> +++ b/samples/bpf/test_overhead_user.c >> @@ -6,6 +6,7 @@ >> */ >> #define _GNU_SOURCE >> #include >> +#include >> #include >> #include >> #include >> @@ -44,8 +45,12 @@ static void test_task_rename(int cpu) >> exit(1); >> } >> start_time = time_get_ns(); >> - for (i = 0; i < MAX_CNT; i++) >> - write(fd, buf, sizeof(buf)); >> + for (i = 0; i < MAX_CNT; i++) { >> + if (write(fd, buf, sizeof(buf)) < 0) { >> + printf("task rename failed: %s\n", strerror(errno)); >> + break; > > I'm not sure 'break' generates sensible output. > OK, it seems to be better to off on the above error case instead of break; >> + } >> + } > > What about partial writes?? > Hum.. do you mean just skipping several errors of the above write() ? >> printf("task_rename:%d: %lld events per sec\n", >> cpu, MAX_CNT * 1000000000ll / (time_get_ns() - start_time)); >> close(fd); >> @@ -55,7 +60,7 @@ static void test_urandom_read(int cpu) >> { >> __u64 start_time; >> char buf[4]; >> - int i, fd; >> + int i, fd, err = 0; >> >> fd = open("/dev/urandom", O_RDONLY); >> if (fd < 0) { >> @@ -63,8 +68,13 @@ static void test_urandom_read(int cpu) >> exit(1); >> } >> start_time = time_get_ns(); >> - for (i = 0; i < MAX_CNT; i++) >> - read(fd, buf, sizeof(buf)); >> + for (i = 0; i < MAX_CNT; i++) { >> + err = read(fd, buf, sizeof(buf)); >> + if (err < 0 || err >= sizeof(buf)) { > > Overlong reads indicate that something is seriously awry. > Short reads are valid - but maybe not expected. >> + printf("failed to read from /dev/urandom: %s\n", strerror(errno)); > > > strerror() won't give anything sensible unless err == -1; > You probably want to include the loop count. > >> + break; > > The summary print will be gibberish after break. > Ditto, will change the code to do exit(1); on the err == -1 case. What do you think about it ? Thanks, Taeung >> + } >> + } >> printf("urandom_read:%d: %lld events per sec\n", >> cpu, MAX_CNT * 1000000000ll / (time_get_ns() - start_time)); >> close(fd); >> -- >> 2.7.4 >