On Wed, 17 Dec 2014 10:40:46 +0100
Greg Kurz <gk...@linux.vnet.ibm.com> wrote:
> Hi,
> 
> This series addresses remarks from Ben and Michael (see individual patches).
> The most notable changes are:
> - the parsing code being pull out into a separate file in patch 3/4. This
>   allows to write userland tests like the one below.
> - a full rewrite of the parsing logic in patch 4/4
> 

Ping ?

> --
> #include <stdio.h>
> #include <byteswap.h>
> 
> typedef unsigned long u64;
> typedef unsigned int u32;
> typedef unsigned short u16;
> typedef enum { false = 0, true } bool;
> 
> #if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
> #define cpu_to_be32(x)                bswap_32(x)
> #define be32_to_cpu(x)                bswap_32(x)
> #define be16_to_cpup(x)               bswap_16(*x)
> #define cpu_to_be64(x)                bswap_64(x)
> #else
> #define cpu_to_be32(x)                (x)
> #define be32_to_cpu(x)                (x)
> #define be16_to_cpup(x)               (*x)
> #define cpu_to_be64(x)                (x)
> #endif
> 
> #define pr_debug(...) printf(__VA_ARGS__)
> 
> #include "vphn.c"
> 
> void print_packed(const long *packed)
> {
>       char *p = (char*) packed;
>       int i;
> 
>       printf("\nRegisters:\n");
>       for (i = 0; i < VPHN_REGISTER_COUNT; i++)
>               printf("0x%016lx\n", packed[i]);
> 
>       printf("\nMemory layout:\n");
>       for (i = 0; i < 6; i++) {
>               printf("0x %02hhx %02hhx %02hhx %02hhx"
>                      " %02hhx %02hhx %02hhx %02hhx\n",
>                      *(p + 0), *(p + 1), *(p + 2), *(p + 3),
>                      *(p + 4), *(p + 5), *(p + 6), *(p + 7));
>               p += 8;
>       }
> 
>       putchar('\n');
> }
> 
> void print_unpacked(const __be32 *unpacked)
> {
>       int i;
> 
>       printf("\nVPHN associativity:\n");
>       for (i = 0; i <= be32_to_cpu(unpacked[0]); i++)
>               printf("0x%08x\n", be32_to_cpu(unpacked[i]));
> 
>       putchar('\n');
> }
> 
> int main(int argc, char **argv)
> {
>       int i;
>       struct {
>               const char *descr;
>               long packed[VPHN_REGISTER_COUNT];
>       } data[] = {
>               {
>                       "16-bit and 32-bit",
>                       0x8001800280038004,
>                       0x8005800680078008,
>                       0x000000090000000a,
>                       0x0000000b0000000c,
>                       0xffffffffffffffff,
>                       0xffffffffffffffff
>               },
>               {
>                       "filled with 16-bit",
>                       0x8001800280038004,
>                       0x8005800680078008,
>                       0x8009800a800b800c,
>                       0x800d800e800f8010,
>                       0x8011801280138014,
>                       0x8015801680178018,
>               },
>               {
>                       "filled with 32-bit",
>                       0x0000000100000002,
>                       0x0000000300000004,
>                       0x0000000500000006,
>                       0x0000000700000008,
>                       0x000000090000000a,
>                       0x0000000b0000000c,
>               },
>               {
>                       "32-bit has all ones in 16 lower bits",
>                       0x0001ffff80028003,
>                       0xffffffffffffffff,
>                       0xffffffffffffffff,
>                       0xffffffffffffffff,
>                       0xffffffffffffffff,
>                       0xffffffffffffffff,
>               },
>               {
>                       "32-bit accross two 64-bit registers",
>                       0x8001000000020000,
>                       0x0003000000048005,
>                       0xffffffffffffffff,
>                       0xffffffffffffffff,
>                       0xffffffffffffffff,
>                       0xffffffffffffffff,
>               },
>               {
>                       "Truncated last 32-bit",
>                       0x0000000100000002,
>                       0x0000000300000004,
>                       0x0000000500000006,
>                       0x0000000700000008,
>                       0x000000090000000a,
>                       0x0000000b800c0bad,
>               },
>       };
> 
>       for (i = 0; i < sizeof(data) / sizeof(data[0]); i++) {
>               __be32 unpacked[VPHN_ASSOC_BUFSIZE] = { 0 };
>               
> printf("\n==================================================\n");
>               printf("\nSet #%d: %s\n", i, data[i].descr);
>               
> printf("\n==================================================\n");
>               print_packed(data[i].packed);
>               vphn_unpack_associativity(data[i].packed, unpacked);
>               print_unpacked(unpacked);
>       }
> 
>       return 0;
> }
> 
> ---
> 
> Greg Kurz (4):
>       powerpc/vphn: clarify the H_HOME_NODE_ASSOCIATIVITY API
>       powerpc/vphn: move endianness fixing to vphn_unpack_associativity()
>       powerpc/vphn: move VPHN parsing logic to a separate file
>       powerpc/vphn: parsing code rewrite
> 
> 
>  arch/powerpc/mm/Makefile |    1 +
>  arch/powerpc/mm/numa.c   |   55 ++----------------------------------
>  arch/powerpc/mm/vphn.c   |   70 
> ++++++++++++++++++++++++++++++++++++++++++++++
>  arch/powerpc/mm/vphn.h   |   16 +++++++++++
>  4 files changed, 90 insertions(+), 52 deletions(-)
>  create mode 100644 arch/powerpc/mm/vphn.c
>  create mode 100644 arch/powerpc/mm/vphn.h
> 
> --
> Greg
> 
> _______________________________________________
> Linuxppc-dev mailing list
> Linuxppc-dev@lists.ozlabs.org
> https://lists.ozlabs.org/listinfo/linuxppc-dev

_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to