Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp340736pxx; Thu, 29 Oct 2020 04:06:22 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzbIa8NwdI7s1nrDbWXCp+eGspPad3WiFjPwzUT+YpJQB/wcYGO6mQpkUaC1EJh+WvWBf27 X-Received: by 2002:aa7:d6c9:: with SMTP id x9mr3491312edr.208.1603969581997; Thu, 29 Oct 2020 04:06:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603969581; cv=none; d=google.com; s=arc-20160816; b=keR0V9CEAC2F5pJQhcVzAslSDgaHfPGNMu3UUeQzgj7fYnPasZt7RdJqZPpNZnxixQ fjM8XxicpGEJjNsaSnPLldusGKp0aaVo7WSsHhyZEBGRXX1XMawVZjZ45Guf06NJAhxb jXpBFLUYcFJu4aFWCtEysWXmlRBOHdTFEOLcPEQMeMmMb6fNtRiYiv93rt3iFMXsc1hS R68sEe4Y9g5ReCBelf4EatA+bIs3ogpV6Mtf6qbbx+dbkZZ52QWayPzD3Cq4usZ/RZQi M3gGU7T41UOVFwG3+r/2RlHdBw3/Yr4PM+5q9c/Fyv5Dt/60jrywAzGgm1YismLMnPVT m7RQ== 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 :in-reply-to:mime-version:user-agent:date:message-id:cc:references :to:from:subject:dkim-signature; bh=zcPYz8S2wXEmW4dS41Qn2A338/K8CGnPDRkKEY4clDQ=; b=E3OwuDsaz/N3fmeQRcxFFAXsZj32vxlKy4J73rOErVPrK3xyJR9+3Wi7olC2nGl2+N 1WbN4WUc6U/MNU6YSAAEkfzfo7K0uIekyvsJj7J7Bql4PGAnLMI2qkEhppfhGAq4lgVt NxRlGpNu11vmhAI57n3/dp+Lz+08aSPWIIL1WWW1pL6pW0AFMWUHWf2GW7V+DLsx4Aan IOS8AHGkqNZjbeVA+/uKfKbYn2lBLTAAQjMvfarPnEazE0W8YWbx6g9rt+02d4tCeiSV ZZG4NSr4QBO0oV++AcMJt/Ega6i3gAEE2E7a4CBfggOuwxNCA32TN1ZAHHwih94vm8ok NU6g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=d65dGmhZ; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id q5si1740313edv.293.2020.10.29.04.05.58; Thu, 29 Oct 2020 04:06:21 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=d65dGmhZ; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727348AbgJ2LER (ORCPT + 99 others); Thu, 29 Oct 2020 07:04:17 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33376 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726071AbgJ2LEQ (ORCPT ); Thu, 29 Oct 2020 07:04:16 -0400 Received: from mail-wm1-x331.google.com (mail-wm1-x331.google.com [IPv6:2a00:1450:4864:20::331]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8C9BFC0613CF; Thu, 29 Oct 2020 04:04:16 -0700 (PDT) Received: by mail-wm1-x331.google.com with SMTP id 13so1955100wmf.0; Thu, 29 Oct 2020 04:04:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:from:to:references:cc:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=zcPYz8S2wXEmW4dS41Qn2A338/K8CGnPDRkKEY4clDQ=; b=d65dGmhZDEcE3Mesu4orSPWJobICIQDaoPNQvxtUoqopsrkhJ2PR0/BumksGcgfEZW RiTqznlgwnYxBrakQQJr4RV8Mm+J+X1sWhLpTBVrMczQfC5mahOfYTA+2eYqt97sVuKM g+ghZK420PwYHtXEJEnh2AJu+aWrbaWW/Ia3muFAdtmxPnQloZiwTmVFMFS/dgEoRjUj eCKOgAYt+7lGNqohKgoWu/dtjzZ/jsFaKPJbP5IMWyk/IX/YNX0O6kiIsooo18hudpk7 juLPJjTQ3b/Op6JjVlElvswMDoBok7BW+wVimVC3SEf2PofUUofhsQnUu8BP9i8ugYmd sqww== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:from:to:references:cc:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=zcPYz8S2wXEmW4dS41Qn2A338/K8CGnPDRkKEY4clDQ=; b=LsVR4+DfY6zUpuyKIdyCM6B1KdIMFy7Kq4Gmzf18P/kh+fC0FQst9I14+RuEgMlsrl Djnsx+agnrUns18I1d0J/+I4CslEo1f+H5m/8M0aYySbzg6D9dxGynL/6MSvMqDx5iCq IWOqn/c8QX7qb04HZpOSspQ/vSBSbiMrHGypIPzz+1YB13PcC0+4FLKf0KMU4fuGc3Pt 6lSmqjvcAnbgSE9svyHwzf2qFfutu8fCwxhlrqx5nqju7PBYD3bliMEwfNdQGBIzwivf u/RF+SOKzKElAS/TBeZumtWYdN1E7225dbWjZOW8oZbSqjflSB9dvrHDKa2e+WqId/I3 EbRg== X-Gm-Message-State: AOAM533kcWPKNlFXnDtjYLeR/vQYvZ8xwLwV1l/eZC8Dgy/MZ9OJNNe0 P5ZvbGUBTtpGRxT3u5CKsSM= X-Received: by 2002:a1c:2d8f:: with SMTP id t137mr3713521wmt.26.1603969455284; Thu, 29 Oct 2020 04:04:15 -0700 (PDT) Received: from [192.168.1.143] ([170.253.60.68]) by smtp.gmail.com with ESMTPSA id l16sm4460532wrx.5.2020.10.29.04.04.14 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 29 Oct 2020 04:04:14 -0700 (PDT) Subject: Re: Possible bug in getdents64()? From: Alejandro Colomar To: libc-help@sourceware.org References: <829387c9-50d7-3d29-83bf-c4fec17cf9dd@gmail.com> Cc: linux-man , "linux-kernel@vger.kernel.org" , "libc-alpha@sourceware.org" , "Michael Kerrisk (man-pages)" Message-ID: <01065580-8602-52e6-0cca-22d1aa20a540@gmail.com> Date: Thu, 29 Oct 2020 12:04:13 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.12.0 MIME-Version: 1.0 In-Reply-To: <829387c9-50d7-3d29-83bf-c4fec17cf9dd@gmail.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org [[ CC += linux-man, linux-kernel, libc-alpha, mtk ]] On 2020-10-28 20:26, Alejandro Colomar wrote: > The manual page for getdents64() says the prototype should be the > following: > >        int getdents64(unsigned int fd, struct linux_dirent64 *dirp, >                     unsigned int count); > > > Note the type of 'count': 'unsigned int' > (usually a 32-bit unsigned integer). > And the Linux kernel seems to use those types (fs/readdir.c:351): > > SYSCALL_DEFINE3(getdents64, unsigned int, fd, >         struct linux_dirent64 __user *, dirent, >         unsigned int, count) > { > ... > } > > But glibc uses 'size_t' (usually a 64-bit unsigned integer) > for the parameter 'count' (sysdeps/unix/linux/getdents64.c:25): > > > /* The kernel struct linux_dirent64 matches the 'struct dirent64' type.  */ > ssize_t > __getdents64 (int fd, void *buf, size_t nbytes) > { >   /* The system call takes an unsigned int argument, and some length >      checks in the kernel use an int type.  */ >   if (nbytes > INT_MAX) >     nbytes = INT_MAX; >   return INLINE_SYSCALL_CALL (getdents64, fd, buf, nbytes); > } > libc_hidden_def (__getdents64) > weak_alias (__getdents64, getdents64) > > > > Isn't it undefined behavior to pass a variable of a different (larger) > type to a variadic function than what it expects? > > Is that behavior defined in this implementation? > > Wouldn't a cast to 'unsigned int' be needed? > > > Thanks, > > Alex