Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp462108rwr; Wed, 19 Apr 2023 08:45:41 -0700 (PDT) X-Google-Smtp-Source: AKy350ZifjqXK0gRJSI5rHAZg6hGcwLxhctMShKqNjt4GWDHSztn9emO9HYPUaSgsGD9KJO8JUWR X-Received: by 2002:a05:6a20:6a10:b0:ef:95de:b877 with SMTP id p16-20020a056a206a1000b000ef95deb877mr5196157pzk.10.1681919141208; Wed, 19 Apr 2023 08:45:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1681919141; cv=none; d=google.com; s=arc-20160816; b=CrS9atEFVR4SWt+xjANCkuBANYsULtjfyAY+AH0H+C6LOHyEFs+rFmzlHnTalTJQ4k 7zOUpQ5SjAa2umZ+zCV7NRD1RfIEozHdYuLSHAgGtR1u1VEs3yLyVNE4SbQVcH+95QzJ M5oxZNbsTqPrz32Kns9KeYZSjEnsB2pbKVXI73EjIqjwND0mQ6TuSqw4EwMl6R8Mj7b/ 4zr0cFZ71ihf42nZwl6YASitowZ0n0i0OkmhesCcGf8wSrTc4jDkwSl3FeGoPRjUoYp6 pfVTsq02WDlwbpswODTIXCwEZmnVFb2yhbGdHumwnUvXVnyHs5KScQF2JuaHTzd0n5ha poAw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :mime-version:accept-language:in-reply-to:references:message-id:date :thread-index:thread-topic:subject:cc:to:from; bh=91IKzK1lkvmuSu4uma0JhUzeBdfGyZPnOHySCaW+W3Y=; b=H4S8E9laSP2fWa6fABu00EA8uPGezp8a434v8E/lfjQ7HORd063JFyBdyvrHAArhj6 UPbAutWt08XjIZ+qhkY2Q4VUjETbQ6gRg3rxA8p95t9oP4EkRcdH4Wv05W1dYQB3NxJE Wm2fFwGQ0TIUdztQODdBAoWkCNiE6qQlZUnDAO/VjI8z0ob9Tj2FUg5rCCX8PDJH9ryB AB4spwY7VMGKvNqfLYh/nm1NzmHoaaEUTnI0dfClcP/6RP6+ClhSr8QVU4aYyFtMXI+h /VGfvc2WNw+HlGxFxiE5sCwlwtUQWsiRlXC9yH1XIiXhctZLxaDwnZfkM/bA2rJ3XPbi 9zBg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=aculab.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h128-20020a636c86000000b0051b1241625bsi16197901pgc.852.2023.04.19.08.45.27; Wed, 19 Apr 2023 08:45:41 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=aculab.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233689AbjDSPoZ convert rfc822-to-8bit (ORCPT + 99 others); Wed, 19 Apr 2023 11:44:25 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35434 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233630AbjDSPoJ (ORCPT ); Wed, 19 Apr 2023 11:44:09 -0400 Received: from eu-smtp-delivery-151.mimecast.com (eu-smtp-delivery-151.mimecast.com [185.58.85.151]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 163BEAD2D for ; Wed, 19 Apr 2023 08:43:48 -0700 (PDT) Received: from AcuMS.aculab.com (156.67.243.121 [156.67.243.121]) by relay.mimecast.com with ESMTP with both STARTTLS and AUTH (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id uk-mta-66-8kzx0OtrNuu2tXAPYOXeXQ-1; Wed, 19 Apr 2023 16:43:45 +0100 X-MC-Unique: 8kzx0OtrNuu2tXAPYOXeXQ-1 Received: from AcuMS.Aculab.com (10.202.163.6) by AcuMS.aculab.com (10.202.163.6) with Microsoft SMTP Server (TLS) id 15.0.1497.48; Wed, 19 Apr 2023 16:43:45 +0100 Received: from AcuMS.Aculab.com ([::1]) by AcuMS.aculab.com ([::1]) with mapi id 15.00.1497.048; Wed, 19 Apr 2023 16:43:45 +0100 From: David Laight To: 'Brad Spencer' , "netdev@vger.kernel.org" CC: "linux-kernel@vger.kernel.org" Subject: RE: netlink getsockopt() sets only one byte? Thread-Topic: netlink getsockopt() sets only one byte? Thread-Index: AQHZciCdeGKq7qWD/UKbta8L5WEwQ68yxwaw Date: Wed, 19 Apr 2023 15:43:45 +0000 Message-ID: <0c2ea86d55454b55a88db716f967dda4@AcuMS.aculab.com> References: In-Reply-To: Accept-Language: en-GB, en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-ms-exchange-transport-fromentityheader: Hosted x-originating-ip: [10.202.205.107] MIME-Version: 1.0 X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: aculab.com Content-Language: en-US Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8BIT X-Spam-Status: No, score=-0.9 required=5.0 tests=BAYES_00,PDS_BAD_THREAD_QP_64, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Brad Spencer > Sent: 18 April 2023 18:38 > > Calling getsockopt() on a netlink socket with SOL_NETLINK options that > use type int only sets the first byte of the int value but returns an > optlen equal to sizeof(int), at least on x86_64. > > > The detailed description: > > It looks like netlink_getsockopt() calls put_user() with a char* > pointer, and I think that causes it to copy only one byte from the val > result, despite len being sizeof(int). > > Is this the expected behaviour? The returned size is 4, after all, > and other int-sized socket options (outside of netlink) like > SO_REUSEADDR set all bytes of the int. It will be horribly broken on anything big-endian. David - Registered Address Lakeside, Bramley Road, Mount Farm, Milton Keynes, MK1 1PT, UK Registration No: 1397386 (Wales)