aboutsummaryrefslogtreecommitdiffstats
path: root/svm/svmtool.c
diff options
context:
space:
mode:
authorDave Barach <dave@barachs.net>2016-07-08 14:44:23 -0400
committerDave Barach <dave@barachs.net>2016-07-08 14:44:38 -0400
commit8a7fb0cf6844ed09173fd58224f7753a1b504cf4 (patch)
tree45e21bd6bac95034fd589daf0ea898c6ede80afa /svm/svmtool.c
parent49a6963b1387bf7535f589f02ffc99de5b59192f (diff)
fd-io-styleify for svm
Change-Id: I816de8b1f255dc3bc6d2904566ea0b0f68fac5d8 Signed-off-by: Dave Barach <dave@barachs.net>
Diffstat (limited to 'svm/svmtool.c')
-rw-r--r--svm/svmtool.c722
1 files changed, 392 insertions, 330 deletions
diff --git a/svm/svmtool.c b/svm/svmtool.c
index e87746110ae..c37afbd152c 100644
--- a/svm/svmtool.c
+++ b/svm/svmtool.c
@@ -1,6 +1,6 @@
-/*
+/*
*------------------------------------------------------------------
- * svmtool.c
+ * svmtool.c
*
* Copyright (c) 2009 Cisco and/or its affiliates.
* Licensed under the Apache License, Version 2.0 (the "License");
@@ -48,417 +48,479 @@
* format_all_svm_regions
* Maps / unmaps regions. Do NOT call from client code!
*/
-u8 *format_all_svm_regions (u8 *s, va_list * args)
+u8 *
+format_all_svm_regions (u8 * s, va_list * args)
{
- int verbose = va_arg (*args, int);
- svm_region_t *root_rp = svm_get_root_rp();
- svm_main_region_t *mp;
- svm_subregion_t *subp;
- svm_region_t *rp;
- svm_map_region_args_t *a = 0;
- u8 ** svm_names=0;
- u8 *name=0;
- int i;
-
- ASSERT(root_rp);
-
- pthread_mutex_lock (&root_rp->mutex);
-
- s = format (s, "%U", format_svm_region, root_rp, verbose);
-
- mp = root_rp->data_base;
-
- /*
- * Snapshoot names, can't hold root rp mutex across
- * find_or_create.
- */
- pool_foreach (subp, mp->subregions, ({
- name = vec_dup (subp->subregion_name);
- vec_add1(svm_names, name);
- }));
-
- pthread_mutex_unlock (&root_rp->mutex);
-
- for (i = 0; i < vec_len(svm_names); i++) {
- vec_validate(a, 0);
- a->name = (char *) svm_names[i];
- rp = svm_region_find_or_create (a);
- if (rp) {
- pthread_mutex_lock (&rp->mutex);
- s = format (s, "%U", format_svm_region, rp, verbose);
- pthread_mutex_unlock (&rp->mutex);
- svm_region_unmap (rp);
- vec_free(svm_names[i]);
- }
- vec_free (a);
+ int verbose = va_arg (*args, int);
+ svm_region_t *root_rp = svm_get_root_rp ();
+ svm_main_region_t *mp;
+ svm_subregion_t *subp;
+ svm_region_t *rp;
+ svm_map_region_args_t *a = 0;
+ u8 **svm_names = 0;
+ u8 *name = 0;
+ int i;
+
+ ASSERT (root_rp);
+
+ pthread_mutex_lock (&root_rp->mutex);
+
+ s = format (s, "%U", format_svm_region, root_rp, verbose);
+
+ mp = root_rp->data_base;
+
+ /*
+ * Snapshoot names, can't hold root rp mutex across
+ * find_or_create.
+ */
+ /* *INDENT-OFF* */
+ pool_foreach (subp, mp->subregions, ({
+ name = vec_dup (subp->subregion_name);
+ vec_add1(svm_names, name);
+ }));
+ /* *INDENT-ON* */
+
+ pthread_mutex_unlock (&root_rp->mutex);
+
+ for (i = 0; i < vec_len (svm_names); i++)
+ {
+ vec_validate (a, 0);
+ a->name = (char *) svm_names[i];
+ rp = svm_region_find_or_create (a);
+ if (rp)
+ {
+ pthread_mutex_lock (&rp->mutex);
+ s = format (s, "%U", format_svm_region, rp, verbose);
+ pthread_mutex_unlock (&rp->mutex);
+ svm_region_unmap (rp);
+ vec_free (svm_names[i]);
+ }
+ vec_free (a);
}
- vec_free(svm_names);
- return (s);
+ vec_free (svm_names);
+ return (s);
}
-void show (char *chroot_path, int verbose)
+void
+show (char *chroot_path, int verbose)
{
- svm_map_region_args_t *a = 0;
+ svm_map_region_args_t *a = 0;
- vec_validate (a, 0);
+ vec_validate (a, 0);
- svm_region_init_chroot(chroot_path);
+ svm_region_init_chroot (chroot_path);
- fformat(stdout, "My pid is %d\n", getpid());
+ fformat (stdout, "My pid is %d\n", getpid ());
- fformat(stdout, "%U", format_all_svm_regions, verbose);
+ fformat (stdout, "%U", format_all_svm_regions, verbose);
- svm_region_exit ();
+ svm_region_exit ();
- vec_free (a);
+ vec_free (a);
}
-static void *svm_map_region_nolock (svm_map_region_args_t *a)
+static void *
+svm_map_region_nolock (svm_map_region_args_t * a)
{
- int svm_fd;
- svm_region_t *rp;
- int deadman=0;
- u8 *shm_name;
+ int svm_fd;
+ svm_region_t *rp;
+ int deadman = 0;
+ u8 *shm_name;
- ASSERT((a->size & ~(MMAP_PAGESIZE-1)) == a->size);
+ ASSERT ((a->size & ~(MMAP_PAGESIZE - 1)) == a->size);
- shm_name = shm_name_from_svm_map_region_args (a);
+ shm_name = shm_name_from_svm_map_region_args (a);
- svm_fd = shm_open((char *)shm_name, O_RDWR, 0777);
+ svm_fd = shm_open ((char *) shm_name, O_RDWR, 0777);
- if (svm_fd < 0) {
- perror("svm_region_map(mmap open)");
- return (0);
+ if (svm_fd < 0)
+ {
+ perror ("svm_region_map(mmap open)");
+ return (0);
}
- vec_free (shm_name);
-
- rp = mmap(0, MMAP_PAGESIZE,
- PROT_READ | PROT_WRITE, MAP_SHARED, svm_fd, 0);
-
- if (rp == (svm_region_t *) MAP_FAILED) {
- close(svm_fd);
- clib_warning("mmap");
- return (0);
+ vec_free (shm_name);
+
+ rp = mmap (0, MMAP_PAGESIZE, PROT_READ | PROT_WRITE, MAP_SHARED, svm_fd, 0);
+
+ if (rp == (svm_region_t *) MAP_FAILED)
+ {
+ close (svm_fd);
+ clib_warning ("mmap");
+ return (0);
}
- /*
- * We lost the footrace to create this region; make sure
- * the winner has crossed the finish line.
- */
- while (rp->version == 0 && deadman++ < 5) {
- sleep(1);
+ /*
+ * We lost the footrace to create this region; make sure
+ * the winner has crossed the finish line.
+ */
+ while (rp->version == 0 && deadman++ < 5)
+ {
+ sleep (1);
}
- /*
- * <bleep>-ed?
- */
- if (rp->version == 0) {
- clib_warning("rp->version %d not %d", rp->version,
- SVM_VERSION);
- return (0);
- }
- /* Remap now that the region has been placed */
- a->baseva = rp->virtual_base;
- a->size = rp->virtual_size;
- munmap(rp, MMAP_PAGESIZE);
-
- rp = (void *) mmap ((void *)a->baseva, a->size,
- PROT_READ | PROT_WRITE,
- MAP_SHARED | MAP_FIXED, svm_fd, 0);
- if ((uword)rp == (uword)MAP_FAILED) {
- clib_unix_warning ("mmap");
- return (0);
+ /*
+ * <bleep>-ed?
+ */
+ if (rp->version == 0)
+ {
+ clib_warning ("rp->version %d not %d", rp->version, SVM_VERSION);
+ return (0);
}
-
- if ((uword) rp != rp->virtual_base) {
- clib_warning("mmap botch");
+ /* Remap now that the region has been placed */
+ a->baseva = rp->virtual_base;
+ a->size = rp->virtual_size;
+ munmap (rp, MMAP_PAGESIZE);
+
+ rp = (void *) mmap ((void *) a->baseva, a->size,
+ PROT_READ | PROT_WRITE,
+ MAP_SHARED | MAP_FIXED, svm_fd, 0);
+ if ((uword) rp == (uword) MAP_FAILED)
+ {
+ clib_unix_warning ("mmap");
+ return (0);
}
-
- if (pthread_mutex_trylock(&rp->mutex)) {
- clib_warning ("rp->mutex LOCKED by pid %d, tag %d, cleared...",
- rp->mutex_owner_pid, rp->mutex_owner_tag);
- memset(&rp->mutex, 0, sizeof (rp->mutex));
-
- } else {
- clib_warning ("mutex OK...\n");
- pthread_mutex_unlock(&rp->mutex);
+
+ if ((uword) rp != rp->virtual_base)
+ {
+ clib_warning ("mmap botch");
}
- return ((void *) rp);
+ if (pthread_mutex_trylock (&rp->mutex))
+ {
+ clib_warning ("rp->mutex LOCKED by pid %d, tag %d, cleared...",
+ rp->mutex_owner_pid, rp->mutex_owner_tag);
+ memset (&rp->mutex, 0, sizeof (rp->mutex));
+
+ }
+ else
+ {
+ clib_warning ("mutex OK...\n");
+ pthread_mutex_unlock (&rp->mutex);
+ }
+
+ return ((void *) rp);
}
/*
* rnd_pagesize
* Round to a pagesize multiple, presumably 4k works
*/
-static unsigned int rnd_pagesize(unsigned int size)
+static unsigned int
+rnd_pagesize (unsigned int size)
{
- unsigned int rv;
+ unsigned int rv;
- rv = (size + (MMAP_PAGESIZE-1)) & ~(MMAP_PAGESIZE-1);
- return(rv);
+ rv = (size + (MMAP_PAGESIZE - 1)) & ~(MMAP_PAGESIZE - 1);
+ return (rv);
}
#define MUTEX_DEBUG
-always_inline void region_lock(svm_region_t *rp, int tag)
+always_inline void
+region_lock (svm_region_t * rp, int tag)
{
- pthread_mutex_lock(&rp->mutex);
+ pthread_mutex_lock (&rp->mutex);
#ifdef MUTEX_DEBUG
- rp->mutex_owner_pid = getpid();
- rp->mutex_owner_tag = tag;
-#endif
+ rp->mutex_owner_pid = getpid ();
+ rp->mutex_owner_tag = tag;
+#endif
}
-always_inline void region_unlock(svm_region_t *rp)
+always_inline void
+region_unlock (svm_region_t * rp)
{
#ifdef MUTEX_DEBUG
- rp->mutex_owner_pid = 0;
- rp->mutex_owner_tag = 0;
-#endif
- pthread_mutex_unlock(&rp->mutex);
+ rp->mutex_owner_pid = 0;
+ rp->mutex_owner_tag = 0;
+#endif
+ pthread_mutex_unlock (&rp->mutex);
}
-static void *svm_existing_region_map_nolock (void *root_arg,
- svm_map_region_args_t *a)
+static void *
+svm_existing_region_map_nolock (void *root_arg, svm_map_region_args_t * a)
{
- svm_region_t *root_rp = root_arg;
- svm_main_region_t *mp;
- svm_region_t *rp;
- void *oldheap;
- uword *p;
-
- a->size += MMAP_PAGESIZE + SVM_PVT_MHEAP_SIZE;
- a->size = rnd_pagesize(a->size);
-
- region_lock (root_rp, 4);
- oldheap = svm_push_pvt_heap(root_rp);
- mp = root_rp->data_base;
-
- ASSERT(mp);
-
- p = hash_get_mem (mp->name_hash, a->name);
-
- if (p) {
- rp = svm_map_region_nolock (a);
- region_unlock(root_rp);
- svm_pop_heap (oldheap);
- return rp;
+ svm_region_t *root_rp = root_arg;
+ svm_main_region_t *mp;
+ svm_region_t *rp;
+ void *oldheap;
+ uword *p;
+
+ a->size += MMAP_PAGESIZE + SVM_PVT_MHEAP_SIZE;
+ a->size = rnd_pagesize (a->size);
+
+ region_lock (root_rp, 4);
+ oldheap = svm_push_pvt_heap (root_rp);
+ mp = root_rp->data_base;
+
+ ASSERT (mp);
+
+ p = hash_get_mem (mp->name_hash, a->name);
+
+ if (p)
+ {
+ rp = svm_map_region_nolock (a);
+ region_unlock (root_rp);
+ svm_pop_heap (oldheap);
+ return rp;
}
- return 0;
+ return 0;
}
-static void trace (char *chroot_path, char *name, int enable_disable)
+static void
+trace (char *chroot_path, char *name, int enable_disable)
{
- svm_map_region_args_t *a = 0;
- svm_region_t *db_rp;
- void *oldheap;
-
- vec_validate (a, 0);
-
- svm_region_init_chroot(chroot_path);
-
- a->name = name;
- a->size = 1<<20;
- a->flags = SVM_FLAGS_MHEAP;
-
- db_rp = svm_region_find_or_create (a);
-
- ASSERT(db_rp);
-
- region_lock (db_rp, 20);
-
- oldheap = svm_push_data_heap (db_rp);
-
- mheap_trace (db_rp->data_heap, enable_disable);
-
- svm_pop_heap (oldheap);
- region_unlock (db_rp);
-
- svm_region_unmap ((void *)db_rp);
- svm_region_exit ();
- vec_free (a);
+ svm_map_region_args_t *a = 0;
+ svm_region_t *db_rp;
+ void *oldheap;
+
+ vec_validate (a, 0);
+
+ svm_region_init_chroot (chroot_path);
+
+ a->name = name;
+ a->size = 1 << 20;
+ a->flags = SVM_FLAGS_MHEAP;
+
+ db_rp = svm_region_find_or_create (a);
+
+ ASSERT (db_rp);
+
+ region_lock (db_rp, 20);
+
+ oldheap = svm_push_data_heap (db_rp);
+
+ mheap_trace (db_rp->data_heap, enable_disable);
+
+ svm_pop_heap (oldheap);
+ region_unlock (db_rp);
+
+ svm_region_unmap ((void *) db_rp);
+ svm_region_exit ();
+ vec_free (a);
}
-static void subregion_repair(char *chroot_path)
+static void
+subregion_repair (char *chroot_path)
{
- int i;
- svm_main_region_t *mp;
- svm_map_region_args_t a;
- svm_region_t *root_rp;
- svm_region_t *rp;
- svm_subregion_t *subp;
- u8 *name=0;
- u8 ** svm_names=0;
-
- svm_region_init_chroot(chroot_path);
- root_rp = svm_get_root_rp();
-
- pthread_mutex_lock (&root_rp->mutex);
-
- mp = root_rp->data_base;
-
- /*
- * Snapshoot names, can't hold root rp mutex across
- * find_or_create.
- */
- pool_foreach (subp, mp->subregions, ({
- name = vec_dup (subp->subregion_name);
- vec_add1(svm_names, name);
- }));
-
- pthread_mutex_unlock (&root_rp->mutex);
-
- for (i = 0; i < vec_len(svm_names); i++) {
- memset (&a, 0, sizeof (a));
- a.root_path = chroot_path;
- a.name = (char *) svm_names[i];
- fformat(stdout, "Checking %s region...\n",
- a.name);
- rp = svm_existing_region_map_nolock (root_rp, &a);
- if (rp) {
- svm_region_unmap (rp);
- vec_free(svm_names[i]);
- }
+ int i;
+ svm_main_region_t *mp;
+ svm_map_region_args_t a;
+ svm_region_t *root_rp;
+ svm_region_t *rp;
+ svm_subregion_t *subp;
+ u8 *name = 0;
+ u8 **svm_names = 0;
+
+ svm_region_init_chroot (chroot_path);
+ root_rp = svm_get_root_rp ();
+
+ pthread_mutex_lock (&root_rp->mutex);
+
+ mp = root_rp->data_base;
+
+ /*
+ * Snapshoot names, can't hold root rp mutex across
+ * find_or_create.
+ */
+ /* *INDENT-OFF* */
+ pool_foreach (subp, mp->subregions, ({
+ name = vec_dup (subp->subregion_name);
+ vec_add1(svm_names, name);
+ }));
+ /* *INDENT-ON* */
+
+ pthread_mutex_unlock (&root_rp->mutex);
+
+ for (i = 0; i < vec_len (svm_names); i++)
+ {
+ memset (&a, 0, sizeof (a));
+ a.root_path = chroot_path;
+ a.name = (char *) svm_names[i];
+ fformat (stdout, "Checking %s region...\n", a.name);
+ rp = svm_existing_region_map_nolock (root_rp, &a);
+ if (rp)
+ {
+ svm_region_unmap (rp);
+ vec_free (svm_names[i]);
+ }
}
- vec_free(svm_names);
+ vec_free (svm_names);
}
-void repair (char *chroot_path, int crash_root_region)
+void
+repair (char *chroot_path, int crash_root_region)
{
- svm_region_t *root_rp = 0;
- svm_map_region_args_t *a = 0;
- void *svm_map_region (svm_map_region_args_t *a);
- int svm_fd;
- u8 *shm_name;
+ svm_region_t *root_rp = 0;
+ svm_map_region_args_t *a = 0;
+ void *svm_map_region (svm_map_region_args_t * a);
+ int svm_fd;
+ u8 *shm_name;
- fformat(stdout, "our pid: %d\n", getpid());
+ fformat (stdout, "our pid: %d\n", getpid ());
- vec_validate (a, 0);
+ vec_validate (a, 0);
- a->root_path = chroot_path;
- a->name = SVM_GLOBAL_REGION_NAME;
- a->baseva = SVM_GLOBAL_REGION_BASEVA;
- a->size = SVM_GLOBAL_REGION_SIZE;
- a->flags = SVM_FLAGS_NODATA;
+ a->root_path = chroot_path;
+ a->name = SVM_GLOBAL_REGION_NAME;
+ a->baseva = SVM_GLOBAL_REGION_BASEVA;
+ a->size = SVM_GLOBAL_REGION_SIZE;
+ a->flags = SVM_FLAGS_NODATA;
- shm_name = shm_name_from_svm_map_region_args (a);
+ shm_name = shm_name_from_svm_map_region_args (a);
- svm_fd = shm_open ((char *)shm_name, O_RDWR, 0777);
+ svm_fd = shm_open ((char *) shm_name, O_RDWR, 0777);
- if (svm_fd < 0) {
- perror("svm_region_map(mmap open)");
- goto out;
+ if (svm_fd < 0)
+ {
+ perror ("svm_region_map(mmap open)");
+ goto out;
}
- vec_free(shm_name);
+ vec_free (shm_name);
- root_rp = mmap(0, MMAP_PAGESIZE,
- PROT_READ | PROT_WRITE, MAP_SHARED, svm_fd, 0);
-
- if (root_rp == (svm_region_t *) MAP_FAILED) {
- close(svm_fd);
- clib_warning("mmap");
- goto out;
+ root_rp = mmap (0, MMAP_PAGESIZE,
+ PROT_READ | PROT_WRITE, MAP_SHARED, svm_fd, 0);
+
+ if (root_rp == (svm_region_t *) MAP_FAILED)
+ {
+ close (svm_fd);
+ clib_warning ("mmap");
+ goto out;
}
-
- /* Remap now that the region has been placed */
- clib_warning ("remap to 0x%x", root_rp->virtual_base);
-
- a->baseva = root_rp->virtual_base;
- a->size = root_rp->virtual_size;
- munmap(root_rp, MMAP_PAGESIZE);
-
- root_rp = (void *) mmap ((void *)a->baseva, a->size,
- PROT_READ | PROT_WRITE,
- MAP_SHARED | MAP_FIXED, svm_fd, 0);
- if ((uword)root_rp == (uword)MAP_FAILED) {
- clib_unix_warning ("mmap");
- goto out;
+
+ /* Remap now that the region has been placed */
+ clib_warning ("remap to 0x%x", root_rp->virtual_base);
+
+ a->baseva = root_rp->virtual_base;
+ a->size = root_rp->virtual_size;
+ munmap (root_rp, MMAP_PAGESIZE);
+
+ root_rp = (void *) mmap ((void *) a->baseva, a->size,
+ PROT_READ | PROT_WRITE,
+ MAP_SHARED | MAP_FIXED, svm_fd, 0);
+ if ((uword) root_rp == (uword) MAP_FAILED)
+ {
+ clib_unix_warning ("mmap");
+ goto out;
}
-
- close(svm_fd);
- if ((uword) root_rp != root_rp->virtual_base) {
- clib_warning("mmap botch");
- goto out;
+ close (svm_fd);
+
+ if ((uword) root_rp != root_rp->virtual_base)
+ {
+ clib_warning ("mmap botch");
+ goto out;
+ }
+
+ if (pthread_mutex_trylock (&root_rp->mutex))
+ {
+ clib_warning ("root_rp->mutex LOCKED by pid %d, tag %d, cleared...",
+ root_rp->mutex_owner_pid, root_rp->mutex_owner_tag);
+ memset (&root_rp->mutex, 0, sizeof (root_rp->mutex));
+ goto out;
}
-
- if (pthread_mutex_trylock(&root_rp->mutex)) {
- clib_warning ("root_rp->mutex LOCKED by pid %d, tag %d, cleared...",
- root_rp->mutex_owner_pid, root_rp->mutex_owner_tag);
- memset(&root_rp->mutex, 0, sizeof (root_rp->mutex));
- goto out;
- } else {
- clib_warning ("root_rp->mutex OK...\n");
- pthread_mutex_unlock(&root_rp->mutex);
+ else
+ {
+ clib_warning ("root_rp->mutex OK...\n");
+ pthread_mutex_unlock (&root_rp->mutex);
}
-
- out:
- vec_free (a);
- /*
- * Now that the root region is known to be OK,
- * fix broken subregions
- */
- subregion_repair(chroot_path);
-
- if (crash_root_region) {
- clib_warning ("Leaving root region locked on purpose...");
- pthread_mutex_lock(&root_rp->mutex);
- root_rp->mutex_owner_pid = getpid();
- root_rp->mutex_owner_tag = 99;
+
+out:
+ vec_free (a);
+ /*
+ * Now that the root region is known to be OK,
+ * fix broken subregions
+ */
+ subregion_repair (chroot_path);
+
+ if (crash_root_region)
+ {
+ clib_warning ("Leaving root region locked on purpose...");
+ pthread_mutex_lock (&root_rp->mutex);
+ root_rp->mutex_owner_pid = getpid ();
+ root_rp->mutex_owner_tag = 99;
}
- svm_region_exit ();
+ svm_region_exit ();
}
-int main (int argc, char **argv)
+int
+main (int argc, char **argv)
{
- unformat_input_t input;
- int parsed =0;
- char *name;
- char *chroot_path = 0;
- u8 *chroot_u8;
-
- unformat_init_command_line (&input, argv);
-
- while (unformat_check_input (&input) != UNFORMAT_END_OF_INPUT) {
- if (unformat(&input, "show-verbose")) {
- show (chroot_path, 1);
- parsed++;
- } else if (unformat (&input, "show")) {
- show (chroot_path, 0);
- parsed++;
- } else if (unformat (&input, "client-scan")) {
- svm_client_scan(chroot_path);
- parsed++;
- } else if (unformat (&input, "repair")) {
- repair(chroot_path, 0 /* fix it */);
- parsed++;
- } else if (unformat (&input, "crash")) {
- repair (chroot_path, 1 /* crash it */);
- parsed++;
- } else if (unformat (&input, "trace-on %s", &name)) {
- trace (chroot_path, name, 1);
- parsed++;
- } else if (unformat (&input, "trace-off %s", &name)) {
- trace (chroot_path, name, 0);
- parsed++;
- } else if (unformat (&input, "chroot %s", &chroot_u8)) {
- chroot_path = (char *) chroot_u8;
- } else {
- break;
- }
+ unformat_input_t input;
+ int parsed = 0;
+ char *name;
+ char *chroot_path = 0;
+ u8 *chroot_u8;
+
+ unformat_init_command_line (&input, argv);
+
+ while (unformat_check_input (&input) != UNFORMAT_END_OF_INPUT)
+ {
+ if (unformat (&input, "show-verbose"))
+ {
+ show (chroot_path, 1);
+ parsed++;
+ }
+ else if (unformat (&input, "show"))
+ {
+ show (chroot_path, 0);
+ parsed++;
+ }
+ else if (unformat (&input, "client-scan"))
+ {
+ svm_client_scan (chroot_path);
+ parsed++;
+ }
+ else if (unformat (&input, "repair"))
+ {
+ repair (chroot_path, 0 /* fix it */ );
+ parsed++;
+ }
+ else if (unformat (&input, "crash"))
+ {
+ repair (chroot_path, 1 /* crash it */ );
+ parsed++;
+ }
+ else if (unformat (&input, "trace-on %s", &name))
+ {
+ trace (chroot_path, name, 1);
+ parsed++;
+ }
+ else if (unformat (&input, "trace-off %s", &name))
+ {
+ trace (chroot_path, name, 0);
+ parsed++;
+ }
+ else if (unformat (&input, "chroot %s", &chroot_u8))
+ {
+ chroot_path = (char *) chroot_u8;
+ }
+ else
+ {
+ break;
+ }
}
- unformat_free (&input);
+ unformat_free (&input);
- if (!parsed) {
- fformat(stdout, "%s: show | show-verbose | client-scan | trace-on <region-name>\n", argv[0]);
- fformat(stdout, " trace-off <region-name>\n");
+ if (!parsed)
+ {
+ fformat (stdout,
+ "%s: show | show-verbose | client-scan | trace-on <region-name>\n",
+ argv[0]);
+ fformat (stdout, " trace-off <region-name>\n");
}
- exit (0);
+ exit (0);
}
+
+/*
+ * fd.io coding-style-patch-verification: ON
+ *
+ * Local Variables:
+ * eval: (c-set-style "gnu")
+ * End:
+ */