提交 d7edde3d 编写于 作者: L Luben Tuikov 提交者: Alex Deucher

drm/amdgpu: Nerf buff

buff --> buf. Essentially buffer abbreviates to
buf, remove 1/2 of it, or just the iron part, as
opposed to just the Er,

Cc: Alexander Deucher <Alexander.Deucher@amd.com>
Cc: Andrey Grodzovsky <Andrey.Grodzovsky@amd.com>
Signed-off-by: NLuben Tuikov <luben.tuikov@amd.com>
Reviewed-by: NAlexander Deucher <Alexander.Deucher@amd.com>
Signed-off-by: NAlex Deucher <alexander.deucher@amd.com>
上级 e4e6a589
...@@ -117,10 +117,10 @@ static bool __get_eeprom_i2c_addr(struct amdgpu_device *adev, ...@@ -117,10 +117,10 @@ static bool __get_eeprom_i2c_addr(struct amdgpu_device *adev,
return true; return true;
} }
static void __encode_table_header_to_buff(struct amdgpu_ras_eeprom_table_header *hdr, static void __encode_table_header_to_buf(struct amdgpu_ras_eeprom_table_header *hdr,
unsigned char *buff) unsigned char *buf)
{ {
uint32_t *pp = (uint32_t *) buff; uint32_t *pp = (uint32_t *) buf;
pp[0] = cpu_to_le32(hdr->header); pp[0] = cpu_to_le32(hdr->header);
pp[1] = cpu_to_le32(hdr->version); pp[1] = cpu_to_le32(hdr->version);
...@@ -129,10 +129,10 @@ static void __encode_table_header_to_buff(struct amdgpu_ras_eeprom_table_header ...@@ -129,10 +129,10 @@ static void __encode_table_header_to_buff(struct amdgpu_ras_eeprom_table_header
pp[4] = cpu_to_le32(hdr->checksum); pp[4] = cpu_to_le32(hdr->checksum);
} }
static void __decode_table_header_from_buff(struct amdgpu_ras_eeprom_table_header *hdr, static void __decode_table_header_from_buf(struct amdgpu_ras_eeprom_table_header *hdr,
unsigned char *buff) unsigned char *buf)
{ {
uint32_t *pp = (uint32_t *)buff; u32 *pp = (uint32_t *) buf;
hdr->header = le32_to_cpu(pp[0]); hdr->header = le32_to_cpu(pp[0]);
hdr->version = le32_to_cpu(pp[1]); hdr->version = le32_to_cpu(pp[1]);
...@@ -142,18 +142,18 @@ static void __decode_table_header_from_buff(struct amdgpu_ras_eeprom_table_heade ...@@ -142,18 +142,18 @@ static void __decode_table_header_from_buff(struct amdgpu_ras_eeprom_table_heade
} }
static int __write_table_header(struct amdgpu_ras_eeprom_control *control, static int __write_table_header(struct amdgpu_ras_eeprom_control *control,
unsigned char *buff) unsigned char *buf)
{ {
int ret = 0; int ret = 0;
struct amdgpu_device *adev = to_amdgpu_device(control); struct amdgpu_device *adev = to_amdgpu_device(control);
__encode_table_header_to_buff(&control->tbl_hdr, buff); __encode_table_header_to_buf(&control->tbl_hdr, buf);
/* i2c may be unstable in gpu reset */ /* i2c may be unstable in gpu reset */
down_read(&adev->reset_sem); down_read(&adev->reset_sem);
ret = amdgpu_eeprom_write(&adev->pm.smu_i2c, ret = amdgpu_eeprom_write(&adev->pm.smu_i2c,
control->i2c_address + RAS_HDR_START, control->i2c_address + RAS_HDR_START,
buff, RAS_TABLE_HEADER_SIZE); buf, RAS_TABLE_HEADER_SIZE);
up_read(&adev->reset_sem); up_read(&adev->reset_sem);
if (ret < 1) if (ret < 1)
...@@ -240,15 +240,15 @@ static int amdgpu_ras_eeprom_correct_header_tag( ...@@ -240,15 +240,15 @@ static int amdgpu_ras_eeprom_correct_header_tag(
struct amdgpu_ras_eeprom_control *control, struct amdgpu_ras_eeprom_control *control,
uint32_t header) uint32_t header)
{ {
unsigned char buff[RAS_TABLE_HEADER_SIZE]; unsigned char buf[RAS_TABLE_HEADER_SIZE];
struct amdgpu_ras_eeprom_table_header *hdr = &control->tbl_hdr; struct amdgpu_ras_eeprom_table_header *hdr = &control->tbl_hdr;
int ret = 0; int ret = 0;
memset(buff, 0, RAS_TABLE_HEADER_SIZE); memset(buf, 0, RAS_TABLE_HEADER_SIZE);
mutex_lock(&control->tbl_mutex); mutex_lock(&control->tbl_mutex);
hdr->header = header; hdr->header = header;
ret = __write_table_header(control, buff); ret = __write_table_header(control, buf);
mutex_unlock(&control->tbl_mutex); mutex_unlock(&control->tbl_mutex);
return ret; return ret;
...@@ -256,7 +256,7 @@ static int amdgpu_ras_eeprom_correct_header_tag( ...@@ -256,7 +256,7 @@ static int amdgpu_ras_eeprom_correct_header_tag(
int amdgpu_ras_eeprom_reset_table(struct amdgpu_ras_eeprom_control *control) int amdgpu_ras_eeprom_reset_table(struct amdgpu_ras_eeprom_control *control)
{ {
unsigned char buff[RAS_TABLE_HEADER_SIZE] = { 0 }; unsigned char buf[RAS_TABLE_HEADER_SIZE] = { 0 };
struct amdgpu_ras_eeprom_table_header *hdr = &control->tbl_hdr; struct amdgpu_ras_eeprom_table_header *hdr = &control->tbl_hdr;
int ret = 0; int ret = 0;
...@@ -269,7 +269,7 @@ int amdgpu_ras_eeprom_reset_table(struct amdgpu_ras_eeprom_control *control) ...@@ -269,7 +269,7 @@ int amdgpu_ras_eeprom_reset_table(struct amdgpu_ras_eeprom_control *control)
__update_tbl_checksum(control, NULL, 0); __update_tbl_checksum(control, NULL, 0);
control->next_addr = RAS_RECORD_START; control->next_addr = RAS_RECORD_START;
ret = __write_table_header(control, buff); ret = __write_table_header(control, buf);
mutex_unlock(&control->tbl_mutex); mutex_unlock(&control->tbl_mutex);
...@@ -282,7 +282,7 @@ int amdgpu_ras_eeprom_init(struct amdgpu_ras_eeprom_control *control, ...@@ -282,7 +282,7 @@ int amdgpu_ras_eeprom_init(struct amdgpu_ras_eeprom_control *control,
{ {
int ret = 0; int ret = 0;
struct amdgpu_device *adev = to_amdgpu_device(control); struct amdgpu_device *adev = to_amdgpu_device(control);
unsigned char buff[RAS_TABLE_HEADER_SIZE] = { 0 }; unsigned char buf[RAS_TABLE_HEADER_SIZE] = { 0 };
struct amdgpu_ras_eeprom_table_header *hdr = &control->tbl_hdr; struct amdgpu_ras_eeprom_table_header *hdr = &control->tbl_hdr;
struct amdgpu_ras *ras = amdgpu_ras_get_context(adev); struct amdgpu_ras *ras = amdgpu_ras_get_context(adev);
...@@ -303,13 +303,13 @@ int amdgpu_ras_eeprom_init(struct amdgpu_ras_eeprom_control *control, ...@@ -303,13 +303,13 @@ int amdgpu_ras_eeprom_init(struct amdgpu_ras_eeprom_control *control,
/* Read/Create table header from EEPROM address 0 */ /* Read/Create table header from EEPROM address 0 */
ret = amdgpu_eeprom_read(&adev->pm.smu_i2c, ret = amdgpu_eeprom_read(&adev->pm.smu_i2c,
control->i2c_address + RAS_HDR_START, control->i2c_address + RAS_HDR_START,
buff, RAS_TABLE_HEADER_SIZE); buf, RAS_TABLE_HEADER_SIZE);
if (ret < 1) { if (ret < 1) {
DRM_ERROR("Failed to read EEPROM table header, ret:%d", ret); DRM_ERROR("Failed to read EEPROM table header, ret:%d", ret);
return ret; return ret;
} }
__decode_table_header_from_buff(hdr, buff); __decode_table_header_from_buf(hdr, buf);
if (hdr->header == RAS_TABLE_HDR_VAL) { if (hdr->header == RAS_TABLE_HDR_VAL) {
control->num_recs = (hdr->tbl_size - RAS_TABLE_HEADER_SIZE) / control->num_recs = (hdr->tbl_size - RAS_TABLE_HEADER_SIZE) /
...@@ -341,57 +341,57 @@ int amdgpu_ras_eeprom_init(struct amdgpu_ras_eeprom_control *control, ...@@ -341,57 +341,57 @@ int amdgpu_ras_eeprom_init(struct amdgpu_ras_eeprom_control *control,
return ret > 0 ? 0 : -EIO; return ret > 0 ? 0 : -EIO;
} }
static void __encode_table_record_to_buff(struct amdgpu_ras_eeprom_control *control, static void __encode_table_record_to_buf(struct amdgpu_ras_eeprom_control *control,
struct eeprom_table_record *record, struct eeprom_table_record *record,
unsigned char *buff) unsigned char *buf)
{ {
__le64 tmp = 0; __le64 tmp = 0;
int i = 0; int i = 0;
/* Next are all record fields according to EEPROM page spec in LE foramt */ /* Next are all record fields according to EEPROM page spec in LE foramt */
buff[i++] = record->err_type; buf[i++] = record->err_type;
buff[i++] = record->bank; buf[i++] = record->bank;
tmp = cpu_to_le64(record->ts); tmp = cpu_to_le64(record->ts);
memcpy(buff + i, &tmp, 8); memcpy(buf + i, &tmp, 8);
i += 8; i += 8;
tmp = cpu_to_le64((record->offset & 0xffffffffffff)); tmp = cpu_to_le64((record->offset & 0xffffffffffff));
memcpy(buff + i, &tmp, 6); memcpy(buf + i, &tmp, 6);
i += 6; i += 6;
buff[i++] = record->mem_channel; buf[i++] = record->mem_channel;
buff[i++] = record->mcumc_id; buf[i++] = record->mcumc_id;
tmp = cpu_to_le64((record->retired_page & 0xffffffffffff)); tmp = cpu_to_le64((record->retired_page & 0xffffffffffff));
memcpy(buff + i, &tmp, 6); memcpy(buf + i, &tmp, 6);
} }
static void __decode_table_record_from_buff(struct amdgpu_ras_eeprom_control *control, static void __decode_table_record_from_buf(struct amdgpu_ras_eeprom_control *control,
struct eeprom_table_record *record, struct eeprom_table_record *record,
unsigned char *buff) unsigned char *buf)
{ {
__le64 tmp = 0; __le64 tmp = 0;
int i = 0; int i = 0;
/* Next are all record fields according to EEPROM page spec in LE foramt */ /* Next are all record fields according to EEPROM page spec in LE foramt */
record->err_type = buff[i++]; record->err_type = buf[i++];
record->bank = buff[i++]; record->bank = buf[i++];
memcpy(&tmp, buff + i, 8); memcpy(&tmp, buf + i, 8);
record->ts = le64_to_cpu(tmp); record->ts = le64_to_cpu(tmp);
i += 8; i += 8;
memcpy(&tmp, buff + i, 6); memcpy(&tmp, buf + i, 6);
record->offset = (le64_to_cpu(tmp) & 0xffffffffffff); record->offset = (le64_to_cpu(tmp) & 0xffffffffffff);
i += 6; i += 6;
record->mem_channel = buff[i++]; record->mem_channel = buf[i++];
record->mcumc_id = buff[i++]; record->mcumc_id = buf[i++];
memcpy(&tmp, buff + i, 6); memcpy(&tmp, buf + i, 6);
record->retired_page = (le64_to_cpu(tmp) & 0xffffffffffff); record->retired_page = (le64_to_cpu(tmp) & 0xffffffffffff);
} }
...@@ -440,7 +440,7 @@ static int amdgpu_ras_eeprom_xfer(struct amdgpu_ras_eeprom_control *control, ...@@ -440,7 +440,7 @@ static int amdgpu_ras_eeprom_xfer(struct amdgpu_ras_eeprom_control *control,
const u32 num, bool write) const u32 num, bool write)
{ {
int i, ret = 0; int i, ret = 0;
unsigned char *buffs, *buff; unsigned char *bufs, *buf;
struct eeprom_table_record *record; struct eeprom_table_record *record;
struct amdgpu_device *adev = to_amdgpu_device(control); struct amdgpu_device *adev = to_amdgpu_device(control);
struct amdgpu_ras *ras = amdgpu_ras_get_context(adev); struct amdgpu_ras *ras = amdgpu_ras_get_context(adev);
...@@ -448,8 +448,8 @@ static int amdgpu_ras_eeprom_xfer(struct amdgpu_ras_eeprom_control *control, ...@@ -448,8 +448,8 @@ static int amdgpu_ras_eeprom_xfer(struct amdgpu_ras_eeprom_control *control,
if (!__is_ras_eeprom_supported(adev)) if (!__is_ras_eeprom_supported(adev))
return 0; return 0;
buffs = kcalloc(num, RAS_TABLE_RECORD_SIZE, GFP_KERNEL); bufs = kcalloc(num, RAS_TABLE_RECORD_SIZE, GFP_KERNEL);
if (!buffs) if (!bufs)
return -ENOMEM; return -ENOMEM;
mutex_lock(&control->tbl_mutex); mutex_lock(&control->tbl_mutex);
...@@ -485,27 +485,27 @@ static int amdgpu_ras_eeprom_xfer(struct amdgpu_ras_eeprom_control *control, ...@@ -485,27 +485,27 @@ static int amdgpu_ras_eeprom_xfer(struct amdgpu_ras_eeprom_control *control,
* 256b * 256b
*/ */
for (i = 0; i < num; i++) { for (i = 0; i < num; i++) {
buff = &buffs[i * RAS_TABLE_RECORD_SIZE]; buf = &bufs[i * RAS_TABLE_RECORD_SIZE];
record = &records[i]; record = &records[i];
control->next_addr = __correct_eeprom_dest_address(control->next_addr); control->next_addr = __correct_eeprom_dest_address(control->next_addr);
/* EEPROM table content is stored in LE format */ /* EEPROM table content is stored in LE format */
if (write) if (write)
__encode_table_record_to_buff(control, record, buff); __encode_table_record_to_buf(control, record, buf);
/* i2c may be unstable in gpu reset */ /* i2c may be unstable in gpu reset */
down_read(&adev->reset_sem); down_read(&adev->reset_sem);
ret = amdgpu_eeprom_xfer(&adev->pm.smu_i2c, ret = amdgpu_eeprom_xfer(&adev->pm.smu_i2c,
control->i2c_address + control->next_addr, control->i2c_address + control->next_addr,
buff, RAS_TABLE_RECORD_SIZE, !write); buf, RAS_TABLE_RECORD_SIZE, !write);
up_read(&adev->reset_sem); up_read(&adev->reset_sem);
if (ret < 1) { if (ret < 1) {
DRM_ERROR("Failed to process EEPROM table records, ret:%d", ret); DRM_ERROR("Failed to process EEPROM table records, ret:%d", ret);
/* TODO Restore prev next EEPROM address ? */ /* TODO Restore prev next EEPROM address ? */
goto free_buff; goto free_buf;
} }
/* /*
* The destination EEPROM address might need to be corrected to account * The destination EEPROM address might need to be corrected to account
...@@ -516,10 +516,10 @@ static int amdgpu_ras_eeprom_xfer(struct amdgpu_ras_eeprom_control *control, ...@@ -516,10 +516,10 @@ static int amdgpu_ras_eeprom_xfer(struct amdgpu_ras_eeprom_control *control,
if (!write) { if (!write) {
for (i = 0; i < num; i++) { for (i = 0; i < num; i++) {
buff = &buffs[i * RAS_TABLE_RECORD_SIZE]; buf = &bufs[i * RAS_TABLE_RECORD_SIZE];
record = &records[i]; record = &records[i];
__decode_table_record_from_buff(control, record, buff); __decode_table_record_from_buf(control, record, buf);
} }
} }
...@@ -539,15 +539,15 @@ static int amdgpu_ras_eeprom_xfer(struct amdgpu_ras_eeprom_control *control, ...@@ -539,15 +539,15 @@ static int amdgpu_ras_eeprom_xfer(struct amdgpu_ras_eeprom_control *control,
control->num_recs * RAS_TABLE_RECORD_SIZE; control->num_recs * RAS_TABLE_RECORD_SIZE;
__update_tbl_checksum(control, records, num); __update_tbl_checksum(control, records, num);
__write_table_header(control, buffs); __write_table_header(control, bufs);
} else if (!__verify_tbl_checksum(control, records, num)) { } else if (!__verify_tbl_checksum(control, records, num)) {
DRM_WARN("EEPROM Table checksum mismatch!"); DRM_WARN("EEPROM Table checksum mismatch!");
/* TODO Uncomment when EEPROM read/write is relliable */ /* TODO Uncomment when EEPROM read/write is relliable */
/* ret = -EIO; */ /* ret = -EIO; */
} }
free_buff: free_buf:
kfree(buffs); kfree(bufs);
mutex_unlock(&control->tbl_mutex); mutex_unlock(&control->tbl_mutex);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册