mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-05 18:41:58 +09:00
p2sb: Introduce the global flag p2sb_hidden_by_bios
[ Upstream commit ae3e6ebc5ab046d434c05c58a3e3f7e94441fec2 ] To prepare for the following fix, introduce the global flag p2sb_hidden_by_bios. Check if the BIOS hides the P2SB device and store the result in the flag. This allows to refer to the check result across functions. Signed-off-by: Shin'ichiro Kawasaki <shinichiro.kawasaki@wdc.com> Reviewed-by: Hans de Goede <hdegoede@redhat.com> Link: https://lore.kernel.org/r/20241128002836.373745-3-shinichiro.kawasaki@wdc.com Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com> Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com> Stable-dep-of: 360c400d0f56 ("p2sb: Do not scan and remove the P2SB device when it is unhidden") Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
da3d454cd5
commit
d552e2e068
@@ -42,6 +42,7 @@ struct p2sb_res_cache {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static struct p2sb_res_cache p2sb_resources[NR_P2SB_RES_CACHE];
|
static struct p2sb_res_cache p2sb_resources[NR_P2SB_RES_CACHE];
|
||||||
|
static bool p2sb_hidden_by_bios;
|
||||||
|
|
||||||
static void p2sb_get_devfn(unsigned int *devfn)
|
static void p2sb_get_devfn(unsigned int *devfn)
|
||||||
{
|
{
|
||||||
@@ -157,13 +158,14 @@ static int p2sb_cache_resources(void)
|
|||||||
* Unhide the P2SB device here, if needed.
|
* Unhide the P2SB device here, if needed.
|
||||||
*/
|
*/
|
||||||
pci_bus_read_config_dword(bus, devfn_p2sb, P2SBC, &value);
|
pci_bus_read_config_dword(bus, devfn_p2sb, P2SBC, &value);
|
||||||
if (value & P2SBC_HIDE)
|
p2sb_hidden_by_bios = value & P2SBC_HIDE;
|
||||||
|
if (p2sb_hidden_by_bios)
|
||||||
pci_bus_write_config_dword(bus, devfn_p2sb, P2SBC, 0);
|
pci_bus_write_config_dword(bus, devfn_p2sb, P2SBC, 0);
|
||||||
|
|
||||||
ret = p2sb_scan_and_cache(bus, devfn_p2sb);
|
ret = p2sb_scan_and_cache(bus, devfn_p2sb);
|
||||||
|
|
||||||
/* Hide the P2SB device, if it was hidden */
|
/* Hide the P2SB device, if it was hidden */
|
||||||
if (value & P2SBC_HIDE)
|
if (p2sb_hidden_by_bios)
|
||||||
pci_bus_write_config_dword(bus, devfn_p2sb, P2SBC, P2SBC_HIDE);
|
pci_bus_write_config_dword(bus, devfn_p2sb, P2SBC, P2SBC_HIDE);
|
||||||
|
|
||||||
pci_unlock_rescan_remove();
|
pci_unlock_rescan_remove();
|
||||||
|
|||||||
Reference in New Issue
Block a user