Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp1847420imm; Tue, 2 Oct 2018 15:14:59 -0700 (PDT) X-Google-Smtp-Source: ACcGV61Clu8d0h/gK3W/mQQoxhNxjVHxrEOBwbUwZCbkZk3MjVAystd8GUEUs9n2Po24hCRTA8CE X-Received: by 2002:a62:d841:: with SMTP id e62-v6mr16905808pfg.60.1538518499185; Tue, 02 Oct 2018 15:14:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1538518499; cv=none; d=google.com; s=arc-20160816; b=IEA9V5tKwfKE3gREfNjaJW+SoOjxGSn5DQwr35GBxAcpxq+/qkUuHXX0AUbOqbZQGI +dqa2ve1K+j9nPf3Ikv/g3t2m1km8rzB5H9kJXXYMoGLe3BgE/HlsoQqyE8U1DzKF22F GaZWDFwSoo/InNnouJugszZpWO0XpaUN2X+b6VT/F+AlKZ5nxreLN/W4rJt8S8P9xSoS SPVl0Ydm32aEh2cNdZCoYgZwFK36oYDzcNaJJgYhPFQs7gAglxbPrTgoghNk2pzmYNO3 0FIgB948ctyRvXeevKCtBUUgezgjKjHc0161wwqkkbfDLGWrxxWMi6Dtj3XP/+pKiWRS L5/w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=oA8JYPDn9qdIq21lD8iSOsYBfzFsVOt5NgNfLqD0MTw=; b=RQYmmIeCCUqfqfLKZGK/EPqIgJGUVulZ9Lr/CKAQjLyGRsHknMelfCRFIgXcGwQyD6 E+za6rIDc+xcnyvtz+A4v2QuXJlLZtCRFKUcg/7prQy385+sG3ZGZQUQSMDlAPrl0GCT ZkKr2JiHaMaqb5q69RywIKHTX4XGZXP7QSlxNjEncAUZ2IXZQQVybsKMXQRX78+N9EZ/ 4lWlvHdBMyt3CobsmWIrFXsx1BpDojgIlnidINNU8GNLhn2KLLYKxK26rIDSTPxsRtf8 I4OcQPzoKDxOMAlhNYI5c0RX7QUP3AFR0sudksbB5R4TUEnQm4W4WHbvOXyPHSdeHgwE KzHg== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j124-v6si18506479pfb.191.2018.10.02.15.14.43; Tue, 02 Oct 2018 15:14:59 -0700 (PDT) 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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727559AbeJCE6f (ORCPT + 99 others); Wed, 3 Oct 2018 00:58:35 -0400 Received: from mga14.intel.com ([192.55.52.115]:37457 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727001AbeJCE6f (ORCPT ); Wed, 3 Oct 2018 00:58:35 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga006.jf.intel.com ([10.7.209.51]) by fmsmga103.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 02 Oct 2018 15:13:03 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.54,333,1534834800"; d="scan'208";a="79352326" Received: from rchatre-mobl.amr.corp.intel.com (HELO [10.24.14.130]) ([10.24.14.130]) by orsmga006.jf.intel.com with ESMTP; 02 Oct 2018 15:13:02 -0700 Subject: Re: [RFC PATCH 10/10] arch/x86: Introduce QOS feature for AMD To: "Moger, Babu" , "tglx@linutronix.de" , "mingo@redhat.com" , "hpa@zytor.com" , "fenghua.yu@intel.com" , "vikas.shivappa@linux.intel.com" , "tony.luck@intel.com" Cc: "x86@kernel.org" , "peterz@infradead.org" , "pombredanne@nexb.com" , "gregkh@linuxfoundation.org" , "kstewart@linuxfoundation.org" , "bp@suse.de" , "rafael.j.wysocki@intel.com" , "ak@linux.intel.com" , "kirill.shutemov@linux.intel.com" , "xiaochen.shen@intel.com" , "colin.king@canonical.com" , "Hurwitz, Sherry" , "Lendacky, Thomas" , "pbonzini@redhat.com" , "dwmw@amazon.co.uk" , "luto@kernel.org" , "jroedel@suse.de" , "jannh@google.com" , "dima@arista.com" , "jpoimboe@redhat.com" , "vkuznets@redhat.com" , "linux-kernel@vger.kernel.org" References: <20180924191841.29111-1-babu.moger@amd.com> <20180924191841.29111-11-babu.moger@amd.com> From: Reinette Chatre Message-ID: <7690b121-dd54-ea58-ec77-2dbb88c25b16@intel.com> Date: Tue, 2 Oct 2018 15:13:02 -0700 User-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <20180924191841.29111-11-babu.moger@amd.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Babu, On 9/24/2018 12:19 PM, Moger, Babu wrote: > +/* > + * Check whether a cache bit mask is valid. AMD allows > + * non-contiguous masks. > + */ > +bool cbm_validate_amd(char *buf, u32 *data, struct rdt_resource *r) > +{ > + unsigned long first_bit, zero_bit, val; > + unsigned int cbm_len = r->cache.cbm_len; > + int ret; > + > + ret = kstrtoul(buf, 16, &val); > + if (ret) { > + rdt_last_cmd_printf("non-hex character in mask %s\n", buf); > + return false; > + } > + > + if (val == 0 || val > r->default_ctrl) { > + rdt_last_cmd_puts("mask out of range\n"); > + return false; > + } According to https://www.amd.com/system/files/TechDocs/56375_Quality_of_Service_Extensions.pdf "If an L3_MASK_n register is programmed with all 0’s, that COS will be prevented from allocating any lines in the L3 cache." The "val == 0" test thus does not seem necessary. > + > + first_bit = find_first_bit(&val, cbm_len); > + zero_bit = find_next_zero_bit(&val, cbm_len, first_bit); > + > + > + if ((zero_bit - first_bit) < r->cache.min_cbm_bits) { > + rdt_last_cmd_printf("Need at least %d bits in mask\n", > + r->cache.min_cbm_bits); > + return false; > + } If AMD platforms accept CBM of all zeroes then it seems that the platforms would not require a minimum number of set bits? Reinette