Loading drivers/gpu/drm/bridge/lt9611uxc.c +29 −25 Original line number Diff line number Diff line Loading @@ -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; Loading Loading @@ -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; } Loading Loading @@ -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; } Loading @@ -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"); Loading @@ -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); } Loading Loading @@ -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; Loading Loading @@ -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, Loading Loading @@ -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); } Loading Loading @@ -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, Loading @@ -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; } Loading @@ -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: Loading @@ -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); Loading Loading
drivers/gpu/drm/bridge/lt9611uxc.c +29 −25 Original line number Diff line number Diff line Loading @@ -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; Loading Loading @@ -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; } Loading Loading @@ -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; } Loading @@ -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"); Loading @@ -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); } Loading Loading @@ -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; Loading Loading @@ -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, Loading Loading @@ -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); } Loading Loading @@ -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, Loading @@ -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; } Loading @@ -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: Loading @@ -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); Loading