Skip to content

Commit 9512920

Browse files
debox1jwrdegoede
authored andcommitted
platform/x86/intel/pmc: Allow pmc_core_ssram_init to fail
Currently, if the PMC SSRAM initialization fails, no error is returned and the only indication is that a PMC device has not been created. Instead, allow an error to be returned and handled directly by the caller. Signed-off-by: David E. Box <[email protected]> Reviewed-by: Ilpo Järvinen <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Hans de Goede <[email protected]>
1 parent 2e35e3a commit 9512920

File tree

2 files changed

+14
-9
lines changed

2 files changed

+14
-9
lines changed

drivers/platform/x86/intel/pmc/core.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -492,7 +492,7 @@ int pmc_core_resume_common(struct pmc_dev *pmcdev);
492492
int get_primary_reg_base(struct pmc *pmc);
493493
extern void pmc_core_get_low_power_modes(struct pmc_dev *pmcdev);
494494

495-
extern void pmc_core_ssram_init(struct pmc_dev *pmcdev);
495+
extern int pmc_core_ssram_init(struct pmc_dev *pmcdev);
496496

497497
int spt_core_init(struct pmc_dev *pmcdev);
498498
int cnp_core_init(struct pmc_dev *pmcdev);

drivers/platform/x86/intel/pmc/core_ssram.c

Lines changed: 13 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -35,20 +35,20 @@ static inline u64 get_base(void __iomem *addr, u32 offset)
3535
return lo_hi_readq(addr + offset) & GENMASK_ULL(63, 3);
3636
}
3737

38-
static void
38+
static int
3939
pmc_core_pmc_add(struct pmc_dev *pmcdev, u64 pwrm_base,
4040
const struct pmc_reg_map *reg_map, int pmc_index)
4141
{
4242
struct pmc *pmc = pmcdev->pmcs[pmc_index];
4343

4444
if (!pwrm_base)
45-
return;
45+
return -ENODEV;
4646

4747
/* Memory for primary PMC has been allocated in core.c */
4848
if (!pmc) {
4949
pmc = devm_kzalloc(&pmcdev->pdev->dev, sizeof(*pmc), GFP_KERNEL);
5050
if (!pmc)
51-
return;
51+
return -ENOMEM;
5252
}
5353

5454
pmc->map = reg_map;
@@ -57,10 +57,12 @@ pmc_core_pmc_add(struct pmc_dev *pmcdev, u64 pwrm_base,
5757

5858
if (!pmc->regbase) {
5959
devm_kfree(&pmcdev->pdev->dev, pmc);
60-
return;
60+
return -ENOMEM;
6161
}
6262

6363
pmcdev->pmcs[pmc_index] = pmc;
64+
65+
return 0;
6466
}
6567

6668
static void
@@ -96,7 +98,7 @@ pmc_core_ssram_get_pmc(struct pmc_dev *pmcdev, void __iomem *ssram, u32 offset,
9698
iounmap(ssram);
9799
}
98100

99-
void pmc_core_ssram_init(struct pmc_dev *pmcdev)
101+
int pmc_core_ssram_init(struct pmc_dev *pmcdev)
100102
{
101103
void __iomem *ssram;
102104
struct pci_dev *pcidev;
@@ -105,7 +107,7 @@ void pmc_core_ssram_init(struct pmc_dev *pmcdev)
105107

106108
pcidev = pci_get_domain_bus_and_slot(0, 0, PCI_DEVFN(20, 2));
107109
if (!pcidev)
108-
goto out;
110+
return -ENODEV;
109111

110112
ret = pcim_enable_device(pcidev);
111113
if (ret)
@@ -123,11 +125,14 @@ void pmc_core_ssram_init(struct pmc_dev *pmcdev)
123125
pmc_core_ssram_get_pmc(pmcdev, ssram, SSRAM_PCH_OFFSET, PMC_IDX_PCH);
124126

125127
iounmap(ssram);
126-
out:
127-
return;
128+
129+
return 0;
128130

129131
disable_dev:
132+
pmcdev->ssram_pcidev = NULL;
130133
pci_disable_device(pcidev);
131134
release_dev:
132135
pci_dev_put(pcidev);
136+
137+
return ret;
133138
}

0 commit comments

Comments
 (0)