Merge pull request #2964 from hathach/fix-2939
fix bug introduced by 2939, with correct offset check logic
This commit is contained in:
		| @@ -190,10 +190,14 @@ int32_t tud_msc_read10_cb(uint8_t lun, uint32_t lba, uint32_t offset, void* buff | ||||
|   (void) lun; | ||||
|  | ||||
|   // out of ramdisk | ||||
|   if ( lba >= DISK_BLOCK_NUM ) return -1; | ||||
|   if ( lba >= DISK_BLOCK_NUM ) { | ||||
|     return -1; | ||||
|   } | ||||
|  | ||||
|   // Check for overflow of offset + bufsize | ||||
|   if ( offset + bufsize >= DISK_BLOCK_SIZE ) return -1; | ||||
|   if ( offset + bufsize > DISK_BLOCK_SIZE ) { | ||||
|     return -1; | ||||
|   } | ||||
|  | ||||
|   uint8_t const* addr = msc_disk[lba] + offset; | ||||
|   memcpy(buffer, addr, bufsize); | ||||
|   | ||||
| @@ -190,9 +190,14 @@ int32_t tud_msc_read10_cb(uint8_t lun, uint32_t lba, uint32_t offset, void* buff | ||||
|   (void) lun; | ||||
|  | ||||
|   // out of ramdisk | ||||
|   if ( lba >= DISK_BLOCK_NUM ) return -1; | ||||
|   if ( lba >= DISK_BLOCK_NUM ) { | ||||
|     return -1; | ||||
|   } | ||||
|  | ||||
|   // Check for overflow of offset + bufsize | ||||
|   if ( offset + bufsize >= DISK_BLOCK_SIZE ) return -1; | ||||
|   if ( offset + bufsize > DISK_BLOCK_SIZE ) { | ||||
|     return -1; | ||||
|   } | ||||
|  | ||||
|   uint8_t const* addr = msc_disk[lba] + offset; | ||||
|   memcpy(buffer, addr, bufsize); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Ha Thach
					Ha Thach