serial: 8250: Fix oops for port->pm on uart_change_pm()
stable inclusion from stable-v4.19.293 commit 720a297b334e85d34099e83d1f375b92c3efedd6 category: bugfix bugzilla: https://gitee.com/openeuler/kernel/issues/I85XNK CVE: NA -------------------------------- [ Upstream commit dfe2aeb2 ] Unloading a hardware specific 8250 driver can produce error "Unable to handle kernel paging request at virtual address" about ten seconds after unloading the driver. This happens on uart_hangup() calling uart_change_pm(). Turns out commit 04e82793 ("serial: 8250: Reinit port->pm on port specific driver unbind") was only a partial fix. If the hardware specific driver has initialized port->pm function, we need to clear port->pm too. Just reinitializing port->ops does not do this. Otherwise serial8250_pm() will call port->pm() instead of serial8250_do_pm(). Fixes: 04e82793 ("serial: 8250: Reinit port->pm on port specific driver unbind") Signed-off-by:Tony Lindgren <tony@atomide.com> Link: https://lore.kernel.org/r/20230804131553.52927-1-tony@atomide.com Signed-off-by:
Greg Kroah-Hartman <gregkh@linuxfoundation.org> Signed-off-by:
Sasha Levin <sashal@kernel.org> Signed-off-by:
Yongqiang Liu <liuyongqiang13@huawei.com>
Loading
Please sign in to comment