On Wed, 20 Dec 2023, Suma Hegde wrote: > This is in advance to supporting ACPI based probe. > > In case of non-ACPI driver, hsmp_test() can be > performed either in plat init() or in probe(). > > however, in case of ACPI probing, hsmp_test() cannot > be called in init(), as the mailbox reg offsets and > base addresses are read from ACPI table in the probe(). > > Hence, move hsmp_test() to probe as preparation for > ACPI support. > > Also use hsmp_send_message() directly in hsmp_test() > as the semaphore is already initialized in probe. > > Signed-off-by: Suma Hegde <suma.hegde@xxxxxxx> > Signed-off-by: Naveen Krishna Chatradhi <nchatrad@xxxxxxx> > Reviewed-by: Hans de Goede <hdegoede@xxxxxxxxxx> > > Changed since v1: > 1. Add "Reviewed-by: Hans de Goede <hdegoede@xxxxxxxxxx>" > > --- > drivers/platform/x86/amd/hsmp.c | 30 +++++++++++------------------- > 1 file changed, 11 insertions(+), 19 deletions(-) > > diff --git a/drivers/platform/x86/amd/hsmp.c b/drivers/platform/x86/amd/hsmp.c > index b55d80e29139..3c17b488f4f8 100644 > --- a/drivers/platform/x86/amd/hsmp.c > +++ b/drivers/platform/x86/amd/hsmp.c > @@ -244,12 +244,7 @@ EXPORT_SYMBOL_GPL(hsmp_send_message); > static int hsmp_test(u16 sock_ind, u32 value) > { > struct hsmp_message msg = { 0 }; > - struct amd_northbridge *nb; > - int ret = -ENODEV; > - > - nb = node_to_amd_nb(sock_ind); > - if (!nb || !nb->root) > - return ret; > + int ret; > > /* > * Test the hsmp port by performing TEST command. The test message > @@ -261,7 +256,7 @@ static int hsmp_test(u16 sock_ind, u32 value) > msg.args[0] = value; > msg.sock_ind = sock_ind; > > - ret = __hsmp_send_message(nb->root, &msg); > + ret = hsmp_send_message(&msg); > if (ret) > return ret; > > @@ -504,6 +499,15 @@ static int hsmp_pltdrv_probe(struct platform_device *pdev) > for (i = 0; i < plat_dev.num_sockets; i++) { > sema_init(&plat_dev.sock[i].hsmp_sem, 1); > plat_dev.sock[i].sock_ind = i; > + > + /* Test the hsmp interface on each socket */ > + ret = hsmp_test(i, 0xDEADBEEF); > + if (ret) { > + pr_err("HSMP test message failed on Fam:%x model:%x\n", > + boot_cpu_data.x86, boot_cpu_data.x86_model); > + pr_err("Is HSMP disabled in BIOS ?\n"); > + return ret; > + } > } > > plat_dev.hsmp_device.name = HSMP_CDEV_NAME; > @@ -544,7 +548,6 @@ static struct platform_device *amd_hsmp_platdev; > static int __init hsmp_plt_init(void) > { > int ret = -ENODEV; > - int i; > > if (boot_cpu_data.x86_vendor != X86_VENDOR_AMD || boot_cpu_data.x86 < 0x19) { > pr_err("HSMP is not supported on Family:%x model:%x\n", > @@ -560,17 +563,6 @@ static int __init hsmp_plt_init(void) > if (plat_dev.num_sockets == 0) > return ret; > > - /* Test the hsmp interface on each socket */ > - for (i = 0; i < plat_dev.num_sockets; i++) { > - ret = hsmp_test(i, 0xDEADBEEF); > - if (ret) { > - pr_err("HSMP test message failed on Fam:%x model:%x\n", > - boot_cpu_data.x86, boot_cpu_data.x86_model); > - pr_err("Is HSMP disabled in BIOS ?\n"); > - return ret; > - } > - } > - > ret = platform_driver_register(&amd_hsmp_driver); > if (ret) > return ret; > Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@xxxxxxxxxxxxxxx> -- i.