Author: avg
Date: Wed Nov 20 11:02:18 2013
New Revision: 258379
URL: http://svnweb.freebsd.org/changeset/base/258379

Log:
  4248 dtrace(1M) should never create DOF with empty probes section
  
  4249 Only probes from the first DTrace object file will be included
  
  illumos/illumos-gate@54a20ab41aadcb81c53e72fc65886e964e9add59

Modified:
  vendor/illumos/dist/lib/libdtrace/common/dt_dof.c
  vendor/illumos/dist/lib/libdtrace/common/dt_error.c
  vendor/illumos/dist/lib/libdtrace/common/dt_impl.h

Changes in other areas also in this revision:
Modified:
  vendor-sys/illumos/dist/uts/common/dtrace/dtrace.c

Modified: vendor/illumos/dist/lib/libdtrace/common/dt_dof.c
==============================================================================
--- vendor/illumos/dist/lib/libdtrace/common/dt_dof.c   Wed Nov 20 11:00:20 
2013        (r258378)
+++ vendor/illumos/dist/lib/libdtrace/common/dt_dof.c   Wed Nov 20 11:02:18 
2013        (r258379)
@@ -22,6 +22,7 @@
 /*
  * Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
  * Copyright (c) 2011 by Delphix. All rights reserved.
+ * Copyright (c) 2013, Joyent, Inc. All rights reserved.
  */
 
 #include <sys/types.h>
@@ -482,7 +483,7 @@ dof_add_probe(dt_idhash_t *dhp, dt_ident
        return (0);
 }
 
-static void
+static int
 dof_add_provider(dt_dof_t *ddo, const dt_provider_t *pvp)
 {
        dtrace_hdl_t *dtp = ddo->ddo_hdl;
@@ -493,8 +494,12 @@ dof_add_provider(dt_dof_t *ddo, const dt
        size_t sz;
        id_t i;
 
-       if (pvp->pv_flags & DT_PROVIDER_IMPL)
-               return; /* ignore providers that are exported by dtrace(7D) */
+       if (pvp->pv_flags & DT_PROVIDER_IMPL) {
+               /*
+                * ignore providers that are exported by dtrace(7D)
+                */
+               return (0);
+       }
 
        nxr = dt_popcb(pvp->pv_xrefs, pvp->pv_xrmax);
        dofs = alloca(sizeof (dof_secidx_t) * (nxr + 1));
@@ -521,6 +526,9 @@ dof_add_provider(dt_dof_t *ddo, const dt
 
        (void) dt_idhash_iter(pvp->pv_probes, dof_add_probe, ddo);
 
+       if (dt_buf_len(&ddo->ddo_probes) == 0)
+               return (dt_set_errno(dtp, EDT_NOPROBES));
+
        dofpv.dofpv_probes = dof_add_lsect(ddo, NULL, DOF_SECT_PROBES,
            sizeof (uint64_t), 0, sizeof (dof_probe_t),
            dt_buf_len(&ddo->ddo_probes));
@@ -575,6 +583,8 @@ dof_add_provider(dt_dof_t *ddo, const dt
                    sizeof (dof_secidx_t), 0, sizeof (dof_secidx_t),
                    sizeof (dof_secidx_t) * (nxr + 1));
        }
+
+       return (0);
 }
 
 static int
@@ -818,8 +828,10 @@ dtrace_dof_create(dtrace_hdl_t *dtp, dtr
         */
        if (flags & DTRACE_D_PROBES) {
                for (pvp = dt_list_next(&dtp->dt_provlist);
-                   pvp != NULL; pvp = dt_list_next(pvp))
-                       dof_add_provider(ddo, pvp);
+                   pvp != NULL; pvp = dt_list_next(pvp)) {
+                       if (dof_add_provider(ddo, pvp) != 0)
+                               return (NULL);
+               }
        }
 
        /*

Modified: vendor/illumos/dist/lib/libdtrace/common/dt_error.c
==============================================================================
--- vendor/illumos/dist/lib/libdtrace/common/dt_error.c Wed Nov 20 11:00:20 
2013        (r258378)
+++ vendor/illumos/dist/lib/libdtrace/common/dt_error.c Wed Nov 20 11:02:18 
2013        (r258379)
@@ -26,6 +26,7 @@
 
 /*
  * Copyright (c) 2012 by Delphix. All rights reserved.
+ * Copyright (c) 2013, Joyent, Inc. All rights reserved.
  */
 
 #include <strings.h>
@@ -108,7 +109,8 @@ static const struct {
        { EDT_BADSTACKPC, "Invalid stack program counter size" },
        { EDT_BADAGGVAR, "Invalid aggregation variable identifier" },
        { EDT_OVERSION, "Client requested deprecated version of library" },
-       { EDT_ENABLING_ERR, "Failed to enable probe" }
+       { EDT_ENABLING_ERR, "Failed to enable probe" },
+       { EDT_NOPROBES, "No probe sites found for declared provider" }
 };
 
 static const int _dt_nerr = sizeof (_dt_errlist) / sizeof (_dt_errlist[0]);

Modified: vendor/illumos/dist/lib/libdtrace/common/dt_impl.h
==============================================================================
--- vendor/illumos/dist/lib/libdtrace/common/dt_impl.h  Wed Nov 20 11:00:20 
2013        (r258378)
+++ vendor/illumos/dist/lib/libdtrace/common/dt_impl.h  Wed Nov 20 11:02:18 
2013        (r258379)
@@ -25,7 +25,7 @@
  */
 
 /*
- * Copyright (c) 2011, Joyent, Inc. All rights reserved.
+ * Copyright (c) 2013, Joyent, Inc. All rights reserved.
  * Copyright (c) 2012 by Delphix. All rights reserved.
  */
 
@@ -512,7 +512,8 @@ enum {
        EDT_BADSTACKPC,         /* invalid stack program counter size */
        EDT_BADAGGVAR,          /* invalid aggregation variable identifier */
        EDT_OVERSION,           /* client is requesting deprecated version */
-       EDT_ENABLING_ERR        /* failed to enable probe */
+       EDT_ENABLING_ERR,       /* failed to enable probe */
+       EDT_NOPROBES            /* no probes sites for declared provider */
 };
 
 /*
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to