From nobody Sat Feb 7 07:36:31 2026 Delivered-To: importer@patchew.org Received-SPF: pass (zoho.com: domain of gnu.org designates 208.118.235.17 as permitted sender) client-ip=208.118.235.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zoho.com; dkim=fail spf=pass (zoho.com: domain of gnu.org designates 208.118.235.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; Return-Path: Received: from lists.gnu.org (lists.gnu.org [208.118.235.17]) by mx.zohomail.com with SMTPS id 1496986870736447.5121868996654; Thu, 8 Jun 2017 22:41:10 -0700 (PDT) Received: from localhost ([::1]:52743 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1dJCfV-0000nA-7O for importer@patchew.org; Fri, 09 Jun 2017 01:41:09 -0400 Received: from eggs.gnu.org ([2001:4830:134:3::10]:49151) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1dJCaq-0004Zo-14 for qemu-devel@nongnu.org; Fri, 09 Jun 2017 01:36:21 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1dJCao-0001OC-3R for qemu-devel@nongnu.org; Fri, 09 Jun 2017 01:36:20 -0400 Received: from mail-qt0-x243.google.com ([2607:f8b0:400d:c0d::243]:34558) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1dJCan-0001O8-V6 for qemu-devel@nongnu.org; Fri, 09 Jun 2017 01:36:18 -0400 Received: by mail-qt0-x243.google.com with SMTP id o21so13026551qtb.1 for ; Thu, 08 Jun 2017 22:36:17 -0700 (PDT) Received: from bigtime.twiddle.net.com (97-113-165-157.tukw.qwest.net. [97.113.165.157]) by smtp.gmail.com with ESMTPSA id m9sm60386qke.8.2017.06.08.22.36.16 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 08 Jun 2017 22:36:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:from:to:cc:subject:date:message-id:in-reply-to:references; bh=bgV8C6HNfS1cTNFYgTRlZLf+bs1owFx2BOM4Bi532Hc=; b=qjXd03G2yFmsknKDvFPiw4onFSj44bBwyQWCQdMUIMWLkOilUemME/1+hCo/kMRuBF i4DhtZANPefqUyLEfM5jdBnqJf1bCXCCuTmsT3OK6awC5dtAcUf3Dfxbsn88Z1JHH17z 1MqDIMXrzM93AAjLsFjE4Ev22vBvFuaFS1y0KI2cNp2O16TJprT/ZKgKJNNDrVthbeCR iMItkBIuLbSnqOaOi1booON0caB2pqS8pGuBGh84qbN+lfaEz7FRZ8SAZwu3G3Yjoma4 8KPNL6znwSZ1AiH2Ks6P1YnPz1rJNSoiAW85b13mJDi3XT7VH3DHpzrFdGtsapURqa6c PIOQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:from:to:cc:subject:date:message-id :in-reply-to:references; bh=bgV8C6HNfS1cTNFYgTRlZLf+bs1owFx2BOM4Bi532Hc=; b=c6g7lTsmNXQxZBYsDdrC2/J9aTxJpJiqc6JNTHG76J16qO04vXRNT1x+Y0XQYPpoGd 027jnTbxOcLs/bPRqAMnBIDyQySryM0WkjQqxdd24y/SonCEeU0AJWN39Xwbn3c6j6aQ OauMT9drfIxj0pTHKoLEpy3KNgWPtUk3ou4//MSS9avJ9bHqBM5EUQbZt/aAIjtHQC5T 34aQxA0ZZysLGSfP2DpYYndxlLwoozwfjFKUS3aodIKt5R0heH5gIclJ1xyV20uLv2m0 RFi65Zb8wITWu7guXDUcaMs602DqZWSfoXKNWHVTHAEf+g4S2cp2FqCmRw5P15TB/dCA gftw== X-Gm-Message-State: AODbwcDI9v1mNCmUh4EgoN/OYGrtiW8px2PmXe4YyM3K+ZI2rD5JEKUd XYXkgN2ogorFRCJydV8= X-Received: by 10.237.54.10 with SMTP id e10mr51355474qtb.51.1496986577167; Thu, 08 Jun 2017 22:36:17 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Date: Thu, 8 Jun 2017 22:36:02 -0700 Message-Id: <20170609053611.26032-2-rth@twiddle.net> X-Mailer: git-send-email 2.9.4 In-Reply-To: <20170609053611.26032-1-rth@twiddle.net> References: <20170609053611.26032-1-rth@twiddle.net> X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2607:f8b0:400d:c0d::243 Subject: [Qemu-devel] [PATCH 1/3] Guess L1 cache linesize for aarch64 X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: cota@braap.org, Marcus Shawcroft Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: fail (Header signature does not verify) X-ZohoMail: RDKM_2 RSF_0 Z_629925259 SPT_0 Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Using the cache hierarchy linesize minimum in CTR_EL0. See the comment within the code for rationale. * sysdeps/unix/sysv/linux/aarch64/sysconf.c: New file. Cc: Marcus Shawcroft --- sysdeps/unix/sysv/linux/aarch64/sysconf.c | 55 +++++++++++++++++++++++++++= ++++ 1 file changed, 55 insertions(+) create mode 100644 sysdeps/unix/sysv/linux/aarch64/sysconf.c diff --git a/sysdeps/unix/sysv/linux/aarch64/sysconf.c b/sysdeps/unix/sysv/= linux/aarch64/sysconf.c new file mode 100644 index 0000000..30608dd --- /dev/null +++ b/sysdeps/unix/sysv/linux/aarch64/sysconf.c @@ -0,0 +1,55 @@ +/* Copyright (C) 2017 Free Software Foundation, Inc. + This file is part of the GNU C Library. + + The GNU C Library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + The GNU C Library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with the GNU C Library. If not, see + . */ + +#include +#include +#include +#include + + +static long int linux_sysconf (int name); + +/* Get the value of the system variable NAME. */ +long int +__sysconf (int name) +{ + unsigned ctr; + + /* Unfortunately, the registers that contain the actual cache info + (CCSIDR_EL1, CLIDR_EL1, and CSSELR_EL1) are protected by the Linux + kernel (though they need not have been). However, CTR_EL0 contains + the *minimum* linesize in the entire cache hierarchy, and is + accessible to userland, for use in __aarch64_sync_cache_range, + and it is a reasonable assumption that the L1 cache will have that + minimum line size. */ + switch (name) + { + case _SC_LEVEL1_ICACHE_LINESIZE: + asm("mrs\t%0, ctr_el0" : "=3Dr"(ctr)); + return 4 << (ctr & 0xf); + case _SC_LEVEL1_DCACHE_LINESIZE: + asm("mrs\t%0, ctr_el0" : "=3Dr"(ctr)); + return 4 << ((ctr >> 16) & 0xf); + } + + return linux_sysconf (name); +} + +/* Now the generic Linux version. */ +#undef __sysconf +#define __sysconf static linux_sysconf +#include --=20 2.9.4