Commit 8eff5109 authored by Johan Hovold's avatar Johan Hovold Committed by Greg Kroah-Hartman

greybus: firmware: abort if AP_READY fails

Abort if the AP_READY request fails.

Also update the comment suggesting that this operation was a temporary
one.
Reviewed-by: default avatarViresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: default avatarJohan Hovold <johan@hovoldconsulting.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@google.com>
parent e0deb079
...@@ -251,25 +251,23 @@ static int gb_firmware_connection_init(struct gb_connection *connection) ...@@ -251,25 +251,23 @@ static int gb_firmware_connection_init(struct gb_connection *connection)
firmware_es2_fixup_vid_pid(firmware); firmware_es2_fixup_vid_pid(firmware);
/* /* Tell bootrom we're ready. */
* Module's Bootrom needs a way to know (currently), when to start
* sending requests to the AP. The version request is sent before this
* routine is called, and if the module sends the request right after
* receiving version request, the connection->private field will be
* NULL.
*
* Fix this TEMPORARILY by sending an AP_READY request.
*/
ret = gb_operation_sync(connection, GB_FIRMWARE_TYPE_AP_READY, NULL, 0, ret = gb_operation_sync(connection, GB_FIRMWARE_TYPE_AP_READY, NULL, 0,
NULL, 0); NULL, 0);
if (ret) { if (ret) {
dev_err(&connection->bundle->dev, dev_err(&connection->bundle->dev,
"failed to send AP READY: %d\n", ret); "failed to send AP READY: %d\n", ret);
goto err_free_firmware;
} }
dev_dbg(&connection->bundle->dev, "%s: AP_READY sent\n", __func__); dev_dbg(&connection->bundle->dev, "%s: AP_READY sent\n", __func__);
return 0; return 0;
err_free_firmware:
kfree(firmware);
return ret;
} }
static void gb_firmware_connection_exit(struct gb_connection *connection) static void gb_firmware_connection_exit(struct gb_connection *connection)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment