23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee/*
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * CDDL HEADER START
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee *
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * The contents of this file are subject to the terms of the
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * Common Development and Distribution License (the "License").
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * You may not use this file except in compliance with the License.
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee *
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * or http://www.opensolaris.org/os/licensing.
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * See the License for the specific language governing permissions
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * and limitations under the License.
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee *
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * When distributing Covered Code, include this CDDL HEADER in each
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * If applicable, add the following below this CDDL HEADER, with the
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * fields enclosed by brackets "[]" replaced with your own identifying
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * information: Portions Copyright [yyyy] [name of copyright owner]
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee *
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * CDDL HEADER END
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee */
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee/*
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * Use is subject to license terms.
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee *
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * ident "%Z%%M% %I% %E% SMI"
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee */
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomeeimport java.util.*;
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomeeimport org.opensolaris.os.dtrace.*;
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee/**
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * Regression test verifies that ProbeData instances sort as expected
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * with multiple enabled probe IDs and multiple records including byte
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * array (sorted as unsigned bytes), stand-alone ufunc() action, and
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee * signed integer.
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee */
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomeepublic class TestProbeData {
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee public static final String PROGRAM =
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee "pid$target::fN:entry\n" +
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee "{\n" +
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee " tracemem(copyin(arg1, 6), 6);\n" +
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee " ufunc(arg0);\n" +
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee " trace((int)arg2);\n" +
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee "}" +
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee "" +
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee "pid$target::fN2:entry\n" +
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee "{\n" +
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee " tracemem(copyin(arg1, 6), 6);\n" +
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee " ufunc(arg0);\n" +
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee " trace((int)arg2);\n" +
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee "}";
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee static String
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee getString(ProbeData p)
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee {
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee StringBuilder buf = new StringBuilder();
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee buf.append("[probe ");
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee buf.append(p.getEnabledProbeID());
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee buf.append(' ');
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee ProbeDescription d = p.getEnabledProbeDescription();
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee buf.append("pid$target");
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee buf.append(':');
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee buf.append(d.getModule());
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee buf.append(':');
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee buf.append(d.getFunction());
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee buf.append(':');
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee buf.append(d.getName());
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee buf.append(' ');
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee buf.append(p.getRecords());
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee buf.append("]");
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee return buf.toString();
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee }
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee public static void
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee main(String[] args)
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee {
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee if (args.length != 1) {
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee System.err.println("usage: java TestProbedata <command>");
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee System.exit(2);
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee }
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee String command = args[0];
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee final Consumer consumer = new LocalConsumer();
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee final List <ProbeData> list = new ArrayList <ProbeData> ();
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee consumer.addConsumerListener(new ConsumerAdapter() {
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee public void dataReceived(DataEvent e) {
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee list.add(e.getProbeData());
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee }
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee public void consumerStopped(ConsumerEvent e) {
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee Collections.sort(list);
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee for (ProbeData p : list) {
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee System.out.println(getString(p));
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee System.out.println();
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee }
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee consumer.close();
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee }
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee });
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee try {
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee consumer.open();
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee consumer.createProcess(command);
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee consumer.compile(PROGRAM);
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee consumer.enable();
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee consumer.go();
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee } catch (DTraceException e) {
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee e.printStackTrace();
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee }
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee }
23b5c241225a8ade2b6b9f06ebb891ee459e3b02tomee}