Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit dd05986c authored by qctecmdr's avatar qctecmdr Committed by Gerrit - the friendly Code Review server
Browse files

Merge "drm/bridge: lt9611uxc: fix a crash issue for hpd support"

parents 45ba2c2e d1844610
Loading
Loading
Loading
Loading
+29 −25
Original line number Diff line number Diff line
@@ -163,7 +163,7 @@ static void lt9611_hpd_work(struct work_struct *work)
	struct lt9611 *pdata = container_of(work, struct lt9611, work);

	if (!pdata || !pdata->connector.funcs ||
		!pdata->connector.funcs->detect)
		!pdata->connector.funcs->detect || !pdata->hpd_support)
		return;

	dev = pdata->connector.dev;
@@ -331,6 +331,7 @@ u8 lt9611_get_version(struct lt9611 *pdata)

	lt9611_write_byte(pdata, 0xFF, 0x80);
	lt9611_write_byte(pdata, 0xEE, 0x00);
	msleep(50);

	return revison;
}
@@ -902,6 +903,7 @@ static int lt9611_read_device_id(struct lt9611 *pdata)

	lt9611_write_byte(pdata, 0xFF, 0x80);
	lt9611_write_byte(pdata, 0xEE, 0x00);
	msleep(50);

	return ret;
}
@@ -921,7 +923,7 @@ static irqreturn_t lt9611_irq_thread_handler(int irq, void *dev_id)
		if (irq_status) {
			lt9611_write_byte(pdata, 0x22, 0);
			lt9611_read(pdata, 0x23, &hpd_status, 1);
			pr_debug("irq hdp status 0x%x\n", hpd_status);
			pr_debug("irq hpd status 0x%x\n", hpd_status);
		}
	} else
		pr_err("get irq status failed\n");
@@ -944,7 +946,7 @@ static void lt9611_reset(struct lt9611 *pdata, bool on_off)
		gpio_set_value(pdata->reset_gpio, 0);
		msleep(20);
		gpio_set_value(pdata->reset_gpio, 1);
		msleep(20);
		msleep(300);
	} else {
		gpio_set_value(pdata->reset_gpio, 0);
	}
@@ -1363,11 +1365,11 @@ lt9611_connector_detect(struct drm_connector *connector, bool force)
	u8 hpd_status = 0;
	struct lt9611 *pdata = connector_to_lt9611(connector);

	pdata->status = connector_status_connected;
	pdata->status = connector_status_disconnected;
	if (force && pdata->hpd_support) {
		lt9611_write_byte(pdata, 0xFF, 0x80);
		lt9611_write_byte(pdata, 0xEE, 0x01);
		lt9611_write_byte(pdata, 0xFF, 0x80);
		lt9611_write_byte(pdata, 0xFF, 0xB0);
		if (!lt9611_read(pdata, 0x23, &hpd_status, 1)) {
			if (hpd_status & BIT(1))
				pdata->status = connector_status_connected;
@@ -1468,7 +1470,11 @@ static void lt9611_bridge_enable(struct drm_bridge *bridge)

static void lt9611_bridge_disable(struct drm_bridge *bridge)
{
	struct lt9611 *pdata = bridge_to_lt9611(bridge);

	pr_debug("bridge disable\n");
	lt9611_enable_vreg(pdata, false);
	lt9611_reset(pdata, false);
}

static void lt9611_bridge_mode_set(struct drm_bridge *bridge,
@@ -1597,6 +1603,7 @@ static void lt9611_bridge_pre_enable(struct drm_bridge *bridge)
	struct lt9611 *pdata = bridge_to_lt9611(bridge);

	pr_debug("bridge pre_enable\n");
	lt9611_enable_vreg(pdata, true);
	lt9611_reset(pdata, true);
}

@@ -1778,37 +1785,25 @@ static int lt9611_probe(struct i2c_client *client,

	lt9611_reset(pdata, true);

	pdata->irq = gpio_to_irq(pdata->irq_gpio);
	ret = request_threaded_irq(pdata->irq, NULL, lt9611_irq_thread_handler,
		IRQF_TRIGGER_FALLING | IRQF_ONESHOT, "lt9611", pdata);
	if (ret) {
		pr_err("failed to request irq\n");
		goto err_i2c_prog;
	}

	ret = lt9611_read_device_id(pdata);
	if (ret) {
		pr_err("failed to read chip rev\n");
		goto err_sysfs_init;
		goto err_i2c_prog;
	}

	msleep(200);

	i2c_set_clientdata(client, pdata);
	dev_set_drvdata(&client->dev, pdata);

	ret = lt9611_sysfs_init(&client->dev);
	if (ret) {
		pr_err("sysfs init failed\n");
		goto err_sysfs_init;
		goto err_i2c_prog;
	}

	chip_version = lt9611_get_version(pdata);
	pdata->hpd_support = false;
	if (chip_version) {
		pr_info("LT9611 works, no need to upgrade FW\n");
		if (chip_version >= 0x40)
			pdata->hpd_support = true;
	} else {
		ret = request_firmware_nowait(THIS_MODULE, true,
			"lt9611_fw.bin", &client->dev, GFP_KERNEL, pdata,
@@ -1816,7 +1811,7 @@ static int lt9611_probe(struct i2c_client *client,
		if (ret) {
			dev_err(&client->dev,
				"Failed to invoke firmware loader: %d\n", ret);
			goto err_sysfs_init;
			goto err_i2c_prog;
		} else
			return 0;
	}
@@ -1831,15 +1826,23 @@ static int lt9611_probe(struct i2c_client *client,
	pdata->wq = create_singlethread_workqueue("lt9611_wk");
	if (!pdata->wq) {
		pr_err("Error creating lt9611 wq\n");
		goto err_sysfs_init;
		goto err_i2c_prog;
	}
	INIT_WORK(&pdata->work, lt9611_hpd_work);

	return 0;
	pdata->irq = gpio_to_irq(pdata->irq_gpio);
	ret = request_threaded_irq(pdata->irq, NULL, lt9611_irq_thread_handler,
		IRQF_TRIGGER_FALLING | IRQF_ONESHOT, "lt9611_irq", pdata);
	if (ret) {
		pr_err("failed to request irq\n");
		goto err_i2c_prog;
	}

err_sysfs_init:
	if (!pdata->hpd_support)
		disable_irq(pdata->irq);
	free_irq(pdata->irq, pdata);

	return 0;

err_i2c_prog:
	lt9611_gpio_configure(pdata, false);
err_dt_supply:
@@ -1864,6 +1867,7 @@ static int lt9611_remove(struct i2c_client *client)

	lt9611_sysfs_remove(&client->dev);

	if (pdata->hpd_support)
		disable_irq(pdata->irq);
	free_irq(pdata->irq, pdata);