// SPDX-License-Identifier: GPL-2.0-only /* * Goodix Touchscreen firmware upload support * * Copyright (c) 2021 Hans de Goede <hdegoede@redhat.com> * * This is a rewrite of gt9xx_update.c from the Allwinner H3 BSP which is: * Copyright (c) 2010 - 2012 Goodix Technology. * Author: andrew@goodix.com
*/
error = goodix_i2c_read(client, GOODIX_REG_SW_WDT, &val, 1); if (error) return error;
/* The value we've written to SW_WDT should have been cleared now */ if (val == 0xaa) {
dev_err(&client->dev, "Error SW_WDT reg not cleared on fw startup\n"); return -EIO;
}
error = goodix_firmware_verify(&ts->client->dev, fw); if (error) goto release;
error = goodix_reset_no_int_sync(ts); if (error) goto release;
error = goodix_enter_upload_mode(ts->client); if (error) goto release;
/* Select SRAM bank 0 and upload section 1 & 2 */
error = goodix_i2c_write_u8(ts->client,
GOODIX_REG_MISCTL_SRAM_BANK, 0x00); if (error) goto release;
data = fw->data + GOODIX_FW_HEADER_LENGTH;
error = goodix_i2c_write(ts->client, GOODIX_FW_UPLOAD_ADDRESS,
data, 2 * GOODIX_FW_SECTION_LENGTH); if (error) goto release;
/* Select SRAM bank 1 and upload section 3 & 4 */
error = goodix_i2c_write_u8(ts->client,
GOODIX_REG_MISCTL_SRAM_BANK, 0x01); if (error) goto release;
data += 2 * GOODIX_FW_SECTION_LENGTH;
error = goodix_i2c_write(ts->client, GOODIX_FW_UPLOAD_ADDRESS,
data, 2 * GOODIX_FW_SECTION_LENGTH); if (error) goto release;
/* Select SRAM bank 2 and upload the DSP firmware */
error = goodix_i2c_write_u8(ts->client,
GOODIX_REG_MISCTL_SRAM_BANK, 0x02); if (error) goto release;
data += 2 * GOODIX_FW_SECTION_LENGTH;
error = goodix_i2c_write(ts->client, GOODIX_FW_UPLOAD_ADDRESS,
data, GOODIX_FW_DSP_LENGTH); if (error) goto release;
error = goodix_start_firmware(ts->client); if (error) goto release;
ts->bak_ref = devm_kzalloc(&ts->client->dev,
ts->bak_ref_len, GFP_KERNEL); if (!ts->bak_ref) return -ENOMEM;
/* * The bak_ref array contains the backup of an array of (self/auto) * calibration related values which the Android version of the driver * stores on the filesystem so that it can be restored after reboot. * The mainline kernel never writes directly to the filesystem like * this, we always start will all the values which give a correction * factor in approx. the -20 - +20 range (in 2s complement) set to 0. * * Note the touchscreen works fine without restoring the reference * values after a reboot / power-cycle. * * The last 2 bytes are a 16 bits unsigned checksum which is expected * to make the addition al all 16 bit unsigned values in the array add * up to 1 (rather then the usual 0), so we must set the last byte to 1.
*/
ts->bak_ref[ts->bak_ref_len - 1] = 1;
return 0;
}
staticint goodix_send_main_clock(struct goodix_ts_data *ts)
{
u32 main_clk = 54; /* Default main clock */
u8 checksum = 0; int i;
bool goodix_handle_fw_request(struct goodix_ts_data *ts)
{ int error;
u8 val;
error = goodix_i2c_read(ts->client, GOODIX_REG_REQUEST, &val, 1); if (error) returnfalse;
switch (val) { case GOODIX_RQST_RESPONDED: /* * If we read back our own last ack the IRQ was not for * a request.
*/ returnfalse; case GOODIX_RQST_CONFIG:
error = goodix_send_cfg(ts, ts->config, ts->chip->config_len); if (error) returnfalse;
break; case GOODIX_RQST_BAK_REF:
error = goodix_prepare_bak_ref(ts); if (error) returnfalse;
error = goodix_i2c_write(ts->client, GOODIX_REG_BAK_REF,
ts->bak_ref, ts->bak_ref_len); if (error) returnfalse;
break; case GOODIX_RQST_RESET:
error = goodix_firmware_upload(ts); if (error) returnfalse;
break; case GOODIX_RQST_MAIN_CLOCK:
error = goodix_send_main_clock(ts); if (error) returnfalse;
break; case GOODIX_RQST_UNKNOWN: case GOODIX_RQST_IDLE: break; default:
dev_err_ratelimited(&ts->client->dev, "Unknown Request: 0x%02x\n", val);
}
/* Ack the request */
goodix_i2c_write_u8(ts->client,
GOODIX_REG_REQUEST, GOODIX_RQST_RESPONDED); returntrue;
}
void goodix_save_bak_ref(struct goodix_ts_data *ts)
{ int error;
u8 val;
if (!ts->firmware_name) return;
error = goodix_i2c_read(ts->client, GOODIX_REG_STATUS, &val, 1); if (error) return;
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.