1 /*
2 * Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation. Oracle designates this
8 * particular file as subject to the "Classpath" exception as provided
9 * by Oracle in the LICENSE file that accompanied this code.
10 *
11 * This code is distributed in the hope that it will be useful, but WITHOUT
12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 * version 2 for more details (a copy is included in the LICENSE file that
15 * accompanied this code).
16 *
17 * You should have received a copy of the GNU General Public License version
18 * 2 along with this work; if not, write to the Free Software Foundation,
19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
20 *
21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22 * or visit www.oracle.com if you need additional information or have any
23 * questions.
24 */
25
26 #include "util.h"
27 #include "ThreadGroupReferenceImpl.h"
28 #include "inStream.h"
29 #include "outStream.h"
30
31 static jboolean
name(PacketInputStream * in,PacketOutputStream * out)32 name(PacketInputStream *in, PacketOutputStream *out)
33 {
34 JNIEnv *env;
35 jthreadGroup group;
36
37 env = getEnv();
38
39 group = inStream_readThreadGroupRef(env, in);
40 if (inStream_error(in)) {
41 return JNI_TRUE;
42 }
43
44 WITH_LOCAL_REFS(env, 1) {
45
46 jvmtiThreadGroupInfo info;
47
48 (void)memset(&info, 0, sizeof(info));
49 threadGroupInfo(group, &info);
50 (void)outStream_writeString(out, info.name == NULL ? "" : info.name);
51 if ( info.name != NULL )
52 jvmtiDeallocate(info.name);
53
54 } END_WITH_LOCAL_REFS(env);
55
56 return JNI_TRUE;
57 }
58
59 static jboolean
parent(PacketInputStream * in,PacketOutputStream * out)60 parent(PacketInputStream *in, PacketOutputStream *out)
61 {
62 JNIEnv *env;
63 jthreadGroup group;
64
65 env = getEnv();
66
67 group = inStream_readThreadGroupRef(env, in);
68 if (inStream_error(in)) {
69 return JNI_TRUE;
70 }
71
72 WITH_LOCAL_REFS(env, 1) {
73
74 jvmtiThreadGroupInfo info;
75
76 (void)memset(&info, 0, sizeof(info));
77 threadGroupInfo(group, &info);
78 (void)outStream_writeObjectRef(env, out, info.parent);
79 if ( info.name != NULL )
80 jvmtiDeallocate(info.name);
81
82 } END_WITH_LOCAL_REFS(env);
83
84 return JNI_TRUE;
85 }
86
87 static jboolean
children(PacketInputStream * in,PacketOutputStream * out)88 children(PacketInputStream *in, PacketOutputStream *out)
89 {
90 JNIEnv *env;
91 jthreadGroup group;
92
93 env = getEnv();
94
95 group = inStream_readThreadGroupRef(env, in);
96 if (inStream_error(in)) {
97 return JNI_TRUE;
98 }
99
100 WITH_LOCAL_REFS(env, 1) {
101
102 jvmtiError error;
103 jint threadCount;
104 jint groupCount;
105 jthread *theThreads;
106 jthread *theGroups;
107
108 error = JVMTI_FUNC_PTR(gdata->jvmti,GetThreadGroupChildren)(gdata->jvmti, group,
109 &threadCount,&theThreads,
110 &groupCount, &theGroups);
111 if (error != JVMTI_ERROR_NONE) {
112 outStream_setError(out, map2jdwpError(error));
113 } else {
114
115 int i;
116
117 /* Squish out all of the debugger-spawned threads */
118 threadCount = filterDebugThreads(theThreads, threadCount);
119
120 (void)outStream_writeInt(out, threadCount);
121 for (i = 0; i < threadCount; i++) {
122 (void)outStream_writeObjectRef(env, out, theThreads[i]);
123 }
124 (void)outStream_writeInt(out, groupCount);
125 for (i = 0; i < groupCount; i++) {
126 (void)outStream_writeObjectRef(env, out, theGroups[i]);
127 }
128
129 jvmtiDeallocate(theGroups);
130 jvmtiDeallocate(theThreads);
131 }
132
133 } END_WITH_LOCAL_REFS(env);
134
135 return JNI_TRUE;
136 }
137
138 void *ThreadGroupReference_Cmds[] = { (void *)3,
139 (void *)name,
140 (void *)parent,
141 (void *)children };
142