From nobody Sat Apr 27 15:34:57 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=fail; spf=none (zoho.com: 198.145.21.10 is neither permitted nor denied by domain of lists.01.org) smtp.mailfrom=edk2-devel-bounces@lists.01.org Return-Path: Received: from ml01.01.org (ml01.01.org [198.145.21.10]) by mx.zohomail.com with SMTPS id 1501616132360769.7347310271023; Tue, 1 Aug 2017 12:35:32 -0700 (PDT) Received: from [127.0.0.1] (localhost [IPv6:::1]) by ml01.01.org (Postfix) with ESMTP id 2C97921D2DCED; Tue, 1 Aug 2017 12:33:19 -0700 (PDT) Received: from NAM03-BY2-obe.outbound.protection.outlook.com (mail-by2nam03on0044.outbound.protection.outlook.com [104.47.42.44]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-SHA384 (256/256 bits)) (No client certificate requested) by ml01.01.org (Postfix) with ESMTPS id 9530421D2DCE7 for ; Tue, 1 Aug 2017 12:33:17 -0700 (PDT) Received: from leduran-Precision-WorkStation-T5400.amd.com (165.204.77.1) by BN6PR12MB1235.namprd12.prod.outlook.com (10.168.227.21) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.1.1304.22; Tue, 1 Aug 2017 19:35:25 +0000 X-Original-To: edk2-devel@lists.01.org DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amdcloud.onmicrosoft.com; s=selector1-amd-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=SH6OVhHGS7V/BWtthnJBgy88x0FdlpLJJt2knLgQZZ4=; b=2Pb7i7Z/+YbSX0qJPQYT55a3VEoiBO2Vj7I3KCo24Qh1XQD37BNXJMDC+hEl9DKYt+mEtQccQ3qyXtgTucOmQVG60hjz2oWxhKyzZRNWUIClnJPakt+DQO8MtnDjQvzc2MstYUgj1Vvpgadg2BkNV5bwl69jp6CYAXIR1zt+sV0= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=leo.duran@amd.com; From: Leo Duran To: edk2-devel@lists.01.org Date: Tue, 1 Aug 2017 14:35:13 -0500 Message-Id: <1501616113-21992-2-git-send-email-leo.duran@amd.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1501616113-21992-1-git-send-email-leo.duran@amd.com> References: <1501616113-21992-1-git-send-email-leo.duran@amd.com> MIME-Version: 1.0 X-Originating-IP: [165.204.77.1] X-ClientProxiedBy: BN6PR1301CA0031.namprd13.prod.outlook.com (10.174.84.172) To BN6PR12MB1235.namprd12.prod.outlook.com (10.168.227.21) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 0719b649-b3d2-4bec-0663-08d4d9147544 X-MS-Office365-Filtering-HT: Tenant X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(300000500095)(300135000095)(300000501095)(300135300095)(22001)(300000502095)(300135100095)(2017030254152)(300000503095)(300135400095)(48565401081)(201703131423075)(201703031133081)(201702281549075)(300000504095)(300135200095)(300000505095)(300135600095)(300000506095)(300135500095); SRVR:BN6PR12MB1235; X-Microsoft-Exchange-Diagnostics: 1; BN6PR12MB1235; 3:AHFeYze44VUPwh3XifzgSl8VoPQByVTSdNkrSRknSL3+c0CYhJfpYcrXOb5FbyyhDTq+iyoqq1uvlagKDMU6iLiIBfAnqzBvTSKF83M/6Bhh8yrbrR1bTVw/Ilyu0aBpKqrkdcSKa7vjOSHYPVAGT0TYm5Lc7YtXw0QOqLY5zhxqFSZm+LnE4XAXsxLxen6U9bB7pqWn61Ir43X8a6NImtoOCCZtOjTqA22Id9NmHDbfWarxtgjZJcZUmUBvgM/9b43+sRkAkJh84q/o4yb16THj9dpkfTyRhwkX9aTDvkmZk8ZaqBU0bUPhZblDLMD08gtg8TQ9L7lk3q7QAshVdYVoKoy3MgxTbjeulE4h5zs2MqBpnA3XAkdLjgL6yL3OfrLSWz1JpRB2YbR4FKNEj3KoZ1zluBLtz02cr0uDtnV6MzeIeZuBsfYn7fbeC/jlf0j0qL26DfwFccSCmNKKwIGaqOKv34emIpikRiHVLTGRBq5oHbiBjhTlsVxoDG4hO8YSTQwq9FoFnKS6oBO407PHa00BJsF7dZg/mX1rZfS6QNPuTneBlhfks/7qkQCtYaj4Jv6GII5j/Jagy4GlKlL+ChCb9NrMmp2J6hFaDMFXGKj5ZsVuf/qiGTmPP3egtk5HXuypmaa3npi8dzPxGodwzlDCj7hKRrcyKneBQyiZY5W6XDD5juWR68j8lOC5E51RvtqermeIbiWyEkFWefBJQ7LJGQnHHSX+7aw8OHcJQDYFRobmShOS7+KdUPAl979+HcwDXWETAlFpEz/9VOTf+uwWGVOgL1XJBYuWPmIQZeJc4kAMvlEid9rbDqdPGShgLxVHg8tNjFqTXNiTYQ== X-MS-TrafficTypeDiagnostic: BN6PR12MB1235: X-Microsoft-Exchange-Diagnostics: 1; BN6PR12MB1235; 25:J2pbRFm0G1n4rFICnAPTqKD5QcpXRA9nRUqNMUO5z19DaTPAciH1EfSJzFMQCE2v26O4S51IFveHe2JxUayFK0cE/3yWOE5T0938MUTj4328pohBEuLzqoA1yOoTxmoQ8c2oMFhwQ4eGlU26QKVXH52cqIJk9dqtg4HvGexoKcs0tfRVfqvLTLUDi56qD+AIh9DhYfQFjkDjgN7wzpVG4IoUCOpUz3Rabh8hCE3wDMxgijneyoFNcZ3k+mcbLMRD4dkFrjfdrBAGJbLBgN5eZZwWPeyPf0v/uDEOszgO83Jw24vWlOBS8lBX59Yk4UjtKunfJwo1QnxWQpTKAPcnnMyNqb43qXAVvBX3R87UA/BNaG9C/aN5OElifNnX0xqWRESLPww+SdhUo36M/MGJ2Qm4l7Y0cPXxp1Qvg8W0sYEQNAHt8zVdBSByfDoEaGdYIQY/HSnq8Ug21JLar32iW+WX3AKeCMop4QGjvHrDCMZPDIPzXRu0EFOwOr+a+23IugHY7MJm2jgMde+uBxXbraYjlnyEUm6WbGVD1Zz4+/s5/8M+VVEU7/DCEg6TwllwGH1MQhd6RdOE1UcgmEIGUzYXYQ+7tCs4BLZ5iwb0kxJKGnUwsrWOd4tltKcQmlYo6tnGz5vfdr96R2EmV4LcOntYEvFcYQybLeD5jIbU5O/Ws4NP2kVkXDVlRcuvkgSWTHPyYIEoQdhsSzT5ICKZ9gjisGNqq+43zMlWUcldeIbck1Cjg0YEfORdqn2DOBxtkLWCgXItnasROidfhzWyAiQUUotrRLcITpqc+x7YTHlKA9Cv+rHqRUsdwvoMPDW2VMXwKB7eTiMlfXIoHQDigphWPXApX/iuSJvr6PG0+ZFP9ubrhYYxkpzJD1iBDO/3e8jZGZr3bX9tOcqSLQAEmURppKQZhGMmjWqY+UYxYFI= X-Microsoft-Exchange-Diagnostics: 1; BN6PR12MB1235; 31:ZfqRMrr0z3mvgE8YVc21wRK8Ft0GEIRAaVqOCfm+opvIFKH/nFZYrzexpMEIZ3LacreuVdvZgT7WgioajiTYy7ZC+2LfqYe4T7eOMRruWBvTZ/uLCkKtrucdNd/3oNKivdOoNHpSI9NlVVuEmcogZ2c4hI9x28kvpKxNUk2MlAdJ3iwX5Sd/lL2DH+w5eI4RbOYFWVtruRZnIlAK4aSz7RZx7k9bDabBQK7sOACNjAzirysu4kPbXjDMDpneVRiIUF5akumhAtDYoPylTqG4tFtG6faJEMntC4AhJwxTtrpPs2Wx1n6gD2gRIHNsVKNdsEut6WqIbKp+yyoekSen8F5/EEhiKF+9jip3IEqW7lOOcB4VC2OjB7lOJSSXmdKl4wZGM2Eu+F+wtl8+7lhTsPN2aflpzmb9iFGuHK7cKAelOfkBWqBd2Et1yQK19Oxuf+1J1aomXgjUIWEDraqZuDvKLI+6/lfwdQA81j0m2RqugN/irE8V6U3jJUEksy9aldMjsT2vooLfvOATSwy0wcynApKyAwrQVJO7X3Cqx21AOH91VE00bI3AGEvdDbMvSNk0GnxZ+8keZZwIVOoyCyCAXX18GMTK928uvtN/xWqhnmn8AN8mP8Vhk+GUEQgUecDPiuyL1euYi2zi1fsVYtAUinnmVX2gdERsoHzoBis= X-Microsoft-Exchange-Diagnostics: 1; BN6PR12MB1235; 20:5ZwGygKDmdvtqRWB+p3Q9ZoPm8P0xPPKuC3p4WNcW10ER2dBQjG3orMaMYb3aA82HbLD4DWx0mAHWJkw8i9Sk6IjV3LZvDtb0EUTsAFkb8UYmciVltiAYj2dJAkwWRm+D9F2w9piPD8qgLg5QdiQopdyvwnah0XBcOAsq4i8DeA5Gk0wpYvljuAN6G5qXUWv8dGHW7FfL4hJMBdW0dHExUFlb5a6qYC4xtdPOBQl0NzIM56iKziBt0gmcE0nnQIk/IF2NtpqXM4VDREe7WwegR2EsTn/WTOV56deGg0A8y32+a3QUVAp//B6Q/LL/mbxxiQwZW8H59W1cM5Hl2NcJbL7KONsSV1VP21KQ66tvaJFlpXBx9xQ/HV/ONefNbTTUwy5ew/OOhLk6Ka4nFXRE9zkVy2iaHmTY79ihNKLaZjLT3HoNv0nScLBUgquGtv75gcmve3tcZZ5MBRYfxgAxa7mtk2OUWTQ5cK51iWoqQxlMRuzkEcUkdNL7NAqkw/3 X-Exchange-Antispam-Report-Test: UriScan:(767451399110)(228905959029699); X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(6040450)(601004)(2401047)(5005006)(8121501046)(10201501046)(100000703101)(100105400095)(3002001)(93006095)(93001095)(6055026)(6041248)(20161123564025)(20161123560025)(20161123562025)(20161123555025)(20161123558100)(201703131423075)(201702281528075)(201703061421075)(201703061406153)(6072148)(100000704101)(100105200095)(100000705101)(100105500095); SRVR:BN6PR12MB1235; BCL:0; PCL:0; RULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(100000804101)(100110200095)(100000805101)(100110500095); SRVR:BN6PR12MB1235; X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; BN6PR12MB1235; 4:8uiGB14T85L1LflW4SeLp1ZKh+Fd0/7UgRAmiw5L4f?= =?us-ascii?Q?inaYR0vlyaKfY+JsXEuhsEsPnKN0D89C0LMJuYGWWeRsvyMu48spuztTcMn1?= =?us-ascii?Q?A5x2EaWygZ0TUqRnpH2DQM0osE+EBksgD2P/M0bmoiXJvSjBVfmo/VitTtY9?= =?us-ascii?Q?Jnj/yKuEZQdNtZ6GV/1P2aTHz7hmZqhNwncf/6CiaQ+YXFl19/yOgRwpdEqr?= =?us-ascii?Q?7614ZaXXRnpyrDoE3qMz6GjIEcDfQbwEBhtmP0rrUChX5uBYy2eDxOEyHZMN?= =?us-ascii?Q?p2obU6QQ55kCA/XTLu4BY9f5kzSDjExlriRv5xz7DqQlY489NgxadLlLoTaq?= =?us-ascii?Q?j98wiflRRRBNkNOux46MRa/fcUN/bqjgLBCzGKt69870EgHJEb/n1tAmzuvD?= =?us-ascii?Q?XxlPDtN5R/lvI4ij15bxumKnJ6zC4Cgdz3TY1r1WnLDJOI00POVH3hLO888o?= =?us-ascii?Q?KwuUZJ1ESLFY7H+Z98CKJs0zCyBlNdhloDUM8tG+8geJ4fJZsnH3nIMcceAk?= =?us-ascii?Q?gefTALFg/7ASANQdvi7T6u7b5KmcmnMLoycjzDphmHW2VCdhEPXd4jafzOcA?= =?us-ascii?Q?XgTeOrEqQjbK2YjibvMURNMVs8VtB6JH3Dn3VHQEksuj0juL1Yqnn+f4sCgM?= =?us-ascii?Q?UiQDm8uLnWRA4xq/v6t+A+52KFY+P9Z9x3HtjaBAPTrNFe8b3ArFK+Vm7JFe?= =?us-ascii?Q?5ZSn0pjaezHWkBgDnjh3UG67ZV91ZP4blxrbsFerwa7auxBV+8WwxzzhUm1K?= =?us-ascii?Q?A2+UTG1SauB4LFiFqM/UqqiagVzVb4hdxCOtgQy+b2SFRr7WlbxsUeke2gcO?= =?us-ascii?Q?MFnY1r3p2r2PKfF5+vT1Kc5P8HkxevtZeQPn68nlvO+xBgdvpNi1rwhsbWzd?= =?us-ascii?Q?3C8m1UvC16rZCA3k0l22E3vW8KIaE9H7CZ4IC1SFms5eRjLskN4iRGSRJUvl?= =?us-ascii?Q?nWsZa0BF1Ru6dkFJZYI+04hcLIpY5OxwO+42WxIT6oQgwJPf6GXlCg0PFJ+B?= =?us-ascii?Q?pVTtpKkzZx73Eaf9jHOsAYWOvB3iF2Kklciaa6FUD2cZaRMk8eR05liERV/R?= =?us-ascii?Q?37X3vvZeYBHvAPKtnzAHmNsB4OBeiIGo49hbZQuR+sodepFsk+MN8Np9sRMz?= =?us-ascii?Q?rt8ssAVyiu8DL7spKyPzhu/jKhb527OSlQDtMbIANuxMKpBA6NLSvNAOlFqO?= =?us-ascii?Q?5VE4bcNUP+c+7abRWuk/u61rEY93Ovf/2CxkEA4MBbvO8clTDYhRWY4QOGGd?= =?us-ascii?Q?oKYR0x6Wl+KKXExNg=3D?= X-Forefront-PRVS: 0386B406AA X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10009020)(4630300001)(7370300001)(6009001)(39450400003)(39860400002)(39840400002)(39400400002)(39410400002)(39850400002)(199003)(189002)(68736007)(5003940100001)(42186005)(8676002)(110136004)(38730400002)(81156014)(81166006)(50986999)(76176999)(478600001)(66066001)(6116002)(101416001)(50226002)(189998001)(47776003)(50466002)(3846002)(2950100002)(6916009)(48376002)(105586002)(53416004)(106356001)(2906002)(6666003)(97736004)(33646002)(2361001)(4326008)(2351001)(25786009)(5660300001)(7350300001)(7736002)(86362001)(575784001)(54906002)(6486002)(36756003)(305945005)(53936002)(19627235001); DIR:OUT; SFP:1101; SCL:1; SRVR:BN6PR12MB1235; H:leduran-Precision-WorkStation-T5400.amd.com; FPR:; SPF:None; PTR:InfoNoRecords; A:1; MX:1; LANG:en; Received-SPF: none (zoho.com: 198.145.21.10 is neither permitted nor denied by domain of lists.01.org) client-ip=198.145.21.10; envelope-from=edk2-devel-bounces@lists.01.org; helo=ml01.01.org; Received-SPF: None (protection.outlook.com: amd.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; BN6PR12MB1235; 23:RvLbNNejDUBM5rkb4pr6cXBBsviYCNODZebE+pVld?= =?us-ascii?Q?4g49UKrWTPUEGm4XokwB7Dt4/0gOBylxuJu9viZ3dHg/smx5XFp7t9WScRvE?= =?us-ascii?Q?vLHvvFTB8ZQ5CSChOHIYLVCmo/+faEVfCK4dg4NGa6bwZ0EUbsethbZyCJ+k?= =?us-ascii?Q?hWVRBh+Eq9Kh3aIlxChLGPAG7BvlYaTm8/PunX16C9kL1u+wd40cTJlo2Tru?= =?us-ascii?Q?us0ohnsptQ+CHbbo8ZrbeXrdM46iFfcOVkbR36I3noOH9K9wLaERjp8mioW2?= =?us-ascii?Q?TGx26NA16VRBkzJJV/DFCo30JlnjJ899XvstpojGo+bWf/K+/02q0crWL/+Z?= =?us-ascii?Q?GOGod3/jglIy00AwkiSG0yylnEzZ3m2cCOl3DsK2/mPinTQYvV1+dM4317QQ?= =?us-ascii?Q?tA0YQz11IdlyQPfaGTyuHINpO1eJyTNOdt5yH++b4bQgmVvuI903bQWan9pl?= =?us-ascii?Q?lHU3dXbkcq0jXnDlXlt8MeOShXaBx7cDdPGcR7bpusFzGNR+qMFhV+pQVEZr?= =?us-ascii?Q?UagfD7UWXUHuciAbagTucddL9SZKum4AhiXm6adpJ0p/CMdgDzN6O2pHfSIO?= =?us-ascii?Q?Lz9Obevrq07Nmw1KXg8M37XXVfaiWJX36ivrqL8Wjl+eWKMY/pWkAz5uROm0?= =?us-ascii?Q?X5CZV9ZzXTQxmQuzLOEEd5DWASJZ2tnp42uLCZV4JLujSfY8EQJ20RNBDWg/?= =?us-ascii?Q?Ztw/UJGJhRtBSLkO8old6v6eLmNTJayYpjt9jhB2kJqIPUTzQC4nJWF3oy1G?= =?us-ascii?Q?xeGuA/quEKf1ILMebq2thVo8VakKoDKhtThx2JW8E9x96ohGR6NrW0RfSu0q?= =?us-ascii?Q?ntBkGXDodm77y5/EO0NaRYrA5RbJTvqj9gCue6nOEGRi8cyg+Jtf6dq23ElS?= =?us-ascii?Q?WsnE6oVUw+Zbz6/5VqGHP69FBqMXNEMfAkw03PzmMpzIT2hknnaZGFwhnY6/?= =?us-ascii?Q?PETRTfncJ4d6Mp22gDHujmSjLj1lasDjgP7oVcLHVFrrsEgo0btwKRJgC93E?= =?us-ascii?Q?+ZXXE+KnSV+yeC6cVfSln7KSu9ss7UJpgc5JqchvJ5Cw3HeY+BoNVt32YYAj?= =?us-ascii?Q?RcH/KKbGNxvdMEA9ZZhAXrKb3ayTVYmulurR0p2WYlezPb5KJqPs3QI8tCmM?= =?us-ascii?Q?NOKO/9knm0gIX4o8HrHbbqjHZyuYb4ROuUb1zatOrneDUn806CuCJ/4Rko75?= =?us-ascii?Q?wHHrsiQQ1FXvYtas5V46QMvkT26uNlWvKA3h2ImVQdRFlqJvc9Qitw/ONa9T?= =?us-ascii?Q?/vl8n29X9btwueEQCro2olw80o2hbhdlH7c9zCx35javIzGjc4Q9rcldHOSt?= =?us-ascii?Q?FH0aFZSFkKyulzH3d0demGVjF9+peW+ZW3bYQXbmEAnzmN7wVgBUcgN6HZjR?= =?us-ascii?Q?OZlEw=3D=3D?= X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; BN6PR12MB1235; 6:cGFnYpHS3LnGw6rQJW7vnQH3tjY4PHWkMDABrDnqEo?= =?us-ascii?Q?XFmFC/rFKX9wG7PIsS63lE0Asw3BeLwSbJeRd8DcTA7MpT77mC//IBJNIA0g?= =?us-ascii?Q?WXApIpikriWeN8lx6ZljzMxUolVlQ/+C6k9TrtaIUSo588Byt1aIDmG/fcvB?= =?us-ascii?Q?QGAfgqPAwuWZ5dMZ9FxH93/kvaZ2Ae15hvpRa7VWUNIGUeHYXzpHt7aSwYmM?= =?us-ascii?Q?QejQck3R1vUto7N0Y/8DO3N8qKNtA7rxWXFWH8FoHR/5z02LCBeRmOHgn14d?= =?us-ascii?Q?V+1Z3fU9HUYId0up1qZ/Qnl2jlB9GJhCu85DipH9viy7WghTxGiZvwcE+aqF?= =?us-ascii?Q?027jxUV/0WZqwUOCoLB+yehWzFA2dhTVGDuHz/mQrKjeYFBBDjracGCKbhPm?= =?us-ascii?Q?qfFRdLVOaWnjFd9cR1Pj2y0b4qexdTCRXXnIFBK0REkF/Xsl7eE8gvyc4eFs?= =?us-ascii?Q?KyJZx4VxRsVO1wrtV2+CxChTCX65FDTYJSeBmwNUs+CIQgfmGZEDz8B+j1IB?= =?us-ascii?Q?/uT8HTMsggAhY40E8E0ad0OPY2JXVBTAs0QEVpK5l4RXJi/Zhh2u5mCLDqae?= =?us-ascii?Q?tVIV2kJJ4pFvNNBPXeG6W1lD2L5+dEIZwJbsCdfWRmR5e5au8wXusDVqGAzv?= =?us-ascii?Q?iAyWnxukwkpj6T9bxsiSgaYXWdR4Odp9Jhe0nT/Q2wKvs0JqE+6voFBCBsh3?= =?us-ascii?Q?zY+Gnb0zp+FtkxJOB/stx68mSKa064RKgn2Hl4N0qLT1DqethChn5dUnFZon?= =?us-ascii?Q?JZlxmHMaWeB7Lf96ZY5s2+gNb8dJG6HGRqoaJ5ha5L66mSOk8zyEh3ov/yq0?= =?us-ascii?Q?p6jgpWLPFF6KVBH/wG85TrhhGQh2xvczPToxYPinUFSMmkKBF9P4qkcMpdO0?= =?us-ascii?Q?FJCyDcht90Rlk3QGD7wj5pQ/RI4610ygQ4PJYiC1sGlramwzf0eHVSZv2Htn?= =?us-ascii?Q?MVyE2dhyHyPTPN9MfaMpxzmZuJ7cBjUCOfsWXk151qjPLT7y04Jf/Dx/E0Wd?= =?us-ascii?Q?wcWwfgV3Smcv4qKdVaByOP?= X-Microsoft-Exchange-Diagnostics: 1; BN6PR12MB1235; 5:raPcAGXhb87uhSh/PDMD1KP/kJ79nQYyURY6pML6ukNR76XFI9rCelJ/mrs2Ud5LiophoR9miyXPIC/X/W8OY1aDzYpccnX8xTzRXYA7z/qqYNBTs2cXKKpxk2bQ3ZFGu8OXAV3i615d5oAUlsB2/Zw+eRnpPL+PksxJ4PMLgLnDvGnVknT8gt2yzkXQANkQty5IBuD1KdifVXCihTnRAK5kE3HCRC9pmPPnQNGwazdAHF9eVWYRGeT27JguZGpvNtrgxccoGn/NzCKRFe/ZySdYNKQtcX1o9Q5zpEYaTLs4DinPPho9P+euFeclPRDLa6g7FACApyZL3GQyUoh3LaCy1i4DR7UfN7A5Pa8gnOjwUhB0EO0yllyv1uPz85TR7utT0qiTI4/pkRIwTXrYpPnX353Q84dqmfNAJUCj4zjnjAUpHQ8YvbV9oCXGW0P1l2XMhckiY8fX3hqON2tMaPu1c1c8EUD8ofwzfYE0tBKKfWUSkW+EJIhrefWjrVbR; 24:rp7jOH5EIx4w/szUXx9meikH2RhgT2IYtGmg1FUTthryta2qwMKEKOTOBDrSIsFvSDgnWQeYBgE8ZuWf3E5Fk4qEjEWtKX06wth7tYe/MVU= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1; BN6PR12MB1235; 7:vZc3cKf1UcY1mS9lW3/VEs7xM+62QZ10OuU01XBV3piWACf51jUfoPrfAjkyiKNUQ2t3w4Lo8g9IbLz3oIc3pHl34DdFp+HycrbEIGmnePbVORayQvKssYui1vRZNELS+MDbXLPwbB35QnL4c+v8G6zFJoO+LBi0hR7eXKdycyjACLbEOh+MC03UFtqDVhtPH/XT+CYDUicvJQvUs5S9s53Ni8KaCzv2pFiN9NF/u5dpr9wmXWziE9dgOO9MU655J2RIB7Eo/AbTjE1FVKYY9nmwSAsvZRAOc9CPzNlO6wbM2hzIot6Zz/M9Uo5DhNjuLZRaxs9LieUDbOnH0bVSBXF7v5Ne9iIXw3yN8H9iOjOHeJZzvP/oDgdEHeKuOir0Y+i1SPiOAUPgZB6+z/xXQPgGPPL1dhbFeDM/O8A1Ycccx/HDAJs999ec7VghguQqc2V4xjJRwOCqfsMVyOJDFqvXCqYVBWrQWcO+iAf0qpLYfVW+zdbHT1hbLmVgJfHwNxCvMHJ4F/bTP5a3h6Gjg1pY6aIbHCDAE+/T9QvGpzFmEWt+/aTxDdVa7lgw5O/iHDcbv7dYRnn2N2M0P3km3o3vDhRxL8Gp+83h7N2gDZf7folPCpIzridtvcj6LrpJ0tK/27iT4zTgRq2qn99auX7TyOHvWaCBUO1dTnIupR4xfPkdMSZznW4f3aYllInCOOmMt4Ylxo7FjkekicPcZn0N7VZByC1XBBK3N2xPND3ScT0prkAZUNo1A5kJL80BlQEAvrS8nC17+JiSHOSZUq7U+wNyCChOoGcKl6WFQ/o= X-Microsoft-Exchange-Diagnostics: 1; BN6PR12MB1235; 20:5PjIEGPfQYePKwiupEIupNX80WZoI44/YwHh6zX6ZF+VOmTzgcO05C6F08BhQhn30a2IwuZvK1hhEJonY+5CrTK3jqqUBKubCbOMPCDBE/9bDOzZ5AZFk6FQzoSIZNqtq29TS1VklAsqi6A18MtqBL8UZg2F3PLhpNRVRCt6B0WUjcvc9YGlYNX5j2MAj8sBaCEOaxXlOsrsUyRD6jLTJ601Qckqmnm4/aziAPYm4WqRAvtV6cR/DVUWjcrsNgQ/ X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 01 Aug 2017 19:35:25.3275 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-Transport-CrossTenantHeadersStamped: BN6PR12MB1235 Subject: [edk2] [PATCH] UefiCpuPkg: ApicLib X-BeenThere: edk2-devel@lists.01.org X-Mailman-Version: 2.1.22 Precedence: list List-Id: EDK II Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Jordan Justen , Leo Duran , Jeff Fan , Liming Gao Content-Transfer-Encoding: quoted-printable Errors-To: edk2-devel-bounces@lists.01.org Sender: "edk2-devel" X-ZohoMail-DKIM: fail (Header signature does not verify) X-ZohoMail: RDKM_2 RSF_4 Z_629925259 SPT_0 Content-Type: text/plain; charset="utf-8" GetProcessorLocationByApicId () - Use max possible thread count to decode InitialApicId on AMD processor. - Clean-up on C Coding standards. Cc: Jordan Justen Cc: Jeff Fan Cc: Liming Gao Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Leo Duran --- UefiCpuPkg/Library/BaseXApicLib/BaseXApicLib.c | 64 ++++++------------= ---- .../BaseXApicX2ApicLib/BaseXApicX2ApicLib.c | 64 ++++++------------= ---- 2 files changed, 32 insertions(+), 96 deletions(-) diff --git a/UefiCpuPkg/Library/BaseXApicLib/BaseXApicLib.c b/UefiCpuPkg/Li= brary/BaseXApicLib/BaseXApicLib.c index 2091e5e..b0b7e32 100644 --- a/UefiCpuPkg/Library/BaseXApicLib/BaseXApicLib.c +++ b/UefiCpuPkg/Library/BaseXApicLib/BaseXApicLib.c @@ -48,7 +48,7 @@ StandardSignatureIsAuthenticAMD ( UINT32 RegEcx; UINT32 RegEdx; =20 - AsmCpuid(CPUID_SIGNATURE, NULL, &RegEbx, &RegEcx, &RegEdx); + AsmCpuid (CPUID_SIGNATURE, NULL, &RegEbx, &RegEcx, &RegEdx); return (RegEbx =3D=3D CPUID_SIGNATURE_AUTHENTIC_AMD_EBX && RegEcx =3D=3D CPUID_SIGNATURE_AUTHENTIC_AMD_ECX && RegEdx =3D=3D CPUID_SIGNATURE_AUTHENTIC_AMD_EDX); @@ -1000,7 +1000,6 @@ GetProcessorLocationByApicId ( CPUID_EXTENDED_TOPOLOGY_ECX ExtendedTopologyEcx; CPUID_AMD_EXTENDED_CPU_SIG_ECX AmdExtendedCpuSigEcx; CPUID_AMD_PROCESSOR_TOPOLOGY_EBX AmdProcessorTopologyEbx; - CPUID_AMD_PROCESSOR_TOPOLOGY_ECX AmdProcessorTopologyEcx; CPUID_AMD_VIR_PHY_ADDRESS_SIZE_ECX AmdVirPhyAddressSizeEcx; UINT32 MaxStandardCpuIdIndex; UINT32 MaxExtendedCpuIdIndex; @@ -1008,18 +1007,13 @@ GetProcessorLocationByApicId ( UINTN LevelType; UINT32 MaxLogicProcessorsPerPackage; UINT32 MaxCoresPerPackage; - UINT32 MaxThreadPerPackageMask; - UINT32 ActualThreadPerPackageMask; - UINT32 MaxCoresPerNode; - UINT32 CorePerNodeMask; - UINT32 ApicIdShift; UINTN ThreadBits; UINTN CoreBits; =20 // // Check if the processor is capable of supporting more than one logical= processor. // - AsmCpuid(CPUID_VERSION_INFO, NULL, NULL, NULL, &VersionInfoEdx.Uint32); + AsmCpuid (CPUID_VERSION_INFO, NULL, NULL, NULL, &VersionInfoEdx.Uint32); if (VersionInfoEdx.Bits.HTT =3D=3D 0) { if (Thread !=3D NULL) { *Thread =3D 0; @@ -1042,8 +1036,8 @@ GetProcessorLocationByApicId ( // // Get max index of CPUID // - AsmCpuid(CPUID_SIGNATURE, &MaxStandardCpuIdIndex, NULL, NULL, NULL); - AsmCpuid(CPUID_EXTENDED_FUNCTION, &MaxExtendedCpuIdIndex, NULL, NULL, NU= LL); + AsmCpuid (CPUID_SIGNATURE, &MaxStandardCpuIdIndex, NULL, NULL, NULL); + AsmCpuid (CPUID_EXTENDED_FUNCTION, &MaxExtendedCpuIdIndex, NULL, NULL, N= ULL); =20 // // If the extended topology enumeration leaf is available, it @@ -1072,7 +1066,7 @@ GetProcessorLocationByApicId ( // the SMT sub-field of x2APIC ID. // LevelType =3D ExtendedTopologyEcx.Bits.LevelType; - ASSERT(LevelType =3D=3D CPUID_EXTENDED_TOPOLOGY_LEVEL_TYPE_SMT); + ASSERT (LevelType =3D=3D CPUID_EXTENDED_TOPOLOGY_LEVEL_TYPE_SMT); ThreadBits =3D ExtendedTopologyEax.Bits.ApicIdShift; =20 // @@ -1081,7 +1075,7 @@ GetProcessorLocationByApicId ( // SubIndex =3D 1; do { - AsmCpuidEx( + AsmCpuidEx ( CPUID_EXTENDED_TOPOLOGY, SubIndex, &ExtendedTopologyEax.Uint32, @@ -1103,7 +1097,7 @@ GetProcessorLocationByApicId ( // // Get logical processor count // - AsmCpuid(CPUID_VERSION_INFO, NULL, &VersionInfoEbx.Uint32, NULL, NULL); + AsmCpuid (CPUID_VERSION_INFO, NULL, &VersionInfoEbx.Uint32, NULL, NULL= ); MaxLogicProcessorsPerPackage =3D VersionInfoEbx.Bits.MaximumAddressabl= eIdsForLogicalProcessors; =20 // @@ -1116,45 +1110,19 @@ GetProcessorLocationByApicId ( // if (StandardSignatureIsAuthenticAMD()) { if (MaxExtendedCpuIdIndex >=3D CPUID_AMD_PROCESSOR_TOPOLOGY) { - AsmCpuid(CPUID_EXTENDED_CPU_SIG, NULL, NULL, &AmdExtendedCpuSigEcx= .Uint32, NULL); + AsmCpuid (CPUID_EXTENDED_CPU_SIG, NULL, NULL, &AmdExtendedCpuSigEc= x.Uint32, NULL); if (AmdExtendedCpuSigEcx.Bits.TopologyExtensions !=3D 0) { - AsmCpuid(CPUID_AMD_PROCESSOR_TOPOLOGY, NULL, &AmdProcessorTopolo= gyEbx.Uint32, - &AmdProcessorTopologyEcx.Uint32, NULL); + // + // Account for max possible thread count to decode ApicId + // + AsmCpuid (CPUID_VIR_PHY_ADDRESS_SIZE, NULL, NULL, &AmdVirPhyAddr= essSizeEcx.Uint32, NULL); + MaxLogicProcessorsPerPackage =3D 1 << AmdVirPhyAddressSizeEcx.Bi= ts.ApicIdCoreIdSize; + // // Get cores per processor package // + AsmCpuid (CPUID_AMD_PROCESSOR_TOPOLOGY, NULL, &AmdProcessorTopol= ogyEbx.Uint32, NULL, NULL); MaxCoresPerPackage =3D MaxLogicProcessorsPerPackage / (AmdProces= sorTopologyEbx.Bits.ThreadsPerCore + 1); - - // - // Account for actual thread count (e.g., SMT disabled) - // - AsmCpuid(CPUID_VIR_PHY_ADDRESS_SIZE, NULL, NULL, &AmdVirPhyAddre= ssSizeEcx.Uint32, NULL); - MaxThreadPerPackageMask =3D 1 << AmdVirPhyAddressSizeEcx.Bits.Ap= icIdCoreIdSize; - ActualThreadPerPackageMask =3D 1; - while (ActualThreadPerPackageMask < MaxLogicProcessorsPerPackage= ) { - ActualThreadPerPackageMask <<=3D 1; - } - - // - // Adjust APIC Id to report concatenation of Package|Core|Thread. - // - if (ActualThreadPerPackageMask < MaxThreadPerPackageMask) { - MaxCoresPerNode =3D MaxCoresPerPackage / (AmdProcessorTopology= Ecx.Bits.NodesPerProcessor + 1); - - CorePerNodeMask =3D 1; - while (CorePerNodeMask < MaxCoresPerNode) { - CorePerNodeMask <<=3D 1; - } - CorePerNodeMask -=3D 1; - - ApicIdShift =3D 0; - do { - ApicIdShift +=3D 1; - ActualThreadPerPackageMask <<=3D 1; - } while (ActualThreadPerPackageMask < MaxThreadPerPackageMask); - - InitialApicId =3D ((InitialApicId & ~CorePerNodeMask) >> ApicI= dShift) | (InitialApicId & CorePerNodeMask); - } } } } @@ -1163,7 +1131,7 @@ GetProcessorLocationByApicId ( // Extract core count based on CACHE information // if (MaxStandardCpuIdIndex >=3D CPUID_CACHE_PARAMS) { - AsmCpuidEx(CPUID_CACHE_PARAMS, 0, &CacheParamsEax.Uint32, NULL, NU= LL, NULL); + AsmCpuidEx (CPUID_CACHE_PARAMS, 0, &CacheParamsEax.Uint32, NULL, N= ULL, NULL); if (CacheParamsEax.Uint32 !=3D 0) { MaxCoresPerPackage =3D CacheParamsEax.Bits.MaximumAddressableIds= ForLogicalProcessors + 1; } diff --git a/UefiCpuPkg/Library/BaseXApicX2ApicLib/BaseXApicX2ApicLib.c b/U= efiCpuPkg/Library/BaseXApicX2ApicLib/BaseXApicX2ApicLib.c index d5d4efa..1f4dcf7 100644 --- a/UefiCpuPkg/Library/BaseXApicX2ApicLib/BaseXApicX2ApicLib.c +++ b/UefiCpuPkg/Library/BaseXApicX2ApicLib/BaseXApicX2ApicLib.c @@ -49,7 +49,7 @@ StandardSignatureIsAuthenticAMD ( UINT32 RegEcx; UINT32 RegEdx; =20 - AsmCpuid(CPUID_SIGNATURE, NULL, &RegEbx, &RegEcx, &RegEdx); + AsmCpuid (CPUID_SIGNATURE, NULL, &RegEbx, &RegEcx, &RegEdx); return (RegEbx =3D=3D CPUID_SIGNATURE_AUTHENTIC_AMD_EBX && RegEcx =3D=3D CPUID_SIGNATURE_AUTHENTIC_AMD_ECX && RegEdx =3D=3D CPUID_SIGNATURE_AUTHENTIC_AMD_EDX); @@ -1095,7 +1095,6 @@ GetProcessorLocationByApicId ( CPUID_EXTENDED_TOPOLOGY_ECX ExtendedTopologyEcx; CPUID_AMD_EXTENDED_CPU_SIG_ECX AmdExtendedCpuSigEcx; CPUID_AMD_PROCESSOR_TOPOLOGY_EBX AmdProcessorTopologyEbx; - CPUID_AMD_PROCESSOR_TOPOLOGY_ECX AmdProcessorTopologyEcx; CPUID_AMD_VIR_PHY_ADDRESS_SIZE_ECX AmdVirPhyAddressSizeEcx; UINT32 MaxStandardCpuIdIndex; UINT32 MaxExtendedCpuIdIndex; @@ -1103,18 +1102,13 @@ GetProcessorLocationByApicId ( UINTN LevelType; UINT32 MaxLogicProcessorsPerPackage; UINT32 MaxCoresPerPackage; - UINT32 MaxThreadPerPackageMask; - UINT32 ActualThreadPerPackageMask; - UINT32 MaxCoresPerNode; - UINT32 CorePerNodeMask; - UINT32 ApicIdShift; UINTN ThreadBits; UINTN CoreBits; =20 // // Check if the processor is capable of supporting more than one logical= processor. // - AsmCpuid(CPUID_VERSION_INFO, NULL, NULL, NULL, &VersionInfoEdx.Uint32); + AsmCpuid (CPUID_VERSION_INFO, NULL, NULL, NULL, &VersionInfoEdx.Uint32); if (VersionInfoEdx.Bits.HTT =3D=3D 0) { if (Thread !=3D NULL) { *Thread =3D 0; @@ -1137,8 +1131,8 @@ GetProcessorLocationByApicId ( // // Get max index of CPUID // - AsmCpuid(CPUID_SIGNATURE, &MaxStandardCpuIdIndex, NULL, NULL, NULL); - AsmCpuid(CPUID_EXTENDED_FUNCTION, &MaxExtendedCpuIdIndex, NULL, NULL, NU= LL); + AsmCpuid (CPUID_SIGNATURE, &MaxStandardCpuIdIndex, NULL, NULL, NULL); + AsmCpuid (CPUID_EXTENDED_FUNCTION, &MaxExtendedCpuIdIndex, NULL, NULL, N= ULL); =20 // // If the extended topology enumeration leaf is available, it @@ -1167,7 +1161,7 @@ GetProcessorLocationByApicId ( // the SMT sub-field of x2APIC ID. // LevelType =3D ExtendedTopologyEcx.Bits.LevelType; - ASSERT(LevelType =3D=3D CPUID_EXTENDED_TOPOLOGY_LEVEL_TYPE_SMT); + ASSERT (LevelType =3D=3D CPUID_EXTENDED_TOPOLOGY_LEVEL_TYPE_SMT); ThreadBits =3D ExtendedTopologyEax.Bits.ApicIdShift; =20 // @@ -1176,7 +1170,7 @@ GetProcessorLocationByApicId ( // SubIndex =3D 1; do { - AsmCpuidEx( + AsmCpuidEx ( CPUID_EXTENDED_TOPOLOGY, SubIndex, &ExtendedTopologyEax.Uint32, @@ -1198,7 +1192,7 @@ GetProcessorLocationByApicId ( // // Get logical processor count // - AsmCpuid(CPUID_VERSION_INFO, NULL, &VersionInfoEbx.Uint32, NULL, NULL); + AsmCpuid (CPUID_VERSION_INFO, NULL, &VersionInfoEbx.Uint32, NULL, NULL= ); MaxLogicProcessorsPerPackage =3D VersionInfoEbx.Bits.MaximumAddressabl= eIdsForLogicalProcessors; =20 // @@ -1211,45 +1205,19 @@ GetProcessorLocationByApicId ( // if (StandardSignatureIsAuthenticAMD()) { if (MaxExtendedCpuIdIndex >=3D CPUID_AMD_PROCESSOR_TOPOLOGY) { - AsmCpuid(CPUID_EXTENDED_CPU_SIG, NULL, NULL, &AmdExtendedCpuSigEcx= .Uint32, NULL); + AsmCpuid (CPUID_EXTENDED_CPU_SIG, NULL, NULL, &AmdExtendedCpuSigEc= x.Uint32, NULL); if (AmdExtendedCpuSigEcx.Bits.TopologyExtensions !=3D 0) { - AsmCpuid(CPUID_AMD_PROCESSOR_TOPOLOGY, NULL, &AmdProcessorTopolo= gyEbx.Uint32, - &AmdProcessorTopologyEcx.Uint32, NULL); + // + // Account for max possible thread count to decode ApicId + // + AsmCpuid (CPUID_VIR_PHY_ADDRESS_SIZE, NULL, NULL, &AmdVirPhyAddr= essSizeEcx.Uint32, NULL); + MaxLogicProcessorsPerPackage =3D 1 << AmdVirPhyAddressSizeEcx.Bi= ts.ApicIdCoreIdSize; + // // Get cores per processor package // + AsmCpuid (CPUID_AMD_PROCESSOR_TOPOLOGY, NULL, &AmdProcessorTopol= ogyEbx.Uint32, NULL, NULL); MaxCoresPerPackage =3D MaxLogicProcessorsPerPackage / (AmdProces= sorTopologyEbx.Bits.ThreadsPerCore + 1); - - // - // Account for actual thread count (e.g., SMT disabled) - // - AsmCpuid(CPUID_VIR_PHY_ADDRESS_SIZE, NULL, NULL, &AmdVirPhyAddre= ssSizeEcx.Uint32, NULL); - MaxThreadPerPackageMask =3D 1 << AmdVirPhyAddressSizeEcx.Bits.Ap= icIdCoreIdSize; - ActualThreadPerPackageMask =3D 1; - while (ActualThreadPerPackageMask < MaxLogicProcessorsPerPackage= ) { - ActualThreadPerPackageMask <<=3D 1; - } - - // - // Adjust APIC Id to report concatenation of Package|Core|Thread. - // - if (ActualThreadPerPackageMask < MaxThreadPerPackageMask) { - MaxCoresPerNode =3D MaxCoresPerPackage / (AmdProcessorTopology= Ecx.Bits.NodesPerProcessor + 1); - - CorePerNodeMask =3D 1; - while (CorePerNodeMask < MaxCoresPerNode) { - CorePerNodeMask <<=3D 1; - } - CorePerNodeMask -=3D 1; - - ApicIdShift =3D 0; - do { - ApicIdShift +=3D 1; - ActualThreadPerPackageMask <<=3D 1; - } while (ActualThreadPerPackageMask < MaxThreadPerPackageMask); - - InitialApicId =3D ((InitialApicId & ~CorePerNodeMask) >> ApicI= dShift) | (InitialApicId & CorePerNodeMask); - } } } } @@ -1258,7 +1226,7 @@ GetProcessorLocationByApicId ( // Extract core count based on CACHE information // if (MaxStandardCpuIdIndex >=3D CPUID_CACHE_PARAMS) { - AsmCpuidEx(CPUID_CACHE_PARAMS, 0, &CacheParamsEax.Uint32, NULL, NU= LL, NULL); + AsmCpuidEx (CPUID_CACHE_PARAMS, 0, &CacheParamsEax.Uint32, NULL, N= ULL, NULL); if (CacheParamsEax.Uint32 !=3D 0) { MaxCoresPerPackage =3D CacheParamsEax.Bits.MaximumAddressableIds= ForLogicalProcessors + 1; } --=20 2.7.4 _______________________________________________ edk2-devel mailing list edk2-devel@lists.01.org https://lists.01.org/mailman/listinfo/edk2-devel