Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp545375pxj; Tue, 18 May 2021 08:59:35 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz0gNUw1z/HnfzI1UnTkZEGFPFOOgleTfQeS3R3erIMJt4lOC0vh0OYgxKhx1OQAiBCeTmV X-Received: by 2002:a17:906:c218:: with SMTP id d24mr6609008ejz.363.1621353574926; Tue, 18 May 2021 08:59:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621353574; cv=none; d=google.com; s=arc-20160816; b=v55kjTZCRUMl309VyjDAEnqyjRnm5M4UNJ/VwUKCYMjogLFIrfYveot8EmJZqKlqoS Ht8GR36ft8IdmV7c6m3n/7ASKzm3JISk+WRiV0ja2+6vQ0zwV72UG8qF38MbMOFcVXK/ k0ZcOLqEN0jJjmobT3zV0NOdu7Ly9X9n2o0U5luY7lrHqFiFAwHw19NSu7itCpArUWZf RbnwHcM5pRmbH+EGdHwnJwA2cQed/iwgk6tEkW54SUQqKi4PITuYttzxAjPq1YfaUW4W Zryzgl5iKta/TsRHQxUKozdLe7IJjX9ElTJDFZyETQlyWrijDYU+wEs3W5RUNbRfU6hw a3tQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=ooZbSfJ9H+JRjvPFNw8DiUmBzPoP76YrOF4BGwSgxTs=; b=dmXllDIuXytumrUbQao8Jc5hRFVhaBhhIDxeDBx5A3jg61UBL980IWcGdAzDbO8ieC lADLhVHxSTm4PUyeEbAONn1iq7sZS6ifiozPqg7BXcfs92CrA2ubYj+ZYhrROpjcVpd2 c6i+d7NqndeiXZne5nocKzUIXwpZNrH8u4D80A+Wt4XVvHzhuJ06v+Co5tNf0/gyHFtk xFBigdmJkU8/WAehIoBD8IVrb5y7vc7IPF1mevjQFdrcvjkAtZdLjFaubF6byuZbzb5A r4UujbrWclujUjkpVt9T+74D6+Rt1eob6VMzv32DtgJ8Y5JtYKsZgdwr+/J2N/jD0xNQ Zzmw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=xFvg8MHl; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a20si5002375edj.419.2021.05.18.08.58.46; Tue, 18 May 2021 08:59:34 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=xFvg8MHl; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345794AbhEQP5X (ORCPT + 99 others); Mon, 17 May 2021 11:57:23 -0400 Received: from mail.kernel.org ([198.145.29.99]:40080 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244102AbhEQPih (ORCPT ); Mon, 17 May 2021 11:38:37 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 3D06F61D10; Mon, 17 May 2021 14:40:48 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1621262448; bh=2JWOO0nh13YmWzLG2VTpumpq0eEZ77ksqcT5BxbVjQo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=xFvg8MHlO/CLpJV9hgikPcrw6/Y+XbhIRMSvhryxWE5dzR2Tlw4iA6z47pFQOta0E u4AXucWHv5EpxFGE2bM6aT0orRKF5SWQGy6TrDjDx9GnuFdnMAQdQPTaFyJf/KuRlp KlnOsp7S8EunNSwSiuMgmkOdc/h92A5T3yFxRuZU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Tomasz Duszynski , Alexandru Ardelean , Stable@vger.kernel.org, Jonathan Cameron Subject: [PATCH 5.11 293/329] iio: core: fix ioctl handlers removal Date: Mon, 17 May 2021 16:03:24 +0200 Message-Id: <20210517140312.013646863@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210517140302.043055203@linuxfoundation.org> References: <20210517140302.043055203@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Tomasz Duszynski commit 901f84de0e16bde10a72d7eb2f2eb73fcde8fa1a upstream. Currently ioctl handlers are removed twice. For the first time during iio_device_unregister() then later on inside iio_device_unregister_eventset() and iio_buffers_free_sysfs_and_mask(). Double free leads to kernel panic. Fix this by not touching ioctl handlers list directly but rather letting code responsible for registration call the matching cleanup routine itself. Fixes: 8dedcc3eee3ac ("iio: core: centralize ioctl() calls to the main chardev") Signed-off-by: Tomasz Duszynski Acked-by: Alexandru Ardelean Cc: Link: https://lore.kernel.org/r/20210423080244.2790-1-tomasz.duszynski@octakon.com Signed-off-by: Jonathan Cameron Signed-off-by: Greg Kroah-Hartman --- drivers/iio/industrialio-core.c | 6 ------ 1 file changed, 6 deletions(-) --- a/drivers/iio/industrialio-core.c +++ b/drivers/iio/industrialio-core.c @@ -1827,9 +1827,6 @@ EXPORT_SYMBOL(__iio_device_register); **/ void iio_device_unregister(struct iio_dev *indio_dev) { - struct iio_dev_opaque *iio_dev_opaque = to_iio_dev_opaque(indio_dev); - struct iio_ioctl_handler *h, *t; - cdev_device_del(&indio_dev->chrdev, &indio_dev->dev); mutex_lock(&indio_dev->info_exist_lock); @@ -1840,9 +1837,6 @@ void iio_device_unregister(struct iio_de indio_dev->info = NULL; - list_for_each_entry_safe(h, t, &iio_dev_opaque->ioctl_handlers, entry) - list_del(&h->entry); - iio_device_wakeup_eventset(indio_dev); iio_buffer_wakeup_poll(indio_dev);