summaryrefslogtreecommitdiff
path: root/usr/src/lib/libproc/common/Putil.c
diff options
context:
space:
mode:
authorKeith M Wesolowski <wesolows@foobazco.org>2013-08-21 23:54:45 +0000
committerKeith M Wesolowski <wesolows@foobazco.org>2013-08-21 23:54:45 +0000
commit84a6527d59b307f3925d3dbac3728fd0d1db4706 (patch)
tree0f87ef159a57043733b2ad0f861e14d22d635942 /usr/src/lib/libproc/common/Putil.c
parent7d7a5b1f6447ad858fd291d2b95da27e7c690325 (diff)
parent2a12f85ad140e332791b4bad1208a734c3f26bf3 (diff)
downloadillumos-joyent-release-20130822.tar.gz
[illumos-gate merge]20130822release-20130822
commit 2a12f85ad140e332791b4bad1208a734c3f26bf3 3946 ::gcore commit 840b2722e5294ae44aa3af6189002f521d7c50e0 3915 Add adjuncts support to the build (fix lint) commit afffa6e9b45cbe9b33943e26568d8ac69b899252 4062 libscf: memory leaks in scf_simple_app_props_get() commit 2fbdf8dbf01ec1c85fcd3827cdf9e9f5f46c4c8a 4061 libzfs: memory leak in iter_dependents_cb() commit 713d6c208802cfbb806329ec0d154b641b80c355 4047 panic from dbuf_free_range() from dmu_free_object() while doing zfs receive
Diffstat (limited to 'usr/src/lib/libproc/common/Putil.c')
-rw-r--r--usr/src/lib/libproc/common/Putil.c98
1 files changed, 96 insertions, 2 deletions
diff --git a/usr/src/lib/libproc/common/Putil.c b/usr/src/lib/libproc/common/Putil.c
index 791ec668cb..f6f2aa862e 100644
--- a/usr/src/lib/libproc/common/Putil.c
+++ b/usr/src/lib/libproc/common/Putil.c
@@ -23,8 +23,9 @@
* Copyright 2005 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
-
-#pragma ident "%Z%%M% %I% %E% SMI"
+/*
+ * Copyright (c) 2013 by Delphix. All rights reserved.
+ */
#include <limits.h>
#include <string.h>
@@ -150,3 +151,96 @@ Perror_printf(struct ps_prochandle *P, const char *format, ...)
{
/* nothing to do here */
}
+
+/*
+ * Default operations.
+ */
+static ssize_t
+Pdefault_ssizet()
+{
+ return (-1);
+}
+
+static int
+Pdefault_int()
+{
+ return (-1);
+}
+
+static void
+Pdefault_void()
+{
+}
+
+static void *
+Pdefault_voidp()
+{
+ return (NULL);
+}
+
+static const ps_ops_t P_default_ops = {
+ .pop_pread = (pop_pread_t)Pdefault_ssizet,
+ .pop_pwrite = (pop_pwrite_t)Pdefault_ssizet,
+ .pop_read_maps = (pop_read_maps_t)Pdefault_int,
+ .pop_read_aux = (pop_read_aux_t)Pdefault_void,
+ .pop_cred = (pop_cred_t)Pdefault_int,
+ .pop_priv = (pop_priv_t)Pdefault_int,
+ .pop_psinfo = (pop_psinfo_t)Pdefault_voidp,
+ .pop_status = (pop_status_t)Pdefault_void,
+ .pop_lstatus = (pop_lstatus_t)Pdefault_voidp,
+ .pop_lpsinfo = (pop_lpsinfo_t)Pdefault_voidp,
+ .pop_fini = (pop_fini_t)Pdefault_void,
+ .pop_platform = (pop_platform_t)Pdefault_voidp,
+ .pop_uname = (pop_uname_t)Pdefault_int,
+ .pop_zonename = (pop_zonename_t)Pdefault_voidp,
+ .pop_execname = (pop_execname_t)Pdefault_voidp,
+#if defined(__i386) || defined(__amd64)
+ .pop_ldt = (pop_ldt_t)Pdefault_int
+#endif
+};
+
+/*
+ * Initialize the destination ops vector with functions from the source.
+ * Functions which are NULL in the source ops vector are set to corresponding
+ * default function in the destination vector.
+ */
+void
+Pinit_ops(ps_ops_t *dst, const ps_ops_t *src)
+{
+ *dst = P_default_ops;
+
+ if (src->pop_pread != NULL)
+ dst->pop_pread = src->pop_pread;
+ if (src->pop_pwrite != NULL)
+ dst->pop_pwrite = src->pop_pwrite;
+ if (src->pop_read_maps != NULL)
+ dst->pop_read_maps = src->pop_read_maps;
+ if (src->pop_read_aux != NULL)
+ dst->pop_read_aux = src->pop_read_aux;
+ if (src->pop_cred != NULL)
+ dst->pop_cred = src->pop_cred;
+ if (src->pop_priv != NULL)
+ dst->pop_priv = src->pop_priv;
+ if (src->pop_psinfo != NULL)
+ dst->pop_psinfo = src->pop_psinfo;
+ if (src->pop_status != NULL)
+ dst->pop_status = src->pop_status;
+ if (src->pop_lstatus != NULL)
+ dst->pop_lstatus = src->pop_lstatus;
+ if (src->pop_lpsinfo != NULL)
+ dst->pop_lpsinfo = src->pop_lpsinfo;
+ if (src->pop_fini != NULL)
+ dst->pop_fini = src->pop_fini;
+ if (src->pop_platform != NULL)
+ dst->pop_platform = src->pop_platform;
+ if (src->pop_uname != NULL)
+ dst->pop_uname = src->pop_uname;
+ if (src->pop_zonename != NULL)
+ dst->pop_zonename = src->pop_zonename;
+ if (src->pop_execname != NULL)
+ dst->pop_execname = src->pop_execname;
+#if defined(__i386) || defined(__amd64)
+ if (src->pop_ldt != NULL)
+ dst->pop_ldt = src->pop_ldt;
+#endif
+}