Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp502467pxb; Tue, 19 Oct 2021 07:18:00 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxLKOWT6Og7msIYQ4tB8nu0GJKP/CrJms+1KSxYHJrmhcw0g8iDEjPTOEvQKUQQOHUg3P/y X-Received: by 2002:a17:903:1252:b0:13d:f3f6:2e1c with SMTP id u18-20020a170903125200b0013df3f62e1cmr33621168plh.73.1634653080067; Tue, 19 Oct 2021 07:18:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634653080; cv=none; d=google.com; s=arc-20160816; b=ww87cja9fKE8dx8P8ZI2mrvoslAvnc4Y+H0tgHjZ3qP6fFCrN96LUDt31mPReI7plB eoGLN2Bp0uUsZI+EVvXE2AYNCN6pZiga9Unj3uuHllcirZ8wUUti5LGryWyLr1umCzKX +tnmAXi11sChDrFiTyPbUcEtL6sSShKvry95EWrjhLqwNHb7tZ+TYjyLs7ConfVDkiKb pwmRF6aBFv0DxVXHNO9yAdKDpms5K75OrL9rhJhB0qe+/x+0mIFsP8/hE1O/qQN2JZd8 /evkvPN7lppJEaaiKOo5j2VbXa6m965ojEqTrAfZf+XTY1odTYInDptjFKPelfBal6SF yDtg== 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=rowoMKw+Ve8yWsMBLnT4xHyW2wR6Cpw7Qpwx05QVips=; b=kwngnYj2Y7BSK99fLtxQvyRnJYP+gw3C3BP9mQNaNiwdHAC3/SAbx3RJY4zdlShzh7 28UVPaNlqdumOqERcP+TSvkVrUClBkrEtDFZjNBgvfjen1/KQ0mJFeyeRN5t+1/gifYU UVXusiLNUSfPCmrQQqN1j3LUzc05rCYmu86v1oWHdFym1UlxZZmitlyHuR72fsUNeVrF 4EwTgVfLhba4/jbJhfaJbLk3+zrRPnttouDgoITLZm1FaJPovVJQwxqCthZfP6i+xPVD Wx17p4rg55pRRseIFrLwKMFTY6kZCMt5ut5SNB/4kj++3pk1X9LeFdTfJz4eBSQyxdBI c4cA== 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 l185si1369939pgd.558.2021.10.19.07.17.45; Tue, 19 Oct 2021 07:18:00 -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 S229755AbhJSOSi (ORCPT + 99 others); Tue, 19 Oct 2021 10:18:38 -0400 Received: from brightrain.aerifal.cx ([216.12.86.13]:33190 "EHLO brightrain.aerifal.cx" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229584AbhJSOSi (ORCPT ); Tue, 19 Oct 2021 10:18:38 -0400 Date: Tue, 19 Oct 2021 10:16:24 -0400 From: Rich Felker To: Arnd Bergmann Cc: musl@lists.openwall.com, Takashi Iwai , 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: <20211019141622.GN7074@brightrain.aerifal.cx> References: <20211008120736.GF7074@brightrain.aerifal.cx> <20211018144259.GK7074@brightrain.aerifal.cx> <20211018150824.GL7074@brightrain.aerifal.cx> <20211018204203.GM7074@brightrain.aerifal.cx> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="0ntfKIWw70PvrIHh" Content-Disposition: inline In-Reply-To: <20211018204203.GM7074@brightrain.aerifal.cx> User-Agent: Mutt/1.5.21 (2010-09-15) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --0ntfKIWw70PvrIHh Content-Type: text/plain; charset=us-ascii Content-Disposition: inline On Mon, Oct 18, 2021 at 04:42:04PM -0400, Rich Felker wrote: > On Mon, Oct 18, 2021 at 05:26:35PM +0200, Arnd Bergmann wrote: > > On Mon, Oct 18, 2021 at 5:08 PM Rich Felker wrote: > > > On Mon, Oct 18, 2021 at 04:58:03PM +0200, Takashi Iwai wrote: > > > > On Mon, 18 Oct 2021 16:43:00 +0200, Rich Felker wrote: > > > > > > No, I don't think so. The musl translator is to translate between the > > > time64 ioctl structures and the old time32 ones for the sake of > > > executing on an old kernel. Up til now, it has been broken comparably > > > to how 32-bit binaries running in compat mode on a 64-bit kernel were > > > broken: the code in musl translated the time64 structure to (and back > > > from) the time32 one assuming the intended padding. But the > > > application was using the actual kernel uapi struct where the padding > > > was (and still is) illogical. Thus, nothing was built with the wrong > > > ABI; it's only the musl-internal translation logic that was wrong (and > > > only pre-time64 kernels are affected). > > > > > > The attached patch should fix it, I think. > > > > > > + int adj = BYTE_ORDER==BIG_ENDIAN ? 4 : 0; > > > + if (dir==W) { > > > + memcpy(old+68, new+72+adj, 4); > > > + memcpy(old+72, new+72+4+2*adj, 4); > > > > I think that should be "new+72+4+3*adj": the "2*adj" would > > be what the code does already for the originally intended > > format. > > Well for little endian either would work (because adj is 0 :) but yes > there are 3 such paddings before the second member on big endian, so > it should be 3. How about this? It avoids open coding the logic and handles it as 2 4-byte substructures with endian-specific offsets. Rich --0ntfKIWw70PvrIHh Content-Type: text/plain; charset=us-ascii Content-Disposition: attachment; filename="snd_pcm_mmap_control_v2.diff" diff --git a/src/misc/ioctl.c b/src/misc/ioctl.c index 49282811..35804f02 100644 --- a/src/misc/ioctl.c +++ b/src/misc/ioctl.c @@ -6,6 +6,7 @@ #include #include #include +#include #include "syscall.h" #define alignof(t) offsetof(struct { char c; t x; }, x) @@ -53,7 +54,7 @@ static const struct ioctl_compat_map compat_map[] = { { _IOWR('A', 0x23, char[136]), _IOWR('A', 0x23, char[132]), 0, WR, 1, 0 }, { 0, 0, 4, WR, 1, 0 }, /* snd_pcm_sync_ptr (flags only) */ { 0, 0, 32, WR, 1, OFFS(8,12,16,24,28) }, /* snd_pcm_mmap_status */ - { 0, 0, 8, WR, 1, OFFS(0,4) }, /* snd_pcm_mmap_control */ + { 0, 0, 4, WR, 1, 0 }, /* snd_pcm_mmap_control (each member) */ /* VIDIOC_QUERYBUF, VIDIOC_QBUF, VIDIOC_DQBUF, VIDIOC_PREPARE_BUF */ { _IOWR('V', 9, new_misaligned(68)), _IOWR('V', 9, char[68]), 68, WR, 1, OFFS(20, 24) }, @@ -90,7 +91,11 @@ static void convert_ioctl_struct(const struct ioctl_compat_map *map, char *old, * if another exception appears this needs changing. */ convert_ioctl_struct(map+1, old, new, dir); convert_ioctl_struct(map+2, old+4, new+8, dir); - convert_ioctl_struct(map+3, old+68, new+72, dir); + /* snd_pcm_mmap_control, special-cased due to kernel + * type definition having been botched. */ + int adj = BYTE_ORDER==BIG_ENDIAN ? 4 : 0; + convert_ioctl_struct(map+3, old+68, new+72+adj, dir); + convert_ioctl_struct(map+3, old+72, new+76+3*adj, dir); return; } for (int i=0; i < map->noffs; i++) { --0ntfKIWw70PvrIHh--