USB: io_ti: fix DMA buffers on stack
Signed-off-by: Johan Hovold <jhovold@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
parent
974fccb7ab
commit
e9305d2f4b
1 changed files with 48 additions and 18 deletions
|
@ -413,11 +413,18 @@ static int write_boot_mem(struct edgeport_serial *serial,
|
|||
{
|
||||
int status = 0;
|
||||
int i;
|
||||
__u8 temp;
|
||||
u8 *temp;
|
||||
|
||||
/* Must do a read before write */
|
||||
if (!serial->TiReadI2C) {
|
||||
status = read_boot_mem(serial, 0, 1, &temp);
|
||||
temp = kmalloc(1, GFP_KERNEL);
|
||||
if (!temp) {
|
||||
dev_err(&serial->serial->dev->dev,
|
||||
"%s - out of memory\n", __func__);
|
||||
return -ENOMEM;
|
||||
}
|
||||
status = read_boot_mem(serial, 0, 1, temp);
|
||||
kfree(temp);
|
||||
if (status)
|
||||
return status;
|
||||
}
|
||||
|
@ -935,37 +942,47 @@ static int build_i2c_fw_hdr(__u8 *header, struct device *dev)
|
|||
static int i2c_type_bootmode(struct edgeport_serial *serial)
|
||||
{
|
||||
int status;
|
||||
__u8 data;
|
||||
u8 *data;
|
||||
|
||||
data = kmalloc(1, GFP_KERNEL);
|
||||
if (!data) {
|
||||
dev_err(&serial->serial->dev->dev,
|
||||
"%s - out of memory\n", __func__);
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
/* Try to read type 2 */
|
||||
status = ti_vread_sync(serial->serial->dev, UMPC_MEMORY_READ,
|
||||
DTK_ADDR_SPACE_I2C_TYPE_II, 0, &data, 0x01);
|
||||
DTK_ADDR_SPACE_I2C_TYPE_II, 0, data, 0x01);
|
||||
if (status)
|
||||
dbg("%s - read 2 status error = %d", __func__, status);
|
||||
else
|
||||
dbg("%s - read 2 data = 0x%x", __func__, data);
|
||||
if ((!status) && (data == UMP5152 || data == UMP3410)) {
|
||||
dbg("%s - read 2 data = 0x%x", __func__, *data);
|
||||
if ((!status) && (*data == UMP5152 || *data == UMP3410)) {
|
||||
dbg("%s - ROM_TYPE_II", __func__);
|
||||
serial->TI_I2C_Type = DTK_ADDR_SPACE_I2C_TYPE_II;
|
||||
return 0;
|
||||
goto out;
|
||||
}
|
||||
|
||||
/* Try to read type 3 */
|
||||
status = ti_vread_sync(serial->serial->dev, UMPC_MEMORY_READ,
|
||||
DTK_ADDR_SPACE_I2C_TYPE_III, 0, &data, 0x01);
|
||||
DTK_ADDR_SPACE_I2C_TYPE_III, 0, data, 0x01);
|
||||
if (status)
|
||||
dbg("%s - read 3 status error = %d", __func__, status);
|
||||
else
|
||||
dbg("%s - read 2 data = 0x%x", __func__, data);
|
||||
if ((!status) && (data == UMP5152 || data == UMP3410)) {
|
||||
dbg("%s - read 2 data = 0x%x", __func__, *data);
|
||||
if ((!status) && (*data == UMP5152 || *data == UMP3410)) {
|
||||
dbg("%s - ROM_TYPE_III", __func__);
|
||||
serial->TI_I2C_Type = DTK_ADDR_SPACE_I2C_TYPE_III;
|
||||
return 0;
|
||||
goto out;
|
||||
}
|
||||
|
||||
dbg("%s - Unknown", __func__);
|
||||
serial->TI_I2C_Type = DTK_ADDR_SPACE_I2C_TYPE_II;
|
||||
return -ENODEV;
|
||||
status = -ENODEV;
|
||||
out:
|
||||
kfree(data);
|
||||
return status;
|
||||
}
|
||||
|
||||
static int bulk_xfer(struct usb_serial *serial, void *buffer,
|
||||
|
@ -1113,7 +1130,7 @@ static int download_fw(struct edgeport_serial *serial)
|
|||
I2C_DESC_TYPE_FIRMWARE_BASIC, rom_desc);
|
||||
if (start_address != 0) {
|
||||
struct ti_i2c_firmware_rec *firmware_version;
|
||||
__u8 record;
|
||||
u8 *record;
|
||||
|
||||
dbg("%s - Found Type FIRMWARE (Type 2) record",
|
||||
__func__);
|
||||
|
@ -1165,6 +1182,15 @@ static int download_fw(struct edgeport_serial *serial)
|
|||
OperationalMajorVersion,
|
||||
OperationalMinorVersion);
|
||||
|
||||
record = kmalloc(1, GFP_KERNEL);
|
||||
if (!record) {
|
||||
dev_err(dev, "%s - out of memory.\n",
|
||||
__func__);
|
||||
kfree(firmware_version);
|
||||
kfree(rom_desc);
|
||||
kfree(ti_manuf_desc);
|
||||
return -ENOMEM;
|
||||
}
|
||||
/* In order to update the I2C firmware we must
|
||||
* change the type 2 record to type 0xF2. This
|
||||
* will force the UMP to come up in Boot Mode.
|
||||
|
@ -1177,13 +1203,14 @@ static int download_fw(struct edgeport_serial *serial)
|
|||
* firmware will update the record type from
|
||||
* 0xf2 to 0x02.
|
||||
*/
|
||||
record = I2C_DESC_TYPE_FIRMWARE_BLANK;
|
||||
*record = I2C_DESC_TYPE_FIRMWARE_BLANK;
|
||||
|
||||
/* Change the I2C Firmware record type to
|
||||
0xf2 to trigger an update */
|
||||
status = write_rom(serial, start_address,
|
||||
sizeof(record), &record);
|
||||
sizeof(*record), record);
|
||||
if (status) {
|
||||
kfree(record);
|
||||
kfree(firmware_version);
|
||||
kfree(rom_desc);
|
||||
kfree(ti_manuf_desc);
|
||||
|
@ -1196,19 +1223,21 @@ static int download_fw(struct edgeport_serial *serial)
|
|||
*/
|
||||
status = read_rom(serial,
|
||||
start_address,
|
||||
sizeof(record),
|
||||
&record);
|
||||
sizeof(*record),
|
||||
record);
|
||||
if (status) {
|
||||
kfree(record);
|
||||
kfree(firmware_version);
|
||||
kfree(rom_desc);
|
||||
kfree(ti_manuf_desc);
|
||||
return status;
|
||||
}
|
||||
|
||||
if (record != I2C_DESC_TYPE_FIRMWARE_BLANK) {
|
||||
if (*record != I2C_DESC_TYPE_FIRMWARE_BLANK) {
|
||||
dev_err(dev,
|
||||
"%s - error resetting device\n",
|
||||
__func__);
|
||||
kfree(record);
|
||||
kfree(firmware_version);
|
||||
kfree(rom_desc);
|
||||
kfree(ti_manuf_desc);
|
||||
|
@ -1226,6 +1255,7 @@ static int download_fw(struct edgeport_serial *serial)
|
|||
__func__, status);
|
||||
|
||||
/* return an error on purpose. */
|
||||
kfree(record);
|
||||
kfree(firmware_version);
|
||||
kfree(rom_desc);
|
||||
kfree(ti_manuf_desc);
|
||||
|
|
Loading…
Reference in a new issue