From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753144AbbJZGtL (ORCPT ); Mon, 26 Oct 2015 02:49:11 -0400 Received: from szxga03-in.huawei.com ([119.145.14.66]:30159 "EHLO szxga03-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750955AbbJZGtJ (ORCPT ); Mon, 26 Oct 2015 02:49:09 -0400 Message-ID: <562DCCAB.5040007@huawei.com> Date: Mon, 26 Oct 2015 14:48:11 +0800 From: "Wangnan (F)" User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:31.0) Gecko/20100101 Thunderbird/31.6.0 MIME-Version: 1.0 To: , CC: , , , Arnaldo Carvalho de Melo , "David S. Miller" Subject: Re: [net-next PATCH] bpf: Output error message to logbuf when loading References: <1445841394-142865-1-git-send-email-wangnan0@huawei.com> In-Reply-To: <1445841394-142865-1-git-send-email-wangnan0@huawei.com> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.111.66.109] X-CFilter-Loop: Reflected X-Mirapoint-Virus-RAPID-Raw: score=unknown(0), refid=str=0001.0A090205.562DCCBA.0025,ss=1,re=0.000,recu=0.000,reip=0.000,cl=1,cld=1,fgs=0, ip=0.0.0.0, so=2013-05-26 15:14:31, dmn=2013-03-21 17:37:32 X-Mirapoint-Loop-Id: 74c76a37fe6ee11401e5ee9b245603d0 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2015/10/26 14:36, Wang Nan wrote: > Many reason can make bpf_prog_load() return EINVAL. This patch utilizes > logbuf passed from user to deliver the actual reason of failure. > > Without this patch, people is easy to forget fixing the "version" > section in their BPF objects. > > Signed-off-by: Wang Nan > Cc: Alexei Starovoitov > Cc: Arnaldo Carvalho de Melo > Cc: David S. Miller > --- > kernel/bpf/syscall.c | 41 ++++++++++++++++++++++++++++++++++++++--- > 1 file changed, 38 insertions(+), 3 deletions(-) > > diff --git a/kernel/bpf/syscall.c b/kernel/bpf/syscall.c > index 687dd6c..3a0e4e7 100644 > --- a/kernel/bpf/syscall.c > +++ b/kernel/bpf/syscall.c > @@ -574,6 +574,32 @@ struct bpf_prog *bpf_prog_get(u32 ufd) > } > EXPORT_SYMBOL_GPL(bpf_prog_get); > > +static void > +bpf_prog_load_note(union bpf_attr *attr, const char *fmt, ...) > +{ > + u32 log_level, log_size, log_len; > + char __user *log_ubuf = NULL; > + /* 64 chars should be long enough for a one line note. */ > + char log_buf[64]; > + va_list args; > + > + log_ubuf = (char __user *) (unsigned long) attr->log_buf; > + log_level = attr->log_level; > + log_size = sizeof(log_buf); > + if (attr->log_size < log_size) > + log_size = attr->log_size; > + > + if (log_level == 0 || !log_size || !log_ubuf) > + return; > + > + va_start(args, fmt); > + log_len = vscnprintf(log_buf, log_size, fmt, args); Don't need this log_len actually. Will send a v2. Thank you.