1ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*
2ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   This file is part of Callgrind, a Valgrind tool for call graph
3ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   profiling programs.
4ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
5b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov   Copyright (C) 2002-2011, Josef Weidendorfer (Josef.Weidendorfer@gmx.de)
6ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
7ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   This tool is derived from and contains lot of code from Cachegrind
8b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov   Copyright (C) 2002-2011 Nicholas Nethercote (njn@valgrind.org)
9ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
10ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   This program is free software; you can redistribute it and/or
11ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   modify it under the terms of the GNU General Public License as
12ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   published by the Free Software Foundation; either version 2 of the
13ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   License, or (at your option) any later version.
14ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
15ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   This program is distributed in the hope that it will be useful, but
16ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   WITHOUT ANY WARRANTY; without even the implied warranty of
17ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
18ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   General Public License for more details.
19ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
20ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   You should have received a copy of the GNU General Public License
21ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   along with this program; if not, write to the Free Software
22ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
23ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   02111-1307, USA.
24ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
25ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   The GNU General Public License is contained in the file COPYING.
26ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown*/
27ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
28ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown#include "global.h"
29ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown#include "events.h"
30ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
31ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/* If debugging mode of, dummy functions are provided (see below)
32ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown */
33ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown#if CLG_ENABLE_DEBUG
34ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
35ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*------------------------------------------------------------*/
36ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*--- Debug output helpers                                 ---*/
37ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*------------------------------------------------------------*/
38ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
39ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownstatic void print_indent(int s)
40ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
41ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    /* max of 40 spaces */
42ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    char sp[] = "                                        ";
43ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (s>40) s=40;
44ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("%s", sp+40-s);
45ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
46ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
47ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_bb)(int s, BB* bb)
48ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
49ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (s<0) {
50ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	s = -s;
51ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	print_indent(s);
52ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
53ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
54ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("BB %#lx (Obj '%s')", bb_addr(bb), bb->obj->name);
55ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
56ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
57ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownstatic
58ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid print_mangled_cxt(Context* cxt, int rec_index)
59ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
60ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    int i;
61ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
62ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (!cxt)
63ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      VG_(printf)("(none)");
64ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    else {
65ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      VG_(printf)("%s", cxt->fn[0]->name);
66ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      if (rec_index >0)
67ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)("'%d", rec_index +1);
68ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      for(i=1;i<cxt->size;i++)
69ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)("'%s", cxt->fn[i]->name);
70ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
71ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
72ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
73ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
74ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
75ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_cxt)(int s, Context* cxt, int rec_index)
76ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
77ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  if (s<0) {
78ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    s = -s;
79ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    print_indent(s);
80ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  }
81ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
82ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  if (cxt) {
83ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    UInt *pactive = CLG_(get_fn_entry)(cxt->fn[0]->number);
84ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    CLG_ASSERT(rec_index < cxt->fn[0]->separate_recursions);
85ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
86ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("Cxt %d" ,cxt->base_number + rec_index);
87ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (*pactive>0)
88ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      VG_(printf)(" [active=%d]", *pactive);
89ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)(": ");
90ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    print_mangled_cxt(cxt, rec_index);
91ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("\n");
92ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  }
93ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  else
94ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("(no context)\n");
95ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
96ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
97ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_execstate)(int s, exec_state* es)
98ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
99ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  if (s<0) {
100ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    s = -s;
101ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    print_indent(s);
102ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  }
103ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
104ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  if (!es) {
105ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("ExecState 0x0\n");
106ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    return;
107ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  }
108ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
109ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  VG_(printf)("ExecState [Sig %d, collect %s, nonskipped %p]: jmps_passed %d\n",
110ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	      es->sig, es->collect?"yes":"no",
111ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	      es->nonskipped, es->jmps_passed);
112ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
113ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
114ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
115ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_bbcc)(int s, BBCC* bbcc)
116ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
117ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  BB* bb;
118ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
119ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  if (s<0) {
120ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    s = -s;
121ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    print_indent(s);
122ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  }
123ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
124ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  if (!bbcc) {
125ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("BBCC 0x0\n");
126ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    return;
127ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  }
128ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
129ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  bb = bbcc->bb;
130ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  CLG_ASSERT(bb!=0);
131ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
132ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  VG_(printf)("%s +%#lx=%#lx, ",
133ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	      bb->obj->name + bb->obj->last_slash_pos,
134ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	      bb->offset, bb_addr(bb));
135ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  CLG_(print_cxt)(s+8, bbcc->cxt, bbcc->rec_index);
136ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
137ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
138ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_eventset)(int s, EventSet* es)
139ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
140ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    int i, j;
141ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    UInt mask;
142ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    EventGroup* eg;
143ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
144ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (s<0) {
145ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	s = -s;
146ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	print_indent(s);
147ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
148ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
149ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (!es) {
150ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)("(EventSet not set)\n");
151ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	return;
152ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
153ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
154ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("EventSet %d (%d groups, size %d):",
155ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		es->mask, es->count, es->size);
156ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
157ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (es->count == 0) {
158ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)("-\n");
159ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	return;
160ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
161ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
162ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    for(i=0, mask=1; i<MAX_EVENTGROUP_COUNT; i++, mask=mask<<1) {
163ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	if ((es->mask & mask)==0) continue;
164ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	eg = CLG_(get_event_group)(i);
165ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	if (!eg) continue;
166ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)(" (%d: %s", i, eg->name[0]);
167ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	for(j=1; j<eg->size; j++)
168ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	    VG_(printf)(" %s", eg->name[j]);
169ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)(")");
170ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
171ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("\n");
172ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
173ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
174ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
175ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_cost)(int s, EventSet* es, ULong* c)
176ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
177ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    Int i, j, pos, off;
178ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    UInt mask;
179ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    EventGroup* eg;
180ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
181ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (s<0) {
182ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	s = -s;
183ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	print_indent(s);
184ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
185ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
186ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (!es) {
187ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      VG_(printf)("Cost (Nothing, EventSet not set)\n");
188ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      return;
189ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
190ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (!c) {
191ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      VG_(printf)("Cost (Null, EventSet %d)\n", es->mask);
192ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      return;
193ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
194ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
195ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (es->size == 0) {
196ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      VG_(printf)("Cost (Nothing, EventSet with len 0)\n");
197ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      return;
198ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
199ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
200ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    pos = s;
201ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    pos += VG_(printf)("Cost [%p]: ", c);
202ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    off = 0;
203ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    for(i=0, mask=1; i<MAX_EVENTGROUP_COUNT; i++, mask=mask<<1) {
204ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	if ((es->mask & mask)==0) continue;
205ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	eg = CLG_(get_event_group)(i);
206ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	if (!eg) continue;
207ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	for(j=0; j<eg->size; j++) {
208ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
209ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	    if (off>0) {
210ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		if (pos > 70) {
211ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		    VG_(printf)(",\n");
212ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		    print_indent(s+5);
213ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		    pos = s+5;
214ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		}
215ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		else
216ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		    pos += VG_(printf)(", ");
217ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	    }
218ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
219ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	    pos += VG_(printf)("%s %llu", eg->name[j], c[off++]);
220ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	}
221ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
222ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("\n");
223ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
224ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
225ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
226ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_short_jcc)(jCC* jcc)
227ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
228ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (jcc)
229ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)("%#lx => %#lx [calls %llu/Ir %llu, Dr %llu, Dw %llu]",
230ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		    bb_jmpaddr(jcc->from->bb),
231ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		    bb_addr(jcc->to->bb),
232ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		    jcc->call_counter,
233ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		    jcc->cost ? jcc->cost[fullOffset(EG_IR)]:0,
234ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		    jcc->cost ? jcc->cost[fullOffset(EG_DR)]:0,
235ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		    jcc->cost ? jcc->cost[fullOffset(EG_DW)]:0);
236ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    else
237ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)("[Skipped JCC]");
238ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
239ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
240ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_jcc)(int s, jCC* jcc)
241ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
242ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (s<0) {
243ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	s = -s;
244ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	print_indent(s);
245ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
246ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
247ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (!jcc) {
248ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)("JCC to skipped function\n");
249ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	return;
250ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
251ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("JCC %p from ", jcc);
252ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    CLG_(print_bbcc)(s+9, jcc->from);
253ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    print_indent(s+4);
254ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("to   ");
255ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    CLG_(print_bbcc)(s+9, jcc->to);
256ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    print_indent(s+4);
257ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("Calls %llu\n", jcc->call_counter);
258ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    print_indent(s+4);
259ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    CLG_(print_cost)(s+9, CLG_(sets).full, jcc->cost);
260ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
261ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
262ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/* dump out the current call stack */
263ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_stackentry)(int s, int sp)
264ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
265ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    call_entry* ce;
266ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
267ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (s<0) {
268ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	s = -s;
269ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	print_indent(s);
270ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
271ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
272ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    ce = CLG_(get_call_entry)(sp);
273ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("[%-2d] SP %#lx, RA %#lx", sp, ce->sp, ce->ret_addr);
274ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (ce->nonskipped)
275ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)(" NonSkipped BB %#lx / %s",
276ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		    bb_addr(ce->nonskipped->bb),
277ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		    ce->nonskipped->cxt->fn[0]->name);
278ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("\n");
279ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    print_indent(s+5);
280ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    CLG_(print_jcc)(5,ce->jcc);
281ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
282ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
283ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/* debug output */
284ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown#if 0
285ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownstatic void print_call_stack()
286ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
287ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    int c;
288ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
289ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("Call Stack:\n");
290ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    for(c=0;c<CLG_(current_call_stack).sp;c++)
291ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      CLG_(print_stackentry)(-2, c);
292ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
293ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown#endif
294ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
295ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_bbcc_fn)(BBCC* bbcc)
296ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
297ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    obj_node* obj;
298ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
299ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (!bbcc) {
300ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)("%08x", 0);
301ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	return;
302ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
303ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
304ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("%08lx/%c  %d:", bb_addr(bbcc->bb),
305ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		(bbcc->bb->sect_kind == Vg_SectText) ? 'T' :
306ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		(bbcc->bb->sect_kind == Vg_SectData) ? 'D' :
307ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		(bbcc->bb->sect_kind == Vg_SectBSS) ? 'B' :
308ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		(bbcc->bb->sect_kind == Vg_SectGOT) ? 'G' :
309ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		(bbcc->bb->sect_kind == Vg_SectPLT) ? 'P' : 'U',
310ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		bbcc->cxt->base_number+bbcc->rec_index);
311ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    print_mangled_cxt(bbcc->cxt, bbcc->rec_index);
312ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
313ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    obj = bbcc->cxt->fn[0]->file->obj;
314ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (obj->name[0])
315ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)(" %s", obj->name+obj->last_slash_pos);
316ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
317ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (VG_(strcmp)(bbcc->cxt->fn[0]->file->name, "???") !=0) {
318ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)(" %s", bbcc->cxt->fn[0]->file->name);
319ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	if ((bbcc->cxt->fn[0] == bbcc->bb->fn) && (bbcc->bb->line>0))
320ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	    VG_(printf)(":%d", bbcc->bb->line);
321ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
322ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
323ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
324ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_bbcc_cost)(int s, BBCC* bbcc)
325ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
326ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  BB* bb;
327ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  Int i, cjmpNo;
328ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  ULong ecounter;
329ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
330ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  if (s<0) {
331ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    s = -s;
332ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    print_indent(s);
333ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  }
334ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
335ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  if (!bbcc) {
336ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("BBCC 0x0\n");
337ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    return;
338ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  }
339ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
340ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  bb = bbcc->bb;
341ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  CLG_ASSERT(bb!=0);
342ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
343ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  CLG_(print_bbcc)(s, bbcc);
344ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
345ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  ecounter = bbcc->ecounter_sum;
346ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
347ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  print_indent(s+2);
348ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  VG_(printf)("ECounter: sum %llu ", ecounter);
349ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  for(i=0; i<bb->cjmp_count; i++) {
350ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      VG_(printf)("[%d]=%llu ",
351ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		  bb->jmp[i].instr, bbcc->jmp[i].ecounter);
352ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  }
353ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  VG_(printf)("\n");
354ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
355ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  cjmpNo = 0;
356ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  for(i=0; i<bb->instr_count; i++) {
357ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      InstrInfo* ii = &(bb->instr[i]);
358ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      print_indent(s+2);
359ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      VG_(printf)("[%2d] IOff %2d ecnt %3llu ",
360ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		  i, ii->instr_offset, ecounter);
361ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      CLG_(print_cost)(s+5, ii->eventset, bbcc->cost + ii->cost_offset);
362ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
363ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* update execution counter */
364ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      if (cjmpNo < bb->cjmp_count)
365ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	  if (bb->jmp[cjmpNo].instr == i) {
366ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	      ecounter -= bbcc->jmp[cjmpNo].ecounter;
367ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	      cjmpNo++;
368ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	  }
369ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  }
370ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
371ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
372ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
373ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/* dump out an address with source info if available */
374ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_addr)(Addr addr)
375ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
376ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    Char fl_buf[FILENAME_LEN];
377ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    Char fn_buf[FN_NAME_LEN];
378ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    const UChar* obj_name;
379ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    DebugInfo* di;
380ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    int ln, i=0, opos=0;
381ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
382ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (addr == 0) {
383ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)("%08lx", addr);
384ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	return;
385ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
386ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
387ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    CLG_(get_debug_info)(addr, fl_buf, fn_buf, &ln, &di);
388ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
389ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (VG_(strcmp)(fn_buf,"???")==0)
390ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)("%#lx", addr);
391ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    else
392ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	VG_(printf)("%#lx %s", addr, fn_buf);
393ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
394ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (di) {
395ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      obj_name = VG_(DebugInfo_get_filename)(di);
396ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      if (obj_name) {
397ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	while(obj_name[i]) {
398ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	  if (obj_name[i]=='/') opos = i+1;
399ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	  i++;
400ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	}
401ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	if (obj_name[0])
402ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	  VG_(printf)(" %s", obj_name+opos);
403ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      }
404ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    }
405ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
406ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    if (ln>0)
407ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    	VG_(printf)(" (%s:%u)", fl_buf,ln);
408ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
409ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
410ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_addr_ln)(Addr addr)
411ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
412ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  CLG_(print_addr)(addr);
413ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  VG_(printf)("\n");
414ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
415ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
416ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownstatic ULong bb_written = 0;
417ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
418ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_bbno)(void)
419ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
420ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  if (bb_written != CLG_(stat).bb_executions) {
421ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    bb_written = CLG_(stat).bb_executions;
422ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    VG_(printf)("BB# %llu\n",CLG_(stat).bb_executions);
423ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  }
424ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
425ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
426ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_context)(void)
427ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
428ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  BBCC* bbcc;
429ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
430ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  CLG_DEBUG(0,"In tid %d [%d] ",
431ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown	   CLG_(current_tid),  CLG_(current_call_stack).sp);
432ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  bbcc =  CLG_(current_state).bbcc;
433ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  print_mangled_cxt(CLG_(current_state).cxt,
434ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown		    bbcc ? bbcc->rec_index : 0);
435ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown  VG_(printf)("\n");
436ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
437ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
438ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid* CLG_(malloc)(HChar* cc, UWord s, char* f)
439ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown{
440ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    CLG_DEBUG(3, "Malloc(%lu) in %s.\n", s, f);
441ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    return VG_(malloc)(cc,s);
442ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown}
443ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
444ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown#else /* CLG_ENABLE_DEBUG */
445ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
446ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_bbno)(void) {}
447ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_context)(void) {}
448ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_jcc)(int s, jCC* jcc) {}
449ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_bbcc)(int s, BBCC* bbcc) {}
450ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_bbcc_fn)(BBCC* bbcc) {}
451ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_cost)(int s, EventSet* es, ULong* cost) {}
452ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_bb)(int s, BB* bb) {}
453ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_cxt)(int s, Context* cxt, int rec_index) {}
454ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_short_jcc)(jCC* jcc) {}
455ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_stackentry)(int s, int sp) {}
456ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_addr)(Addr addr) {}
457ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid CLG_(print_addr_ln)(Addr addr) {}
458ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
459ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown#endif
460