• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1// Copyright 2016 the V8 project authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5function CppProcessor(cppEntriesProvider, timedRange, pairwiseTimedRange) {
6  LogReader.call(this, {
7      'shared-library': { parsers: [null, parseInt, parseInt, parseInt],
8          processor: this.processSharedLibrary }
9  }, timedRange, pairwiseTimedRange);
10
11  this.cppEntriesProvider_ = cppEntriesProvider;
12  this.codeMap_ = new CodeMap();
13  this.lastLogFileName_ = null;
14}
15inherits(CppProcessor, LogReader);
16
17/**
18 * @override
19 */
20CppProcessor.prototype.printError = function(str) {
21  print(str);
22};
23
24CppProcessor.prototype.processLogFile = function(fileName) {
25  this.lastLogFileName_ = fileName;
26  var line;
27  while (line = readline()) {
28    this.processLogLine(line);
29  }
30};
31
32CppProcessor.prototype.processLogFileInTest = function(fileName) {
33   // Hack file name to avoid dealing with platform specifics.
34  this.lastLogFileName_ = 'v8.log';
35  var contents = readFile(fileName);
36  this.processLogChunk(contents);
37};
38
39CppProcessor.prototype.processSharedLibrary = function(
40    name, startAddr, endAddr, aslrSlide) {
41  var self = this;
42  var libFuncs = this.cppEntriesProvider_.parseVmSymbols(
43      name, startAddr, endAddr, aslrSlide, function(fName, fStart, fEnd) {
44    var entry = new CodeMap.CodeEntry(fEnd - fStart, fName, 'CPP');
45    self.codeMap_.addStaticCode(fStart, entry);
46  });
47};
48
49CppProcessor.prototype.dumpCppSymbols = function() {
50  var staticEntries = this.codeMap_.getAllStaticEntriesWithAddresses();
51  var total = staticEntries.length;
52  for (var i = 0; i < total; ++i) {
53    var entry = staticEntries[i];
54    var printValues = ['cpp', '0x' + entry[0].toString(16), entry[1].size,
55                       '"' + entry[1].name + '"'];
56    print(printValues.join(','));
57  }
58};
59