Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752729AbeAJSd2 (ORCPT + 1 other); Wed, 10 Jan 2018 13:33:28 -0500 Received: from mail-cys01nam02on0059.outbound.protection.outlook.com ([104.47.37.59]:43456 "EHLO NAM02-CY1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1752249AbeAJSd0 (ORCPT ); Wed, 10 Jan 2018 13:33:26 -0500 Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=Felix.Kuehling@amd.com; Subject: Re: [PATCH] drm/amdkfd: Fix potential NULL pointer dereferences To: "Gustavo A. R. Silva" , Oded Gabbay , Alex Deucher , =?UTF-8?Q?Christian_K=c3=b6nig?= , David Airlie Cc: amd-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org References: <20180110165008.GA10691@embeddedor.com> From: Felix Kuehling Organization: AMD Inc. Message-ID: Date: Wed, 10 Jan 2018 13:33:20 -0500 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.5.0 MIME-Version: 1.0 In-Reply-To: <20180110165008.GA10691@embeddedor.com> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit Content-Language: en-CA X-Originating-IP: [165.204.55.251] X-ClientProxiedBy: CY4PR01CA0017.prod.exchangelabs.com (10.169.249.27) To DM5PR1201MB0235.namprd12.prod.outlook.com (10.174.107.23) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-HT: Tenant X-MS-Office365-Filtering-Correlation-Id: 4cb0d3e9-42d4-4e91-c162-08d55858a252 X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:(48565401081)(4534020)(4602075)(4627115)(201703031133081)(201702281549075)(5600026)(4604075)(2017052603307)(7153060)(7193020);SRVR:DM5PR1201MB0235; X-Microsoft-Exchange-Diagnostics: 1;DM5PR1201MB0235;3:G83OqplBmW4MHshUE5A2EV6NaMkpxJ2gpfNDymfqqgQYM7MHZ0jcLk2S/4Zdz9CVlZiZHMdsKE7x3iDBOkgVHd/noOhqn2tSnP73I8rjhRqekbnIcc6ihmUfIxDQeY7WtWJp1PxONxAXqS5SY6xbDNAw5IXQRYSwHZOOUH+PTwf8SajqAJ1TsMy2DC2RMLhJ/633xj3yPo6LgXT9+FcyXKGJ3ycC0U/dNNFOEPo0QErbPEJIvE81oqrr5g6ADdAR;25:BW8H3JGHmnnzUfoBkWbWGosbgApkx2xEAb45VDhrm/atc4JochdHrIRCD44v//mGE4UggzCNY9yidAJAXvdW5wiPTKWufqhEwFU1qMj/wS2RPfvwn/Rug3dY69Jvg05QBidbOwgZjbkVWJECbAe1H8FnG70+tPIpuarJBDGjd2Jad+SC79AZ8fFomMHe0rMjZ1daNs+MicmCf+atAEvfTnDouIVDv8P6MZ5VyfGX/CT5Pz/QqcL4yp72pHDft0fQchKPzaRD4ddC4Ec2LDeJrq+sF6xqMhY6eX2wT6Toz5GMa3r2r2iqd0BYOfKt0CBYgo2QH03eT1g2PapccCEpSA==;31:cnnWqzKdNGyC7mhMGjEXOCuAFnz8T91vF7rYIG70cNgywcoWx7ugksFqAdv+91rNQqKRlMzirt7Scj1OOYx0FysKSH1xU6GhPVJ57tbIkBcREDzu8LkRtFHG1CyO3EilSFFsJZ8ci6v+/kblH+X7/VNmWi5n1wH5isPm21WFfFN29sRi5hW2sop8iZyaVGJR40JsEd4zg4/eg0owl6Y7p9LShvXS+ZuFXZoPLeSdNXU= X-MS-TrafficTypeDiagnostic: DM5PR1201MB0235: X-Microsoft-Exchange-Diagnostics: 1;DM5PR1201MB0235;20:uiof+Bx+8TY0PtnrchlohGRlZsoB4EEzfWHfvTIoX6NoQ3aubOj4C+OdH839FEFDrX5HTlkX8u7HZ2s47+0NqMnqjheDKHVPozKuImkAVvgFG2CeSqAYZ/dsNBrLni+KWtWhzBKydKvTXMk7I+zphZ5KCDFhHhcpTa11lDndBRg1hsIkJ+ZyLNcloGUcTruucCJt2I9Qga0D/RPZhAiDQXq0NnOzciVmebXZxhppM913ksTSvNzynqWfSZQ5HGdMbuiUVS28/QN8Sl9BPpHUFjzsPoEiN53Pr3d+f5k5h67y+Z3kYR5uen49T7IAuLpmMxuWNB0aNWOyT2bY2SEAMj8Cls/zY0tSNVkJYH+YDTAcorQ2TctXnSEVVG8dvFdt8T8GTnCGLUQIb3O9R9LBnoUEK6gx4JyJ41l7jyl7Gv3tyYq6bnncuZEL/fNnKOjtBQDvVogw9+opHyzjLr09d9Jm6QHhjZpB/ulMavGEW5+9Wpjx+VIfXuDeSz7TiEkI;4:lOu36zqHKc9ctSA8eU4NzcIGoy3cSkYT6BqYMYaqWeZ+WlfNw/y9r6yAWH/q+TzIyLjK+6xfHDHwKY9KpjySo+VIXwp/QDgODA+ZMpqLqB+uxWv+oSK6U8kVc3tgRirT+GK86iiXmYujwlDe1pHgiySKuCw7ob8BcBZpfEwH+0FmscSk6DPsDdH1YIHxt33HVavPMCrdWCDjPqTSJvMeEbHnnbwEhoBLTiYwgMa8EFcJ/TrI8gMRZ7JTiyiDDEMH24ZXsEdNC8iGS8RMPI3m6A== X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(6040470)(2401047)(8121501046)(5005006)(3002001)(93006095)(93001095)(10201501046)(3231023)(944501075)(6055026)(6041268)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(20161123560045)(20161123564045)(20161123562045)(20161123558120)(6072148)(201708071742011);SRVR:DM5PR1201MB0235;BCL:0;PCL:0;RULEID:(100000803101)(100110400095);SRVR:DM5PR1201MB0235; X-Forefront-PRVS: 0548586081 X-Forefront-Antispam-Report: SFV:NSPM;SFS:(10009020)(6049001)(396003)(39380400002)(346002)(39860400002)(376002)(366004)(24454002)(189003)(377424004)(199004)(77096006)(6486002)(76176011)(105586002)(86362001)(8676002)(53936002)(106356001)(50466002)(39060400002)(68736007)(2950100002)(5660300001)(305945005)(6246003)(7736002)(81156014)(229853002)(90366009)(36756003)(31696002)(16526018)(72206003)(97736004)(65826007)(6116002)(31686004)(65956001)(52116002)(52146003)(83506002)(316002)(53546011)(3846002)(47776003)(65806001)(8936002)(478600001)(110136005)(64126003)(386003)(2486003)(25786009)(2870700001)(36916002)(23676004)(4326008)(2906002)(81166006)(58126008)(16576012)(59450400001)(66066001);DIR:OUT;SFP:1101;SCL:1;SRVR:DM5PR1201MB0235;H:[172.27.225.16];FPR:;SPF:None;PTR:InfoNoRecords;MX:1;A:1;LANG:en; X-Microsoft-Exchange-Diagnostics: =?utf-8?B?MTtETTVQUjEyMDFNQjAyMzU7MjM6bGxDekVTWm13ejFidTA3K2lya2E3K2VN?= =?utf-8?B?NFROUUZvMSszMGFoazF3T3BpdVhhQXYrUkRaOExyU25VUjV5YnppbnhOL3Bn?= =?utf-8?B?ZEd5ZlpLRjI4VkVQd0dOWXV2YnlvcGx2ZDFteFpEV3A5STRWK0hBK2JLOFhh?= =?utf-8?B?NDdQQ3dzVWx0TWJBT2U2WEg0S1pLUWd0NnVmTTJpMDhIMFNmMmU2d2RTRHpm?= =?utf-8?B?aFRsdXdTN2FnNWFRWnZqTmdjU1NOZE1LNEhwN0hXb0R0cFZpR0lRM1VBWVRL?= =?utf-8?B?ZTd2S1pra0tCbHdZQ0xES0lwOWFyTHgxazlabnpvWGJpMVg3eE15UkNOSFBh?= =?utf-8?B?L0hlRFBvOUExbFNaUHRES0FSazU5cWNnTmtPcGJzZFl6ZVBISjRodkEzWjFP?= =?utf-8?B?a2NCRmRWUmtXeWFRb21BMnIvUGhmTWwxaU91Vy85OHBvMjVLNnIrcGs0REl2?= =?utf-8?B?dXErZFZiVFNxMWRuZnNRTVNaZm96S1h2bnRXQzVYTGRTM3ZWYlVPRlJsTGlO?= =?utf-8?B?Q2tBSVJxVVhOeTlQOVUrQXBCb1RERFRKUFdLRnJMazMrUnFaRzhXWEZnbERt?= =?utf-8?B?UEZqNVNYNWFHNFRWMmJsR3JJR1V3ZDYwM2ZHaEptSmRMS09kdWNOYWFMNXZL?= =?utf-8?B?U0hGWTdjV2xyZXllbEpPZUdnaUFSQmtGRDZselVwaDBFeFMxNXpLNUowaGR3?= =?utf-8?B?Z3BqMjEyUklKODJXNDcyN1QrK0swSGY0bzdneU05aWdBUEVlRlV6Z3MvK1Bk?= =?utf-8?B?c3djT2ZmZmd2RWtKS3hIYkZwTUV3MGQ5cVRoRHc4NndsVzdSZzRLbldjc2Ra?= =?utf-8?B?OCtRdHRzenk0L2s0MnIyeDBKSWZlbTk2empPNEZuRlhiRXdxNFE4aGxFYmxO?= =?utf-8?B?MWFlUHYyOGtkVzBHMmp6YW11TnNGblFMaEU4QWpJdWNKVnIyTnhLWThDQ2h4?= =?utf-8?B?VkJoTmF2eFVKa05iY1FGdmdQc3RCN2VBeFpyNzJwbW1BUGRRK0hwWHVkV0w4?= =?utf-8?B?THU0MnhSckJ5anZJRHR2UWFsZXdnTVo2WFFoUzJVamszcW1rMjMzcTYwUGU5?= =?utf-8?B?Q2c5SGtkVkJZa054S1EzbGp5MUlXemtHZ1BhT2Zkb0orRGVZL2MzL1pXaXRT?= =?utf-8?B?TWRmVDNBMm12NFJpbzFWKzVWazYwNWIwNFREQW1NZ0dWeE43T0xjSXR0UXgw?= =?utf-8?B?T3djT2YyZENNZXpLalJMUzdXMU4veVVYZ3JBZnlXMU1zQzBjUjIwN3lWSjhi?= =?utf-8?B?Yzl5RzQvb1J1UXZhQlozNmxiMExzRDRwaU5kL05NLzJkRHZrM3hXejBXNzFa?= =?utf-8?B?cXFFcHNSbzdrVUhlbUhKRHdGbWdHUm9VaVlLWjBha1VTK2ZDdzBNd3VXdldx?= =?utf-8?B?b1loRnVKWm9UTE1OQ244REM2dzhYbDlvRGJFZXptc05TZTZNYU9KeGNsSnpm?= =?utf-8?B?SzByTWFhelhjVXhYREx1TTBYN3piMnZFVWlrV29odytnZ3llVUgrM1hoQWI0?= =?utf-8?B?Ym9wNWN3REYvKzhmdFNybGI1SlVhWm5jdmsxK1A0SUFEVzZLK1puUUd3Sk9D?= =?utf-8?B?dTJnTzlPeFFjTHZUSG5PdXlOZDQzTnVmZmhzNTdTQmZKUHRKYUx1YnBiYmtr?= =?utf-8?B?YmFKSUMwQzNKQ3NZaWRjbWNmSUJ6Sk1OMTlyUnVwdEdIN2ZFemFPa21JOEdN?= =?utf-8?B?RDNWRW9DY2lXT3FyL2VFeTlOZjR4NmV2elpFak11S2V0SEZDWWlCb1phU0xR?= =?utf-8?B?a1k2Um9ueDB2VGFHaHU5eE9iVjk5VHJWM0Rab0F4dVJIMG9ISktJeTJGZlAv?= =?utf-8?B?TW10RDJKSlZ4UldFTXQrRWhyM1VEZXlFUkZ3Q3lKaDVva21DcjVSQVNUTmo4?= =?utf-8?B?ZkY5WmlxN21LbUJmSWsxSFh4aU9uYzZvMnlreS9ud2ozeThBTDF1d0NiL3VB?= =?utf-8?B?OHk4KzRUOXZjcHRDZGRoMkVtemw2dSt1VFRwYXpNNSswRmFoT1BySzU1TXlk?= =?utf-8?B?S2ZLQnRZUlBIWGRlbXZCQlViWERXUWVuMWxURlNBPT0=?= X-Microsoft-Exchange-Diagnostics: 1;DM5PR1201MB0235;6:h6R7v8+WD/nFM83sg8jFkFCwZPLOt/JAZTt7lA9ChhuMOBsMjQCHkRO1wd+swN8ev89znaljwxuh93klLPGmiX4TrxKyFL7UzfDsj6mxQu+akTxjmVENCDOq4iFzEzpKE4U8LtwCBBm+QacSE0osW/wMp8Me3LL5kwNOlAoUUI4gem5gO9yxEGoAGHStWuJT3UG3jVMECDEGmhtk61aJVjYzf5mjLaehpv+Q+0Wwzfnca33rIsBzPU0y/8B/ms88zz8FYoDU++lYbiqAzKEgQUrAnpH7tLjZEjyyG/OUh7ognofHHjNrMVNp1okIFqAStj95Zt6W1I1oumz7XdutmJycIXe37PFGOfuV2PfYnPQ=;5:VKMVUjHq6pqSigUNweRBr79SkuiF1iyLDfjWf7y+P3M/3y1Z2SVTPupJI8mobLRKvp+bRTtHty0Yg2S5qncxA51QURlKzF1nHRT4MJgdOC34RiihsaJoALJLsORWtuzRJlnRWfeFNUZ2pVJbi2SvBeOl2oRJmSiyHHka04Gt0ck=;24:h0cAkD7+2mrgAeRZteav06aeW81CcY0Ui3mLiVbvIaSuVxlpeW1VN3KworjfwpNtFd7NZpO7BagsmJz7zD4b5zjqC7om/9WbhAtVlwFkm60=;7:of8Y5qjl2JqOCjT9FwlKbomadR1ABaaN5uj9IPnO44BF8OI29Yoxh7toyiQ+vaUR5oYxA3VBnB97NE/v9HXNJ1W6/DsACwPbD9IMvH2n+m0hpV1bfsACQLkF/2aTb1tC/YKLMtvoKhvItZmJXUi7k7+RRTrvfFyoUbJv4b+oPibgBoGJ72ED4+Ehyg0Pzy13SwDzDmITJEfrZoJj8+JYl98LsSZSJgg+i977lSTK95OqYmr0cro4Ht8XqH0q20ie SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1;DM5PR1201MB0235;20:ZoxVhMDfRQz39gmdzR0rIqbHoY+X0JCO81J7rX5T/D412dXqN0d+vMC16Jj/KivNDuw65XAzpopP3G15HoY+sZZ/zHD/ppQvA7zoLWyuO5nYJ48LOQ5LfjQHZLHup0kHiomI53t+/LLtd9dSqC9n5VImwOh5YSctBh7MM6JefUueFpnZyCcYrFpjosi4ZE2gEZ59By38xMZW49WfaUDIv7+wwMkgI2kuRvkUajBbdNrmErpSRvDmIRaodBkHs56v X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 10 Jan 2018 18:33:23.8679 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 4cb0d3e9-42d4-4e91-c162-08d55858a252 X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM5PR1201MB0235 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Return-Path: Hi Gustavo, Thanks for catching that. When returning a fault, I think you also need to srcu_read_unlock(&kfd_processes_srcu, idx). However, instead of returning an error, I think I'd prefer to skip PDDs that can't be found with continue statements. That way others would still suspend and resume successfully. Maybe just print a WARN_ON for PDDs that aren't found, because that's an unexpected situation, currently. Maybe in the future it could be normal thing if we ever support GPU hotplug. Regards,   Felix On 2018-01-10 11:50 AM, Gustavo A. R. Silva wrote: > In case kfd_get_process_device_data returns null, there are some > null pointer dereferences in functions kfd_bind_processes_to_device > and kfd_unbind_processes_from_device. > > Fix this by null checking pdd before dereferencing it. > > Addresses-Coverity-ID: 1463794 ("Dereference null return value") > Addresses-Coverity-ID: 1463772 ("Dereference null return value") > Signed-off-by: Gustavo A. R. Silva > --- > drivers/gpu/drm/amd/amdkfd/kfd_process.c | 12 ++++++++++++ > 1 file changed, 12 insertions(+) > > diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_process.c b/drivers/gpu/drm/amd/amdkfd/kfd_process.c > index a22fb071..29d51d5 100644 > --- a/drivers/gpu/drm/amd/amdkfd/kfd_process.c > +++ b/drivers/gpu/drm/amd/amdkfd/kfd_process.c > @@ -461,6 +461,13 @@ int kfd_bind_processes_to_device(struct kfd_dev *dev) > hash_for_each_rcu(kfd_processes_table, temp, p, kfd_processes) { > mutex_lock(&p->mutex); > pdd = kfd_get_process_device_data(dev, p); > + > + if (!pdd) { > + pr_err("Process device data doesn't exist\n"); > + mutex_unlock(&p->mutex); > + return -EFAULT; > + } > + > if (pdd->bound != PDD_BOUND_SUSPENDED) { > mutex_unlock(&p->mutex); > continue; > @@ -501,6 +508,11 @@ void kfd_unbind_processes_from_device(struct kfd_dev *dev) > mutex_lock(&p->mutex); > pdd = kfd_get_process_device_data(dev, p); > > + if (!pdd) { > + mutex_unlock(&p->mutex); > + return; > + } > + > if (pdd->bound == PDD_BOUND) > pdd->bound = PDD_BOUND_SUSPENDED; > mutex_unlock(&p->mutex);