Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754292AbbBTKNp (ORCPT ); Fri, 20 Feb 2015 05:13:45 -0500 Received: from mail-we0-f173.google.com ([74.125.82.173]:46528 "EHLO mail-we0-f173.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753735AbbBTKNn (ORCPT ); Fri, 20 Feb 2015 05:13:43 -0500 MIME-Version: 1.0 In-Reply-To: <54E7072C.30303@mm-sol.com> References: <1424367708-17149-1-git-send-email-matwey@sai.msu.ru> <54E7072C.30303@mm-sol.com> From: "Matwey V. Kornilov" Date: Fri, 20 Feb 2015 14:13:21 +0400 X-Google-Sender-Auth: szoPCuCWWpg28p0ZBCQn38QNlZc Message-ID: Subject: Re: [PATCH v3] pci: spear: Drop __initdata from spear13xx_pcie_driver To: Stanimir Varbanov Cc: Mohit Kumar , Viresh Kumar , "linux-pci@vger.kernel.org" , Greg KH , Bjorn Helgaas , linux-kernel Content-Type: text/plain; charset=ISO-8859-1 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1967 Lines: 56 2015-02-20 13:06 GMT+03:00 Stanimir Varbanov : > On 02/19/2015 07:41 PM, Matwey V. Kornilov wrote: >> spear13xx_pcie_driver.driver is allocated in text.init section >> and then the pointer to it is passed futher. This patch is to avoid >> crashes like the following, when freed memory is used. >> >> Also, __init has been dropped from the probe() function referred from the struct >> and all called functions. >> > > > >> >> Signed-off-by: Matwey V. Kornilov >> --- >> Changes from v2: >> - Drop __init from all probing functions to allow deferred probing. >> Changes from v1: >> - Use platform_driver_probe instead of platform_driver_register to make linker happy. >> >> drivers/pci/host/pcie-designware.c | 2 +- >> drivers/pci/host/pcie-spear13xx.c | 6 +++--- >> 2 files changed, 4 insertions(+), 4 deletions(-) >> >> diff --git a/drivers/pci/host/pcie-designware.c b/drivers/pci/host/pcie-designware.c >> index df781cd..5b8a056 100644 >> --- a/drivers/pci/host/pcie-designware.c >> +++ b/drivers/pci/host/pcie-designware.c >> @@ -339,7 +339,7 @@ static const struct irq_domain_ops msi_domain_ops = { >> .map = dw_pcie_msi_map, >> }; >> >> -int __init dw_pcie_host_init(struct pcie_port *pp) >> +int dw_pcie_host_init(struct pcie_port *pp) >> { > > we need to fix up the other pci drivers which use dw_pcie_host_init(), too. > > pci-exynos, pci-imx6, pci-keystone and pci-layerscape. > > Could you prepare a patch with above drivers included? What is wrong with them? To call ordinary function from __init section is perfectly legal. -- With best regards, Matwey V. Kornilov. Sternberg Astronomical Institute, Lomonosov Moscow State University, Russia -- 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/