Message ID | 20231221172114.1569559-1-suma.hegde@amd.com (mailing list archive) |
---|---|
State | Changes Requested, archived |
Headers | show |
Series | [v3,1/7] platform/x86: Move hsmp_test to probe | expand |
Hi, The subjects of all patches in the series are very generic. They should have some more specific prefix IMO. Dec 21, 2023 18:21:48 Suma Hegde <suma.hegde@amd.com>: > 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@amd.com> > Signed-off-by: Naveen Krishna Chatradhi <nchatrad@amd.com> > Reviewed-by: Hans de Goede <hdegoede@redhat.com> > Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com> > --- > Changes since v1: > 1. Add "Reviewed-by: Hans de Goede <hdegoede@redhat.com>" > Changes since v2: > 1. Add "Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>" > > drivers/platform/x86/amd/hsmp.c | 30 +++++++++++------------------- > 1 file changed, 11 insertions(+), 19 deletions(-)
Hi Thomas, On 12/21/23 18:27, Thomas Weißschuh wrote: > Hi, > > The subjects of all patches in the series are > very generic. > They should have some more specific prefix IMO. That is a good point, but that is something which I can fix while merging these. So assuming this is the only outstanding comment there is no need to send a v4 for this. Regards, Hans > > Dec 21, 2023 18:21:48 Suma Hegde <suma.hegde@amd.com>: > >> 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@amd.com> >> Signed-off-by: Naveen Krishna Chatradhi <nchatrad@amd.com> >> Reviewed-by: Hans de Goede <hdegoede@redhat.com> >> Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com> >> --- >> Changes since v1: >> 1. Add "Reviewed-by: Hans de Goede <hdegoede@redhat.com>" >> Changes since v2: >> 1. Add "Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>" >> >> drivers/platform/x86/amd/hsmp.c | 30 +++++++++++------------------- >> 1 file changed, 11 insertions(+), 19 deletions(-) >
Hi Hans, On 12/22/2023 1:50 AM, Hans de Goede wrote: > Caution: This message originated from an External Source. Use proper caution when opening attachments, clicking links, or responding. > > > Hi Thomas, > > On 12/21/23 18:27, Thomas Weißschuh wrote: >> Hi, >> >> The subjects of all patches in the series are >> very generic. >> They should have some more specific prefix IMO. > That is a good point, but that is something which > I can fix while merging these. So assuming this > is the only outstanding comment there is no need > to send a v4 for this. > > Regards, > > Hans > Thank you! I will not send v4 unless I receive other new comments. > >> Dec 21, 2023 18:21:48 Suma Hegde <suma.hegde@amd.com>: >> >>> 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@amd.com> >>> Signed-off-by: Naveen Krishna Chatradhi <nchatrad@amd.com> >>> Reviewed-by: Hans de Goede <hdegoede@redhat.com> >>> Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com> >>> --- >>> Changes since v1: >>> 1. Add "Reviewed-by: Hans de Goede <hdegoede@redhat.com>" >>> Changes since v2: >>> 1. Add "Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>" >>> >>> 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;