-
Notifications
You must be signed in to change notification settings - Fork 29.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Restrict process and Buffer globals to CommonJS #26334
Conversation
@guybedford sadly an error occured when I tried to trigger a build :( |
4b94aef
to
10e7988
Compare
can you undo all the unrelated changes to context.js? |
While |
In other words, this PR provides a valid technical means to remove these globals from ESM, but it will still create a world where many kinds of CJS modules will be unable to be refactored to ESM, or will break if they are naively refactored (ie, will silently start going down browser code paths, because the use of |
|
Process-related: if we are going to do this, we need to doc-deprecate first before emitting warnings. |
Using import.meta (would that work in CJS too? It’s important imo that both cjs and ESM have the same mechanisms available to them) would force a build tool on what was a simple typeof check. It sounds like what you really want is to deprecate process.binding and process.hrtime, and perhaps some others - can we focus on deprecating those, instead of throwing the baby out with the bathwater by getting rid of the entire useful global? |
"Fixing" process to be a secure global is what we'd be left with otherwise certainly. It would also mean individually replacing all of these APIs with alternatives, so we'd be looking at dozens of individual API changes instead. It won't be pretty, but yes that is the alternative to work towards these properties. The other side of that is that we wouldn't want ES module users to use |
fwiw process.binding is being deprecated anyway. |
@devsnek do you have a link? What is it being replaced with? |
it's not being replaced with anything |
@devsnek interesting - Note also what a huge effort changing |
A couple of questions that come to mind:
Thanks! |
Different hooks for attenuation / different analysis of dynamic access. Dynamic global access is quite hard to check for and you get lots of bailouts as can be seen in some tools for auditing like https://github.com/bmeck/tofu .
Yes and no; by moving it to an import, it still allows it to be polyfilled via means like import hooks or redirection. It however does help show when something is used that is not present in all environments more easily per the point above.
You don't need sandboxes for imports if you have import hooks. You do need sandboxes for attenuating globals (which is also complex once you start talking about shared intrinsics). Realms are not going to be ready anytime soon for this that I can tell. The underpinnings to even allow Realms as often talked about is still somewhat up in the air per tc39/ecma262#1420 Overall I don't think we should equate global attenuation with import attenuation. |
Ok I will update along these lines. @joyeecheung does that mean the deprecation warnings can be added as a semver minor? |
63618d0
to
8968f53
Compare
8968f53
to
0f7e94f
Compare
I’ll post the data in the rowesr form. Have we tried running the http benchmarks in core? |
@mcollina here are the http benchmark results - Http benchmarks01:08:36 http/bench-parser.js n=100000 len=16 0.89 % ±1.44% ±1.92% ±2.52% 01:08:36 http/bench-parser.js n=100000 len=32 -0.12 % ±2.10% ±2.80% ±3.68% 01:08:36 http/bench-parser.js n=100000 len=4 -0.75 % ±3.14% ±4.20% ±5.51% 01:08:36 http/bench-parser.js n=100000 len=8 * 1.81 % ±1.40% ±1.86% ±2.43% 01:08:36 http/check_invalid_header_char.js n=1000000 input='' 0.96 % ±3.62% ±4.83% ±6.29% 01:08:36 http/check_invalid_header_char.js n=1000000 input='\177' -0.93 % ±5.16% ±6.86% ±8.93% 01:08:36 http/check_invalid_header_char.js n=1000000 input='1' -2.99 % ±3.93% ±5.25% ±6.87% 01:08:36 http/check_invalid_header_char.js n=1000000 input='20091' -1.93 % ±3.25% ±4.32% ±5.63% 01:08:36 http/check_invalid_header_char.js n=1000000 input='close' -2.26 % ±3.99% ±5.31% ±6.91% 01:08:36 http/check_invalid_header_char.js n=1000000 input='en-US' -3.95 % ±4.12% ±5.48% ±7.13% 01:08:36 http/check_invalid_header_char.js n=1000000 input='foo\\nbar' 1.25 % ±4.63% ±6.17% ±8.04% 01:08:36 http/check_invalid_header_char.js n=1000000 input='group_acmeair' 1.03 % ±2.92% ±3.90% ±5.09% 01:08:36 http/check_invalid_header_char.js n=1000000 input='gzip' -2.48 % ±3.83% ±5.12% ±6.69% 01:08:36 http/check_invalid_header_char.js n=1000000 input='keep-alive' * -3.68 % ±3.31% ±4.41% ±5.74% 01:08:36 http/check_invalid_header_char.js n=1000000 input='LONG_AND_INVALID' -1.11 % ±2.01% ±2.67% ±3.48% 01:08:36 http/check_invalid_header_char.js n=1000000 input='private' 1.09 % ±3.84% ±5.11% ±6.65% 01:08:36 http/check_invalid_header_char.js n=1000000 input='SAMEORIGIN' -1.13 % ±4.42% ±5.89% ±7.67% 01:08:36 http/check_invalid_header_char.js n=1000000 input='Sat, 07 May 2016 16:54:48 GMT' 1.36 % ±4.62% ±6.17% ±8.08% 01:08:36 http/check_invalid_header_char.js n=1000000 input='text/html; charset=utf-8' 0.41 % ±3.22% ±4.28% ±5.57% 01:08:36 http/check_invalid_header_char.js n=1000000 input='text/plain' -1.29 % ±4.30% ±5.73% ±7.46% 01:08:36 http/check_invalid_header_char.js n=1000000 input='\\t\\t\\t\\t\\t\\t\\t\\t\\t\\tFoo bar baz' 1.24 % ±3.26% ±4.35% ±5.66% 01:08:36 http/check_invalid_header_char.js n=1000000 input='中文呢' -1.20 % ±5.85% ±7.79% ±10.18% 01:08:36 http/check_is_http_token.js n=1000000 key=':' -0.74 % ±3.41% ±4.53% ±5.90% 01:08:36 http/check_is_http_token.js n=1000000 key='((((())))' 2.38 % ±5.32% ±7.09% ±9.25% 01:08:36 http/check_is_http_token.js n=1000000 key='@@' -1.60 % ±4.09% ±5.45% ±7.12% 01:08:36 http/check_is_http_token.js n=1000000 key='Accept-Ranges' 2.25 % ±4.56% ±6.07% ±7.90% 01:08:36 http/check_is_http_token.js n=1000000 key=':alternate-protocol' 0.85 % ±4.75% ±6.32% ±8.23% 01:08:36 http/check_is_http_token.js n=1000000 key='alternate-protocol:' -0.84 % ±3.15% ±4.19% ±5.45% 01:08:36 http/check_is_http_token.js n=1000000 key='alternate-protocol' 2.60 % ±4.82% ±6.47% ±8.52% 01:08:36 http/check_is_http_token.js n=1000000 key='alt-svc' -0.79 % ±3.70% ±4.92% ±6.41% 01:08:36 http/check_is_http_token.js n=1000000 key='Cache-Control' 1.26 % ±3.66% ±4.87% ±6.34% 01:08:36 http/check_is_http_token.js n=1000000 key='Connection' 1.24 % ±3.84% ±5.11% ±6.65% 01:08:36 http/check_is_http_token.js n=1000000 key='Content-Encoding' -2.69 % ±2.75% ±3.67% ±4.78% 01:08:36 http/check_is_http_token.js n=1000000 key='content-length' 2.38 % ±2.98% ±3.97% ±5.18% 01:08:36 http/check_is_http_token.js n=1000000 key='Content-Location' 0.35 % ±3.61% ±4.80% ±6.25% 01:08:36 http/check_is_http_token.js n=1000000 key='content-type' 2.43 % ±2.87% ±3.82% ±4.97% 01:08:36 http/check_is_http_token.js n=1000000 key='Content-Type' -0.05 % ±3.75% ±4.99% ±6.52% 01:08:36 http/check_is_http_token.js n=1000000 key='date' 2.76 % ±3.67% ±4.90% ±6.39% 01:08:36 http/check_is_http_token.js n=1000000 key='ETag' 3.01 % ±6.29% ±8.41% ±11.03% 01:08:36 http/check_is_http_token.js n=1000000 key='Expires' -0.96 % ±4.35% ±5.79% ±7.55% 01:08:36 http/check_is_http_token.js n=1000000 key='Keep-Alive' 0.64 % ±3.54% ±4.70% ±6.12% 01:08:36 http/check_is_http_token.js n=1000000 key='Last-Modified' 2.50 % ±3.76% ±5.00% ±6.52% 01:08:36 http/check_is_http_token.js n=1000000 key='location' 1.51 % ±3.40% ±4.53% ±5.90% 01:08:36 http/check_is_http_token.js n=1000000 key='server' 0.21 % ±3.51% ±4.67% ±6.09% 01:08:36 http/check_is_http_token.js n=1000000 key='Server' * -3.22 % ±3.14% ±4.18% ±5.44% 01:08:36 http/check_is_http_token.js n=1000000 key='status' -0.59 % ±3.18% ±4.23% ±5.51% 01:08:36 http/check_is_http_token.js n=1000000 key='TCN' 1.52 % ±4.74% ±6.30% ±8.21% 01:08:36 http/check_is_http_token.js n=1000000 key='Transfer-Encoding' -0.03 % ±2.73% ±3.63% ±4.72% 01:08:36 http/check_is_http_token.js n=1000000 key='Vary' -1.57 % ±4.38% ±5.83% ±7.59% 01:08:36 http/check_is_http_token.js n=1000000 key='version' 3.50 % ±5.80% ±7.74% ±10.14% 01:08:36 http/check_is_http_token.js n=1000000 key='x-frame-options' -1.31 % ±3.96% ±5.28% ±6.89% 01:08:36 http/check_is_http_token.js n=1000000 key='x-xss-protection' -2.06 % ±2.51% ±3.34% ±4.35% 01:08:36 http/check_is_http_token.js n=1000000 key='中文呢' 0.14 % ±5.54% ±7.39% ±9.63% 01:08:36 http/chunked.js c=100 len=1 n=16 benchmarker='wrk' *** -1.39 % ±0.65% ±0.86% ±1.12% 01:08:36 http/chunked.js c=100 len=1 n=1 benchmarker='wrk' 0.05 % ±0.27% ±0.37% ±0.48% 01:08:36 http/chunked.js c=100 len=1 n=4 benchmarker='wrk' -0.06 % ±0.28% ±0.38% ±0.49% 01:08:36 http/chunked.js c=100 len=1 n=8 benchmarker='wrk' -0.24 % ±0.26% ±0.35% ±0.45% 01:08:36 http/chunked.js c=100 len=256 n=16 benchmarker='wrk' *** -2.19 % ±0.80% ±1.06% ±1.38% 01:08:36 http/chunked.js c=100 len=256 n=1 benchmarker='wrk' 0.04 % ±0.29% ±0.39% ±0.51% 01:08:36 http/chunked.js c=100 len=256 n=4 benchmarker='wrk' -0.28 % ±0.29% ±0.38% ±0.50% 01:08:36 http/chunked.js c=100 len=256 n=8 benchmarker='wrk' -0.29 % ±0.33% ±0.44% ±0.57% 01:08:36 http/chunked.js c=100 len=64 n=16 benchmarker='wrk' *** -1.72 % ±0.71% ±0.94% ±1.23% 01:08:36 http/chunked.js c=100 len=64 n=1 benchmarker='wrk' 0.05 % ±0.26% ±0.34% ±0.44% 01:08:36 http/chunked.js c=100 len=64 n=4 benchmarker='wrk' 0.02 % ±0.29% ±0.39% ±0.50% 01:08:36 http/chunked.js c=100 len=64 n=8 benchmarker='wrk' -0.06 % ±0.30% ±0.40% ±0.52% 01:08:36 http/client-request-body.js method='end' len=1024 type='asc' dur=5 -3.97 % ±7.03% ±9.40% ±12.32% 01:08:36 http/client-request-body.js method='end' len=1024 type='buf' dur=5 2.47 % ±5.50% ±7.31% ±9.52% 01:08:36 http/client-request-body.js method='end' len=1024 type='utf' dur=5 0.22 % ±6.97% ±9.28% ±12.09% 01:08:36 http/client-request-body.js method='end' len=256 type='asc' dur=5 -0.82 % ±5.28% ±7.03% ±9.17% 01:08:36 http/client-request-body.js method='end' len=256 type='buf' dur=5 ** 7.86 % ±4.86% ±6.52% ±8.58% 01:08:36 http/client-request-body.js method='end' len=256 type='utf' dur=5 1.59 % ±7.22% ±9.61% ±12.52% 01:08:36 http/client-request-body.js method='end' len=32 type='asc' dur=5 3.82 % ±4.82% ±6.42% ±8.38% 01:08:36 http/client-request-body.js method='end' len=32 type='buf' dur=5 0.63 % ±6.61% ±8.80% ±11.46% 01:08:36 http/client-request-body.js method='end' len=32 type='utf' dur=5 -2.99 % ±4.55% ±6.09% ±8.00% 01:08:36 http/client-request-body.js method='write' len=1024 type='asc' dur=5 0.64 % ±6.68% ±8.88% ±11.56% 01:08:36 http/client-request-body.js method='write' len=1024 type='buf' dur=5 0.22 % ±3.90% ±5.21% ±6.84% 01:08:36 http/client-request-body.js method='write' len=1024 type='utf' dur=5 1.71 % ±5.79% ±7.70% ±10.02% 01:08:36 http/client-request-body.js method='write' len=256 type='asc' dur=5 -0.44 % ±5.99% ±7.97% ±10.37% 01:08:36 http/client-request-body.js method='write' len=256 type='buf' dur=5 -0.39 % ±5.22% ±6.95% ±9.06% 01:08:36 http/client-request-body.js method='write' len=256 type='utf' dur=5 0.22 % ±6.86% ±9.13% ±11.89% 01:08:36 http/client-request-body.js method='write' len=32 type='asc' dur=5 -0.60 % ±6.55% ±8.71% ±11.35% 01:08:36 http/client-request-body.js method='write' len=32 type='buf' dur=5 3.31 % ±6.31% ±8.39% ±10.92% 01:08:36 http/client-request-body.js method='write' len=32 type='utf' dur=5 -3.25 % ±6.39% ±8.50% ±11.06% 01:08:36 http/cluster.js c=500 len=102400 type='buffer' benchmarker='wrk' -2.62 % ±4.47% ±5.95% ±7.75% 01:08:36 http/cluster.js c=500 len=102400 type='bytes' benchmarker='wrk' 0.55 % ±3.66% ±4.87% ±6.34% 01:08:36 http/cluster.js c=500 len=1024 type='buffer' benchmarker='wrk' -3.16 % ±3.20% ±4.25% ±5.54% 01:08:36 http/cluster.js c=500 len=1024 type='bytes' benchmarker='wrk' *** -7.76 % ±3.32% ±4.42% ±5.77% 01:08:36 http/cluster.js c=500 len=4 type='buffer' benchmarker='wrk' *** -8.73 % ±3.70% ±4.92% ±6.40% 01:08:36 http/cluster.js c=500 len=4 type='bytes' benchmarker='wrk' *** -8.26 % ±3.37% ±4.48% ±5.83% 01:08:36 http/cluster.js c=50 len=102400 type='buffer' benchmarker='wrk' * -5.34 % ±4.15% ±5.52% ±7.19% 01:08:36 http/cluster.js c=50 len=102400 type='bytes' benchmarker='wrk' 2.04 % ±5.20% ±6.92% ±9.01% 01:08:36 http/cluster.js c=50 len=1024 type='buffer' benchmarker='wrk' *** -6.31 % ±3.55% ±4.72% ±6.14% 01:08:36 http/cluster.js c=50 len=1024 type='bytes' benchmarker='wrk' *** -6.75 % ±3.86% ±5.14% ±6.69% 01:08:36 http/cluster.js c=50 len=4 type='buffer' benchmarker='wrk' * -4.56 % ±3.99% ±5.31% ±6.93% 01:08:36 http/cluster.js c=50 len=4 type='bytes' benchmarker='wrk' * -4.90 % ±4.07% ±5.42% ±7.05% 01:08:36 http/create-clientrequest.js e=1 arg='options' url='idn' -2.00 % ±5.39% ±7.17% ±9.33% 01:08:36 http/create-clientrequest.js e=1 arg='options' url='long' 1.43 % ±4.58% ±6.10% ±7.94% 01:08:36 http/create-clientrequest.js e=1 arg='options' url='wpt' 0.72 % ±4.29% ±5.71% ±7.44% 01:08:36 http/create-clientrequest.js e=1 arg='string' url='idn' -3.89 % ±5.10% ±6.79% ±8.86% 01:08:36 http/create-clientrequest.js e=1 arg='string' url='long' -1.96 % ±4.46% ±5.94% ±7.72% 01:08:36 http/create-clientrequest.js e=1 arg='string' url='wpt' -2.83 % ±4.92% ±6.56% ±8.55% 01:08:36 http/create-clientrequest.js e=1 arg='URL' url='idn' -3.55 % ±4.66% ±6.19% ±8.06% 01:08:36 http/create-clientrequest.js e=1 arg='URL' url='long' -4.42 % ±4.68% ±6.22% ±8.10% 01:08:36 http/create-clientrequest.js e=1 arg='URL' url='wpt' -0.90 % ±5.01% ±6.68% ±8.73% 01:08:36 http/end-vs-write-end.js method='end' c=100 len=1048576 type='asc' benchmarker='wrk' 3.03 % ±3.87% ±5.15% ±6.70% 01:08:36 http/end-vs-write-end.js method='end' c=100 len=1048576 type='buf' benchmarker='wrk' -3.43 % ±5.62% ±7.47% ±9.73% 01:08:36 http/end-vs-write-end.js method='end' c=100 len=1048576 type='utf' benchmarker='wrk' * 3.17 % ±3.06% ±4.07% ±5.30% 01:08:36 http/end-vs-write-end.js method='end' c=100 len=131072 type='asc' benchmarker='wrk' -0.98 % ±2.11% ±2.81% ±3.66% 01:08:36 http/end-vs-write-end.js method='end' c=100 len=131072 type='buf' benchmarker='wrk' -3.16 % ±3.62% ±4.82% ±6.27% 01:08:36 http/end-vs-write-end.js method='end' c=100 len=131072 type='utf' benchmarker='wrk' 2.92 % ±2.95% ±3.94% ±5.15% 01:08:36 http/end-vs-write-end.js method='end' c=100 len=262144 type='asc' benchmarker='wrk' 0.41 % ±2.48% ±3.30% ±4.30% 01:08:36 http/end-vs-write-end.js method='end' c=100 len=262144 type='buf' benchmarker='wrk' -0.58 % ±4.48% ±5.96% ±7.77% 01:08:36 http/end-vs-write-end.js method='end' c=100 len=262144 type='utf' benchmarker='wrk' -0.14 % ±2.62% ±3.49% ±4.55% 01:08:36 http/end-vs-write-end.js method='end' c=100 len=65536 type='asc' benchmarker='wrk' 1.38 % ±2.54% ±3.37% ±4.39% 01:08:36 http/end-vs-write-end.js method='end' c=100 len=65536 type='buf' benchmarker='wrk' 5.17 % ±5.55% ±7.39% ±9.63% 01:08:36 http/end-vs-write-end.js method='end' c=100 len=65536 type='utf' benchmarker='wrk' -0.43 % ±2.32% ±3.09% ±4.02% 01:08:36 http/end-vs-write-end.js method='write' c=100 len=1048576 type='asc' benchmarker='wrk' 1.19 % ±4.54% ±6.04% ±7.86% 01:08:36 http/end-vs-write-end.js method='write' c=100 len=1048576 type='buf' benchmarker='wrk' * -5.06 % ±4.72% ±6.29% ±8.18% 01:08:36 http/end-vs-write-end.js method='write' c=100 len=1048576 type='utf' benchmarker='wrk' 2.88 % ±6.18% ±8.22% ±10.70% 01:08:36 http/end-vs-write-end.js method='write' c=100 len=131072 type='asc' benchmarker='wrk' 2.81 % ±4.81% ±6.39% ±8.32% 01:08:36 http/end-vs-write-end.js method='write' c=100 len=131072 type='buf' benchmarker='wrk' -1.93 % ±3.37% ±4.49% ±5.84% 01:08:36 http/end-vs-write-end.js method='write' c=100 len=131072 type='utf' benchmarker='wrk' 1.17 % ±2.59% ±3.44% ±4.48% 01:08:36 http/end-vs-write-end.js method='write' c=100 len=262144 type='asc' benchmarker='wrk' -2.48 % ±4.10% ±5.47% ±7.15% 01:08:36 http/end-vs-write-end.js method='write' c=100 len=262144 type='buf' benchmarker='wrk' 0.70 % ±3.95% ±5.25% ±6.84% 01:08:36 http/end-vs-write-end.js method='write' c=100 len=262144 type='utf' benchmarker='wrk' ** 4.06 % ±2.96% ±3.95% ±5.19% 01:08:36 http/end-vs-write-end.js method='write' c=100 len=65536 type='asc' benchmarker='wrk' 0.82 % ±2.80% ±3.72% ±4.85% 01:08:36 http/end-vs-write-end.js method='write' c=100 len=65536 type='buf' benchmarker='wrk' -1.06 % ±4.90% ±6.52% ±8.49% 01:08:36 http/end-vs-write-end.js method='write' c=100 len=65536 type='utf' benchmarker='wrk' -1.86 % ±3.31% ±4.40% ±5.75% 01:08:36 http/headers.js len=100 n=1000 benchmarker='wrk' 0.54 % ±2.53% ±3.36% ±4.38% 01:08:36 http/headers.js len=100 n=10 benchmarker='wrk' 0.72 % ±4.92% ±6.55% ±8.52% 01:08:36 http/headers.js len=1 n=1000 benchmarker='wrk' -0.23 % ±3.17% ±4.23% ±5.54% 01:08:36 http/headers.js len=1 n=10 benchmarker='wrk' -1.21 % ±4.17% ±5.55% ±7.23% |
@bmeck the problem is that i don’t consider the process object to be problematic, and more importantly i consider a number of properties of it being available as globals to be critical. The request is to not avoid the harder but more correct task of sequestering the actually dangerous parts rather than deprecating what is overwhelmingly the means of environment detection, cross-package config (NODE_ENV, BABEL_ENV, and many others), nextTick (which isn’t a global like setTimeout but is just as important), the cwd which is how tons of tools locate the current project dir, etc - saying “you can just import the module” minimizes the herculean task it will be for the ecosystem to actually do that, and imo simultaneously hugely overexaggerates the security benefits of this change. |
@ljharb I do not believe that approach to be more correct. With the dependencies remapping in policies, you can control the access to modules. However, we cannot well control access to globals and their properties without something like Compartments and the ECMA262 PR to allow them. As it stands, we simply do not have the proper mechanism to control globals in the way you describe at a granular level. |
I’d invite you to consider that the consequence of not having the mechanisms yet means that you simply can’t get the security properties you want yet, instead of meaning that it’s ok to worsen the DX of ESM users in the meantime. |
@guybedford I don't think that decrease is acceptable. We work a lot to bring up perf there, and I'm not sure we should be decreasing it. |
@nodejs/tsc what do you think? |
I'm going to be spending some time profiling what is going on. I don't see code related to this in inspector profiles or --prof that would make the time difference make sense. I'm wondering if something odd is happening and will have to dig into opts/deopts a bit. The only other alternative for what is causing stuff is the context wrapper but I would have to talk to V8 about why it isn't being optimized away which might take time. Prof with PR:$ node --prof-process with.log
Statistical profiling result from with.log, (4502 ticks, 1408 unaccounted, 0 excluded).
[Shared libraries]:
ticks total nonlib name
10 0.2% /usr/lib/system/libsystem_pthread.dylib
8 0.2% /usr/lib/system/libsystem_platform.dylib
3 0.1% /usr/lib/system/libsystem_malloc.dylib
[JavaScript]:
ticks total nonlib name
65 1.4% 1.5% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
51 1.1% 1.1% LazyCompile: *onwrite _stream_writable.js:445:17
46 1.0% 1.0% LazyCompile: *resOnFinish _http_server.js:617:21
45 1.0% 1.0% LazyCompile: *clearBuffer _stream_writable.js:498:21
44 1.0% 1.0% LazyCompile: *assignSocket _http_server.js:203:62
34 0.8% 0.8% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
27 0.6% 0.6% LazyCompile: *parserOnIncoming _http_server.js:662:26
26 0.6% 0.6% LazyCompile: *Readable.read _stream_readable.js:400:35
23 0.5% 0.5% LazyCompile: *write_ _http_outgoing.js:564:16
23 0.5% 0.5% LazyCompile: *socketListenerWrap _http_server.js:780:37
22 0.5% 0.5% LazyCompile: *emitReadable_ _stream_readable.js:560:23
20 0.4% 0.4% LazyCompile: *nextTick internal/process/task_queues.js:109:18
17 0.4% 0.4% LazyCompile: *_storeHeader _http_outgoing.js:285:22
16 0.4% 0.4% LazyCompile: *readableAddChunk _stream_readable.js:224:26
16 0.4% 0.4% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
16 0.4% 0.4% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
15 0.3% 0.3% LazyCompile: *setHeader _http_outgoing.js:462:57
14 0.3% 0.3% LazyCompile: *resume_ _stream_readable.js:920:17
13 0.3% 0.3% LazyCompile: *_finish _http_server.js:169:52
13 0.3% 0.3% LazyCompile: *ReadableState _stream_readable.js:72:23
13 0.3% 0.3% LazyCompile: *<anonymous> internal/util/debuglog.js:57:18
12 0.3% 0.3% LazyCompile: *Readable.removeAllListeners _stream_readable.js:861:49
11 0.2% 0.2% LazyCompile: *debug internal/util/debuglog.js:45:35
10 0.2% 0.2% RegExp: [^\t\x20-\x7e\x80-\xff]
10 0.2% 0.2% LazyCompile: *resetHeadersTimeoutOnReqEnd _http_server.js:796:37
10 0.2% 0.2% LazyCompile: *endReadableNT _stream_readable.js:1124:23
10 0.2% 0.2% LazyCompile: *Writable.uncork _stream_writable.js:311:37
9 0.2% 0.2% LazyCompile: *parserOnMessageComplete _http_common.js:135:33
8 0.2% 0.2% LazyCompile: *ServerResponse _http_server.js:145:24
7 0.2% 0.2% RegExp: ^[\^_`a-zA-Z\-0-9!#$%&'*+.|~]+$
7 0.2% 0.2% LazyCompile: *setStreamTimeout internal/stream_base_commons.js:202:26
7 0.2% 0.2% LazyCompile: *onFinish _http_outgoing.js:657:18
6 0.1% 0.1% LazyCompile: *matchKnownFields _http_incoming.js:139:26
5 0.1% 0.1% LazyCompile: *updateOutgoingData _http_server.js:445:28
5 0.1% 0.1% LazyCompile: *removeListener events.js:320:28
5 0.1% 0.1% LazyCompile: *emit events.js:153:44
4 0.1% 0.1% LazyCompile: *byteLength buffer.js:488:20
4 0.1% 0.1% LazyCompile: *Readable.on _stream_readable.js:815:33
3 0.1% 0.1% LazyCompile: *removeAllListeners events.js:376:32
3 0.1% 0.1% LazyCompile: *nop _stream_writable.js:54:13
3 0.1% 0.1% LazyCompile: *Writable.write _stream_writable.js:275:36
2 0.0% 0.0% LazyCompile: *unenroll timers.js:62:18
2 0.0% 0.0% LazyCompile: *onParserExecute _http_server.js:525:25
2 0.0% 0.0% LazyCompile: *afterWrite _stream_writable.js:479:20
2 0.0% 0.0% LazyCompile: *_unrefTimer net.js:344:52
1 0.0% 0.0% LazyCompile: *writeHead _http_server.js:234:19
1 0.0% 0.0% LazyCompile: *insert internal/timers.js:305:16
1 0.0% 0.0% LazyCompile: *emitCloseNT _http_server.js:655:21
1 0.0% 0.0% LazyCompile: *append internal/linkedlist.js:29:16
1 0.0% 0.0% LazyCompile: *_send _http_outgoing.js:222:49
1 0.0% 0.0% LazyCompile: *Writable.cork _stream_writable.js:307:35
[C++]:
ticks total nonlib name
1606 35.7% 35.8% T __ZN2v88internal10ClassScope28GetUnresolvedPrivateNameTailEv
46 1.0% 1.0% t _szone_malloc_should_clear
43 1.0% 1.0% T __ZN2v86Object3GetENS_5LocalINS_7ContextEEEj
37 0.8% 0.8% T node::StreamBase::Writev(v8::FunctionCallbackInfo<v8::Value> const&)
30 0.7% 0.7% T void node::StreamBase::JSMethod<&(node::StreamBase::Writev(v8::FunctionCallbackInfo<v8::Value> const&))>(v8::FunctionCallbackInfo<v8::Value> const&)
30 0.7% 0.7% T node::native_module::NativeModuleEnv::CompileFunction(v8::FunctionCallbackInfo<v8::Value> const&)
28 0.6% 0.6% T __ZNK2v86String9WriteUtf8EPNS_7IsolateEPciPii
26 0.6% 0.6% T _munmap
19 0.4% 0.4% T ___mach_stack_logging_enumerate_records
16 0.4% 0.4% t __ZN2v812_GLOBAL__N_114CallDepthScopeILb0EEC1EPNS_8internal7IsolateENS_5LocalINS_7ContextEEE
16 0.4% 0.4% T __ZN2v88Function4CallENS_5LocalINS_7ContextEEENS1_INS_5ValueEEEiPS5_
15 0.3% 0.3% t node::LibuvStreamWrap::Initialize(v8::Local<v8::Object>, v8::Local<v8::Value>, v8::Local<v8::Context>, void*)::$_0::__invoke(v8::FunctionCallbackInfo<v8::Value> const&)
15 0.3% 0.3% T __ZN2v811HandleScope10InitializeEPNS_7IsolateE
14 0.3% 0.3% T ___malloc_init
12 0.3% 0.3% t node::(anonymous namespace)::Parser::Proxy<int (node::(anonymous namespace)::Parser::*)(), &(node::(anonymous namespace)::Parser::on_headers_complete())>::Raw(llhttp__internal_s*)
12 0.3% 0.3% t __ZN2v88internal6String7FlattenEPNS0_7IsolateENS0_6HandleIS1_EENS0_14AllocationTypeE
12 0.3% 0.3% T node::ParseEncoding(v8::Isolate*, v8::Local<v8::Value>, node::encoding)
11 0.2% 0.2% t _update_cache_for_file_streams
11 0.2% 0.2% t _small_free_list_remove_ptr_no_clear
11 0.2% 0.2% T _vm_region_recurse_64
10 0.2% 0.2% t __enlarge
10 0.2% 0.2% T node::StringBytes::StorageSize(v8::Isolate*, v8::Local<v8::Value>, node::encoding)
9 0.2% 0.2% t node::StreamBase::Write(uv_buf_t*, unsigned long, uv_stream_s*, v8::Local<v8::Object>)
9 0.2% 0.2% T node::InternalCallbackScope::Close()
8 0.2% 0.2% t __os_nospin_lock_unlock_slow
8 0.2% 0.2% T node::InternalMakeCallback(node::Environment*, v8::Local<v8::Object>, v8::Local<v8::Function>, int, v8::Local<v8::Value>*, node::async_context)
8 0.2% 0.2% T __simple_dprintf
8 0.2% 0.2% T ___channel_get_opt
8 0.2% 0.2% T __ZNK2v85Value8ToStringENS_5LocalINS_7ContextEEE
7 0.2% 0.2% t node::(anonymous namespace)::StringPtr::Reset()
7 0.2% 0.2% T ___carbon_delete
6 0.1% 0.1% T node::StringBytes::Write(v8::Isolate*, char*, unsigned long, v8::Local<v8::Value>, node::encoding, int*)
6 0.1% 0.1% T node::AsyncWrap::EmitTraceEventAfter(node::AsyncWrap::ProviderType, double)
6 0.1% 0.1% T __ZN2v87Isolate17GetCurrentContextEv
6 0.1% 0.1% T __ZN2v87Integer15NewFromUnsignedEPNS_7IsolateEj
6 0.1% 0.1% T __ZN2v87Context29GetNumberOfEmbedderDataFieldsEv
6 0.1% 0.1% T __ZN2v86String14NewFromOneByteEPNS_7IsolateEPKhNS_13NewStringTypeEi
5 0.1% 0.1% t node::NodeArrayBufferAllocator::Free(void*, unsigned long)
5 0.1% 0.1% t node::MaybeStackBuffer<char, 1024ul>::AllocateSufficientStorage(unsigned long)
5 0.1% 0.1% t node::AsyncHooks::pop_async_id(double)
5 0.1% 0.1% T node::Utf8Value::Utf8Value(v8::Isolate*, v8::Local<v8::Value>)
5 0.1% 0.1% T node::ParseEncoding(char const*, node::encoding)
5 0.1% 0.1% T node::LibuvStreamWrap::DoTryWrite(uv_buf_t**, unsigned long*)
5 0.1% 0.1% T node::Environment::GetNow()
5 0.1% 0.1% T node::Emit(node::Environment*, double, node::AsyncHooks::Fields, v8::Local<v8::Function>)
5 0.1% 0.1% T node::AsyncWrap::MakeCallback(v8::Local<v8::Function>, int, v8::Local<v8::Value>*)
5 0.1% 0.1% T _free
5 0.1% 0.1% T __ZNK2v86String12WriteOneByteEPNS_7IsolateEPhiii
5 0.1% 0.1% T __ZNK2v85Value10IsFunctionEv
4 0.1% 0.1% t node::MaybeStackBuffer<uv_buf_t, 16ul>::AllocateSufficientStorage(unsigned long)
4 0.1% 0.1% t node::Buffer::(anonymous namespace)::ByteLengthUtf8(v8::FunctionCallbackInfo<v8::Value> const&)
4 0.1% 0.1% t node::(anonymous namespace)::Parser::OnStreamRead(long, uv_buf_t const&)
4 0.1% 0.1% t _free_small
4 0.1% 0.1% t _allocate_pages_securely
4 0.1% 0.1% t _allocate_pages
4 0.1% 0.1% t __ZN2v88internal12_GLOBAL__N_124ProbeInstantiationsCacheEPNS0_7IsolateEiNS1_11CachingModeE
4 0.1% 0.1% t __ZN2v88internal12_GLOBAL__N_117InstantiateObjectEPNS0_7IsolateENS0_6HandleINS0_18ObjectTemplateInfoEEENS4_INS0_10JSReceiverEEEbb
4 0.1% 0.1% t __ZN2v812_GLOBAL__N_114CallDepthScopeILb1EEC1EPNS_8internal7IsolateENS_5LocalINS_7ContextEEE
4 0.1% 0.1% T node::DTRACE_HTTP_SERVER_RESPONSE(v8::FunctionCallbackInfo<v8::Value> const&)
4 0.1% 0.1% T node::DTRACE_HTTP_SERVER_REQUEST(v8::FunctionCallbackInfo<v8::Value> const&)
4 0.1% 0.1% T node::AsyncWrap::EmitTraceEventBefore()
4 0.1% 0.1% T __ZN2v85Array3NewEPNS_7IsolateEPNS_5LocalINS_5ValueEEEm
4 0.1% 0.1% T __ZN2v811HandleScopeD1Ev
4 0.1% 0.1% T __ZN2v811HandleScopeC1EPNS_7IsolateE
3 0.1% 0.1% t node::MaybeStackBuffer<char, 1024ul>::SetLength(unsigned long)
3 0.1% 0.1% t node::(anonymous namespace)::Parser::Proxy<int (node::(anonymous namespace)::Parser::*)(), &(node::(anonymous namespace)::Parser::on_message_complete())>::Raw(llhttp__internal_s*)
3 0.1% 0.1% T non-virtual thunk to node::LibuvStreamWrap::DoTryWrite(uv_buf_t**, unsigned long*)
3 0.1% 0.1% T node::TTYWrap::New(v8::FunctionCallbackInfo<v8::Value> const&)
3 0.1% 0.1% T node::InternalCallbackScope::InternalCallbackScope(node::Environment*, v8::Local<v8::Object>, node::async_context const&, node::InternalCallbackScope::ResourceExpectation)
3 0.1% 0.1% T node::Buffer::HasInstance(v8::Local<v8::Value>)
3 0.1% 0.1% T _mach_msg
3 0.1% 0.1% T __ZNK2v86String6LengthEv
3 0.1% 0.1% T __ZNK2v86String10Utf8LengthEPNS_7IsolateE
3 0.1% 0.1% T __ZNK2v85Value17IsArrayBufferViewEv
3 0.1% 0.1% T __ZNK2v85Array6LengthEv
3 0.1% 0.1% T __ZN2v88internal25FunctionCallbackArgumentsC1EPNS0_7IsolateENS0_6ObjectENS0_10HeapObjectES4_S5_Pmi
3 0.1% 0.1% T __ZN2v87Isolate9InContextEv
2 0.0% 0.0% t node::LibuvStreamWrap::ReadStart()::$_2::__invoke(uv_stream_s*, long, uv_buf_t const*)
2 0.0% 0.0% t node::(anonymous namespace)::StringPtr::Update(char const*, unsigned long)
2 0.0% 0.0% t node::(anonymous namespace)::Parser::Proxy<int (node::(anonymous namespace)::Parser::*)(char const*, unsigned long), &(node::(anonymous namespace)::Parser::on_url(char const*, unsigned long))>::Raw(llhttp__internal_s*, char const*, unsigned long)
2 0.0% 0.0% t node::(anonymous namespace)::Parser::Proxy<int (node::(anonymous namespace)::Parser::*)(char const*, unsigned long), &(node::(anonymous namespace)::Parser::on_header_field(char const*, unsigned long))>::Raw(llhttp__internal_s*, char const*, unsigned long)
2 0.0% 0.0% t node::(anonymous namespace)::Parser::Execute(char const*, unsigned long)
2 0.0% 0.0% t __read_images
2 0.0% 0.0% t __os_nospin_lock_lock_slow
2 0.0% 0.0% t __malloc_initialize
2 0.0% 0.0% T node::binding::GetInternalBinding(v8::FunctionCallbackInfo<v8::Value> const&)
2 0.0% 0.0% T node::LibuvStreamWrap::OnUvRead(long, uv_buf_t const*)
2 0.0% 0.0% T node::LibuvStreamWrap::OnUvAlloc(unsigned long, uv_buf_t*)
2 0.0% 0.0% T _mach_vm_purgable_control
2 0.0% 0.0% T __ZN2v87Isolate10GetCurrentEv
2 0.0% 0.0% T __ZN2v87Integer3NewEPNS_7IsolateEi
2 0.0% 0.0% T __ZN2v87Context5EnterEv
1 0.0% 0.0% t std::__1::__function::__func<node::(anonymous namespace)::Parser::OnStreamRead(long, uv_buf_t const&)::'lambda'(), std::__1::allocator<node::(anonymous namespace)::Parser::OnStreamRead(long, uv_buf_t const&)::'lambda'()>, void ()>::operator()()
1 0.0% 0.0% t non-virtual thunk to node::(anonymous namespace)::Parser::OnStreamAlloc(unsigned long)
1 0.0% 0.0% t node::fs::Read(v8::FunctionCallbackInfo<v8::Value> const&)
1 0.0% 0.0% t node::NodeArrayBufferAllocator::AllocateUninitialized(unsigned long)
1 0.0% 0.0% t node::MaybeStackBuffer<char, 1024ul>::SetLengthAndZeroTerminate(unsigned long)
1 0.0% 0.0% t node::LibuvStreamWrap::ReadStart()::$_1::__invoke(uv_handle_s*, unsigned long, uv_buf_t*)
1 0.0% 0.0% t node::(anonymous namespace)::Parser::Proxy<int (node::(anonymous namespace)::Parser::*)(char const*, unsigned long), &(node::(anonymous namespace)::Parser::on_header_value(char const*, unsigned long))>::Raw(llhttp__internal_s*, char const*, unsigned long)
1 0.0% 0.0% t node::(anonymous namespace)::Parser::Proxy<int (node::(anonymous namespace)::Parser::*)(), &(node::(anonymous namespace)::Parser::on_message_begin())>::Raw(llhttp__internal_s*)
1 0.0% 0.0% t node::(anonymous namespace)::Parser::New(v8::FunctionCallbackInfo<v8::Value> const&)
1 0.0% 0.0% t node::(anonymous namespace)::Parser::MaybePause()
1 0.0% 0.0% t node::(anonymous namespace)::Parser::CreateHeaders()
1 0.0% 0.0% t _unwind_stack_from_table_index
1 0.0% 0.0% t _insert_node
1 0.0% 0.0% t __cxxabiv1::do_free(void*)
1 0.0% 0.0% t ___vfprintf
1 0.0% 0.0% t __ZNSt3__16vectorIdNS_9allocatorIdEEE21__push_back_slow_pathIRKdEEvOT_
1 0.0% 0.0% t __ZN2v88internal22HandleScopeImplementer12EnterContextENS0_7ContextE
1 0.0% 0.0% t __ZN2v88internal14LookupIterator17PropertyOrElementEPNS0_7IsolateENS0_6HandleINS0_6ObjectEEENS4_INS0_4NameEEENS4_INS0_10JSReceiverEEENS1_13ConfigurationE
1 0.0% 0.0% t __ZN2v84base19TemplateHashMapImplIPvS2_NS0_26HashEqualityThenKeyMatcherIS2_PFbS2_S2_EEENS0_23DefaultAllocationPolicyEE14LookupOrInsertIZNS8_14LookupOrInsertERKS2_jS7_EUlvE_EEPNS0_20TemplateHashMapEntryIS2_S2_EESB_jRKT_S7_
1 0.0% 0.0% T non-virtual thunk to node::LibuvStreamWrap::GetAsyncWrap()
1 0.0% 0.0% T node::TCPWrap::Bind6(v8::FunctionCallbackInfo<v8::Value> const&)
1 0.0% 0.0% T node::NodePlatform::CallOnWorkerThread(std::__1::unique_ptr<v8::Task, std::__1::default_delete<v8::Task> >)
1 0.0% 0.0% T node::AsyncWrap::EmitAfter(node::Environment*, double)
1 0.0% 0.0% T _malloc
1 0.0% 0.0% T _mach_vm_allocate
1 0.0% 0.0% T _mach_msg_server_once
1 0.0% 0.0% T __os_nospin_lock_unlock
1 0.0% 0.0% T __ZNK2v88internal12RootIndexMap6LookupEmPNS0_9RootIndexE
1 0.0% 0.0% T __ZNK2v86String17IsExternalOneByteEv
1 0.0% 0.0% T __ZNK2v85Value6IsTrueEv
1 0.0% 0.0% T __ZNK2v85Value12IntegerValueENS_5LocalINS_7ContextEEE
1 0.0% 0.0% T __ZN2v88internal21PerIsolateAssertScopeILNS0_20PerIsolateAssertTypeE0ELb1EE9IsAllowedEPNS0_7IsolateE
1 0.0% 0.0% T __ZN2v88internal10ApiNatives17InstantiateObjectEPNS0_7IsolateENS0_6HandleINS0_18ObjectTemplateInfoEEENS4_INS0_10JSReceiverEEE
1 0.0% 0.0% T __ZN2v86Object32SetAlignedPointerInInternalFieldEiPv
[Summary]:
ticks total nonlib name
712 15.8% 15.9% JavaScript
2361 52.4% 52.7% C++
54 1.2% 1.2% GC
21 0.5% Shared libraries
1408 31.3% Unaccounted
[C++ entry points]:
ticks cpp total name
1465 79.1% 32.5% T __ZN2v88internal10ClassScope28GetUnresolvedPrivateNameTailEv
37 2.0% 0.8% T node::StreamBase::Writev(v8::FunctionCallbackInfo<v8::Value> const&)
35 1.9% 0.8% t _szone_malloc_should_clear
34 1.8% 0.8% T __ZN2v86Object3GetENS_5LocalINS_7ContextEEEj
28 1.5% 0.6% T __ZNK2v86String9WriteUtf8EPNS_7IsolateEPciPii
14 0.8% 0.3% T ___mach_stack_logging_enumerate_records
12 0.6% 0.3% t __ZN2v812_GLOBAL__N_114CallDepthScopeILb0EEC1EPNS_8internal7IsolateENS_5LocalINS_7ContextEEE
12 0.6% 0.3% T void node::StreamBase::JSMethod<&(node::StreamBase::Writev(v8::FunctionCallbackInfo<v8::Value> const&))>(v8::FunctionCallbackInfo<v8::Value> const&)
12 0.6% 0.3% T node::ParseEncoding(v8::Isolate*, v8::Local<v8::Value>, node::encoding)
12 0.6% 0.3% T ___malloc_init
10 0.5% 0.2% T node::StringBytes::StorageSize(v8::Isolate*, v8::Local<v8::Value>, node::encoding)
10 0.5% 0.2% T _vm_region_recurse_64
9 0.5% 0.2% t node::StreamBase::Write(uv_buf_t*, unsigned long, uv_stream_s*, v8::Local<v8::Object>)
9 0.5% 0.2% t _update_cache_for_file_streams
8 0.4% 0.2% T __ZNK2v85Value8ToStringENS_5LocalINS_7ContextEEE
7 0.4% 0.2% t __enlarge
7 0.4% 0.2% T __simple_dprintf
7 0.4% 0.2% T __ZN2v811HandleScope10InitializeEPNS_7IsolateE
6 0.3% 0.1% t _small_free_list_remove_ptr_no_clear
6 0.3% 0.1% T node::StringBytes::Write(v8::Isolate*, char*, unsigned long, v8::Local<v8::Value>, node::encoding, int*)
5 0.3% 0.1% t node::NodeArrayBufferAllocator::Free(void*, unsigned long)
5 0.3% 0.1% t node::MaybeStackBuffer<char, 1024ul>::AllocateSufficientStorage(unsigned long)
5 0.3% 0.1% T node::Utf8Value::Utf8Value(v8::Isolate*, v8::Local<v8::Value>)
5 0.3% 0.1% T node::ParseEncoding(char const*, node::encoding)
5 0.3% 0.1% T node::LibuvStreamWrap::DoTryWrite(uv_buf_t**, unsigned long*)
5 0.3% 0.1% T node::Environment::GetNow()
5 0.3% 0.1% T _free
5 0.3% 0.1% T __ZNK2v86String12WriteOneByteEPNS_7IsolateEPhiii
5 0.3% 0.1% T __ZN2v87Integer15NewFromUnsignedEPNS_7IsolateEj
4 0.2% 0.1% t node::MaybeStackBuffer<uv_buf_t, 16ul>::AllocateSufficientStorage(unsigned long)
4 0.2% 0.1% t _free_small
4 0.2% 0.1% t _allocate_pages_securely
4 0.2% 0.1% t _allocate_pages
4 0.2% 0.1% T node::DTRACE_HTTP_SERVER_RESPONSE(v8::FunctionCallbackInfo<v8::Value> const&)
4 0.2% 0.1% T node::DTRACE_HTTP_SERVER_REQUEST(v8::FunctionCallbackInfo<v8::Value> const&)
3 0.2% 0.1% t node::MaybeStackBuffer<char, 1024ul>::SetLength(unsigned long)
3 0.2% 0.1% T non-virtual thunk to node::LibuvStreamWrap::DoTryWrite(uv_buf_t**, unsigned long*)
3 0.2% 0.1% T node::Buffer::HasInstance(v8::Local<v8::Value>)
3 0.2% 0.1% T __ZNK2v86String6LengthEv
3 0.2% 0.1% T __ZNK2v86String10Utf8LengthEPNS_7IsolateE
3 0.2% 0.1% T __ZNK2v85Value17IsArrayBufferViewEv
3 0.2% 0.1% T __ZNK2v85Array6LengthEv
3 0.2% 0.1% T __ZN2v87Isolate17GetCurrentContextEv
3 0.2% 0.1% T __ZN2v811HandleScopeD1Ev
3 0.2% 0.1% T __ZN2v811HandleScopeC1EPNS_7IsolateE
2 0.1% 0.0% t node::Buffer::(anonymous namespace)::ByteLengthUtf8(v8::FunctionCallbackInfo<v8::Value> const&)
1 0.1% 0.0% t node::NodeArrayBufferAllocator::AllocateUninitialized(unsigned long)
1 0.1% 0.0% t node::MaybeStackBuffer<char, 1024ul>::SetLengthAndZeroTerminate(unsigned long)
1 0.1% 0.0% t _unwind_stack_from_table_index
1 0.1% 0.0% t _insert_node
1 0.1% 0.0% t __malloc_initialize
1 0.1% 0.0% t __ZN2v88internal6String7FlattenEPNS0_7IsolateENS0_6HandleIS1_EENS0_14AllocationTypeE
1 0.1% 0.0% T non-virtual thunk to node::LibuvStreamWrap::GetAsyncWrap()
1 0.1% 0.0% T _malloc
1 0.1% 0.0% T __ZNK2v86String17IsExternalOneByteEv
1 0.1% 0.0% T __ZNK2v85Value6IsTrueEv
[Bottom up (heavy) profile]:
Note: percentage shows a share of a particular caller in the total
amount of its parent calls.
Callers occupying less than 1.0% are not shown.
ticks parent name
1606 35.7% T __ZN2v88internal10ClassScope28GetUnresolvedPrivateNameTailEv
318 19.8% T __ZN2v88internal10ClassScope28GetUnresolvedPrivateNameTailEv
116 36.5% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
115 99.1% LazyCompile: *parserOnIncoming _http_server.js:662:26
115 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
42 13.2% LazyCompile: *_storeHeader _http_outgoing.js:285:22
41 97.6% LazyCompile: *write_ _http_outgoing.js:564:16
41 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
40 97.6% LazyCompile: *parserOnIncoming _http_server.js:662:26
1 2.4% LazyCompile: *emit events.js:153:44
1 2.4% LazyCompile: *writeHead _http_server.js:234:19
1 100.0% LazyCompile: ~_implicitHeader _http_server.js:229:68
1 100.0% LazyCompile: ~write_ _http_outgoing.js:564:16
35 11.0% LazyCompile: *Readable.read _stream_readable.js:400:35
26 74.3% LazyCompile: *resume_ _stream_readable.js:920:17
26 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
8 22.9% LazyCompile: *emitReadable_ _stream_readable.js:560:23
8 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
1 2.9% LazyCompile: *flow _stream_readable.js:944:14
1 100.0% LazyCompile: ~resume_ _stream_readable.js:920:17
1 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
32 10.1% LazyCompile: *clearBuffer _stream_writable.js:498:21
32 100.0% LazyCompile: *assignSocket _http_server.js:203:62
31 96.9% LazyCompile: *resOnFinish _http_server.js:617:21
28 90.3% LazyCompile: *onFinish _http_outgoing.js:657:18
3 9.7% LazyCompile: *emit events.js:153:44
1 3.1% LazyCompile: ~resOnFinish _http_server.js:617:21
1 100.0% LazyCompile: *emit events.js:153:44
6 1.9% LazyCompile: ~emitBeforeScript internal/async_hooks.js:345:26
6 100.0% LazyCompile: ~processTicksAndRejections internal/process/task_queues.js:65:35
4 1.3% LazyCompile: ~parserOnIncoming _http_server.js:662:26
3 75.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
1 25.0% LazyCompile: ~parserOnHeadersComplete _http_common.js:71:33
4 1.3% LazyCompile: ~<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
3 75.0% LazyCompile: ~emit events.js:153:44
3 100.0% LazyCompile: ~parserOnIncoming _http_server.js:662:26
3 100.0% LazyCompile: ~parserOnHeadersComplete _http_common.js:71:33
1 25.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
1 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
4 1.3% LazyCompile: *parserOnIncoming _http_server.js:662:26
4 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
222 13.8% LazyCompile: *clearBuffer _stream_writable.js:498:21
221 99.5% LazyCompile: *assignSocket _http_server.js:203:62
221 100.0% LazyCompile: *resOnFinish _http_server.js:617:21
217 98.2% LazyCompile: *onFinish _http_outgoing.js:657:18
217 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
4 1.8% LazyCompile: *emit events.js:153:44
4 100.0% LazyCompile: ~onFinish _http_outgoing.js:657:18
100 6.2% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
58 3.6% LazyCompile: *assignSocket _http_server.js:203:62
58 100.0% LazyCompile: *resOnFinish _http_server.js:617:21
55 94.8% LazyCompile: *onFinish _http_outgoing.js:657:18
55 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
55 100.0% LazyCompile: *afterWrite _stream_writable.js:479:20
3 5.2% LazyCompile: *emit events.js:153:44
3 100.0% LazyCompile: ~onFinish _http_outgoing.js:657:18
3 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
47 2.9% LazyCompile: *parserOnIncoming _http_server.js:662:26
47 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
43 2.7% LazyCompile: *resOnFinish _http_server.js:617:21
40 93.0% LazyCompile: *onFinish _http_outgoing.js:657:18
40 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
40 100.0% LazyCompile: *afterWrite _stream_writable.js:479:20
40 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
3 7.0% LazyCompile: *emit events.js:153:44
3 100.0% LazyCompile: ~onFinish _http_outgoing.js:657:18
3 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
3 100.0% LazyCompile: *afterWrite _stream_writable.js:479:20
37 2.3% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
36 97.3% LazyCompile: *parserOnIncoming _http_server.js:662:26
36 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
1 2.7% LazyCompile: *emit events.js:153:44
1 100.0% LazyCompile: ~parserOnIncoming _http_server.js:662:26
1 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
31 1.9% LazyCompile: *write_ _http_outgoing.js:564:16
31 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
30 96.8% LazyCompile: *parserOnIncoming _http_server.js:662:26
30 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
1 3.2% LazyCompile: *emit events.js:153:44
1 100.0% LazyCompile: ~parserOnIncoming _http_server.js:662:26
1 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
28 1.7% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
21 1.3% LazyCompile: *resume_ _stream_readable.js:920:17
21 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
17 1.1% LazyCompile: *setHeader _http_outgoing.js:462:57
17 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
16 94.1% LazyCompile: *parserOnIncoming _http_server.js:662:26
16 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
1 5.9% LazyCompile: *emit events.js:153:44
1 100.0% LazyCompile: ~parserOnIncoming _http_server.js:662:26
1 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
1408 31.3% UNKNOWN
1187 84.3% LazyCompile: *clearBuffer _stream_writable.js:498:21
1184 99.7% LazyCompile: *assignSocket _http_server.js:203:62
1184 100.0% LazyCompile: *resOnFinish _http_server.js:617:21
1149 97.0% LazyCompile: *onFinish _http_outgoing.js:657:18
1149 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
35 3.0% LazyCompile: *emit events.js:153:44
35 100.0% LazyCompile: ~onFinish _http_outgoing.js:657:18
123 8.7% LazyCompile: *Writable.uncork _stream_writable.js:311:37
123 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
121 98.4% LazyCompile: *parserOnIncoming _http_server.js:662:26
121 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
2 1.6% LazyCompile: *emit events.js:153:44
2 100.0% LazyCompile: ~parserOnIncoming _http_server.js:662:26
2 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
65 1.4% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
51 1.1% LazyCompile: *onwrite _stream_writable.js:445:17
40 78.4% LazyCompile: *clearBuffer _stream_writable.js:498:21
40 100.0% LazyCompile: *assignSocket _http_server.js:203:62
40 100.0% LazyCompile: *resOnFinish _http_server.js:617:21
38 95.0% LazyCompile: *onFinish _http_outgoing.js:657:18
38 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
2 5.0% LazyCompile: *emit events.js:153:44
2 100.0% LazyCompile: ~onFinish _http_outgoing.js:657:18
7 13.7% LazyCompile: *assignSocket _http_server.js:203:62
7 100.0% LazyCompile: *resOnFinish _http_server.js:617:21
6 85.7% LazyCompile: *onFinish _http_outgoing.js:657:18
6 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
6 100.0% LazyCompile: *afterWrite _stream_writable.js:479:20
1 14.3% LazyCompile: *emit events.js:153:44
1 100.0% LazyCompile: ~onFinish _http_outgoing.js:657:18
1 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
3 5.9% LazyCompile: *afterWriteDispatched internal/stream_base_commons.js:141:30
3 100.0% LazyCompile: *Writable.uncork _stream_writable.js:311:37
3 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
3 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
3 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
1 2.0% LazyCompile: *Writable.uncork _stream_writable.js:311:37
1 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
1 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
1 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
46 1.0% t _szone_malloc_should_clear
32 69.6% LazyCompile: *clearBuffer _stream_writable.js:498:21
32 100.0% LazyCompile: *assignSocket _http_server.js:203:62
32 100.0% LazyCompile: *resOnFinish _http_server.js:617:21
30 93.8% LazyCompile: *onFinish _http_outgoing.js:657:18
30 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
2 6.3% LazyCompile: *emit events.js:153:44
2 100.0% LazyCompile: ~onFinish _http_outgoing.js:657:18
8 17.4% T __ZN2v88internal10ClassScope28GetUnresolvedPrivateNameTailEv
7 87.5% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
6 85.7% LazyCompile: *parserOnIncoming _http_server.js:662:26
6 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
1 14.3% LazyCompile: ~emit events.js:153:44
1 100.0% LazyCompile: ~parserOnIncoming _http_server.js:662:26
1 100.0% LazyCompile: ~parserOnHeadersComplete _http_common.js:71:33
1 12.5% LazyCompile: ~errnoException internal/errors.js:446:24
1 100.0% LazyCompile: ~afterWriteDispatched internal/stream_base_commons.js:141:30
1 100.0% LazyCompile: ~writevGeneric internal/stream_base_commons.js:107:23
1 100.0% LazyCompile: ~Socket._writeGeneric net.js:672:42
3 6.5% LazyCompile: *Writable.uncork _stream_writable.js:311:37
3 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
3 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
3 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
46 1.0% LazyCompile: *resOnFinish _http_server.js:617:21
42 91.3% LazyCompile: *onFinish _http_outgoing.js:657:18
42 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
42 100.0% LazyCompile: *afterWrite _stream_writable.js:479:20
42 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
3 6.5% LazyCompile: *emit events.js:153:44
3 100.0% LazyCompile: ~onFinish _http_outgoing.js:657:18
3 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
3 100.0% LazyCompile: *afterWrite _stream_writable.js:479:20
3 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
1 2.2% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
1 100.0% LazyCompile: *afterWrite _stream_writable.js:479:20
1 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
Prof without PR:$ node --prof-process without.log
Code move event for unknown code: 0x75c6bc4ab0
Code move event for unknown code: 0x75c36ebd00
Code move event for unknown code: 0x75c36ebf58
Code move event for unknown code: 0x75c6bc7fc8
Code move event for unknown code: 0x75c36ec648
Code move event for unknown code: 0x75c6bc8190
Code move event for unknown code: 0x75c36f8f28
Code move event for unknown code: 0x75c36f9188
Code move event for unknown code: 0x75a1ad2b98
Code move event for unknown code: 0x75c6bccd40
Code move event for unknown code: 0x75c6bcd318
Code move event for unknown code: 0x75c6bcd930
Code move event for unknown code: 0x75c6bce3e0
Code move event for unknown code: 0x75c6bce570
Code move event for unknown code: 0x75a1ad63c8
Code move event for unknown code: 0x75a1ad6770
Code move event for unknown code: 0x75a1ad6c78
Code move event for unknown code: 0x75a1adbdf0
Code move event for unknown code: 0x75a1adc618
Code move event for unknown code: 0x75a1adc8c8
Code move event for unknown code: 0x75a1adcff0
Code move event for unknown code: 0x75a1addba0
Code move event for unknown code: 0x75a1ade5d0
Code move event for unknown code: 0x75a1ade8f8
Code move event for unknown code: 0x75a1adea98
Code move event for unknown code: 0x75a1adec00
Code move event for unknown code: 0x75a1aded58
Code move event for unknown code: 0x75a1adf0f0
Code move event for unknown code: 0x7552b517b0
Code move event for unknown code: 0x7552b51f58
Code move event for unknown code: 0x7552b526c0
Code move event for unknown code: 0x7552b53910
Code move event for unknown code: 0x7552b53a80
Code move event for unknown code: 0x7552b53da0
Code move event for unknown code: 0x7552b540f0
Code move event for unknown code: 0x7552b547d8
Code move event for unknown code: 0x7552b54f30
Code move event for unknown code: 0x7552b55240
Code move event for unknown code: 0x7552b557a0
Code move event for unknown code: 0x7552b55a60
Code move event for unknown code: 0x7552b55d98
Code move event for unknown code: 0x7552b55f68
Code move event for unknown code: 0x7552b565d0
Code move event for unknown code: 0x7552b56a08
Code move event for unknown code: 0x7552b57490
Code move event for unknown code: 0x7552b57688
Code move event for unknown code: 0x7552b577c0
Code move event for unknown code: 0x7552b57b28
Code move event for unknown code: 0x7552b58740
Code move event for unknown code: 0x7552b58988
Code move event for unknown code: 0x7552b58b08
Code move event for unknown code: 0x7552b58cc8
Code move event for unknown code: 0x7552b58ec0
Code move event for unknown code: 0x7552b590a8
Code move event for unknown code: 0x7552b592b8
Code move event for unknown code: 0x7552b59460
Code move event for unknown code: 0x7552b59678
Code move event for unknown code: 0x7552b59848
Code move event for unknown code: 0x7552b59a50
Code move event for unknown code: 0x7552b59dd0
Code move event for unknown code: 0x7552b5a008
Code move event for unknown code: 0x7552b5a220
Code move event for unknown code: 0x7552b5a508
Code move event for unknown code: 0x7552b5a810
Code move event for unknown code: 0x7552b5ac10
Code move event for unknown code: 0x7552b5b0a0
Code move event for unknown code: 0x7552b5b2b8
Code move event for unknown code: 0x7552b5b710
Code move event for unknown code: 0x7552b5b9a0
Code move event for unknown code: 0x7552b5bed8
Code move event for unknown code: 0x7552b5c100
Code move event for unknown code: 0x7552b5c730
Code move event for unknown code: 0x7552b5c8a8
Code move event for unknown code: 0x7552b5c9f8
Code move event for unknown code: 0x7552b5cba8
Code move event for unknown code: 0x7552b5ce20
Code move event for unknown code: 0x7552b5d2b8
Code move event for unknown code: 0x7552b5d7d8
Code move event for unknown code: 0x7552b5da70
Code move event for unknown code: 0x7552b5dc90
Code move event for unknown code: 0x7552b5de98
Code move event for unknown code: 0x7552b5e018
Code move event for unknown code: 0x7552b5e1f8
Code move event for unknown code: 0x7552b5e468
Code move event for unknown code: 0x7552b5e5f8
Code move event for unknown code: 0x7552b5e860
Code move event for unknown code: 0x7552b5eb90
Code move event for unknown code: 0x7552b5ee50
Code move event for unknown code: 0x7552b5f790
Code move event for unknown code: 0x7552b5f9f0
Code move event for unknown code: 0x7552b5fba8
Code move event for unknown code: 0x7552b5ff58
Code move event for unknown code: 0x7552b60778
Code move event for unknown code: 0x7552b60e70
Code move event for unknown code: 0x7552b619c0
Code move event for unknown code: 0x7552b61d08
Code move event for unknown code: 0x7552b61ee0
Code move event for unknown code: 0x7552b62230
Code move event for unknown code: 0x75c6be90c0
Code move event for unknown code: 0x75c6be9230
Code move event for unknown code: 0x75c6be93f0
Code move event for unknown code: 0x75c6bebb60
Code move event for unknown code: 0x75c6bebd00
Code move event for unknown code: 0x75c6bebfe0
Code move event for unknown code: 0x75a1af0ff8
Code move event for unknown code: 0x75a1af1878
Code move event for unknown code: 0x75a1af1e28
Code move event for unknown code: 0x75a1af2500
Code move event for unknown code: 0x75c6bef1b8
Code move event for unknown code: 0x75a1af27a8
Code move event for unknown code: 0x75c6befa48
Code move event for unknown code: 0x75a1af2c80
Code move event for unknown code: 0x75c6bf0788
Code move event for unknown code: 0x75a1af2df0
Code move event for unknown code: 0x75c6bf0ac0
Code move event for unknown code: 0x75a1af2f50
Code move event for unknown code: 0x75c6bf0c20
Code move event for unknown code: 0x75a1af30e8
Code move event for unknown code: 0x75c6bf0e38
Code move event for unknown code: 0x75a1af3360
Code move event for unknown code: 0x75c6bf13b8
Code move event for unknown code: 0x75a1af34d8
Code move event for unknown code: 0x75c6bf15d0
Code move event for unknown code: 0x75a1af3660
Code move event for unknown code: 0x75c6bf17b8
Code move event for unknown code: 0x75a1af37d8
Code move event for unknown code: 0x75c6bf19d0
Code move event for unknown code: 0x75a1af3a10
Code move event for unknown code: 0x75c6bf1c28
Code move event for unknown code: 0x75a1af3ba8
Code move event for unknown code: 0x75c6bf1e90
Code move event for unknown code: 0x75a1af3de8
Code move event for unknown code: 0x75a1af4178
Code move event for unknown code: 0x75a1af4378
Code move event for unknown code: 0x75c6bf2758
Code move event for unknown code: 0x75a1af4650
Code move event for unknown code: 0x75c6bf2958
Code move event for unknown code: 0x75a1af4848
Code move event for unknown code: 0x75c6bf2d08
Code move event for unknown code: 0x75a1af4a88
Code move event for unknown code: 0x75c6bf3338
Code move event for unknown code: 0x75a1af4df0
Code move event for unknown code: 0x75c6bf3510
Code move event for unknown code: 0x75a1af4f80
Code move event for unknown code: 0x75c6bf3850
Code move event for unknown code: 0x75a1af50e8
Code move event for unknown code: 0x75c6bf3b18
Code move event for unknown code: 0x75a1af52d8
Code move event for unknown code: 0x75a1af57e8
Code move event for unknown code: 0x75a1af5dd8
Code move event for unknown code: 0x75c6bf3e68
Code move event for unknown code: 0x75c6bf41a8
Code move event for unknown code: 0x75c6bf4750
Code move event for unknown code: 0x75c6bf4ae0
Code move event for unknown code: 0x75c6bf4dc8
Code move event for unknown code: 0x75c6bf5058
Code move event for unknown code: 0x75c6bf52d0
Code move event for unknown code: 0x75c6bf55d0
Code move event for unknown code: 0x75c6bf5af0
Code move event for unknown code: 0x75c6bf6298
Code move event for unknown code: 0x75c6bf6a60
Code move event for unknown code: 0x75c6bf72c0
Code move event for unknown code: 0x75c6bf74b0
Code move event for unknown code: 0x7552b7f448
Statistical profiling result from without.log, (4455 ticks, 1311 unaccounted, 0 excluded).
[Shared libraries]:
ticks total nonlib name
19 0.4% /usr/lib/system/libsystem_pthread.dylib
8 0.2% /usr/lib/system/libsystem_platform.dylib
3 0.1% /usr/lib/system/libsystem_malloc.dylib
[JavaScript]:
ticks total nonlib name
61 1.4% 1.4% LazyCompile: *onwrite _stream_writable.js:445:17
49 1.1% 1.1% LazyCompile: *resOnFinish _http_server.js:617:21
49 1.1% 1.1% LazyCompile: *clearBuffer _stream_writable.js:498:21
46 1.0% 1.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
41 0.9% 0.9% LazyCompile: *assignSocket _http_server.js:203:62
40 0.9% 0.9% LazyCompile: *Readable.read _stream_readable.js:400:35
38 0.9% 0.9% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
30 0.7% 0.7% LazyCompile: *write_ _http_outgoing.js:564:16
25 0.6% 0.6% LazyCompile: *parserOnIncoming _http_server.js:662:26
24 0.5% 0.5% LazyCompile: *socketListenerWrap _http_server.js:780:37
23 0.5% 0.5% LazyCompile: *_storeHeader _http_outgoing.js:285:22
22 0.5% 0.5% LazyCompile: *resetHeadersTimeoutOnReqEnd _http_server.js:796:37
21 0.5% 0.5% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
19 0.4% 0.4% LazyCompile: *resume_ _stream_readable.js:920:17
17 0.4% 0.4% LazyCompile: *setHeader _http_outgoing.js:462:57
16 0.4% 0.4% LazyCompile: *nextTick internal/process/task_queues.js:109:18
16 0.4% 0.4% LazyCompile: *endReadableNT _stream_readable.js:1124:23
14 0.3% 0.3% RegExp: [^\t\x20-\x7e\x80-\xff]
14 0.3% 0.3% LazyCompile: *readableAddChunk _stream_readable.js:224:26
13 0.3% 0.3% LazyCompile: *ReadableState _stream_readable.js:72:23
12 0.3% 0.3% LazyCompile: *<anonymous> internal/util/debuglog.js:57:18
11 0.2% 0.2% LazyCompile: *afterWrite _stream_writable.js:479:20
10 0.2% 0.2% LazyCompile: *_finish _http_server.js:169:52
9 0.2% 0.2% LazyCompile: *onFinish _http_outgoing.js:657:18
9 0.2% 0.2% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
8 0.2% 0.2% RegExp: ^[\^_`a-zA-Z\-0-9!#$%&'*+.|~]+$
8 0.2% 0.2% LazyCompile: *parserOnMessageComplete _http_common.js:135:33
7 0.2% 0.2% LazyCompile: *updateOutgoingData _http_server.js:445:28
7 0.2% 0.2% LazyCompile: *matchKnownFields _http_incoming.js:139:26
7 0.2% 0.2% LazyCompile: *emit events.js:153:44
6 0.1% 0.1% LazyCompile: *Readable.on _stream_readable.js:815:33
5 0.1% 0.1% LazyCompile: *setStreamTimeout internal/stream_base_commons.js:202:26
5 0.1% 0.1% LazyCompile: *ServerResponse _http_server.js:145:24
4 0.1% 0.1% LazyCompile: *removeListener events.js:320:28
4 0.1% 0.1% LazyCompile: *emitReadable_ _stream_readable.js:560:23
4 0.1% 0.1% LazyCompile: *debug internal/util/debuglog.js:45:35
4 0.1% 0.1% LazyCompile: *byteLength buffer.js:488:20
4 0.1% 0.1% LazyCompile: *_unrefTimer net.js:344:52
4 0.1% 0.1% LazyCompile: *Writable.uncork _stream_writable.js:311:37
3 0.1% 0.1% LazyCompile: *insert internal/timers.js:305:16
3 0.1% 0.1% LazyCompile: *Readable.removeAllListeners _stream_readable.js:861:49
2 0.0% 0.0% LazyCompile: *removeAllListeners events.js:376:32
2 0.0% 0.0% LazyCompile: *nop _stream_writable.js:54:13
2 0.0% 0.0% LazyCompile: *emitCloseNT _http_server.js:655:21
2 0.0% 0.0% LazyCompile: *Writable.write _stream_writable.js:275:36
1 0.0% 0.0% LazyCompile: *writeHead _http_server.js:234:19
1 0.0% 0.0% LazyCompile: *unenroll timers.js:62:18
1 0.0% 0.0% LazyCompile: *remove internal/linkedlist.js:15:16
1 0.0% 0.0% LazyCompile: *onParserExecuteCommon _http_server.js:568:31
1 0.0% 0.0% LazyCompile: *onParserExecute _http_server.js:525:25
1 0.0% 0.0% LazyCompile: *afterWriteDispatched internal/stream_base_commons.js:141:30
1 0.0% 0.0% LazyCompile: *addListener events.js:276:58
1 0.0% 0.0% LazyCompile: *Writable.cork _stream_writable.js:307:35
[C++]:
ticks total nonlib name
1612 36.2% 36.4% T __ZN2v88internal10ClassScope28ResolvePrivateNamesPartiallyEv
46 1.0% 1.0% t _szone_malloc_should_clear
38 0.9% 0.9% T __ZN2v86Object3GetENS_5LocalINS_7ContextEEEj
32 0.7% 0.7% T node::StreamBase::Writev(v8::FunctionCallbackInfo<v8::Value> const&)
27 0.6% 0.6% T void node::StreamBase::JSMethod<&(node::StreamBase::Writev(v8::FunctionCallbackInfo<v8::Value> const&))>(v8::FunctionCallbackInfo<v8::Value> const&)
27 0.6% 0.6% T __ZN2v88Function4CallENS_5LocalINS_7ContextEEENS1_INS_5ValueEEEiPS5_
25 0.6% 0.6% T _munmap
24 0.5% 0.5% T __ZNK2v86String9WriteUtf8EPNS_7IsolateEPciPii
23 0.5% 0.5% T _mach_msg
20 0.4% 0.5% T node::native_module::NativeModuleEnv::CompileFunction(v8::FunctionCallbackInfo<v8::Value> const&)
16 0.4% 0.4% t node::LibuvStreamWrap::Initialize(v8::Local<v8::Object>, v8::Local<v8::Value>, v8::Local<v8::Context>, void*)::$_0::__invoke(v8::FunctionCallbackInfo<v8::Value> const&)
16 0.4% 0.4% T ___channel_get_opt
15 0.3% 0.3% T ___mach_stack_logging_enumerate_records
13 0.3% 0.3% t __enlarge
13 0.3% 0.3% t __ZN2v88internal6String7FlattenEPNS0_7IsolateENS0_6HandleIS1_EENS0_14AllocationTypeE
13 0.3% 0.3% T _vm_region_recurse_64
12 0.3% 0.3% t node::StreamBase::Write(uv_buf_t*, unsigned long, uv_stream_s*, v8::Local<v8::Object>)
12 0.3% 0.3% T node::LibuvStreamWrap::DoTryWrite(uv_buf_t**, unsigned long*)
12 0.3% 0.3% T __ZN2v87Isolate17GetCurrentContextEv
12 0.3% 0.3% T __ZN2v811HandleScope10InitializeEPNS_7IsolateE
10 0.2% 0.2% t __ZN2v812_GLOBAL__N_114CallDepthScopeILb0EEC1EPNS_8internal7IsolateENS_5LocalINS_7ContextEEE
9 0.2% 0.2% t node::NodeArrayBufferAllocator::Free(void*, unsigned long)
9 0.2% 0.2% T node::InternalCallbackScope::InternalCallbackScope(node::Environment*, v8::Local<v8::Object>, node::async_context const&, node::InternalCallbackScope::ResourceExpectation)
9 0.2% 0.2% T node::AsyncWrap::EmitTraceEventAfter(node::AsyncWrap::ProviderType, double)
9 0.2% 0.2% T _malloc
9 0.2% 0.2% T ___carbon_delete
8 0.2% 0.2% t _small_free_list_remove_ptr_no_clear
8 0.2% 0.2% t __cxxabiv1::do_free(void*)
8 0.2% 0.2% T node::StringBytes::Write(v8::Isolate*, char*, unsigned long, v8::Local<v8::Value>, node::encoding, int*)
8 0.2% 0.2% T node::ParseEncoding(v8::Isolate*, v8::Local<v8::Value>, node::encoding)
8 0.2% 0.2% T node::InternalMakeCallback(node::Environment*, v8::Local<v8::Object>, v8::Local<v8::Function>, int, v8::Local<v8::Value>*, node::async_context)
8 0.2% 0.2% T node::Environment::GetNow()
8 0.2% 0.2% T __ZNK2v85Value10IsFunctionEv
7 0.2% 0.2% t node::(anonymous namespace)::StringPtr::Reset()
7 0.2% 0.2% t node::(anonymous namespace)::Parser::Proxy<int (node::(anonymous namespace)::Parser::*)(), &(node::(anonymous namespace)::Parser::on_headers_complete())>::Raw(llhttp__internal_s*)
7 0.2% 0.2% T node::StringBytes::StorageSize(v8::Isolate*, v8::Local<v8::Value>, node::encoding)
7 0.2% 0.2% T node::InternalCallbackScope::Close()
7 0.2% 0.2% T __ZNK2v85Value8ToStringENS_5LocalINS_7ContextEEE
7 0.2% 0.2% T __ZN2v85Array3NewEPNS_7IsolateEPNS_5LocalINS_5ValueEEEm
6 0.1% 0.1% t __os_nospin_lock_unlock_slow
6 0.1% 0.1% T node::Emit(node::Environment*, double, node::AsyncHooks::Fields, v8::Local<v8::Function>)
6 0.1% 0.1% T _free
6 0.1% 0.1% T __ZNK2v86String10Utf8LengthEPNS_7IsolateE
5 0.1% 0.1% t _update_cache_for_file_streams
5 0.1% 0.1% t _allocate_pages_securely
5 0.1% 0.1% t __ZN2v812_GLOBAL__N_114CallDepthScopeILb1EEC1EPNS_8internal7IsolateENS_5LocalINS_7ContextEEE
5 0.1% 0.1% T non-virtual thunk to node::LibuvStreamWrap::IsAlive()
5 0.1% 0.1% T node::ParseEncoding(char const*, node::encoding)
5 0.1% 0.1% T node::DTRACE_HTTP_SERVER_REQUEST(v8::FunctionCallbackInfo<v8::Value> const&)
5 0.1% 0.1% T node::Buffer::HasInstance(v8::Local<v8::Value>)
5 0.1% 0.1% T node::AsyncWrap::MakeCallback(v8::Local<v8::Function>, int, v8::Local<v8::Value>*)
5 0.1% 0.1% T __ZNK2v86String6LengthEv
5 0.1% 0.1% T __ZNK2v85Value17IsArrayBufferViewEv
5 0.1% 0.1% T __ZN2v86String14NewFromOneByteEPNS_7IsolateEPKhNS_13NewStringTypeEi
5 0.1% 0.1% T __ZN2v811HandleScopeC1EPNS_7IsolateE
4 0.1% 0.1% t node::(anonymous namespace)::StringPtr::Update(char const*, unsigned long)
4 0.1% 0.1% t node::(anonymous namespace)::GetLibuvNow(v8::FunctionCallbackInfo<v8::Value> const&)
4 0.1% 0.1% T node::Utf8Value::Utf8Value(v8::Isolate*, v8::Local<v8::Value>)
4 0.1% 0.1% T node::AsyncWrap::EmitTraceEventBefore()
4 0.1% 0.1% T _mprotect
4 0.1% 0.1% T __simple_dprintf
4 0.1% 0.1% T ___malloc_init
4 0.1% 0.1% T ___mach_stack_logging_uniquing_table_read_stack
3 0.1% 0.1% t std::__1::__function::__func<node::(anonymous namespace)::Parser::OnStreamRead(long, uv_buf_t const&)::'lambda'(), std::__1::allocator<node::(anonymous namespace)::Parser::OnStreamRead(long, uv_buf_t const&)::'lambda'()>, void ()>::operator()()
3 0.1% 0.1% t node::MaybeStackBuffer<char, 1024ul>::SetLengthAndZeroTerminate(unsigned long)
3 0.1% 0.1% t node::MaybeStackBuffer<char, 1024ul>::SetLength(unsigned long)
3 0.1% 0.1% t node::MaybeStackBuffer<char, 1024ul>::AllocateSufficientStorage(unsigned long)
3 0.1% 0.1% t node::Buffer::(anonymous namespace)::ByteLengthUtf8(v8::FunctionCallbackInfo<v8::Value> const&)
3 0.1% 0.1% t node::AsyncHooks::pop_async_id(double)
3 0.1% 0.1% t node::(anonymous namespace)::Parser::Proxy<int (node::(anonymous namespace)::Parser::*)(char const*, unsigned long), &(node::(anonymous namespace)::Parser::on_url(char const*, unsigned long))>::Raw(llhttp__internal_s*, char const*, unsigned long)
3 0.1% 0.1% t __malloc_initialize
3 0.1% 0.1% T node::TTYWrap::New(v8::FunctionCallbackInfo<v8::Value> const&)
3 0.1% 0.1% T node::LibuvStreamWrap::OnUvAlloc(unsigned long, uv_buf_t*)
3 0.1% 0.1% T __ZN2v88internal25FunctionCallbackArgumentsC1EPNS0_7IsolateENS0_6ObjectENS0_10HeapObjectES4_S5_Pmi
3 0.1% 0.1% T __ZN2v87Integer3NewEPNS_7IsolateEi
3 0.1% 0.1% T __ZN2v811HandleScopeD1Ev
2 0.0% 0.0% t node::LibuvStreamWrap::ReadStart()::$_1::__invoke(uv_handle_s*, unsigned long, uv_buf_t*)
2 0.0% 0.0% t node::(anonymous namespace)::Parser::Execute(char const*, unsigned long)
2 0.0% 0.0% t node::(anonymous namespace)::Parser::CreateHeaders()
2 0.0% 0.0% t _unwind_stack_from_table_index
2 0.0% 0.0% t _allocate_pages
2 0.0% 0.0% t __ZN2v88internal12_GLOBAL__N_124ProbeInstantiationsCacheEPNS0_7IsolateEiNS1_11CachingModeE
2 0.0% 0.0% T node::binding::GetInternalBinding(v8::FunctionCallbackInfo<v8::Value> const&)
2 0.0% 0.0% T node::AsyncWrap::EmitAfter(node::Environment*, double)
2 0.0% 0.0% T _mach_vm_purgable_control
2 0.0% 0.0% T _guarded_open_np
2 0.0% 0.0% T __ZNK2v86String12WriteOneByteEPNS_7IsolateEPhiii
2 0.0% 0.0% T __ZNK2v85Value6IsTrueEv
2 0.0% 0.0% T __ZN2v88internal10ApiNatives17InstantiateObjectEPNS0_7IsolateENS0_6HandleINS0_18ObjectTemplateInfoEEENS4_INS0_10JSReceiverEEE
2 0.0% 0.0% T __ZN2v87Integer15NewFromUnsignedEPNS_7IsolateEj
1 0.0% 0.0% t void std::__1::__init_pat<char>(std::__1::money_base::pattern&, std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> >&, bool, char, char, char, char)
1 0.0% 0.0% t non-virtual thunk to node::(anonymous namespace)::Parser::OnStreamAlloc(unsigned long)
1 0.0% 0.0% t node::TaskQueue<node::DelayedTask>::Push(std::__1::unique_ptr<node::DelayedTask, std::__1::default_delete<node::DelayedTask> >)
1 0.0% 0.0% t node::NodeArrayBufferAllocator::AllocateUninitialized(unsigned long)
1 0.0% 0.0% t node::MaybeStackBuffer<uv_buf_t, 16ul>::AllocateSufficientStorage(unsigned long)
1 0.0% 0.0% t node::(anonymous namespace)::Parser::Proxy<int (node::(anonymous namespace)::Parser::*)(char const*, unsigned long), &(node::(anonymous namespace)::Parser::on_header_value(char const*, unsigned long))>::Raw(llhttp__internal_s*, char const*, unsigned long)
1 0.0% 0.0% t node::(anonymous namespace)::Parser::Proxy<int (node::(anonymous namespace)::Parser::*)(char const*, unsigned long), &(node::(anonymous namespace)::Parser::on_header_field(char const*, unsigned long))>::Raw(llhttp__internal_s*, char const*, unsigned long)
1 0.0% 0.0% t node::(anonymous namespace)::Parser::Proxy<int (node::(anonymous namespace)::Parser::*)(), &(node::(anonymous namespace)::Parser::on_message_begin())>::Raw(llhttp__internal_s*)
1 0.0% 0.0% t node::(anonymous namespace)::Parser::OnStreamRead(long, uv_buf_t const&)
1 0.0% 0.0% t node::(anonymous namespace)::Parser::OnStreamAlloc(unsigned long)
1 0.0% 0.0% t node::(anonymous namespace)::Parser::MaybePause()
1 0.0% 0.0% t _free_small
1 0.0% 0.0% t __read_images
1 0.0% 0.0% t __os_nospin_lock_lock_slow
1 0.0% 0.0% t ___CFNumberGetTypeID_block_invoke
1 0.0% 0.0% t __ZN2v88internal22HandleScopeImplementer12EnterContextENS0_7ContextE
1 0.0% 0.0% T std::__1::basic_istream<wchar_t, std::__1::char_traits<wchar_t> >::get(wchar_t&)
1 0.0% 0.0% T non-virtual thunk to node::LibuvStreamWrap::GetAsyncWrap()
1 0.0% 0.0% T non-virtual thunk to node::LibuvStreamWrap::DoTryWrite(uv_buf_t**, unsigned long*)
1 0.0% 0.0% T node::contextify::ContextifyContext::CompileFunction(v8::FunctionCallbackInfo<v8::Value> const&)
1 0.0% 0.0% T node::NodePlatform::CallOnWorkerThread(std::__1::unique_ptr<v8::Task, std::__1::default_delete<v8::Task> >)
1 0.0% 0.0% T node::LibuvStreamWrap::OnUvRead(long, uv_buf_t const*)
1 0.0% 0.0% T node::DTRACE_HTTP_SERVER_RESPONSE(v8::FunctionCallbackInfo<v8::Value> const&)
1 0.0% 0.0% T _fprintf
1 0.0% 0.0% T __simple_vsprintf
1 0.0% 0.0% T __ZNK2v88internal12RootIndexMap6LookupEmPNS0_9RootIndexE
1 0.0% 0.0% T __ZNK2v88Function29NewInstanceWithSideEffectTypeENS_5LocalINS_7ContextEEEiPNS1_INS_5ValueEEENS_14SideEffectTypeE
1 0.0% 0.0% T __ZNK2v85Value8IsObjectEv
1 0.0% 0.0% T __ZNK2v85Value7IsArrayEv
1 0.0% 0.0% T __ZNK2v85Value12IntegerValueENS_5LocalINS_7ContextEEE
1 0.0% 0.0% T __ZNK2v85Array6LengthEv
1 0.0% 0.0% T __ZN2v88internal9Accessors23FunctionPrototypeGetterENS_5LocalINS_4NameEEERKNS_20PropertyCallbackInfoINS_5ValueEEE
1 0.0% 0.0% T __ZN2v88internal21PerIsolateAssertScopeILNS0_20PerIsolateAssertTypeE1ELb0EE9IsAllowedEPNS0_7IsolateE
1 0.0% 0.0% T __ZN2v88internal21PerIsolateAssertScopeILNS0_20PerIsolateAssertTypeE0ELb1EE9IsAllowedEPNS0_7IsolateE
1 0.0% 0.0% T __ZN2v88internal13VirtualMemory14SetPermissionsEmmNS_13PageAllocator10PermissionE
1 0.0% 0.0% T __ZN2v88internal12ArrayLiteral17InitDepthAndFlagsEv
1 0.0% 0.0% T __ZN2v87Isolate9InContextEv
1 0.0% 0.0% T __ZN2v87Isolate10GetCurrentEv
1 0.0% 0.0% T __ZN2v87Context5EnterEv
1 0.0% 0.0% T __ZN2v87Context4ExitEv
1 0.0% 0.0% T __ZN2v87Context29GetNumberOfEmbedderDataFieldsEv
1 0.0% 0.0% T __CFExecutableLinkedOnOrAfter
[Summary]:
ticks total nonlib name
728 16.3% 16.5% JavaScript
2386 53.6% 53.9% C++
88 2.0% 2.0% GC
30 0.7% Shared libraries
1311 29.4% Unaccounted
[C++ entry points]:
ticks cpp total name
1477 80.6% 33.2% T __ZN2v88internal10ClassScope28ResolvePrivateNamesPartiallyEv
32 1.7% 0.7% T node::StreamBase::Writev(v8::FunctionCallbackInfo<v8::Value> const&)
30 1.6% 0.7% t _szone_malloc_should_clear
25 1.4% 0.6% T __ZN2v86Object3GetENS_5LocalINS_7ContextEEEj
24 1.3% 0.5% T __ZNK2v86String9WriteUtf8EPNS_7IsolateEPciPii
14 0.8% 0.3% T ___mach_stack_logging_enumerate_records
13 0.7% 0.3% T void node::StreamBase::JSMethod<&(node::StreamBase::Writev(v8::FunctionCallbackInfo<v8::Value> const&))>(v8::FunctionCallbackInfo<v8::Value> const&)
13 0.7% 0.3% T _vm_region_recurse_64
12 0.7% 0.3% t node::StreamBase::Write(uv_buf_t*, unsigned long, uv_stream_s*, v8::Local<v8::Object>)
12 0.7% 0.3% T node::LibuvStreamWrap::DoTryWrite(uv_buf_t**, unsigned long*)
10 0.5% 0.2% T __ZN2v87Isolate17GetCurrentContextEv
9 0.5% 0.2% t node::NodeArrayBufferAllocator::Free(void*, unsigned long)
8 0.4% 0.2% T node::StringBytes::Write(v8::Isolate*, char*, unsigned long, v8::Local<v8::Value>, node::encoding, int*)
8 0.4% 0.2% T node::ParseEncoding(v8::Isolate*, v8::Local<v8::Value>, node::encoding)
8 0.4% 0.2% T node::Environment::GetNow()
7 0.4% 0.2% t __ZN2v812_GLOBAL__N_114CallDepthScopeILb0EEC1EPNS_8internal7IsolateENS_5LocalINS_7ContextEEE
7 0.4% 0.2% T node::StringBytes::StorageSize(v8::Isolate*, v8::Local<v8::Value>, node::encoding)
7 0.4% 0.2% T __ZNK2v85Value8ToStringENS_5LocalINS_7ContextEEE
7 0.4% 0.2% T __ZN2v811HandleScope10InitializeEPNS_7IsolateE
6 0.3% 0.1% T __ZNK2v86String10Utf8LengthEPNS_7IsolateE
5 0.3% 0.1% t _update_cache_for_file_streams
5 0.3% 0.1% t __enlarge
5 0.3% 0.1% T non-virtual thunk to node::LibuvStreamWrap::IsAlive()
5 0.3% 0.1% T node::ParseEncoding(char const*, node::encoding)
5 0.3% 0.1% T node::DTRACE_HTTP_SERVER_REQUEST(v8::FunctionCallbackInfo<v8::Value> const&)
5 0.3% 0.1% T node::Buffer::HasInstance(v8::Local<v8::Value>)
5 0.3% 0.1% T _free
5 0.3% 0.1% T __ZNK2v86String6LengthEv
5 0.3% 0.1% T __ZNK2v85Value17IsArrayBufferViewEv
4 0.2% 0.1% T node::Utf8Value::Utf8Value(v8::Isolate*, v8::Local<v8::Value>)
3 0.2% 0.1% t node::MaybeStackBuffer<char, 1024ul>::SetLengthAndZeroTerminate(unsigned long)
3 0.2% 0.1% t node::MaybeStackBuffer<char, 1024ul>::SetLength(unsigned long)
3 0.2% 0.1% t node::MaybeStackBuffer<char, 1024ul>::AllocateSufficientStorage(unsigned long)
3 0.2% 0.1% t node::(anonymous namespace)::GetLibuvNow(v8::FunctionCallbackInfo<v8::Value> const&)
3 0.2% 0.1% t _small_free_list_remove_ptr_no_clear
3 0.2% 0.1% t _allocate_pages_securely
3 0.2% 0.1% t __ZN2v88internal6String7FlattenEPNS0_7IsolateENS0_6HandleIS1_EENS0_14AllocationTypeE
3 0.2% 0.1% T __ZN2v811HandleScopeD1Ev
2 0.1% 0.0% t node::Buffer::(anonymous namespace)::ByteLengthUtf8(v8::FunctionCallbackInfo<v8::Value> const&)
2 0.1% 0.0% t _unwind_stack_from_table_index
2 0.1% 0.0% t __malloc_initialize
2 0.1% 0.0% T _malloc
2 0.1% 0.0% T __simple_dprintf
2 0.1% 0.0% T ___malloc_init
2 0.1% 0.0% T ___mach_stack_logging_uniquing_table_read_stack
2 0.1% 0.0% T __ZNK2v86String12WriteOneByteEPNS_7IsolateEPhiii
2 0.1% 0.0% T __ZNK2v85Value6IsTrueEv
2 0.1% 0.0% T __ZN2v811HandleScopeC1EPNS_7IsolateE
1 0.1% 0.0% t node::NodeArrayBufferAllocator::AllocateUninitialized(unsigned long)
1 0.1% 0.0% t node::MaybeStackBuffer<uv_buf_t, 16ul>::AllocateSufficientStorage(unsigned long)
1 0.1% 0.0% t _free_small
1 0.1% 0.0% T non-virtual thunk to node::LibuvStreamWrap::GetAsyncWrap()
1 0.1% 0.0% T non-virtual thunk to node::LibuvStreamWrap::DoTryWrite(uv_buf_t**, unsigned long*)
1 0.1% 0.0% T node::DTRACE_HTTP_SERVER_RESPONSE(v8::FunctionCallbackInfo<v8::Value> const&)
1 0.1% 0.0% T __simple_vsprintf
1 0.1% 0.0% T __ZNK2v85Value8IsObjectEv
1 0.1% 0.0% T __ZNK2v85Value7IsArrayEv
1 0.1% 0.0% T __ZNK2v85Array6LengthEv
[Bottom up (heavy) profile]:
Note: percentage shows a share of a particular caller in the total
amount of its parent calls.
Callers occupying less than 1.0% are not shown.
ticks parent name
1612 36.2% T __ZN2v88internal10ClassScope28ResolvePrivateNamesPartiallyEv
273 16.9% T __ZN2v88internal10ClassScope28ResolvePrivateNamesPartiallyEv
80 29.3% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
78 97.5% LazyCompile: *parserOnIncoming _http_server.js:662:26
78 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
2 2.5% LazyCompile: *emit events.js:153:44
2 100.0% LazyCompile: ~parserOnIncoming _http_server.js:662:26
2 100.0% LazyCompile: ~parserOnHeadersComplete _http_common.js:71:33
48 17.6% LazyCompile: *_storeHeader _http_outgoing.js:285:22
46 95.8% LazyCompile: *write_ _http_outgoing.js:564:16
46 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
46 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
1 2.1% LazyCompile: ~writeHead _http_server.js:234:19
1 100.0% LazyCompile: ~_implicitHeader _http_server.js:229:68
1 100.0% LazyCompile: ~write_ _http_outgoing.js:564:16
1 2.1% LazyCompile: *writeHead _http_server.js:234:19
1 100.0% LazyCompile: ~_implicitHeader _http_server.js:229:68
1 100.0% LazyCompile: ~write_ _http_outgoing.js:564:16
43 15.8% LazyCompile: *Readable.read _stream_readable.js:400:35
39 90.7% LazyCompile: *resume_ _stream_readable.js:920:17
39 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
4 9.3% LazyCompile: *emitReadable_ _stream_readable.js:560:23
4 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
39 14.3% LazyCompile: *clearBuffer _stream_writable.js:498:21
38 97.4% LazyCompile: *assignSocket _http_server.js:203:62
37 97.4% LazyCompile: *resOnFinish _http_server.js:617:21
34 91.9% LazyCompile: *onFinish _http_outgoing.js:657:18
3 8.1% LazyCompile: *emit events.js:153:44
1 2.6% LazyCompile: ~resOnFinish _http_server.js:617:21
1 100.0% LazyCompile: *emit events.js:153:44
1 2.6% LazyCompile: ~Writable.uncork _stream_writable.js:311:37
1 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
1 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
5 1.8% LazyCompile: ~_storeHeader _http_outgoing.js:285:22
3 60.0% LazyCompile: *write_ _http_outgoing.js:564:16
3 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
3 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
2 40.0% LazyCompile: ~writeHead _http_server.js:234:19
2 100.0% LazyCompile: ~_implicitHeader _http_server.js:229:68
2 100.0% LazyCompile: ~write_ _http_outgoing.js:564:16
4 1.5% LazyCompile: *Writable.uncork _stream_writable.js:311:37
4 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
4 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
4 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
3 1.1% LazyCompile: *parserOnIncoming _http_server.js:662:26
3 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
3 1.1% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
226 14.0% LazyCompile: *clearBuffer _stream_writable.js:498:21
226 100.0% LazyCompile: *assignSocket _http_server.js:203:62
224 99.1% LazyCompile: *resOnFinish _http_server.js:617:21
216 96.4% LazyCompile: *onFinish _http_outgoing.js:657:18
216 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
8 3.6% LazyCompile: *emit events.js:153:44
8 100.0% LazyCompile: ~onFinish _http_outgoing.js:657:18
117 7.3% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
61 3.8% LazyCompile: *assignSocket _http_server.js:203:62
61 100.0% LazyCompile: *resOnFinish _http_server.js:617:21
61 100.0% LazyCompile: *onFinish _http_outgoing.js:657:18
61 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
61 100.0% LazyCompile: *afterWrite _stream_writable.js:479:20
52 3.2% LazyCompile: *resOnFinish _http_server.js:617:21
50 96.2% LazyCompile: *onFinish _http_outgoing.js:657:18
50 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
50 100.0% LazyCompile: *afterWrite _stream_writable.js:479:20
50 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
2 3.8% LazyCompile: *emit events.js:153:44
2 100.0% LazyCompile: ~onFinish _http_outgoing.js:657:18
2 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
1 50.0% LazyCompile: ~afterWrite _stream_writable.js:479:20
1 50.0% LazyCompile: *afterWrite _stream_writable.js:479:20
47 2.9% LazyCompile: *parserOnIncoming _http_server.js:662:26
47 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
38 2.4% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
38 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
38 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
36 2.2% LazyCompile: *write_ _http_outgoing.js:564:16
36 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
36 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
36 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
35 2.2% LazyCompile: *onwrite _stream_writable.js:445:17
32 91.4% LazyCompile: *clearBuffer _stream_writable.js:498:21
32 100.0% LazyCompile: *assignSocket _http_server.js:203:62
32 100.0% LazyCompile: *resOnFinish _http_server.js:617:21
28 87.5% LazyCompile: *onFinish _http_outgoing.js:657:18
4 12.5% LazyCompile: *emit events.js:153:44
3 8.6% LazyCompile: *afterWriteDispatched internal/stream_base_commons.js:141:30
3 100.0% LazyCompile: *Writable.uncork _stream_writable.js:311:37
3 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
3 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
33 2.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
28 1.7% LazyCompile: *_storeHeader _http_outgoing.js:285:22
28 100.0% LazyCompile: *write_ _http_outgoing.js:564:16
28 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
28 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
28 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
27 1.7% LazyCompile: *setHeader _http_outgoing.js:462:57
27 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
27 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
27 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
27 1.7% LazyCompile: *Writable.uncork _stream_writable.js:311:37
27 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
27 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
27 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
17 1.1% LazyCompile: *resume_ _stream_readable.js:920:17
17 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
1311 29.4% UNKNOWN
1094 83.4% LazyCompile: *clearBuffer _stream_writable.js:498:21
1091 99.7% LazyCompile: *assignSocket _http_server.js:203:62
1089 99.8% LazyCompile: *resOnFinish _http_server.js:617:21
1060 97.3% LazyCompile: *onFinish _http_outgoing.js:657:18
1060 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
29 2.7% LazyCompile: *emit events.js:153:44
29 100.0% LazyCompile: ~onFinish _http_outgoing.js:657:18
124 9.5% LazyCompile: *Writable.uncork _stream_writable.js:311:37
124 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
124 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
124 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
61 1.4% LazyCompile: *onwrite _stream_writable.js:445:17
56 91.8% LazyCompile: *clearBuffer _stream_writable.js:498:21
56 100.0% LazyCompile: *assignSocket _http_server.js:203:62
56 100.0% LazyCompile: *resOnFinish _http_server.js:617:21
55 98.2% LazyCompile: *onFinish _http_outgoing.js:657:18
55 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
1 1.8% LazyCompile: *emit events.js:153:44
1 100.0% LazyCompile: ~onFinish _http_outgoing.js:657:18
3 4.9% LazyCompile: *assignSocket _http_server.js:203:62
3 100.0% LazyCompile: *resOnFinish _http_server.js:617:21
3 100.0% LazyCompile: *onFinish _http_outgoing.js:657:18
3 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
3 100.0% LazyCompile: *afterWrite _stream_writable.js:479:20
2 3.3% LazyCompile: *afterWriteDispatched internal/stream_base_commons.js:141:30
2 100.0% LazyCompile: *Writable.uncork _stream_writable.js:311:37
2 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
2 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
2 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
49 1.1% LazyCompile: *resOnFinish _http_server.js:617:21
44 89.8% LazyCompile: *onFinish _http_outgoing.js:657:18
44 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
44 100.0% LazyCompile: *afterWrite _stream_writable.js:479:20
44 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
5 10.2% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
5 100.0% LazyCompile: *afterWrite _stream_writable.js:479:20
5 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
49 1.1% LazyCompile: *clearBuffer _stream_writable.js:498:21
47 95.9% LazyCompile: *assignSocket _http_server.js:203:62
47 100.0% LazyCompile: *resOnFinish _http_server.js:617:21
44 93.6% LazyCompile: *onFinish _http_outgoing.js:657:18
44 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
44 100.0% LazyCompile: *afterWrite _stream_writable.js:479:20
3 6.4% LazyCompile: *emit events.js:153:44
3 100.0% LazyCompile: ~onFinish _http_outgoing.js:657:18
3 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
2 4.1% LazyCompile: *resOnFinish _http_server.js:617:21
2 100.0% LazyCompile: *onFinish _http_outgoing.js:657:18
2 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
2 100.0% LazyCompile: *afterWrite _stream_writable.js:479:20
2 100.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
46 1.0% t _szone_malloc_should_clear
25 54.3% LazyCompile: *clearBuffer _stream_writable.js:498:21
24 96.0% LazyCompile: *assignSocket _http_server.js:203:62
24 100.0% LazyCompile: *resOnFinish _http_server.js:617:21
24 100.0% LazyCompile: *onFinish _http_outgoing.js:657:18
24 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
1 4.0% LazyCompile: ~Writable.uncork _stream_writable.js:311:37
1 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
1 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
1 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
11 23.9% T __ZN2v88internal10ClassScope28ResolvePrivateNamesPartiallyEv
10 90.9% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
10 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
10 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
1 9.1% LazyCompile: ~resOnFinish _http_server.js:617:21
1 100.0% LazyCompile: *emit events.js:153:44
1 100.0% LazyCompile: ~onFinish _http_outgoing.js:657:18
1 100.0% LazyCompile: *onCorkedFinish _stream_writable.js:672:24
5 10.9% LazyCompile: *Writable.uncork _stream_writable.js:311:37
5 100.0% LazyCompile: *<anonymous> /Users/bfarias/Documents/node/bench.js:3:54
5 100.0% LazyCompile: *parserOnIncoming _http_server.js:662:26
5 100.0% LazyCompile: *parserOnHeadersComplete _http_common.js:71:33
46 1.0% LazyCompile: *processTicksAndRejections internal/process/task_queues.js:65:35
|
It sounds like the context is deoptimizing more than we can allow, so we probably need to reconsider the technical approach here. Closing to reopen a new PR if we make progress on that. |
To update here further, after exploring various alternatives in discussions with @bmeck and @devsnek it seems to be the case that there is simply nothing we can do without some serious assistance from v8 on this, which we were unable to get any interest in. Perhaps a later TC39 proposal can provide per-module global access permissions, and we can focus our future efforts there, but for now I'll be abandoning this deprecation. Thanks all for your help and feedback. |
Yes. Realms and SES |
The problem we have is that the npm ecosystem will now proliferate with ES modules containing global |
The issue being that, a custom realm that doesn't provide the global process, will simply not support large swathes of the ecosystem due to compatibility issues on the expectation of global process being present. |
SES enables virtualizing globals as well, so that an individual module can be given a global binding of |
@erights global-per-module virtualization (or even global-per-package boundary) seems very expensive for performance, especially with module counts of the scale of the npm ecosystem. Seems like it makes it much harder to justify. I agree we likely need a separate secure JS runtime from Node.js at this point, especially given the outcome of this PR. Perhaps the |
It should only be a few objects per compartment. If compartments are expensive enough to deter using them for safe module linkage, they weren't implemented right.
In a SES environment code can only dereference the
The first can reliably be statically recognized. The other two are interesting. I'm betting that separate compartments will prove to be the more practical way to give different modules access to different global bindings of |
All top-level lookups being deoptimized (as in they can't be inlined on hotpaths) due to the top-level context wrapper managing this is exactly the performance reason this PR can't move forward. I'd expect SES suffers from the same issue. If the builtins are shared between the compartment wrappers then it can be done performantly apart from that, but until v8 optimize the top-level context that seems like the major common issue.
The binding escape analysis needed both in build tool optimizations and security analysis are very similar problems, and interesting ones indeed. |
The SES shim will definitely suffer from this issue. However, SES is a proposal. Once accepted, the platform will directly support Compartments. There's no reason for platform supported compartments to have any extra overheads.
I don't understand this sentence. Clarify? Thanks.
Fortunately, SES and the SES shim do not rely on any additional static analysis, and so work soundly despite the notorious difficulty of statically analyzing JavaScript. Our transitions plans do rely on @bmeck 's TOFU analysis, but this need only be approximate. Neither TOFU failures of inclusion or exclusion make the security enforcement unsound. Though of course, TOFU imprecisions impede the process of getting the code working again in a much more secure manner. |
Actually, if |
Note that the optimizer mechanism is only appropriate when the property is a non-configurable, non-writable data property, since this guarantees that its value won't change. The Realm shim optimizer mechanism will notice this and shadow it with a |
The problem with the optimization approach is:
These hard backwards compatibility constraints mean the optimizations approaches can't work in Node.js. The issues will likely also be hit for a secure Node.js environment that wants to support third-party packages, but perhaps they are a bit more relaxed for a security-focused project on top of Node - SES likely doesn't need to support (2) apart from possibly through an attenuation phase that could be locked down. The slow paths in this PR are also not for the hits though - the slow paths are for the fall-throughs. Because we have an inner context, falling back to the outer global. The test case brought up was with the use of Ideally, the optimization we would need from v8 here would be that I guess this fallthrough case doesn't apply to SES though actually since it only has the single wrapping of the context, instead of say a two-layer context. Although I'm still not sure I follow how Would be great to discuss further, maybe we can add this as an agenda item to the coming SES meeting if there'd be time for it, or another place we can discuss to avoid continuing to pollute this thread. |
I'm a sucker for "best practices" - nodejs/node#26334
This PR deprecates access to
global.process
andglobal.Buffer
access in ECMAScript modules only, while ensuring they continue to behave fine for all CommonJS modules and contexts providing comprehensive backwards compatibility.This is done by making them getters which check the context in which they are called and throw when inside an ECMAScript module. To avoid this getter slowpath in accesses,
process
andBuffer
are also added as a context to the compileFunction wrapper in CJS. In addition these getters are only defined as soon as there is a load of an ECMAScript module to avoid any slowdowns in these cases.The benefits of this are that then ECMAScript modules don't by default have to assume access to all the root-level-security functions and properties on
process
allowing access control to be added in future, as well as helping towards browser compatibility by making process an import.ECMAScript modules share the same realm global, so there isn't a way to do this otherwise. In addition once users start running and writing and publishing ECMAScript modules in Node.js that assume the
process
andBuffer
globals exist, it becomes very difficult to change this then.For these reasons I think it is quite important to land this with the ECMAScript modules implementation in Node.js to provide these properties, or risk never being able to provide them at all in Node.js due to ecosystem compatibility constraints.
Previous discussion: nodejs/modules#235.
Checklist
make -j4 test
(UNIX), orvcbuild test
(Windows) passes