Input: atmel_mxt_ts - simplify mxt_initialize a bit

I think having control flow with 2 goto/labels/flags is quite hard to read,
this version is a bit more readable IMO.

Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Signed-off-by: Nick Dyer <nick.dyer@itdev.co.uk>
This commit is contained in:
Dmitry Torokhov 2014-08-08 09:28:45 -07:00
parent 23526d9497
commit 6cd1ab0fb6
1 changed files with 43 additions and 40 deletions

View File

@ -359,7 +359,6 @@ static int mxt_bootloader_read(struct mxt_data *data,
msg.buf = val; msg.buf = val;
ret = i2c_transfer(data->client->adapter, &msg, 1); ret = i2c_transfer(data->client->adapter, &msg, 1);
if (ret == 1) { if (ret == 1) {
ret = 0; ret = 0;
} else { } else {
@ -414,6 +413,7 @@ static int mxt_lookup_bootloader_address(struct mxt_data *data, bool retry)
case 0x5b: case 0x5b:
bootloader = appmode - 0x26; bootloader = appmode - 0x26;
break; break;
default: default:
dev_err(&data->client->dev, dev_err(&data->client->dev,
"Appmode i2c address 0x%02x not found\n", "Appmode i2c address 0x%02x not found\n",
@ -425,20 +425,20 @@ static int mxt_lookup_bootloader_address(struct mxt_data *data, bool retry)
return 0; return 0;
} }
static int mxt_probe_bootloader(struct mxt_data *data, bool retry) static int mxt_probe_bootloader(struct mxt_data *data, bool alt_address)
{ {
struct device *dev = &data->client->dev; struct device *dev = &data->client->dev;
int ret; int error;
u8 val; u8 val;
bool crc_failure; bool crc_failure;
ret = mxt_lookup_bootloader_address(data, retry); error = mxt_lookup_bootloader_address(data, alt_address);
if (ret) if (error)
return ret; return error;
ret = mxt_bootloader_read(data, &val, 1); error = mxt_bootloader_read(data, &val, 1);
if (ret) if (error)
return ret; return error;
/* Check app crc fail mode */ /* Check app crc fail mode */
crc_failure = (val & ~MXT_BOOT_STATUS_MASK) == MXT_APP_CRC_FAIL; crc_failure = (val & ~MXT_BOOT_STATUS_MASK) == MXT_APP_CRC_FAIL;
@ -1645,41 +1645,39 @@ static void mxt_config_cb(const struct firmware *cfg, void *ctx)
static int mxt_initialize(struct mxt_data *data) static int mxt_initialize(struct mxt_data *data)
{ {
struct i2c_client *client = data->client; struct i2c_client *client = data->client;
int recovery_attempts = 0;
int error; int error;
bool alt_bootloader_addr = false;
bool retry = false;
retry_info: while (1) {
error = mxt_get_info(data); error = mxt_get_info(data);
if (error) { if (!error)
retry_bootloader: break;
error = mxt_probe_bootloader(data, alt_bootloader_addr);
/* Check bootloader state */
error = mxt_probe_bootloader(data, false);
if (error) { if (error) {
if (alt_bootloader_addr) { dev_info(&client->dev, "Trying alternate bootloader address\n");
error = mxt_probe_bootloader(data, true);
if (error) {
/* Chip is not in appmode or bootloader mode */ /* Chip is not in appmode or bootloader mode */
return error; return error;
} }
dev_info(&client->dev, "Trying alternate bootloader address\n");
alt_bootloader_addr = true;
goto retry_bootloader;
} else {
if (retry) {
dev_err(&client->dev, "Could not recover from bootloader mode\n");
/*
* We can reflash from this state, so do not
* abort init
*/
data->in_bootloader = true;
return 0;
}
/* Attempt to exit bootloader into app mode */
mxt_send_bootloader_cmd(data, false);
msleep(MXT_FW_RESET_TIME);
retry = true;
goto retry_info;
} }
/* OK, we are in bootloader, see if we can recover */
if (++recovery_attempts > 1) {
dev_err(&client->dev, "Could not recover from bootloader mode\n");
/*
* We can reflash from this state, so do not
* abort initialization.
*/
data->in_bootloader = true;
return 0;
}
/* Attempt to exit bootloader into app mode */
mxt_send_bootloader_cmd(data, false);
msleep(MXT_FW_RESET_TIME);
} }
/* Get object table information */ /* Get object table information */
@ -1693,9 +1691,14 @@ retry_bootloader:
if (error) if (error)
goto err_free_object_table; goto err_free_object_table;
request_firmware_nowait(THIS_MODULE, true, MXT_CFG_NAME, error = request_firmware_nowait(THIS_MODULE, true, MXT_CFG_NAME,
&data->client->dev, GFP_KERNEL, data, &client->dev, GFP_KERNEL, data,
mxt_config_cb); mxt_config_cb);
if (error) {
dev_err(&client->dev, "Failed to invoke firmware loader: %d\n",
error);
goto err_free_object_table;
}
return 0; return 0;