Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S934460AbbKSTEo (ORCPT ); Thu, 19 Nov 2015 14:04:44 -0500 Received: from mail-bn1bon0130.outbound.protection.outlook.com ([157.56.111.130]:31552 "EHLO na01-bn1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1758325AbbKSTEm (ORCPT ); Thu, 19 Nov 2015 14:04:42 -0500 Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=gratian.crisan@ni.com; References: <1447099142-10220-1-git-send-email-gratian.crisan@ni.com> <20151109220232.GO17308@twins.programming.kicks-ass.net> <87mvultz5f.fsf@spline.amer.corp.natinst.com> <87io58tufu.fsf@spline.amer.corp.natinst.com> <20151113204338.GA9928@worktop.ger.corp.intel.com> User-agent: mu4e 0.9.13; emacs 24.3.1 From: Gratian Crisan To: Peter Zijlstra CC: Gratian Crisan , Josh Hunt , Thomas Gleixner , LKML , Ingo Molnar , "H . Peter Anvin" , , Borislav Petkov , Josh Cartwright , Subject: Re: [RFC PATCH] tsc: synchronize TSCs on buggy Intel Xeon E5 CPUs with offset error In-Reply-To: <20151113204338.GA9928@worktop.ger.corp.intel.com> Date: Thu, 19 Nov 2015 13:04:30 -0600 Message-ID: <87io4xg69t.fsf@spline.amer.corp.natinst.com> MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [130.164.62.191] X-ClientProxiedBy: BLUPR08CA0032.namprd08.prod.outlook.com (10.141.200.12) To BY2PR04MB864.namprd04.prod.outlook.com (10.242.40.156) X-Microsoft-Exchange-Diagnostics: 1;BY2PR04MB864;2:Bc84W02hxGRYxNU6rkz4JutQuP70v1vr7S6VqP0mfZbB3aiNHARmMqGop1uCa5xE75uHDfAxusB6DooHM8ubZGBhkUuaYdTO7fbUVMmlDMe0IF6RMghRb96UbJXp3aFTHAlXmfrX/uAwZKGrbPo1Jg==;3:FH8LK/uJgJDP2h76YUjDa6nagB3/H/u90c/OJ3sFmxkcvxvQxQ3pWCDzsF33Kmzub0I379GCMpHQH/ce4+RvvJBG7Tzl+WjIwKWDeyVd3Zk6GVXpzCUCGmM9ExH5KEdL;25:gyg1XpZ1XXX6GxsZ/ZXEJd5x+tG0f+jtzlH02ORmQDQqiONiSrsIEdsAiJIJ210HSzwGKJaryVew0DwC2hewJuwXFmRYyUJMyrd93mJI+Fzkvmfl60Va5TqCy2U1ePPKJyM8SxfUjZ3ckK+c0BNi7rVPRaMyZLFDluJjF2xNtKKQELa8lZv+6vO+YboUoJxpHLleBmuCm9V5Yfbm8u6fqSb/hBYSqXOuItIZ6aWExdGKa3NWQWYGURaC3UHTEigrDSUS7eteiK9qetyMjnT5ZQ== X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:BY2PR04MB864; X-Microsoft-Exchange-Diagnostics: 1;BY2PR04MB864;20:+REOOT3uOblCN31+SBeg0gYdJzhVqz4YrfXNR98s6e4/4xqBZV4ZYwE7o+L4tUxVTF4REytVNtdGoMWycHKUFpU4AVKhVNFp5vTiS9++utMh0xjW3GyvndQAtqhwJRaJwWuFQ6sy2thf9bsSm0gwPNikQHsvB5XR4Ehqa7JaSNqB/J7mOY8ogCA8q7gseoom3ZBawQ6kM2bDEibpibmpYEgICWkghd+tJ5sAQxc/vS/wEj0706pA7//0PnunobH1UNtpQ2a56XmpdwUxROOUB41l+sHBhl3TPuIOZdlpdb7SrS62pCntf+BxXeafViGuVht1hTFkw+EGO8/ryYElsHdjjdGrtLMaAIqmUFBUorOwOaknbN2rEtkH+oMhbicIdHb2sFKuetHHJVlqUWTF1dxvu2xe8mJgyH2y4D9rhar2+JNi0zbMyVsiQpMfvUOMHr5xI/PinvkszWpi/VN3J+voaggX9wJMKVXo/5nuyUgymVz/qz827LApJXNNMX1TlThVk9iYB8GRLmf3RpPyDbF/4lYmNKFeDcIFIC3eG+38HRl1ppEqNjf3+dFcoZlmwSoZJa1ah5apbjqy7MrOgiDRCeHc2Smtw2W+EgXnazM= X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(601004)(2401047)(5005006)(520078)(8121501046)(10201501046)(3002001);SRVR:BY2PR04MB864;BCL:0;PCL:0;RULEID:;SRVR:BY2PR04MB864; X-Microsoft-Exchange-Diagnostics: 1;BY2PR04MB864;4:SHR+EkexueJRCepOi6VJ2arp9ssS8PgUsEab9WVAlduT+BCk3eClAICq5iec0OUOrvZaUwxhywO6NqH2HRWzkdrLQBMzn5+M+QWR4R1U2oYDwHASr/ioqbNfYOs9chgY1WdZBK57S4nkjuBBCsWJhNO8N4XHg/xkdnkUiiPQkcW6a7qo05rwnfuwzBwRQHl0mis0dSOxudVnxeUdnEZ/UewaCxHMIwnAOwODREFoN2t3FBNpeML1IzUdAxXmhdHOP/BnbFyoct0X83wMHK1pWQMwl4DotYhw2vVWG1Wdh1hKp72WXad7KFrmWJtgoA0rg4FggHE0QTUa+U94j1JKv1IUHB1Gv1Kr4AGTaGGNXFI8Ro/wtsbeZt5OA+TJyj03 X-Forefront-PRVS: 07658B8EA3 X-Forefront-Antispam-Report: SFV:NSPM;SFS:(10019020)(6009001)(24454002)(189002)(199003)(164054003)(76176999)(92566002)(105586002)(5003940100001)(106356001)(86362001)(5008740100001)(5004730100002)(586003)(87976001)(48376002)(50466002)(5007970100001)(33646002)(101416001)(50986999)(66066001)(110136002)(122386002)(93886004)(2950100001)(81156007)(40100003)(42186005)(83506001)(4001350100001)(6116002)(77096005)(5001920100001)(97736004)(47776003)(3846002)(54356999)(5001960100002)(189998001)(473944003);DIR:OUT;SFP:1102;SCL:1;SRVR:BY2PR04MB864;H:spline.amer.corp.natinst.com;FPR:;SPF:None;PTR:InfoNoRecords;MX:1;A:1;LANG:en; X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1;BY2PR04MB864;23:AVYjDXBWJ0lBGwFe4Fo0nvPHj3/ZeRHqLNGaNZNRkm?= =?us-ascii?Q?NUMgAjDISxfXhypUW+YUawukN/E2VmEliLCBHAGKNx87U2quI9CfxDQf5vRS?= =?us-ascii?Q?UshIxraHqcTVJFwv/kp3moGenRccHtgdAl2UNQokYpy0yyPYBz/QEzLpXD7o?= =?us-ascii?Q?gJmp7KJ1E88Jq5dWwK2JTnpD10kbtbhL6HwXxotFQ8soU70wdlo0QNlC6Yin?= =?us-ascii?Q?CzB1qyDoOGBmfXhGtSu6DvVpBhpKrG0K5GSEe0XSQHTvnLBi69JcehX5GxYh?= =?us-ascii?Q?Yxmr4k3RkkOkZtp6U3NPlu494KGZX55AUMLJlgf3IjiYPtNS1pG7Guqs1cUH?= =?us-ascii?Q?phA5KR2SIgQD2RFSfA929JFT4MNbyJJJC8rrqG1x5HIh9zeWUTHclGuNy/E0?= =?us-ascii?Q?k6eZJWsfJQ/WmXBh3TaRGGfY7/ise3Ty4aIfidVydi/qysM5N2EXbPrE16Io?= =?us-ascii?Q?xh7Oq1422rhvK8z7HFkvYAGTwWqdLUiiIKOPApdgnh5u17pl7ZLoMcCw1dHF?= =?us-ascii?Q?fnZ9sUdFbtkIO2MeGjL79nBgZ0fywMa7zk4vG+o6qV2Ic31I/IAM9uYTPOOm?= =?us-ascii?Q?zLbOqxofKP+E3ila+jRkUgQRaB7AqxmVvar0SToGH/XyJP5guL9s7poD+b4G?= =?us-ascii?Q?YFzhwR7jFeunbqA4tiLz3DBmM7BBpAjq3C6aYm6oIt2TsCX5dc3buTzDcgY3?= =?us-ascii?Q?4ib1YfBpm2iHYRlcWv0KHg1WAe/p4bLNq9DhowNC7b1ssREfRqAyp7tNBM6r?= =?us-ascii?Q?sH3zzKPlYwScaVEwTe+REklmXTe9pDntIR8pQJjFvW1PKGjnw1pz5BcufYWl?= =?us-ascii?Q?nenVZ1xi5xQorbvTGoh8hnSl3CZbM2/dSjdQt962Q/9xdpG1JX5+YY4FcWl1?= =?us-ascii?Q?hXgSiqcfBWvHJ07K1dvkhRVCJYFTPpfKRIob5hJaEyu/RKL+6PoVlao7FDNt?= =?us-ascii?Q?81rjXOVhn9UZNtfZs3icmeO5bFPHoseCsqIIw5xljAEZxzdtZmAyF9tjvopv?= =?us-ascii?Q?Lsk4KFs+7AqQBujPdw9vP1O1jIsU8rk0RIgw1/rxhRZBlfyvhXRCAox1y+Ap?= =?us-ascii?Q?ACj7ttRbQZeF9HmqLsN0LhY/hOsXRmgvZeicF4eAgr3dQ7Eq6LU6fdhkDK9S?= =?us-ascii?Q?0uUkr4uJs=3D?= X-Microsoft-Exchange-Diagnostics: 1;BY2PR04MB864;5:w4X6n4d9Jg9uDwM9nUoaU0ZlDXbsk5MEerXpbuK40aTQma5ctHMvs96qNqJZc24vIki3CCp4hJJMFTp46tY/Iz+0Lgb+YuhPzpmKmmS1ckJwj+V4+dX8s/MTgpAB8nGMB0QbT4hnQbfk3aIbR65zQg==;24:6EFkIQpFAyN/ZTM7gZv0c14SfFUzcUEBkeRv88QedSxWXaiPEcoD6cY3znbd3QrnKU9t7efOgn2TzBiHSGEIVS/bYYXLCxQHckjtLCGRWuA= SpamDiagnosticOutput: 1:23 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: ni.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 19 Nov 2015 19:04:37.2329 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-Transport-CrossTenantHeadersStamped: BY2PR04MB864 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2854 Lines: 71 Peter Zijlstra writes: > On Wed, Nov 11, 2015 at 09:41:25AM -0600, Gratian Crisan wrote: >> I also wrote a small C utility[1], with a bit of code borrowed from the >> kernel, for reading the TSC on all CPUs. It starts a high priority >> thread per CPU, tries to synchronize them and prints out the TSC values >> and their offset with regards to CPU0. >> It can be called from a SysV init shell script[2] at the beginning of >> the boot process and right before a reboot to save the values in a file. > > Could you also read and print TSC_ADJUST (msr 0x3b) ? This would tell us > if for example your BIOS messed it up. We've gathered some more information on this: 1. We were able to confirm that the TSC_ADJUST is set for CPU0 before the bootloader or kernel start. Using an EFI shell to read MSR 0x3b shows: 0: 0xFFFFFFFFAD999CCB 1: 0x0000000000000000 2: 0x0000000000000000 3: 0x0000000000000000 4: 0x0000000000000000 5: 0x0000000000000000 6: 0x0000000000000000 7: 0x0000000000000000 2. We were also able to reproduce this behavior on a Dell Precision T5810 workstation PC. Relevant /proc/cpuinfo below[1]. Additionally we have observed the same behavior on an off the shelf motherboard equipped with a Haswell-E similar to the Haswell-EP we originally saw this on. We are still trying to figure out what in the boot chain sets the CPU0's TSC_ADJUST i.e. BIOS, something pre-BIOS and how to proceed from there. Thanks, Gratian [1] processor : 0 vendor_id : GenuineIntel cpu family : 6 model : 63 model name : Intel(R) Core(TM) i7-5930K CPU @ 3.50GHz stepping : 2 microcode : 0x27 cpu MHz : 1200.117 cache size : 15360 KB physical id : 0 siblings : 12 core id : 0 cpu cores : 6 apicid : 0 initial apicid : 0 fpu : yes fpu_exception : yes cpuid level : 15 wp : yes flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon pebs bts rep_good nopl xtopology nonstop_tsc aperfmperf eagerfpu pni pclmulqdq dtes64 monitor ds_cpl vmx est tm2 ssse3 fma cx16 xtpr pdcm pcid dca sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline_timer aes xsave avx f16c rdrand lahf_lm abm ida arat epb xsaveopt pln pts dtherm tpr_shadow vnmi flexpriority ept vpid fsgsbase tsc_adjust bmi1 avx2 smep bmi2 erms invpcid bogomips : 6983.91 clflush size : 64 cache_alignment : 64 address sizes : 46 bits physical, 48 bits virtual power management: -- 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/