Received: by 10.213.65.68 with SMTP id h4csp620131imn; Tue, 13 Mar 2018 15:16:35 -0700 (PDT) X-Google-Smtp-Source: AG47ELuxN70Ea3kg5Vpk7hUPL1+Cz15g3oLPG5lSOnPCOM3DybKz8JpbDWXNz1BVqbjDQO/ytVFu X-Received: by 10.99.61.204 with SMTP id k195mr1755463pga.312.1520979395409; Tue, 13 Mar 2018 15:16:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1520979395; cv=none; d=google.com; s=arc-20160816; b=D148/qdunc8OB2bomx/NkP9l6SQVg/ljiQcSItexU3FJbEeZLN+Tu7d7o62D+ZazK6 RQWCNTD9sniUifh30NipcgLsGBU5hQHrccRTd9MHP8r3jZlyMreUdhak/hvYUjx0wLF8 oo54M1w+RZJCfDShXj51U1V680gL3wpVKmS/cdZXU4y2UTlbe6tquD5S4OQd7w/mZgyM Y0n5boH6/SZHS/2gdl+xtTxORHG9lCDrjOQx7M3ma1tyzZ9dM3Cz4B8+aRrBihGTAvYT z+uUGwrIePgAuR2h9EYg1nAojtxMhIs6xXiiC9JtwEgtT+mGVktp+3ZHriY+TeEeIjtn MHtA== 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:from:date:arc-authentication-results; bh=CZiiFYfoLTofvlC+i08yaqML8adeu145/hhfyobCyYU=; b=qWwBu19l3tLRDO0WWlitgpr+uEi/ZMFXUuSjDYHdunnKRZ31jTlOZctW7xSl2potFf ZN5xWjVL7BOOuI2W07PxttU3csEd5OR1eTgsYuSPMVvza6J9x+I7e2mvPvN8RbzAxPr+ jiLTGS3YF+Lvp7C4BumVvmDCw0UFc8grdwK8gIApjsyK9bEfLPkcZ+4BQn2ksuldIJ4C WvMqVmzq9u9Y84kqvgXqLUT3eKnuOc/4AKQV/+J+QT4d0uSa6aRmlSxWFRElrVeV5vpR gXdoYu/jRvVnANASGjgRIGGRxWo2IfkqkhuSAeWvbO0kjhIpMAb1LqdTQwmi3b4EnlxA 60Kw== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b1-v6si799492plc.679.2018.03.13.15.16.20; Tue, 13 Mar 2018 15:16:35 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753074AbeCMWOz (ORCPT + 99 others); Tue, 13 Mar 2018 18:14:55 -0400 Received: from mga05.intel.com ([192.55.52.43]:36669 "EHLO mga05.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752967AbeCMWOw (ORCPT ); Tue, 13 Mar 2018 18:14:52 -0400 X-Amp-Result: UNKNOWN X-Amp-Original-Verdict: FILE UNKNOWN X-Amp-File-Uploaded: False Received: from fmsmga003.fm.intel.com ([10.253.24.29]) by fmsmga105.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 13 Mar 2018 15:13:15 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.47,466,1515484800"; d="scan'208";a="33587213" Received: from dph9ls1.fm.intel.com (HELO intel.com) ([10.80.209.182]) by FMSMGA003.fm.intel.com with ESMTP; 13 Mar 2018 15:13:15 -0700 Date: Tue, 13 Mar 2018 15:05:35 -0700 From: Ivan Gorinov To: Thomas Gleixner , Frank Rowand , Andy Shevchenko Cc: Linux Kernel Mailing List , Ingo Molnar , Rob Herring , Mark Rutland Subject: [PATCH v6 2/2] x86/devicetree: Use CPU description from Device Tree Message-ID: <80e8f3018e54b9ceb84615cb543c109f9f6d0985.1520974793.git.ivan.gorinov@intel.com> References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Current x86 Device Tree implementation does not support multiprocessing. Use new DT bindings to describe the processors. Signed-off-by: Ivan Gorinov --- arch/x86/kernel/devicetree.c | 39 ++++++++++++++++++++++++++++----------- 1 file changed, 28 insertions(+), 11 deletions(-) diff --git a/arch/x86/kernel/devicetree.c b/arch/x86/kernel/devicetree.c index 5cd387f..a601f08 100644 --- a/arch/x86/kernel/devicetree.c +++ b/arch/x86/kernel/devicetree.c @@ -131,31 +131,46 @@ static void __init dtb_setup_hpet(void) #endif } +static void __init dtb_cpu_setup(void) +{ + struct device_node *dn; + u32 apic_id, version; + int ret; + + version = GET_APIC_VERSION(apic_read(APIC_LVR)); + for_each_node_by_type(dn, "cpu") { + ret = of_property_read_u32(dn, "reg", &apic_id); + if (ret < 0) { + pr_warn("%pOF: missing local APIC ID\n", dn); + continue; + } + generic_processor_info(apic_id, version); + } +} + static void __init dtb_lapic_setup(void) { #ifdef CONFIG_X86_LOCAL_APIC struct device_node *dn; struct resource r; + unsigned long lapic_addr = APIC_DEFAULT_PHYS_BASE; int ret; dn = of_find_compatible_node(NULL, NULL, "intel,ce4100-lapic"); - if (!dn) - return; - - ret = of_address_to_resource(dn, 0, &r); - if (WARN_ON(ret)) - return; + if (dn) { + ret = of_address_to_resource(dn, 0, &r); + if (WARN_ON(ret)) + return; + lapic_addr = r.start; + } /* Did the boot loader setup the local APIC ? */ if (!boot_cpu_has(X86_FEATURE_APIC)) { - if (apic_force_enable(r.start)) + if (apic_force_enable(lapic_addr)) return; } - smp_found_config = 1; pic_mode = 1; - register_lapic_address(r.start); - generic_processor_info(boot_cpu_physical_apicid, - GET_APIC_VERSION(apic_read(APIC_LVR))); + register_lapic_address(lapic_addr); #endif } @@ -260,6 +275,7 @@ static void __init dtb_ioapic_setup(void) {} static void __init dtb_apic_setup(void) { dtb_lapic_setup(); + dtb_cpu_setup(); dtb_ioapic_setup(); } @@ -297,6 +313,7 @@ void __init x86_dtb_init(void) if (!of_have_populated_dt()) return; + smp_found_config = 1; dtb_setup_hpet(); dtb_apic_setup(); } -- 2.7.4