Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp1920906imm; Tue, 10 Jul 2018 10:01:47 -0700 (PDT) X-Google-Smtp-Source: AAOMgpeM4d3vi2agLQb+a8rwvoxtIaxpZkVn8jnw/p7aGZSr8xz9OjjJpdRBFgqXxlLTbPvM+1OE X-Received: by 2002:a65:6688:: with SMTP id b8-v6mr17874325pgw.24.1531242107435; Tue, 10 Jul 2018 10:01:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531242107; cv=none; d=google.com; s=arc-20160816; b=pBGj7frGuF2QJe0DXrdVHknTnze99GuWvJXMAO/jgQxkqDhJCJuzIFi8UR6bBYqLut opOWE149i11c7bkxksnoPe+3+lz6MQ46u8Q2Zp64EHQUXl+U95g941HVYhISblqGwWmn Hex3/WCBlLHuQY1WASPPdLB+jufEKx/8n+HnTDwX+rmJYwT8mFW4FXkOLRVghE50KVMp /55RBvP16dAkgofldjib7drG9TZr4LEmKmAq3O2V05987Uga9+F1fN3w1vPnOUrrVnXY 9kta/8vdtDayE7K5BIy8Jzzp5VYDEMyCzDY/PsAWOGlMENx4MhV4UZMuKnjq5ofTar6w CX1w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :content-language:accept-language:in-reply-to:references:message-id :date:thread-index:thread-topic:subject:cc:to:from :arc-authentication-results; bh=TPtUoWNzAE5f1mC8jN4PEQjtBq1XlSnFHiJKvGBV5OI=; b=R6HJW+xQVHSrYiMB1HLtXmWqkBDXjV3msCKJBaQfW1R5FKUdhhWE0/AaKmItSXFpoz bShrvwwvfzbotxGXAk5DwkmdoApdDb0gxDucIZMjYYvbaH69s6paVJUsXLx/KvJzVOn4 ElaPXVuFmVljaTdkErMIRgeLHtpxbxNKfYBzdXlvQfeuAX432eYuRdd/kYchufoZ5hqg abTCjYSvYNcy6gfV7CQe5X8Cd5+pxsB8gTVoOthmSPYb6d5BL3+NrhbGwwXoko2S1jg0 A5FnAdVl5WYdXHvLOf8a8q05VT9n+lG7q8YgStBgWSjGkWJdL7GMtZyb3EByEvo0YNPa m72w== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 200-v6si16637043pgf.378.2018.07.10.10.01.32; Tue, 10 Jul 2018 10:01:47 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S934526AbeGJQdb convert rfc822-to-8bit (ORCPT + 99 others); Tue, 10 Jul 2018 12:33:31 -0400 Received: from smtp-out6.electric.net ([192.162.217.187]:50464 "EHLO smtp-out6.electric.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S934101AbeGJQda (ORCPT ); Tue, 10 Jul 2018 12:33:30 -0400 Received: from 1fcvZt-0004di-UD by out6d.electric.net with emc1-ok (Exim 4.90_1) (envelope-from ) id 1fcvZv-0004jq-TR; Tue, 10 Jul 2018 09:33:27 -0700 Received: by emcmailer; Tue, 10 Jul 2018 09:33:27 -0700 Received: from [156.67.243.126] (helo=AcuMS.aculab.com) by out6d.electric.net with esmtps (TLSv1.2:ECDHE-RSA-AES256-SHA384:256) (Exim 4.90_1) (envelope-from ) id 1fcvZt-0004di-UD; Tue, 10 Jul 2018 09:33:25 -0700 Received: from AcuMS.Aculab.com (fd9f:af1c:a25b:0:43c:695e:880f:8750) by AcuMS.aculab.com (fd9f:af1c:a25b:0:43c:695e:880f:8750) with Microsoft SMTP Server (TLS) id 15.0.1347.2; Tue, 10 Jul 2018 17:35:04 +0100 Received: from AcuMS.Aculab.com ([fe80::43c:695e:880f:8750]) by AcuMS.aculab.com ([fe80::43c:695e:880f:8750%12]) with mapi id 15.00.1347.000; Tue, 10 Jul 2018 17:35:04 +0100 From: David Laight To: 'Martin KaFai Lau' , Okash Khawaja CC: Daniel Borkmann , Alexei Starovoitov , Yonghong Song , Jakub Kicinski , "David S. Miller" , "netdev@vger.kernel.org" , "kernel-team@fb.com" , "linux-kernel@vger.kernel.org" Subject: RE: [PATCH bpf 1/1] bpf: btf: Fix bitfield extraction for big endian Thread-Topic: [PATCH bpf 1/1] bpf: btf: Fix bitfield extraction for big endian Thread-Index: AQHUF7OfQA7M1iwM3EWyyOlGSAzC+KSIqAuw Date: Tue, 10 Jul 2018 16:35:04 +0000 Message-ID: <457ec72d8d7c4cdd8c112f9c8c91b0e7@AcuMS.aculab.com> References: <20180709002202.019053555@fb.com> <20180709004002.440153594@fb.com> <20180709183236.r4b7gzmev5h4lcbw@kafai-mbp.dhcp.thefacebook.com> In-Reply-To: <20180709183236.r4b7gzmev5h4lcbw@kafai-mbp.dhcp.thefacebook.com> Accept-Language: en-GB, en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-ms-exchange-transport-fromentityheader: Hosted x-originating-ip: [10.202.205.33] Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 8BIT MIME-Version: 1.0 X-Outbound-IP: 156.67.243.126 X-Env-From: David.Laight@ACULAB.COM X-Proto: esmtps X-Revdns: X-HELO: AcuMS.aculab.com X-TLS: TLSv1.2:ECDHE-RSA-AES256-SHA384:256 X-Authenticated_ID: X-PolicySMART: 3396946, 3397078 X-Virus-Status: Scanned by VirusSMART (c) X-Virus-Status: Scanned by VirusSMART (s) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Martin KaFai Lau > Sent: 09 July 2018 19:33 > On Sun, Jul 08, 2018 at 05:22:03PM -0700, Okash Khawaja wrote: > > When extracting bitfield from a number, btf_int_bits_seq_show() builds > > a mask and accesses least significant byte of the number in a way > > specific to little-endian. This patch fixes that by checking endianness > > of the machine and then shifting left and right the unneeded bits. > > > > Thanks to Martin Lau for the help in navigating potential pitfalls when > > dealing with endianess and for the final solution. > > > > Fixes: b00b8daec828 ("bpf: btf: Add pretty print capability for data with BTF type info") > > Signed-off-by: Okash Khawaja > > > > --- > > kernel/bpf/btf.c | 32 +++++++++++++++----------------- > > 1 file changed, 15 insertions(+), 17 deletions(-) > > > > --- a/kernel/bpf/btf.c > > +++ b/kernel/bpf/btf.c > > @@ -162,6 +162,8 @@ > > #define BITS_ROUNDDOWN_BYTES(bits) ((bits) >> 3) > > #define BITS_ROUNDUP_BYTES(bits) \ > > (BITS_ROUNDDOWN_BYTES(bits) + !!BITS_PER_BYTE_MASKED(bits)) > > +const int one = 1; > > +#define is_big_endian() ((*(char *)&one) == 0) > > > > #define BTF_INFO_MASK 0x0f00ffff > > #define BTF_INT_MASK 0x0fffffff > > @@ -991,16 +993,13 @@ static void btf_int_bits_seq_show(const > > void *data, u8 bits_offset, > > struct seq_file *m) > > { > > + u8 left_shift_bits, right_shift_bits; > Nit. > Although only max 64 bit int is allowed now (ensured by btf_int_check_meta), > it is better to use u16 such that it will be consistent to BTF_INT_BITS. Double-nit. Use 'int' or 'unsigned int'. Sub-word arithmetic will require extra instructions on almost everything except x86. David