Fix error code checking for SetFilePointer() call
An error has occurred if the return value is invalid_set_file_pointer and getlasterror doesn't return no_error. Signed-off-by: Fabien Chouteau <chouteau@adacore.com> Acked-by: Stefan Hajnoczi <stefanha@redhat.com>
This commit is contained in:
		
							parent
							
								
									473c7f0255
								
							
						
					
					
						commit
						fbcad04d6b
					
				| @ -303,13 +303,24 @@ static int raw_truncate(BlockDriverState *bs, int64_t offset) | |||||||
| { | { | ||||||
|     BDRVRawState *s = bs->opaque; |     BDRVRawState *s = bs->opaque; | ||||||
|     LONG low, high; |     LONG low, high; | ||||||
|  |     DWORD dwPtrLow; | ||||||
| 
 | 
 | ||||||
|     low = offset; |     low = offset; | ||||||
|     high = offset >> 32; |     high = offset >> 32; | ||||||
|     if (!SetFilePointer(s->hfile, low, &high, FILE_BEGIN)) | 
 | ||||||
| 	return -EIO; |     /*
 | ||||||
|     if (!SetEndOfFile(s->hfile)) |      * An error has occurred if the return value is INVALID_SET_FILE_POINTER | ||||||
|  |      * and GetLastError doesn't return NO_ERROR. | ||||||
|  |      */ | ||||||
|  |     dwPtrLow = SetFilePointer(s->hfile, low, &high, FILE_BEGIN); | ||||||
|  |     if (dwPtrLow == INVALID_SET_FILE_POINTER && GetLastError() != NO_ERROR) { | ||||||
|  |         fprintf(stderr, "SetFilePointer error: %d\n", GetLastError()); | ||||||
|         return -EIO; |         return -EIO; | ||||||
|  |     } | ||||||
|  |     if (SetEndOfFile(s->hfile) == 0) { | ||||||
|  |         fprintf(stderr, "SetEndOfFile error: %d\n", GetLastError()); | ||||||
|  |         return -EIO; | ||||||
|  |     } | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Fabien Chouteau
						Fabien Chouteau