Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp2403424ybl; Sat, 14 Dec 2019 11:50:12 -0800 (PST) X-Google-Smtp-Source: APXvYqz9gbF/dEDPG6+5dpzL83nVZ2Xp6J/SWvogJwjRBI11NjhNCwqzaSnNLUVvQD4SnuWL9tUE X-Received: by 2002:a05:6830:1555:: with SMTP id l21mr20787405otp.41.1576353012566; Sat, 14 Dec 2019 11:50:12 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1576353012; cv=none; d=google.com; s=arc-20160816; b=ghFVtZA4j2G30k+MsFL6/BM6QrjCvZ1wQBYNHWh63j5+2erfPQKCdSyMYL7EpF/oFO /NWzu+YzvDJIFPzTp4MmzEfwl59eq6tM6KPw0laU0V6DMr7TG60XAjHsycVfXSJaSKw4 vDasnXL0xyR0ETrq3zap6kANsqmmzzXwo6G97qU0xtW/qvruFR2/2vk4PsVyfUefzefM 6sof7i3iUIS449vgDGaIDR/L4c3ryqAh6K3r0/H7Lw3gPEA6FoEsg38/gdz77bfcWGDe DA9WojAZ8dyXmSEk5ngWxn+0I4oGPtHKlms5RpA/KjzMYczULfyLQSlZ1/QBKOx55QVl FjDg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:date:from:dkim-signature; bh=taLHS8JyLC+BenbNT7BxnrVrwoDPqQMtSy8lb0fixC0=; b=aYICIULESBJ5QHuZQ066hGfvSftqYsx2K+XNMWVSBJI9Ha8HHPdjs8XbqzUo8cZzhB YmOlcp9yRp51zew0xfzhHO3rKSrGBaQtDPnAeAHVZlVmzcXd+y1J0anpj7S0mh5Rxl0e wCPY9DuUngOKYh21a2BPRtUE+YmT0EhFczEeLZH55MGTDFV/J4knU1qFowmqx+M8zEqW xlqdlYUS0SPnDePM8OCF4Ny3Tql1l0+eaexLrhKd9s+qHiHjafUFbemZZFvCiVOPaDMU G5Oo9kTbY3JwO0wqP+xtadoPx1H4k2YSZM3P+8Mu1aJk9cecj9fnUenv/1/ZC+3Siyzu OENA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=HVurpgad; 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 b10si7172901oic.153.2019.12.14.11.49.51; Sat, 14 Dec 2019 11:50:12 -0800 (PST) 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; dkim=fail header.i=@gmail.com header.s=20161025 header.b=HVurpgad; 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 S1726903AbfLNTqb (ORCPT + 99 others); Sat, 14 Dec 2019 14:46:31 -0500 Received: from mail-qk1-f193.google.com ([209.85.222.193]:46350 "EHLO mail-qk1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726484AbfLNTqa (ORCPT ); Sat, 14 Dec 2019 14:46:30 -0500 Received: by mail-qk1-f193.google.com with SMTP id r14so1641608qke.13; Sat, 14 Dec 2019 11:46:30 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:from:date:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=taLHS8JyLC+BenbNT7BxnrVrwoDPqQMtSy8lb0fixC0=; b=HVurpgad1QMZQN0+i58d659mAg2CARQfC7k6Yc2ns+gRiGEMv+w662w2XASNY+IBO0 obJd8LRJkqjqAenPYRGZZnrote5+1rpMa9nHxa5DQTQueo+82hxsRVo3D8ANaRk75+si 9G81TK6fBwZeIxbVZLaaDVMQFMw1OSEDE7VojohAI1kRpEMxwoAjJ/iZoijSrYueLjV/ xxSmyZlzThT5yo90i1oUBwhSjiCKrqZgRIbTU1By6IEKtkODA/IlqX0o3/ICRpPQY6we EqbRu5FKQiNHdG+48YSA0nFN9mnHx6O3sBHSO2ttCAbzSWjn2TFOtqBKkswukr8sF+zT N6mw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:from:date:to:cc:subject:message-id :references:mime-version:content-disposition:in-reply-to:user-agent; bh=taLHS8JyLC+BenbNT7BxnrVrwoDPqQMtSy8lb0fixC0=; b=TftmVZc4oWBcZsk62txCrodD1Ioqgiy6GF8wy4/BaPYUl1YqnMSmH1FMPuKQGU2/9/ sWtN+wPVrCMs9RKXhz85mj58tO+rNcMtssUMKZQNiZDVuwvE6zqs7iNjg2sehbVftAtz o2oNXuDM9kx+n7ZpPj2blPNjKkuL3JCIbWXJvgtYx7HPvbvGvLq4UB2+gD6Go7emD3zZ FdV+Vxxjt37L07R87K3ZsBedrVT3Dw4TxXXwiEOq/THmPds2OLHMyFkhLwWY9tNz1oDd 4828ZrDA983abCtY1xCtYVSNvCnSLRPuZ2zyhKEOdKyAUPv2u4rjWRim2swv4aDdGqKV 4RPQ== X-Gm-Message-State: APjAAAVtEkh0MWgsIQqW7O1ZkbA8MEo1GlyYMwb1kUlhBZ5aCBCW+O7/ 8oYDsQRVL8mg+2/EJhwQfzg= X-Received: by 2002:a37:2e47:: with SMTP id u68mr19395733qkh.485.1576352789530; Sat, 14 Dec 2019 11:46:29 -0800 (PST) Received: from rani.riverdale.lan ([2001:470:1f07:5f3::b55f]) by smtp.gmail.com with ESMTPSA id d25sm4837459qtm.67.2019.12.14.11.46.28 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 14 Dec 2019 11:46:28 -0800 (PST) From: Arvind Sankar X-Google-Original-From: Arvind Sankar Date: Sat, 14 Dec 2019 14:46:27 -0500 To: Ard Biesheuvel Cc: linux-kernel@vger.kernel.org, linux-efi@vger.kernel.org, Hans de Goede , Matthew Garrett , Ingo Molnar , Andy Lutomirski , Thomas Gleixner , Arvind Sankar Subject: Re: [PATCH 05/10] efi/libstub: distinguish between native/mixed not 32/64 bit Message-ID: <20191214194626.GA140998@rani.riverdale.lan> References: <20191214175735.22518-1-ardb@kernel.org> <20191214175735.22518-6-ardb@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20191214175735.22518-6-ardb@kernel.org> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Dec 14, 2019 at 06:57:30PM +0100, Ard Biesheuvel wrote: > + > +#define efi_table_attr(table, attr, instance) ({ \ > + __typeof__(((table##_t *)0)->attr) __ret; \ > + if (efi_is_native()) { \ > + __ret = ((table##_t *)instance)->attr; \ > + } else { \ > + __typeof__(((table##_32_t *)0)->attr) at; \ > + at = (((table##_32_t *)(unsigned long)instance)->attr); \ > + __ret = (__typeof__(__ret))(unsigned long)at; \ > + } \ > + __ret; \ > +}) The casting of `at' is appropriate if the attr is a pointer type which needs to be zero-extended to 64-bit, but for other fields it is unnecessary at best and possibly dangerous. There are probably no instances currently where it is called for a non-pointer field, but is it possible to detect if the type is pointer and avoid the cast if not?