blob: 728d073308a96c4a90edf1ecbadb110f3f457541 [file] [log] [blame]
Austin Schuh745610d2015-09-06 18:19:50 -07001// -*- Mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*-
2// Copyright (c) 2009, Google Inc.
3// All rights reserved.
4//
5// Redistribution and use in source and binary forms, with or without
6// modification, are permitted provided that the following conditions are
7// met:
8//
9// * Redistributions of source code must retain the above copyright
10// notice, this list of conditions and the following disclaimer.
11// * Redistributions in binary form must reproduce the above
12// copyright notice, this list of conditions and the following disclaimer
13// in the documentation and/or other materials provided with the
14// distribution.
15// * Neither the name of Google Inc. nor the names of its
16// contributors may be used to endorse or promote products derived from
17// this software without specific prior written permission.
18//
19// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30
31// ---
32// Author: Craig Silverstein
33
34#ifndef TCMALLOC_SYMBOLIZE_H_
35#define TCMALLOC_SYMBOLIZE_H_
36
37#include "config.h"
38#ifdef HAVE_STDINT_H
39#include <stdint.h> // for uintptr_t
40#endif
41#include <stddef.h> // for NULL
42#include <map>
43
44using std::map;
45
46// SymbolTable encapsulates the address operations necessary for stack trace
47// symbolization. A common use-case is to Add() the addresses from one or
48// several stack traces to a table, call Symbolize() once and use GetSymbol()
49// to get the symbol names for pretty-printing the stack traces.
50class SymbolTable {
51 public:
52 SymbolTable()
53 : symbol_buffer_(NULL) {}
54 ~SymbolTable() {
55 delete[] symbol_buffer_;
56 }
57
58 // Adds an address to the table. This may overwrite a currently known symbol
59 // name, so Add() should not generally be called after Symbolize().
60 void Add(const void* addr);
61
62 // Returns the symbol name for addr, if the given address was added before
63 // the last successful call to Symbolize(). Otherwise may return an empty
64 // c-string.
65 const char* GetSymbol(const void* addr);
66
67 // Obtains the symbol names for the addresses stored in the table and returns
68 // the number of addresses actually symbolized.
69 int Symbolize();
70
71 private:
72 typedef map<const void*, const char*> SymbolMap;
73
74 // An average size of memory allocated for a stack trace symbol.
75 static const int kSymbolSize = 1024;
76
77 // Map from addresses to symbol names.
78 SymbolMap symbolization_table_;
79
80 // Pointer to the buffer that stores the symbol names.
81 char *symbol_buffer_;
82};
83
84#endif // TCMALLOC_SYMBOLIZE_H_