Received: by 10.213.65.68 with SMTP id h4csp2120905imn; Sun, 8 Apr 2018 20:13:15 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/m3li4A7DtCoSyQS8+ovo3SPOENLUg6t9kWg5EvbTcJl8IoQVnHiDLZYoHNhu1P9MVloMX X-Received: by 2002:a17:902:5204:: with SMTP id z4-v6mr36812843plh.385.1523243595050; Sun, 08 Apr 2018 20:13:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1523243595; cv=none; d=google.com; s=arc-20160816; b=0m5gfKMBzWskc5tjaPqyX3qD4tMD9xnB5XXua2zdOqIRqHLuNXyujPVu/pt3HGTClJ fn09oEmhhuPsOAnH1w1Qzz5LMbjG5J48cMUZOQuS3LM27wgjGgZC4pfS5VGKQ74bI3uA jFDyBBvc5P3xqQEZzL/UJJ3xJkLJtvuKYT3l0199Tpki/k8zwrMs44SyZ2b3FU6JlDyc I7LUu/P6ilP15YpDOoetEGVMsISp2arg8wok/DZ/VrkMp9mCn7LsLoZiMcxMPeePXnCy 2n4dLHKapDc7JRQYgLHWTCouVJHrO/5D4WvPGgApZ9saRI9OC0Dp4FwpQWxnpUYMmqyf SDwQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :spamdiagnosticmetadata:spamdiagnosticoutput:content-language :accept-language:in-reply-to:references:message-id:date:thread-index :thread-topic:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=D8Q5W03mgNZuzBZTpOGSmyjkp8KsscGI7ISYH3ffmko=; b=stytyL6uaSa1+PL0DGNgbz/cXCnSdFPN4SQ+dxXhCaPERPSMW5JeRBjkfLM0fZEwuu zLe2u463iKRC2+bqB1qSjjDbzI/JsttFWyUJasr08DCbyJbFmLkftQsrcHh2wZ2dXVIq Rax3DuBNVzpiF1MH2MQg0RENioWLeCH2/0p6OR/nxpSQRG5sBryhpx98SVWP4yMGlMI0 DVfMddkoPm4Iq2KiJwRLouXODm892fpNNcoDZkO2dY/XljKzoqoXgXNA5nJX1J4FgpD9 5zFfvprGL+UxeEgiGqste7CJHbvfJ9+xQ4QrXoKSsakV5+E7sK2OH76UjArKH7jYQnVR 7sbw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@microsoft.com header.s=selector1 header.b=jcddq2OG; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=microsoft.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h3-v6si13643635plb.285.2018.04.08.20.12.38; Sun, 08 Apr 2018 20:13:15 -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; dkim=pass header.i=@microsoft.com header.s=selector1 header.b=jcddq2OG; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=microsoft.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1758180AbeDIC6E (ORCPT + 99 others); Sun, 8 Apr 2018 22:58:04 -0400 Received: from mail-bn3nam01on0139.outbound.protection.outlook.com ([104.47.33.139]:14848 "EHLO NAM01-BN3-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1755188AbeDIAZg (ORCPT ); Sun, 8 Apr 2018 20:25:36 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=D8Q5W03mgNZuzBZTpOGSmyjkp8KsscGI7ISYH3ffmko=; b=jcddq2OGNPyXDfLDXCj6WvQPTHs5EZL2pPFusXtmNt3V2w0NpfgzoYinW4dah3Hcik9pYKYJKWJb0ZTa+5uuMHP3MgjpVWSVjWBfiXXEWtPQ5OU/yb0jCWuGO455hrHqBYDzTckbZ1yOMXcyCiCOZ/523o1KY0oX5lLhG7XfNVw= Received: from DM5PR2101MB1032.namprd21.prod.outlook.com (52.132.128.13) by DM5PR2101MB1013.namprd21.prod.outlook.com (52.132.133.35) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.696.0; Mon, 9 Apr 2018 00:25:34 +0000 Received: from DM5PR2101MB1032.namprd21.prod.outlook.com ([fe80::8109:aef0:a777:7059]) by DM5PR2101MB1032.namprd21.prod.outlook.com ([fe80::8109:aef0:a777:7059%2]) with mapi id 15.20.0696.003; Mon, 9 Apr 2018 00:25:34 +0000 From: Sasha Levin To: "stable@vger.kernel.org" , "linux-kernel@vger.kernel.org" CC: Matt Redfearn , Ralf Baechle , "linux-mips@linux-mips.org" , James Hogan , Sasha Levin Subject: [PATCH AUTOSEL for 4.14 126/161] MIPS: Generic: Support GIC in EIC mode Thread-Topic: [PATCH AUTOSEL for 4.14 126/161] MIPS: Generic: Support GIC in EIC mode Thread-Index: AQHTz5i4tpDjJ+CkEUW7ERLU5WNKMg== Date: Mon, 9 Apr 2018 00:21:36 +0000 Message-ID: <20180409001936.162706-126-alexander.levin@microsoft.com> References: <20180409001936.162706-1-alexander.levin@microsoft.com> In-Reply-To: <20180409001936.162706-1-alexander.levin@microsoft.com> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-originating-ip: [52.168.54.252] x-ms-publictraffictype: Email x-microsoft-exchange-diagnostics: 1;DM5PR2101MB1013;7:60ZROYFX8grO2Odc//pvNYOlnboMwrFk4hB6geoVmmNvZYMdelVAbEMTpusIn6fh2QCgAVYLuFchIY/8yB29LpjftnYR2xN83VZkeFd8WCRYyah7WC3PJdvjV0cCicfSIqi+gNVIi0F2M+yPowZF6l7Lo6b78oft8rDM3Yd71gIwe65bIw8qoxoVMEg8vd6iSzbEbruwkq94/mASH2kousl5qXo/DwafjqP9PnfivDgoGBiL2xBXkQtCVLKTyjJ6;20:kluLAoX9oNSg7YUBI3FziNLa7Aab3GCmd7pOOt/wSTkPo1Bk70YEQcSjiEHr30Oa+olRibu0QPPbjpa6X0WsQ3y3J4Dzm5ReGa40xiOk0rWNCBIriQby9GT3ShkvLbrpSB5YdGb6ouorUKVa8xmvD3PoP9ki4ZVzYrDHAafXx2U= X-MS-Office365-Filtering-Correlation-Id: 41b05cf8-66ac-450f-06df-08d59db0690f x-ms-office365-filtering-ht: Tenant x-microsoft-antispam: UriScan:;BCL:0;PCL:0;RULEID:(7020095)(4652020)(4534165)(4627221)(201703031133081)(201702281549075)(5600026)(4604075)(3008032)(48565401081)(2017052603328)(7193020);SRVR:DM5PR2101MB1013; x-ms-traffictypediagnostic: DM5PR2101MB1013: authentication-results: spf=none (sender IP is ) smtp.mailfrom=Alexander.Levin@microsoft.com; x-microsoft-antispam-prvs: x-exchange-antispam-report-test: UriScan:(28532068793085)(89211679590171); x-exchange-antispam-report-cfa-test: BCL:0;PCL:0;RULEID:(8211001083)(61425038)(6040522)(2401047)(8121501046)(5005006)(3231221)(944501327)(52105095)(3002001)(93006095)(93001095)(10201501046)(6055026)(61426038)(61427038)(6041310)(20161123560045)(20161123564045)(20161123558120)(20161123562045)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(6072148)(201708071742011);SRVR:DM5PR2101MB1013;BCL:0;PCL:0;RULEID:;SRVR:DM5PR2101MB1013; x-forefront-prvs: 0637FCE711 x-forefront-antispam-report: SFV:NSPM;SFS:(10019020)(346002)(366004)(376002)(396003)(39860400002)(39380400002)(189003)(199004)(3280700002)(2616005)(8936002)(7736002)(476003)(446003)(11346002)(53936002)(3660700001)(86362001)(86612001)(81156014)(2906002)(186003)(81166006)(105586002)(1076002)(8676002)(26005)(97736004)(25786009)(6306002)(6512007)(3846002)(68736007)(72206003)(106356001)(5660300001)(6486002)(6116002)(966005)(14454004)(4326008)(305945005)(6436002)(2501003)(5250100002)(10290500003)(478600001)(2900100001)(22452003)(110136005)(316002)(99286004)(66066001)(10090500001)(107886003)(76176011)(102836004)(54906003)(6506007)(36756003)(486006)(22906009)(41533002)(217873001);DIR:OUT;SFP:1102;SCL:1;SRVR:DM5PR2101MB1013;H:DM5PR2101MB1032.namprd21.prod.outlook.com;FPR:;SPF:None;LANG:en;PTR:InfoNoRecords;MX:1;A:1; received-spf: None (protection.outlook.com: microsoft.com does not designate permitted sender hosts) x-microsoft-antispam-message-info: Eko95FMDKQy/I+SCXnQHw7ypZqjpbadlQfmCwMiwmMS4rv0a53DyCB385EtiP7fFxyLpyX54H0dUbhvqm5py/bSEQDB92mkUDf9Y55bvPB8PJ6ti0df9u77GAtocpnWkLNhDwvq+8F5C9DJQsg2s6okJdi4R4vigQlD1PK+W9nnWrKmbgvHKL1m4F/3+dpJPz+t4pD89V2cNTmyzH3Ug0w3gBQToWDr9Y6kmEFpEvVQk0pX1vsUj/AFaQoxxfRkxMuDe4nTGv4oII3+UcsR7kO2x7owPZyHfyyVKbVqfZMsFTkNciyjLpKVMHLAM9U2H3Ogt70L4OOoNWKxxCL6hIW6/3MTRJss3SpFKqlMX/1i91AYK7wqeQ5Y8YoRZITFAmxYUciyTr/lRQQVuL2PXSdb+HXpAG9HlUnCgMlYoCR4= spamdiagnosticoutput: 1:99 spamdiagnosticmetadata: NSPM Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-OriginatorOrg: microsoft.com X-MS-Exchange-CrossTenant-Network-Message-Id: 41b05cf8-66ac-450f-06df-08d59db0690f X-MS-Exchange-CrossTenant-originalarrivaltime: 09 Apr 2018 00:21:36.7374 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 72f988bf-86f1-41af-91ab-2d7cd011db47 X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM5PR2101MB1013 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Matt Redfearn [ Upstream commit 7bf8b16d1b60419c865e423b907a05f413745b3e ] The GIC supports running in External Interrupt Controller (EIC) mode, and will signal this via cpu_has_veic if enabled in hardware. Currently the generic kernel will panic if cpu_has_veic is set - but the GIC can legitimately set this flag if either configured to boot in EIC mode, or if the GIC driver enables this mode. Make the kernel not panic in this case, and instead just check if the GIC is present. If so, use it's CPU local interrupt routing functions. If an EIC is present, but it is not the GIC, then the kernel does not know how to get the VIRQ for the CPU local interrupts and should panic. Support for alternative EICs being present is needed here for the generic kernel to support them. Suggested-by: Paul Burton Signed-off-by: Matt Redfearn Cc: Ralf Baechle Cc: linux-mips@linux-mips.org Patchwork: https://patchwork.linux-mips.org/patch/18191/ Signed-off-by: James Hogan Signed-off-by: Sasha Levin --- arch/mips/generic/irq.c | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/arch/mips/generic/irq.c b/arch/mips/generic/irq.c index 394f8161e462..cb7fdaeef426 100644 --- a/arch/mips/generic/irq.c +++ b/arch/mips/generic/irq.c @@ -22,10 +22,10 @@ int get_c0_fdc_int(void) { int mips_cpu_fdc_irq; =20 - if (cpu_has_veic) - panic("Unimplemented!"); - else if (mips_gic_present()) + if (mips_gic_present()) mips_cpu_fdc_irq =3D gic_get_c0_fdc_int(); + else if (cpu_has_veic) + panic("Unimplemented!"); else if (cp0_fdc_irq >=3D 0) mips_cpu_fdc_irq =3D MIPS_CPU_IRQ_BASE + cp0_fdc_irq; else @@ -38,10 +38,10 @@ int get_c0_perfcount_int(void) { int mips_cpu_perf_irq; =20 - if (cpu_has_veic) - panic("Unimplemented!"); - else if (mips_gic_present()) + if (mips_gic_present()) mips_cpu_perf_irq =3D gic_get_c0_perfcount_int(); + else if (cpu_has_veic) + panic("Unimplemented!"); else if (cp0_perfcount_irq >=3D 0) mips_cpu_perf_irq =3D MIPS_CPU_IRQ_BASE + cp0_perfcount_irq; else @@ -54,10 +54,10 @@ unsigned int get_c0_compare_int(void) { int mips_cpu_timer_irq; =20 - if (cpu_has_veic) - panic("Unimplemented!"); - else if (mips_gic_present()) + if (mips_gic_present()) mips_cpu_timer_irq =3D gic_get_c0_compare_int(); + else if (cpu_has_veic) + panic("Unimplemented!"); else mips_cpu_timer_irq =3D MIPS_CPU_IRQ_BASE + cp0_compare_irq; =20 --=20 2.15.1