Alexey Kardashevskiy <a...@ozlabs.ru> writes: > Every caller of SLOF_alloc_mem_aligned() assumes the size is the first > argument while it is not. > > This switches align and size and fixes random memory corruptions. > > This is grep for SLOF_alloc_mem_aligned with this patch applied: > > include/helpers.h|27| extern void *SLOF_alloc_mem_aligned(long size, long > align); > lib/libveth/veth.c|103| buffer_list = SLOF_alloc_mem_aligned(8192, 4096); > lib/libveth/veth.c|105| rx_queue = SLOF_alloc_mem_aligned(rx_queue_len, 16); > lib/libvirtio/virtio-net.c|101| vq[i].desc = > SLOF_alloc_mem_aligned(virtio_vring_size(vq[i].size), 4096); > slof/helpers.c|70| void *SLOF_alloc_mem_aligned(long size, long align) > > Signed-off-by: Alexey Kardashevskiy <a...@ozlabs.ru>
Reviewed-by: Nikunj A Dadhania <nik...@linux.vnet.ibm.com> > --- > include/helpers.h | 2 +- > slof/helpers.c | 2 +- > 2 files changed, 2 insertions(+), 2 deletions(-) > > diff --git a/include/helpers.h b/include/helpers.h > index f6d4375..fb10534 100644 > --- a/include/helpers.h > +++ b/include/helpers.h > @@ -24,7 +24,7 @@ extern void SLOF_usleep(uint32_t time); > extern void *SLOF_dma_alloc(long size); > extern void SLOF_dma_free(void *virt, long size); > extern void *SLOF_alloc_mem(long size); > -extern void *SLOF_alloc_mem_aligned(long align, long size); > +extern void *SLOF_alloc_mem_aligned(long size, long align); > extern void SLOF_free_mem(void *addr, long size); > extern long SLOF_dma_map_in(void *virt, long size, int cacheable); > extern void SLOF_dma_map_out(long phys, void *virt, long size); > diff --git a/slof/helpers.c b/slof/helpers.c > index c582996..d7c1888 100644 > --- a/slof/helpers.c > +++ b/slof/helpers.c > @@ -67,7 +67,7 @@ void *SLOF_alloc_mem(long size) > return (void *)forth_pop(); > } > > -void *SLOF_alloc_mem_aligned(long align, long size) > +void *SLOF_alloc_mem_aligned(long size, long align) > { > unsigned long addr = (unsigned long)SLOF_alloc_mem(size + align - 1); > addr = addr + align - 1; > -- > 2.0.0 _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev