Skip to content

Commit 35928bc

Browse files
Wang Haoranaegl
authored andcommitted
EDAC/{skx_common,i10nm}: Use scnprintf() for safer buffer handling
snprintf() is fragile when its return value will be used to append additional data to a buffer. Use scnprintf() instead. Signed-off-by: Wang Haoran <[email protected]> Signed-off-by: Tony Luck <[email protected]> Tested-by: Qiuxu Zhuo <[email protected]> Reviewed-by: Qiuxu Zhuo <[email protected]> Link: https://lore.kernel.org/r/[email protected]
1 parent b1dc7f0 commit 35928bc

File tree

2 files changed

+11
-11
lines changed

2 files changed

+11
-11
lines changed

drivers/edac/i10nm_base.c

Lines changed: 9 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -344,7 +344,7 @@ static void show_retry_rd_err_log(struct decoded_addr *res, char *msg,
344344

345345
status_mask = rrl->over_mask | rrl->uc_mask | rrl->v_mask;
346346

347-
n = snprintf(msg, len, " retry_rd_err_log[");
347+
n = scnprintf(msg, len, " retry_rd_err_log[");
348348
for (i = 0; i < rrl->set_num; i++) {
349349
scrub = (rrl->modes[i] == FRE_SCRUB || rrl->modes[i] == LRE_SCRUB);
350350
if (scrub_err != scrub)
@@ -356,9 +356,9 @@ static void show_retry_rd_err_log(struct decoded_addr *res, char *msg,
356356
log = read_imc_reg(imc, ch, offset, width);
357357

358358
if (width == 4)
359-
n += snprintf(msg + n, len - n, "%.8llx ", log);
359+
n += scnprintf(msg + n, len - n, "%.8llx ", log);
360360
else
361-
n += snprintf(msg + n, len - n, "%.16llx ", log);
361+
n += scnprintf(msg + n, len - n, "%.16llx ", log);
362362

363363
/* Clear RRL status if RRL in Linux control mode. */
364364
if (retry_rd_err_log == 2 && !j && (log & status_mask))
@@ -368,31 +368,31 @@ static void show_retry_rd_err_log(struct decoded_addr *res, char *msg,
368368

369369
/* Move back one space. */
370370
n--;
371-
n += snprintf(msg + n, len - n, "]");
371+
n += scnprintf(msg + n, len - n, "]");
372372

373373
if (len - n > 0) {
374-
n += snprintf(msg + n, len - n, " correrrcnt[");
374+
n += scnprintf(msg + n, len - n, " correrrcnt[");
375375
for (i = 0; i < rrl->cecnt_num && len - n > 0; i++) {
376376
offset = rrl->cecnt_offsets[i];
377377
width = rrl->cecnt_widths[i];
378378
corr = read_imc_reg(imc, ch, offset, width);
379379

380380
/* CPUs {ICX,SPR} encode two counters per 4-byte CORRERRCNT register. */
381381
if (res_cfg->type <= SPR) {
382-
n += snprintf(msg + n, len - n, "%.4llx %.4llx ",
382+
n += scnprintf(msg + n, len - n, "%.4llx %.4llx ",
383383
corr & 0xffff, corr >> 16);
384384
} else {
385385
/* CPUs {GNR} encode one counter per CORRERRCNT register. */
386386
if (width == 4)
387-
n += snprintf(msg + n, len - n, "%.8llx ", corr);
387+
n += scnprintf(msg + n, len - n, "%.8llx ", corr);
388388
else
389-
n += snprintf(msg + n, len - n, "%.16llx ", corr);
389+
n += scnprintf(msg + n, len - n, "%.16llx ", corr);
390390
}
391391
}
392392

393393
/* Move back one space. */
394394
n--;
395-
n += snprintf(msg + n, len - n, "]");
395+
n += scnprintf(msg + n, len - n, "]");
396396
}
397397
}
398398

drivers/edac/skx_common.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -670,12 +670,12 @@ static void skx_mce_output_error(struct mem_ctl_info *mci,
670670
}
671671

672672
if (res->decoded_by_adxl) {
673-
len = snprintf(skx_msg, MSG_SIZE, "%s%s err_code:0x%04x:0x%04x %s",
673+
len = scnprintf(skx_msg, MSG_SIZE, "%s%s err_code:0x%04x:0x%04x %s",
674674
overflow ? " OVERFLOW" : "",
675675
(uncorrected_error && recoverable) ? " recoverable" : "",
676676
mscod, errcode, adxl_msg);
677677
} else {
678-
len = snprintf(skx_msg, MSG_SIZE,
678+
len = scnprintf(skx_msg, MSG_SIZE,
679679
"%s%s err_code:0x%04x:0x%04x ProcessorSocketId:0x%x MemoryControllerId:0x%x PhysicalRankId:0x%x Row:0x%x Column:0x%x Bank:0x%x BankGroup:0x%x",
680680
overflow ? " OVERFLOW" : "",
681681
(uncorrected_error && recoverable) ? " recoverable" : "",

0 commit comments

Comments
 (0)