OLD | NEW |
1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 101 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
112 } | 112 } |
113 | 113 |
114 | 114 |
115 // Creates a global function named 'func_name' that calls the tracing | 115 // Creates a global function named 'func_name' that calls the tracing |
116 // function 'trace_func_name' with an actual EBP register value, | 116 // function 'trace_func_name' with an actual EBP register value, |
117 // encoded as one or two Smis. | 117 // encoded as one or two Smis. |
118 static void CreateTraceCallerFunction(v8::Local<v8::Context> context, | 118 static void CreateTraceCallerFunction(v8::Local<v8::Context> context, |
119 const char* func_name, | 119 const char* func_name, |
120 const char* trace_func_name) { | 120 const char* trace_func_name) { |
121 i::EmbeddedVector<char, 256> trace_call_buf; | 121 i::EmbeddedVector<char, 256> trace_call_buf; |
122 i::OS::SNPrintF(trace_call_buf, | 122 i::SNPrintF(trace_call_buf, |
123 "function %s() {" | 123 "function %s() {" |
124 " fp = new FPGrabber();" | 124 " fp = new FPGrabber();" |
125 " %s(fp.low_bits, fp.high_bits);" | 125 " %s(fp.low_bits, fp.high_bits);" |
126 "}", | 126 "}", |
127 func_name, trace_func_name); | 127 func_name, trace_func_name); |
128 | 128 |
129 // Create the FPGrabber function, which grabs the caller's frame pointer | 129 // Create the FPGrabber function, which grabs the caller's frame pointer |
130 // when called as a constructor. | 130 // when called as a constructor. |
131 CreateFramePointerGrabberConstructor(context, "FPGrabber"); | 131 CreateFramePointerGrabberConstructor(context, "FPGrabber"); |
132 | 132 |
133 // Compile the script. | 133 // Compile the script. |
134 CompileRun(trace_call_buf.start()); | 134 CompileRun(trace_call_buf.start()); |
135 } | 135 } |
136 | 136 |
137 | 137 |
(...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
277 v8::Local<v8::Context> context = CcTest::NewContext(TRACE_EXTENSION); | 277 v8::Local<v8::Context> context = CcTest::NewContext(TRACE_EXTENSION); |
278 v8::Context::Scope context_scope(context); | 278 v8::Context::Scope context_scope(context); |
279 CHECK_EQ(0, i::TraceExtension::GetJsEntrySp()); | 279 CHECK_EQ(0, i::TraceExtension::GetJsEntrySp()); |
280 CompileRun("a = 1; b = a + 1;"); | 280 CompileRun("a = 1; b = a + 1;"); |
281 CHECK_EQ(0, i::TraceExtension::GetJsEntrySp()); | 281 CHECK_EQ(0, i::TraceExtension::GetJsEntrySp()); |
282 CompileRun("js_entry_sp();"); | 282 CompileRun("js_entry_sp();"); |
283 CHECK_EQ(0, i::TraceExtension::GetJsEntrySp()); | 283 CHECK_EQ(0, i::TraceExtension::GetJsEntrySp()); |
284 CompileRun("js_entry_sp_level2();"); | 284 CompileRun("js_entry_sp_level2();"); |
285 CHECK_EQ(0, i::TraceExtension::GetJsEntrySp()); | 285 CHECK_EQ(0, i::TraceExtension::GetJsEntrySp()); |
286 } | 286 } |
OLD | NEW |