Re: [PATCH] soc: qcom: geni: shield ICC calls for ACPI boot

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Il 28/12/20 14:56, Shawn Guo ha scritto:
Currently, GENI devices like i2c-qcom-geni fails to probe in ACPI boot,
if interconnect support is enabled.  That's because interconnect driver
only supports DT right now.  As interconnect is not necessarily required
for basic function of GENI devices, let's shield those ICC calls to get
GENI devices probe for ACPI boot.

Signed-off-by: Shawn Guo <shawn.guo@xxxxxxxxxx>
---
  drivers/soc/qcom/qcom-geni-se.c | 15 +++++++++++++++
  1 file changed, 15 insertions(+)

Hello!

To avoid developers booting on ACPI getting "strange slownesses" and possibly timeouts with no apparent reason, wouldn't it be a bit more proper and friendly to actually send a kernel message to advertise that there is *no interconnect support* and that this may lead to the aforementioned potential issues?

--Angelo

diff --git a/drivers/soc/qcom/qcom-geni-se.c b/drivers/soc/qcom/qcom-geni-se.c
index f42954e2c98e..9feb1d78a5df 100644
--- a/drivers/soc/qcom/qcom-geni-se.c
+++ b/drivers/soc/qcom/qcom-geni-se.c
@@ -760,6 +760,9 @@ int geni_icc_get(struct geni_se *se, const char *icc_ddr)
  	int i, err;
  	const char *icc_names[] = {"qup-core", "qup-config", icc_ddr};
+ if (has_acpi_companion(se->dev))
+		return 0;
+
  	for (i = 0; i < ARRAY_SIZE(se->icc_paths); i++) {
  		if (!icc_names[i])
  			continue;
@@ -785,6 +788,9 @@ int geni_icc_set_bw(struct geni_se *se)
  {
  	int i, ret;
+ if (has_acpi_companion(se->dev))
+		return 0;
+
  	for (i = 0; i < ARRAY_SIZE(se->icc_paths); i++) {
  		ret = icc_set_bw(se->icc_paths[i].path,
  			se->icc_paths[i].avg_bw, se->icc_paths[i].avg_bw);
@@ -803,6 +809,9 @@ void geni_icc_set_tag(struct geni_se *se, u32 tag)
  {
  	int i;
+ if (has_acpi_companion(se->dev))
+		return;
+
  	for (i = 0; i < ARRAY_SIZE(se->icc_paths); i++)
  		icc_set_tag(se->icc_paths[i].path, tag);
  }
@@ -813,6 +822,9 @@ int geni_icc_enable(struct geni_se *se)
  {
  	int i, ret;
+ if (has_acpi_companion(se->dev))
+		return 0;
+
  	for (i = 0; i < ARRAY_SIZE(se->icc_paths); i++) {
  		ret = icc_enable(se->icc_paths[i].path);
  		if (ret) {
@@ -830,6 +842,9 @@ int geni_icc_disable(struct geni_se *se)
  {
  	int i, ret;
+ if (has_acpi_companion(se->dev))
+		return 0;
+
  	for (i = 0; i < ARRAY_SIZE(se->icc_paths); i++) {
  		ret = icc_disable(se->icc_paths[i].path);
  		if (ret) {





[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [Linux for Sparc]     [IETF Annouce]     [Security]     [Bugtraq]     [Linux MIPS]     [ECOS]     [Asterisk Internet PBX]     [Linux API]

  Powered by Linux