Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932935AbbGJReC (ORCPT ); Fri, 10 Jul 2015 13:34:02 -0400 Received: from mail-am1on0078.outbound.protection.outlook.com ([157.56.112.78]:25136 "EHLO emea01-am1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S932256AbbGJRd4 (ORCPT ); Fri, 10 Jul 2015 13:33:56 -0400 Authentication-Results: spf=fail (sender IP is 12.216.194.146) smtp.mailfrom=ezchip.com; ezchip.com; dkim=none (message not signed) header.d=none; From: Chris Metcalf To: Frederic Weisbecker , , CC: Chris Metcalf Subject: [PATCH] nohz: prevent tilegx network driver interrupts Date: Fri, 10 Jul 2015 13:33:44 -0400 Message-ID: <1436549624-16104-1-git-send-email-cmetcalf@ezchip.com> X-Mailer: git-send-email 2.1.2 X-EOPAttributedMessage: 0 X-Microsoft-Exchange-Diagnostics: 1;DB3FFO11FD026;1:am7x1+1gipjdxnvpkFjuBmkR7ybLs9zHlqE5n8Cwg9kXLlJXmvOJ8GSvo5iQr33j3jqpFo+WQLAE2F6MH/61nU/kVFCvSqJLE3P5DQmepzFW37ub4xASfit9aRWC22vohBQuZCvwXhTGE54dgd0K62j8BDU/IgIOZLxSHgQOx0Q2px7/1Cvz97YpzexI79Z/v94f26xUwgqD04uESw59IdrUApLzeELpOsTq481xDMc1wItOlKbvVNWI2v1ytkgiOBSkVNZxHAxmOoELUj9mUhgovbfGo5R0vgdZCVEN1ycum4JzQVXSH/CJtjTohs/LRZEbbfyhqokcl2Bup9vdf74ThZnOT6ev2GbFOf01bCjbjK3Sq7PRcIto/v6eB5c6LfbirCfVXD1axPITzEgGSs4nkuOlGqm4iIQfXETfXuniRenHYem6aExiqGx2w3f3 X-Forefront-Antispam-Report: CIP:12.216.194.146;CTRY:US;IPV:NLI;EFV:NLI;SFV:NSPM;SFS:(10009020)(6009001)(2980300002)(339900001)(189002)(199003)(33646002)(189998001)(92566002)(5001770100001)(48376002)(42186005)(36756003)(50986999)(5001960100002)(229853001)(5003940100001)(47776003)(107886002)(50466002)(104016003)(86362001)(50226001)(85426001)(77156002)(105606002)(19580395003)(46102003)(2201001)(62966003)(6806004)(19580405001)(106466001)(87936001)(4001430100001);DIR:OUT;SFP:1101;SCL:1;SRVR:AM2PR02MB0770;H:ld-1.internal.tilera.com;FPR:;SPF:Fail;MLV:sfv;MX:1;A:1;LANG:en; MIME-Version: 1.0 Content-Type: text/plain X-Microsoft-Exchange-Diagnostics: 1;AM2PR02MB0770;2:Gt22iTCqsbjMlZicHdipC8mqSv2/4MT+IkeRssd+2VQroDsJ8KZZTZmHs4c53pN3;3:hJLefBtjR0WU3lwLHpuozWSz4P29KBGfqNojzlgxGIyQH07Q7dq8jTOfIOOa4hUpGRNQHUdURoxkcQ0DAlEgprqUYkV67UJAa6PFBGIvxtcyk8itaovfZxY5lvdgskWFCVFUKKs/7hDl0djwExo1AuX968av+r56ozll9CpUIDBqVjZJ1HYNKwHdJSwGlt8S5Rqt+ifAvMzW0+YzysBwseMyb2Ko3EbPYhY0iHnPG6a0jT/vkFibWaHnJFnHJ4lv;25:CG65QnMQm2Wfq4efGbJo2nD22ZzFFMaOnB1ZxyBTHHpJhOJYwYN4Hlzx0YXkz8qwoSz4o1hqr5Xmnaai4VVsNSyAZIQFb2LYVej8fIlKZ6DL8nUN4qqaCjagUBamAcvVEQbp8sT6PaE9vW/psLmocGwExtbFjdoVaPfuUjSkR3VaBWH+14smeCjUj383gCK9zDXmcxBeHzJAjUacrTiHH0eZuXPLgTh99RaB9pbULG1x3UAPhqBVwvWtnI1HqICSfuvgmx5CWLsFDE5Mp0Mb+w==;20:FRozvp3HMNAjBpJNqpJFPnDbux8xo0KLaEsXW5QDs8vbyqYRn5JK1ygmjDS1+IQ9ArmxVYql7DEPIQ//mObHGLH6PS2V+O4MPIAK/ZubRzpkSnm4DFpAA8OXzsZ6ZuE++F1Q9NTKiQPWB2DcN0KUyaA0edTzhbdmeot8wO16e6w= X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:AM2PR02MB0770; X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(601004)(5005006)(3002001);SRVR:AM2PR02MB0770;BCL:0;PCL:0;RULEID:;SRVR:AM2PR02MB0770; X-Microsoft-Exchange-Diagnostics: 1;AM2PR02MB0770;4:8htRMJhYTeR0nx8Mu9nhI0NAtS00k63UNm3tMXh3eVydszmyH37WcSUlaaWM5v36JLz4QksWtGV7J0actiPWZyBt1WBAzhpj623ql7tPYISDTYwCBD2Hyeox2//+74BZx58aQ30cUeZtr0JMqNk2XkkaFDdXnaDZhSwZAkxynyKDM9h5f7JCC1UHKlbJq++lvjrK9PUNSsjoR1X0PFtw0OGyIa6npbLY1JhzP53S8O1+yhABrAbCbSZyx/3VHqPpeT05j240wTH09nb1bBrUq+dtsHFzPlTiQCaBZbOhUm0= X-Forefront-PRVS: 06339BAE63 X-Microsoft-Exchange-Diagnostics: 1;AM2PR02MB0770;23:Yc8VFp7o3IB2+Uglkf6E3aYe545XE0jNJcA++alCnnlsjOZVXC2M9AgSpi0z8csPjhXKWr3PqK42mVKL9lsstKG9MnPfCOJa/0YMQ3YRJdbI54m+FySa7QSoIxd47yuD4aR3EpC84kkFRBohehMe65876v7YpWqLgA//sttWtC05Gy4J9cBSSzmdv8WVY+f6eKbMWXFXV+yamI1Ji5o1W6Eje8GaNuz9tXdgI0+GRDniliFITcdSw/nC/3TOpwnBv6oSHlPuZQLif/hn56kB6TG4YkBRTm+0kEpq1uqtwdO20IWNIXFRea0jqoJvl1XL346Vnte2uJ8Kzllm/nsgfgBWWDZjlfnEg7s1mbHpEcsrEdVS2L856GLU1WOWd+vLM5xSJJXA6fvML33mJ6Tz0372ud/kK2BECCd0JqblUS5jNnN851lt8hdDFinwTc95UBjfcZ34B7+VbrKBwIYCYgYrqwsA8VEf1QVzjm+FgyPM4aTUk3OWWOMlwXBHeSLAXHZ0gJ1qIF/YBHUlq3c8Kwdk8OtMkgJFhgZM+bRyJ/9U1BNUQrOLpTthQCpSefEEcowhJV1dt3mdzPkB4oIDIa0hoQP0p/uV7mnhuvhHFtvAA+cn6jcYCcjcjXXyYx+LuWUWeFTxZZr/Ebc2z8x833IT0IN2aGVo1VbPFqyZ5pPX8Olz2LnYClRYy0T7NXXroT6lCV7X+TU08Vn5RESnu8i4oRJkA9ncF827APu24JPnRrFLGb++moNghRjliJCKyNNX5pFnQMu8cliT7bbGOhlV6fluDnFmA3Eo/E7ze609tzFzHynBP2+deKWylJt7OplBA3F6q+gWrWA2YNO/QXhvndU+ujVr1t4h9oOMMKsDJe46I/IXEhWTe4VoZ5MI8LZwuE1iYHL0lWRzUt/VGShFVQGuI4cC1+GJfl9JDFI= X-Microsoft-Exchange-Diagnostics: 1;AM2PR02MB0770;5:/fHfkPl3GGEcX5/l41Eag0+dkagWD1YYB/N+H+Yk7MRFVxEaFL7LU/Tg0ufUtm69JR4jJ92dbzLrlIWJ8QxRLieTsZW35lxK4Q7rFUTU2NnDaMw+nfrSIyO5qQqeb2sNsc58btnH/ZAWb01u9lkOnw==;24:ed6+gAz/IYraABmd8l3fEYPj87y6OBybnQw3GLBHjzNrlWG0kusuRRZpaQJjvzGzdsRDTn6D1BLV7yWAAnbFc557gYw6MlADYXbME90JF58=;20:R3NoJHG0z3dcTQgArUkGrxSV8GbLyIg3X2Z4eiEuHm4AnELr3NZ40Sm7YetVGml5uIq4nsFrhkUCFnKoDpHVQw== SpamDiagnosticOutput: 1:23 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: ezchip.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 10 Jul 2015 17:33:51.8190 (UTC) X-MS-Exchange-CrossTenant-Id: 0fc16e0a-3cd3-4092-8b2f-0a42cff122c3 X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=0fc16e0a-3cd3-4092-8b2f-0a42cff122c3;Ip=[12.216.194.146];Helo=[ld-1.internal.tilera.com] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM2PR02MB0770 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1858 Lines: 59 In nohz_full mode, by default distribute networking shim interrupts across the housekeeping cores, not all the cores. Signed-off-by: Chris Metcalf --- The alternate approaches to this might be: 1. "#define housekeeping_mask cpu_online_mask" in the non-nohz_full arm in , then just unconditionally use "housekeeping_mask". 2. Provide an accessor that returns the cpumask to use for housekeeping chores and implement it in the obvious ways for both nohz_full and non-nohz_full. The latter seems like arguably the most satisfying approach, but the patch below is, if nothing else, suitable to push for 4.3 without any further API development work. Frederic (or others), comments? drivers/net/ethernet/tile/tilegx.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/drivers/net/ethernet/tile/tilegx.c b/drivers/net/ethernet/tile/tilegx.c index a3f7610002aa..7687c62e7d75 100644 --- a/drivers/net/ethernet/tile/tilegx.c +++ b/drivers/net/ethernet/tile/tilegx.c @@ -40,6 +40,7 @@ #include #include #include +#include #include #include @@ -2272,8 +2273,13 @@ static int __init tile_net_init_module(void) for (i = 0; gxio_mpipe_link_enumerate_mac(i, name, mac) >= 0; i++) tile_net_dev_init(name, mac); - if (!network_cpus_init()) + if (!network_cpus_init()) { +#ifdef CONFIG_NO_HZ_FULL + network_cpus_map = *housekeeping_mask; +#else network_cpus_map = *cpu_online_mask; +#endif + } return 0; } -- 2.1.2 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/