On (03/10/08 18:37), Andy Whitcroft didst pronounce: > Expose possible page sizes. Expose the page sizes which are available > (have pages assigned to them) via --page-sizes. Expose all possible page > sizes (supported by the processor) via --page-sizes-all. > > Signed-off-by: Andy Whitcroft <[EMAIL PROTECTED]> > --- > hpoolcfg.c | 40 ++++++++++++++++++++++++++++++++++++++-- > 1 files changed, 38 insertions(+), 2 deletions(-) > > diff --git a/hpoolcfg.c b/hpoolcfg.c > index 46e8de4..e9ac665 100644 > --- a/hpoolcfg.c > +++ b/hpoolcfg.c > @@ -50,6 +50,9 @@ void print_usage() > > OPTION("--pool-list", "List all pools"); > > + OPTION("--page-sizes", "List all available page sizes"); > + OPTION("--page-sizes-all", "List all supported page sizes"); > + > OPTION("--help, -h", "Prints this message"); > } > > @@ -61,6 +64,10 @@ int opt_dry_run = 0; > #define LONG_POOL ('p' << 8) > #define LONG_POOL_LIST (LONG_POOL|'l') > > +#define LONG_PAGE ('P' << 8) > +#define LONG_PAGE_SIZES (LONG_PAGE|'s') > +#define LONG_PAGE_AVAIL (LONG_PAGE|'a') > + > #define MAX_POOLS 32 > void pool_list(void) > { > @@ -74,14 +81,32 @@ void pool_list(void) > exit(EXIT_FAILURE); > } > > - printf("%10s %8s %8s %8s\n", "Size", "Minimum", "Current", "Maximum"); > + printf("%10s %8s %8s %8s\n", "Size", "Minimum", "Current", "Maximum"); > for (pos = 0; cnt--; pos++) { > - printf("%10ldkB %8ld %8ld %8ld\n", pools[pos].pagesize_kb, > + printf("%10ld %8ld %8ld %8ld\n", pools[pos].pagesize_kb, > pools[pos].minimum, pools[pos].size, > pools[pos].maximum); > }
Does this hunk belong in the previous patch? > } > > +void page_sizes(int all) > +{ > + struct hpage_pool pools[MAX_POOLS]; > + int pos; > + int cnt; > + > + cnt = __lh_hpool_sizes(pools, MAX_POOLS); > + if (cnt < 0) { > + ERROR("unable to obtain pools list"); > + exit(EXIT_FAILURE); > + } > + > + for (pos = 0; cnt--; pos++) { > + if (all || pools[pos].maximum) > + printf("%ld\n", pools[pos].pagesize_kb); > + } > +} Ok, so the definition of available page sizes is that a pool has been configured. Is this intentional? Maybe the description of the options should be --page-sizes Display page sizes that have a configured pool --page-sizes-all Display page sizes supported by the hardware ? I also wonder if the display of pagesizes belongs in a separate pagesize utility similar to what is available on other operating systems. > + > int main(int argc, char** argv) > { > char opts[] = "+h"; > @@ -91,6 +116,9 @@ int main(int argc, char** argv) > > {"pool-list", no_argument, NULL, LONG_POOL_LIST}, > > + {"page-sizes", no_argument, NULL, LONG_PAGE_SIZES}, > + {"page-sizes-all", no_argument, NULL, LONG_PAGE_AVAIL}, > + > {0}, > }; > > @@ -114,6 +142,14 @@ int main(int argc, char** argv) > pool_list(); > break; > > + case LONG_PAGE_SIZES: > + page_sizes(0); > + break; > + > + case LONG_PAGE_AVAIL: > + page_sizes(1); > + break; > + > default: > WARNING("unparsed option %08x\n", ret); > ret = -1; > -- > 1.6.0.1.451.gc8d31 > -- Mel Gorman Part-time Phd Student Linux Technology Center University of Limerick IBM Dublin Software Lab ------------------------------------------------------------------------- This SF.Net email is sponsored by the Moblin Your Move Developer's challenge Build the coolest Linux based applications with Moblin SDK & win great prizes Grand prize is a trip for two to an Open Source event anywhere in the world http://moblin-contest.org/redirect.php?banner_id=100&url=/ _______________________________________________ Libhugetlbfs-devel mailing list Libhugetlbfs-devel@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/libhugetlbfs-devel