On Fri, Oct 1, 2010 at 1:00 PM, Svatopluk Kraus <onw...@gmail.com> wrote:
> Hallo,
>
>  a size of 'struct vpglocks' is padded to CACHE_LINE_SIZE size in
> 'sys/vm/vm_page.h'
> header file. I work on a 'coldfire' port where CACHE_LINE_SIZE is 16 bytes and
> sizeof(struct mtx) is 20 bytes thus size alignment doesn't work.
>
>  I solved it somehow, but I like to learn how to solve it in spirit
> of FreeBSD.
> There are a couple of possibilities:
>
> A1. Do nothing for small CACHE_LINE_SIZE.
> A2. Pad to multiple of CACHE_LINE_SIZE.
>
> B1. use #if with CACHE_LINE_SIZE
> B2. use #if with __coldfire__
>
> When I use B1 solution I need to known sizeof(struct mtx) value in
> preprocessing time.
> So, is it correct to use something like 'assym.s' magic
> (sys/i386/i386/genassym.c)
> in MI code? Or has someone another suggestion?

What about padding to CACHE_LINE_SIZE - (sizeof(struct vpglocks) &
(CACHE_LINE_SIZE-1)) ?

Some compilers will complain about 0-sized arrays, but gcc isn't one of them.

Cheers,
matthew
_______________________________________________
freebsd-current@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-current
To unsubscribe, send any mail to "freebsd-current-unsubscr...@freebsd.org"

Reply via email to