Received: by 10.223.176.5 with SMTP id f5csp1422832wra; Wed, 7 Feb 2018 19:43:05 -0800 (PST) X-Google-Smtp-Source: AH8x227UkGGlqp2PO1uE7PKrADJLqXaqcS1DmF4eVCt6NWjJOheNGBJelURd+MRs9dJyMhHKwTCZ X-Received: by 2002:a17:902:125:: with SMTP id 34-v6mr8353444plb.54.1518061384915; Wed, 07 Feb 2018 19:43:04 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518061384; cv=none; d=google.com; s=arc-20160816; b=DPS03dCcHSd5qVuM7rswRktgFddB8JmIMxKGOVQUWPMiOgMnXYxdPl4KVlbcBkDsiv j1yDu6tWOXo1kY989yVrB6rWaCd+ghBQVDDn6oZovn3OIubzpQpttnY0yQYKtYwCtDoa cQAl+Ja9Cn0ezDMOzoKcwnDkzzLRyjp8SQ1kF5e+Os6aVhwFLl6gqc9yIA237LJBNtpA aq7yfV5tzoozzlJTGHATGP4PbA3HSNdBWUKUKGbHw8PEg99vOrRo7kdZH07A6bMT/T37 Lq4WHvhbcCHCMvm7g10i5XydfzJ/HzrDDRNlqpQ3fy8iAKOXbfUP+ffDJmTHCvimUuot /LFw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :from:references:cc:to:subject:arc-authentication-results; bh=AVLdz4xiI/Wb2+6cIvVvp3AJP9Jz8rrppzICaePa/Gg=; b=vBlnelUIEbX1v2Ip/nIM1ihFkFGtEWbQ+Y5lk2AEKTQGW56c6oHrAPbXUQrMgOew33 hB5C8n7e5YIeClHQdAl95/Djf06LJO1eokqvIaAgplASQDC2eAcbSqQp2HMZvAkPWgZ8 W3itKSo3OzHt/ImgkAKFmfM3gJ+dgYf39Wfglhx9urXY2Yh0I8Z2LqSD2CskElgKepfi 37gxl832vx5xmTleh8SU5oRhbiU8Gyjw+ZaDGh3TKhOyKktxw28jygO/rvK/FhDqSb4I LTJT9PfC0e4I2elylQ7FSD3v/RKaH8wVtg5roEuDDNDSVjg0BPtRmItLO/CdgpLS5cBa T2Lw== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 204si584824pgb.389.2018.02.07.19.42.51; Wed, 07 Feb 2018 19:43:04 -0800 (PST) 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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751186AbeBHDmO (ORCPT + 99 others); Wed, 7 Feb 2018 22:42:14 -0500 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:41964 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1750810AbeBHDmN (ORCPT ); Wed, 7 Feb 2018 22:42:13 -0500 Received: from pps.filterd (m0098416.ppops.net [127.0.0.1]) by mx0b-001b2d01.pphosted.com (8.16.0.22/8.16.0.22) with SMTP id w183dYBM047828 for ; Wed, 7 Feb 2018 22:42:11 -0500 Received: from e06smtp12.uk.ibm.com (e06smtp12.uk.ibm.com [195.75.94.108]) by mx0b-001b2d01.pphosted.com with ESMTP id 2g0d9u34jr-1 (version=TLSv1.2 cipher=AES256-SHA bits=256 verify=NOT) for ; Wed, 07 Feb 2018 22:42:11 -0500 Received: from localhost by e06smtp12.uk.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Thu, 8 Feb 2018 03:42:09 -0000 Received: from b06cxnps4075.portsmouth.uk.ibm.com (9.149.109.197) by e06smtp12.uk.ibm.com (192.168.101.142) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; Thu, 8 Feb 2018 03:42:05 -0000 Received: from d06av21.portsmouth.uk.ibm.com (d06av21.portsmouth.uk.ibm.com [9.149.105.232]) by b06cxnps4075.portsmouth.uk.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id w183g4Lv46530586; Thu, 8 Feb 2018 03:42:04 GMT Received: from d06av21.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 714455204B; Thu, 8 Feb 2018 02:34:12 +0000 (GMT) Received: from [9.124.31.240] (unknown [9.124.31.240]) by d06av21.portsmouth.uk.ibm.com (Postfix) with ESMTP id BBD2F5203F; Thu, 8 Feb 2018 02:34:10 +0000 (GMT) Subject: Re: [PATCH 2/2] trace_uprobe: Simplify probes_seq_show() To: Kees Cook , wangnan0 Cc: Steven Rostedt , Ingo Molnar , Srikar Dronamraju , Oleg Nesterov , Masami Hiramatsu , Namhyung Kim , LKML , Ravi Bangoria References: <20180206093430.7550-1-ravi.bangoria@linux.vnet.ibm.com> <20180206093430.7550-2-ravi.bangoria@linux.vnet.ibm.com> From: Ravi Bangoria Date: Thu, 8 Feb 2018 09:13:54 +0530 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit Content-Language: en-US X-TM-AS-GCONF: 00 x-cbid: 18020803-0008-0000-0000-000004CA9340 X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 18020803-0009-0000-0000-00001E5E4538 Message-Id: <536fd857-2ee9-ef9c-4cc5-588ae1a07355@linux.vnet.ibm.com> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2018-02-08_01:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 malwarescore=0 suspectscore=0 phishscore=0 bulkscore=0 spamscore=0 clxscore=1015 lowpriorityscore=0 impostorscore=0 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1709140000 definitions=main-1802080029 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 02/08/2018 08:59 AM, Kees Cook wrote: > On Tue, Feb 6, 2018 at 8:34 PM, Ravi Bangoria > wrote: >> Simplify probes_seq_show() function. We are using %lx to display >> the offset and we don't prepend unnecessary 0s in the offset. >> >> Signed-off-by: Ravi Bangoria >> --- >> kernel/trace/trace_uprobe.c | 21 +++------------------ >> 1 file changed, 3 insertions(+), 18 deletions(-) >> >> diff --git a/kernel/trace/trace_uprobe.c b/kernel/trace/trace_uprobe.c >> index c2c965398893..c12a3957e1ee 100644 >> --- a/kernel/trace/trace_uprobe.c >> +++ b/kernel/trace/trace_uprobe.c >> @@ -602,24 +602,9 @@ static int probes_seq_show(struct seq_file *m, void *v) >> char c = is_ret_probe(tu) ? 'r' : 'p'; >> int i; >> >> - seq_printf(m, "%c:%s/%s", c, tu->tp.call.class->system, >> - trace_event_name(&tu->tp.call)); >> - seq_printf(m, " %s:", tu->filename); >> - >> - /* Don't print "0x (null)" when offset is 0 */ >> - if (tu->offset) { >> - seq_printf(m, "0x%lx", tu->offset); >> - } else { >> - switch (sizeof(void *)) { >> - case 4: >> - seq_printf(m, "0x00000000"); >> - break; >> - case 8: >> - default: >> - seq_printf(m, "0x0000000000000000"); >> - break; >> - } >> - } >> + seq_printf(m, "%c:%s/%s %s:0x%lx", c, tu->tp.call.class->system, >> + trace_event_name(&tu->tp.call), tu->filename, >> + tu->offset); > To keep the prepended zeros (and avoid the redundant 0x prefix): > > "...%#0*lx...", ... sizeof(void *) * 2, tu->offset); > > As in: > > + seq_printf(m, "%c:%s/%s %s:%#0*lx", c, tu->tp.call.class->system, > + trace_event_name(&tu->tp.call), tu->filename, > + sizeof(void *) * 2, tu->offset); This is useful, thanks Kees. @Wang, Do we really need those 0s? Won't just 0x0 should suffice? Here is the sample output...   # echo "p:probe_a/main /tmp/a.out:0x0" > uprobe_events Before patch:   # cat uprobe_events     p:probe_a/main /tmp/a.out:0x0000000000000000 After patch:   # cat uprobe_events     p:probe_a/main /tmp/a.out:0x0 Thanks, Ravi > -Kees > >> for (i = 0; i < tu->tp.nr_args; i++) >> seq_printf(m, " %s=%s", tu->tp.args[i].name, tu->tp.args[i].comm); >> -- >> 2.13.6 >> > >