Skip to content

Commit 25dd70a

Browse files
Sanman Pradhangroeck
authored andcommitted
hwmon: (pmbus/q54sj108a2) fix stack overflow in debugfs read
The q54sj108a2_debugfs_read function suffers from a stack buffer overflow due to incorrect arguments passed to bin2hex(). The function currently passes 'data' as the destination and 'data_char' as the source. Because bin2hex() converts each input byte into two hex characters, a 32-byte block read results in 64 bytes of output. Since 'data' is only 34 bytes (I2C_SMBUS_BLOCK_MAX + 2), this writes 30 bytes past the end of the buffer onto the stack. Additionally, the arguments were swapped: it was reading from the zero-initialized 'data_char' and writing to 'data', resulting in all-zero output regardless of the actual I2C read. Fix this by: 1. Expanding 'data_char' to 66 bytes to safely hold the hex output. 2. Correcting the bin2hex() argument order and using the actual read count. 3. Using a pointer to select the correct output buffer for the final simple_read_from_buffer call. Fixes: d014538 ("hwmon: (pmbus) Driver for Delta power supplies Q54SJ108A2") Cc: stable@vger.kernel.org Signed-off-by: Sanman Pradhan <psanman@juniper.net> Link: https://lore.kernel.org/r/20260304235116.1045-1-sanman.p211993@gmail.com Signed-off-by: Guenter Roeck <linux@roeck-us.net>
1 parent 170a4b2 commit 25dd70a

1 file changed

Lines changed: 10 additions & 9 deletions

File tree

drivers/hwmon/pmbus/q54sj108a2.c

Lines changed: 10 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -79,7 +79,8 @@ static ssize_t q54sj108a2_debugfs_read(struct file *file, char __user *buf,
7979
int idx = *idxp;
8080
struct q54sj108a2_data *psu = to_psu(idxp, idx);
8181
char data[I2C_SMBUS_BLOCK_MAX + 2] = { 0 };
82-
char data_char[I2C_SMBUS_BLOCK_MAX + 2] = { 0 };
82+
char data_char[I2C_SMBUS_BLOCK_MAX * 2 + 2] = { 0 };
83+
char *out = data;
8384
char *res;
8485

8586
switch (idx) {
@@ -150,27 +151,27 @@ static ssize_t q54sj108a2_debugfs_read(struct file *file, char __user *buf,
150151
if (rc < 0)
151152
return rc;
152153

153-
res = bin2hex(data, data_char, 32);
154-
rc = res - data;
155-
154+
res = bin2hex(data_char, data, rc);
155+
rc = res - data_char;
156+
out = data_char;
156157
break;
157158
case Q54SJ108A2_DEBUGFS_FLASH_KEY:
158159
rc = i2c_smbus_read_block_data(psu->client, PMBUS_FLASH_KEY_WRITE, data);
159160
if (rc < 0)
160161
return rc;
161162

162-
res = bin2hex(data, data_char, 4);
163-
rc = res - data;
164-
163+
res = bin2hex(data_char, data, rc);
164+
rc = res - data_char;
165+
out = data_char;
165166
break;
166167
default:
167168
return -EINVAL;
168169
}
169170

170-
data[rc] = '\n';
171+
out[rc] = '\n';
171172
rc += 2;
172173

173-
return simple_read_from_buffer(buf, count, ppos, data, rc);
174+
return simple_read_from_buffer(buf, count, ppos, out, rc);
174175
}
175176

176177
static ssize_t q54sj108a2_debugfs_write(struct file *file, const char __user *buf,

0 commit comments

Comments
 (0)