Received: by 2002:a05:6a10:d5a5:0:0:0:0 with SMTP id gn37csp2569509pxb; Fri, 8 Oct 2021 10:21:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxM27KLT2ssqneyjsN2a6AIcFitYXr1VT5ALVv+fNix2BRmcAhyp0hCAon7EED2kpnmi4a4 X-Received: by 2002:a17:90b:388c:: with SMTP id mu12mr13092875pjb.146.1633713688568; Fri, 08 Oct 2021 10:21:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1633713688; cv=none; d=google.com; s=arc-20160816; b=oJkEwbfh+TL4b1wiLHGolQJU9vsnXuV5WP4LD7tB8gpmn6XxuzP9xB2NMWaenTMl+/ EDmEiMIL9NYG+V2gk38RmCBODAsq6nawMNQ+7mx8hoPNsyfbDunUKD2er8+YWFxc/onr arKlKM/9vMQTMM6kakhR2ldr5dQGpRjSOFFYMGykzVRGFpyqVb7ghKW2fK4zwCVVYCeh pe7dLmSA2WQ68jyp63Cw0AuERj26zhEFg7RqlfCJ/uDwdCr/hBy39HZscjsnLxqf/NpU oe1/b0iR/uAL+CSO3/altVhNEMDmEkFQGFV6tTxc1KHtGf7LtaXDo/OBjNtQ7EEPjl6X ehzg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=RC8NsjUEXqr8DlSrGQ31Rme/dsWnKDm7N9NxMgrgBHo=; b=PquejdWAwxuOVus1I3TDDNh3XAMyiYBnqfMJYC0SVQIx9LuBTnmyeHvy1NwHuYIKd1 nAjVZRjbtJ1gQxRd4ujTedHNKaiwhDuKxx9PAS1jXNGnn5tykUu2BtFRV5GoFFXQNNWi Jn6n8NiPiLjTT60HoXyoSMcwmgAsz0dypOBh/ynJOf/bCW4Wr+CKryOfVr3YlVGLlZbh 5idEV4ZdyeyKyJ3/g2jEOOtEydSXMzw8As+Rn1t10V5e139bU4bATK+DtZSJZrwEup5G nVy2Ii9yoqegkaJHYtYftUxkAKnS8+hlMUdsUYf3Vnv1sWwG97r3PEvFajq4iI9fJ9xr L/Sg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h126si3578152pgc.276.2021.10.08.10.21.15; Fri, 08 Oct 2021 10:21:28 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232659AbhJHRWH (ORCPT + 99 others); Fri, 8 Oct 2021 13:22:07 -0400 Received: from brightrain.aerifal.cx ([216.12.86.13]:43190 "EHLO brightrain.aerifal.cx" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231215AbhJHRWH (ORCPT ); Fri, 8 Oct 2021 13:22:07 -0400 Date: Fri, 8 Oct 2021 13:20:10 -0400 From: Rich Felker To: Arnd Bergmann Cc: musl@lists.openwall.com, Michael Forney , ALSA Development Mailing List , Takashi Iwai , Baolin Wang , y2038 Mailman List , Linux Kernel Mailing List , Mark Brown , Baolin Wang Subject: Re: [musl] Re: [alsa-devel] [PATCH v7 8/9] ALSA: add new 32-bit layout for snd_pcm_mmap_status/control Message-ID: <20211008172010.GG7074@brightrain.aerifal.cx> References: <20211007160634.GB7074@brightrain.aerifal.cx> <20211007165158.GC7074@brightrain.aerifal.cx> <20211008120609.GE7074@brightrain.aerifal.cx> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.21 (2010-09-15) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Oct 08, 2021 at 02:37:12PM +0200, Arnd Bergmann wrote: > On Fri, Oct 8, 2021 at 2:06 PM Rich Felker wrote: > > On Fri, Oct 08, 2021 at 11:24:39AM +0200, Arnd Bergmann wrote: > > > > > > I've tried to understand this part of musl's convert_ioctl_struct(), but I just > > > can't figure out whether it does the conversion based the on the layout that > > > is currently used in the kernel, or based on the layout we should have been > > > using, and would use with the above fix. Rich, can you help me here? > > > > If the attempted 64-bit ioctl is missing (ENOTTY), it does the > > conversion to the legacy 32-bit one and retries with that, then > > converts the results back to the 64-bit form. > > I understand that it tries to do that. > > The part that I'm not sure about is which of the two possible > 64-bit forms it's using -- the broken one we have defined in the > kernel headers, or the one we were trying to define but failed. It's attempting to convert the intended format, not the one that the uapi headers defined. That is, it's taking padded-to-64-bit values at offsets 0 and 8 in __snd_pcm_mmap_control64, putting them at offsets 0 and 4 in the 32-bit struct, and padding them back to 64-bit in the result. Since applications would have been compiled with the buggy (unintended) version of the uapi headers, this will not match the application's layout of the struct. I haven't worked through what all the consequences of that are, but I think some fix is needed here in musl regardless of what happens on the kernel side. Rich