vmstate: Fix varrays with uint8 indexes
Signed-off-by: Juan Quintela <quintela@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
		
							parent
							
								
									9122a8fed7
								
							
						
					
					
						commit
						82fa39b751
					
				
							
								
								
									
										3
									
								
								hw/hw.h
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								hw/hw.h
									
									
									
									
									
								
							@ -298,6 +298,7 @@ enum VMStateFlags {
 | 
			
		||||
    VMS_VARRAY_UINT16    = 0x080,  /* Array with size in uint16_t field */
 | 
			
		||||
    VMS_VBUFFER          = 0x100,  /* Buffer with size in int32_t field */
 | 
			
		||||
    VMS_MULTIPLY         = 0x200,  /* multiply "size" field by field_size */
 | 
			
		||||
    VMS_VARRAY_UINT8     = 0x400,  /* Array with size in uint8_t field*/
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
typedef struct {
 | 
			
		||||
@ -493,7 +494,7 @@ extern const VMStateInfo vmstate_info_unused_buffer;
 | 
			
		||||
    .version_id = (_version),                                        \
 | 
			
		||||
    .vmsd       = &(_vmsd),                                          \
 | 
			
		||||
    .size       = sizeof(_type),                                     \
 | 
			
		||||
    .flags      = VMS_STRUCT|VMS_VARRAY_INT32,                       \
 | 
			
		||||
    .flags      = VMS_STRUCT|VMS_VARRAY_UINT8,                       \
 | 
			
		||||
    .offset     = offsetof(_state, _field),                          \
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										2
									
								
								savevm.c
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								savevm.c
									
									
									
									
									
								
							@ -1331,6 +1331,8 @@ int vmstate_load_state(QEMUFile *f, const VMStateDescription *vmsd,
 | 
			
		||||
                n_elems = *(int32_t *)(opaque+field->num_offset);
 | 
			
		||||
            } else if (field->flags & VMS_VARRAY_UINT16) {
 | 
			
		||||
                n_elems = *(uint16_t *)(opaque+field->num_offset);
 | 
			
		||||
            } else if (field->flags & VMS_VARRAY_UINT8) {
 | 
			
		||||
                n_elems = *(uint8_t *)(opaque+field->num_offset);
 | 
			
		||||
            }
 | 
			
		||||
            if (field->flags & VMS_POINTER) {
 | 
			
		||||
                base_addr = *(void **)base_addr + field->start;
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user