Blue Swirl
9a975d6356
esp: avoid structure holes spotted by pahole
Report from pahole on amd64 host:
struct ESPState {
SysBusDevice busdev; /* 0 5648 */
/* --- cacheline 88 boundary (5632 bytes) was 16 bytes ago --- */
uint32_t it_shift; /* 5648 4 */
/* XXX 4 bytes hole, try to pack */
qemu_irq irq; /* 5656 8 */
uint8_t rregs[16]; /* 5664 16 */
uint8_t wregs[16]; /* 5680 16 */
/* --- cacheline 89 boundary (5696 bytes) --- */
int32_t ti_size; /* 5696 4 */
uint32_t ti_rptr; /* 5700 4 */
uint32_t ti_wptr; /* 5704 4 */
uint8_t ti_buf[16]; /* 5708 16 */
uint32_t status; /* 5724 4 */
uint32_t dma; /* 5728 4 */
/* XXX 4 bytes hole, try to pack */
SCSIBus bus; /* 5736 2120 */
/* --- cacheline 122 boundary (7808 bytes) was 48 bytes ago --- */
SCSIDevice * current_dev; /* 7856 8 */
SCSIRequest * current_req; /* 7864 8 */
/* --- cacheline 123 boundary (7872 bytes) --- */
uint8_t cmdbuf[16]; /* 7872 16 */
uint32_t cmdlen; /* 7888 4 */
uint32_t do_cmd; /* 7892 4 */
uint32_t dma_left; /* 7896 4 */
uint32_t dma_counter; /* 7900 4 */
uint8_t * async_buf; /* 7904 8 */
uint32_t async_len; /* 7912 4 */
/* XXX 4 bytes hole, try to pack */
ESPDMAMemoryReadWriteFunc dma_memory_read; /* 7920 8 */
ESPDMAMemoryReadWriteFunc dma_memory_write; /* 7928 8 */
/* --- cacheline 124 boundary (7936 bytes) --- */
void * dma_opaque; /* 7936 8 */
int dma_enabled; /* 7944 4 */
/* XXX 4 bytes hole, try to pack */
void (*dma_cb)(ESPState *); /* 7952 8 */
/* size: 7960, cachelines: 125 */
/* sum members: 7944, holes: 4, sum holes: 16 */
/* last cacheline: 24 bytes */
}; /* definitions: 1 */
Fix by rearranging the structure to avoid padding.
Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
2011-08-21 19:52:36 +00:00
..
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-07-23 11:26:12 -05:00
2011-08-08 10:22:30 -05:00
2011-07-23 11:26:06 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-07-23 11:26:12 -05:00
2011-08-08 10:15:53 -05:00
2011-08-20 23:01:08 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-08-20 23:01:08 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-06-24 09:13:37 +01:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-07-24 14:48:57 +00:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:15:53 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-07-23 11:26:12 -05:00
2011-08-20 23:01:08 -05:00
2011-08-11 11:12:16 +02:00
2011-08-08 10:22:29 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-08-08 10:22:30 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:30 -05:00
2011-08-08 10:22:29 -05:00
2011-08-08 10:22:29 -05:00
2011-08-21 19:52:36 +00:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-11 12:02:30 +02:00
2011-08-11 11:12:16 +02:00
2011-07-30 06:42:16 +02:00
2011-07-04 22:12:21 +02:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:15:53 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:15:53 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-10 14:14:00 +02:00
2011-08-10 14:14:00 +02:00
2011-07-12 20:00:26 +00:00
2011-08-10 14:14:00 +02:00
2011-07-23 11:26:12 -05:00
2011-07-30 06:00:42 +02:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:29 -05:00
2011-07-23 11:26:12 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:30 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-05 12:04:27 -03:00
2011-06-26 17:35:47 +00:00
2011-07-23 11:26:12 -05:00
2011-08-09 08:57:21 +02:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-06-24 09:13:37 +01:00
2011-06-24 09:13:37 +01:00
2011-06-24 09:13:37 +01:00
2011-07-30 06:00:42 +02:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:29 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:30 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-06-24 09:13:37 +01:00
2011-06-24 09:13:37 +01:00
2011-06-24 09:13:36 +01:00
2011-06-24 09:13:36 +01:00
2011-08-10 14:14:00 +02:00
2011-06-24 09:13:37 +01:00
2011-06-24 09:13:36 +01:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-07-20 20:54:51 +00:00
2011-08-20 23:01:08 -05:00
2011-07-23 11:26:12 -05:00
2011-07-12 20:00:28 +00:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:30 -05:00
2011-08-20 23:01:08 -05:00
2011-07-23 11:18:57 -05:00
2011-08-20 23:01:08 -05:00
2011-07-23 11:26:12 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:29 -05:00
2011-08-08 10:22:30 -05:00
2011-08-08 10:22:29 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:29 -05:00
2011-07-30 06:00:40 +02:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:15:53 -05:00
2011-07-27 10:57:22 +03:00
2011-08-04 17:15:22 -05:00
2011-07-19 08:03:20 -05:00
2011-08-08 10:15:53 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:30 -05:00
2011-08-20 23:01:08 -05:00
2011-07-29 08:01:52 +03:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:30 -05:00
2011-08-08 10:22:29 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:15:53 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:29 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:15:53 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:15:53 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-08-20 23:01:08 -05:00
2011-07-23 11:26:12 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-07-04 15:35:12 +02:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:15:52 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-08-20 23:01:08 -05:00
2011-07-12 20:00:32 +00:00
2011-07-05 11:23:29 +02:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-12 08:31:28 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-12 08:31:28 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:15:53 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-21 19:52:31 +00:00
2011-08-21 19:52:29 +00:00
2011-08-21 19:52:27 +00:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-08-20 23:01:08 -05:00
2011-07-30 09:41:14 +00:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-07-12 20:00:33 +00:00
2011-07-30 06:21:31 +02:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-07-23 11:26:12 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-21 19:52:32 +00:00
2011-08-21 19:52:35 +00:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-07-29 08:25:44 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-21 19:52:33 +00:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:15:53 -05:00
2011-08-04 15:51:22 +02:00
2011-08-20 23:01:08 -05:00
2011-08-04 15:51:22 +02:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-10 14:14:00 +02:00
2011-08-04 15:51:22 +02:00
2011-08-04 15:51:22 +02:00
2011-08-12 08:27:37 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:30 -05:00
2011-08-04 15:51:29 +02:00
2011-08-20 23:01:08 -05:00
2011-08-04 15:51:22 +02:00
2011-08-04 15:51:22 +02:00
2011-08-10 14:14:00 +02:00
2011-08-08 10:15:53 -05:00
2011-07-23 11:26:12 -05:00
2011-08-08 10:15:53 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:15:52 -05:00
2011-08-08 10:22:30 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-04 16:43:10 -05:00
2011-08-20 23:01:08 -05:00
2011-07-05 11:23:29 +02:00
2011-07-23 11:20:41 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:30 -05:00
2011-08-08 10:22:30 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-04 16:43:10 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:30 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-07-17 01:54:25 +02:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-08 10:22:30 -05:00
2011-07-26 06:43:11 +02:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-08-20 23:01:08 -05:00
2011-07-30 07:08:30 +02:00