SILENT KILLERPanel

Current Path: > > usr > include > python3.6m > >


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //usr/include/python3.6m//

NameTypeSizeLast ModifiedActions
Python-ast.h File 22274 bytes December 24 2018 02:45:11.
Python.h File 3221 bytes December 23 2018 21:37:14.
_hashopenssl.h File 1365 bytes July 01 2025 22:09:53.
abstract.h File 47451 bytes December 23 2018 21:37:14.
accu.h File 1016 bytes December 23 2018 21:37:14.
asdl.h File 1213 bytes December 23 2018 21:37:14.
ast.h File 477 bytes December 23 2018 21:37:14.
bitset.h File 792 bytes December 23 2018 21:37:14.
bltinmodule.h File 264 bytes December 23 2018 21:37:14.
boolobject.h File 886 bytes December 23 2018 21:37:14.
bytearrayobject.h File 2114 bytes December 23 2018 21:37:14.
bytes_methods.h File 3191 bytes December 23 2018 21:37:14.
bytesobject.h File 8363 bytes December 23 2018 21:37:14.
cellobject.h File 701 bytes December 23 2018 21:37:14.
ceval.h File 8524 bytes December 23 2018 21:37:14.
classobject.h File 1666 bytes December 23 2018 21:37:14.
code.h File 5945 bytes December 23 2018 21:37:14.
codecs.h File 6793 bytes December 23 2018 21:37:14.
compile.h File 2164 bytes December 23 2018 21:37:14.
complexobject.h File 1807 bytes December 23 2018 21:37:14.
datetime.h File 9414 bytes December 23 2018 21:37:14.
descrobject.h File 2964 bytes December 23 2018 21:37:14.
dictobject.h File 7178 bytes December 23 2018 21:37:14.
dtoa.h File 458 bytes December 23 2018 21:37:14.
dynamic_annotations.h File 22469 bytes December 23 2018 21:37:14.
enumobject.h File 253 bytes December 23 2018 21:37:14.
errcode.h File 1497 bytes December 23 2018 21:37:14.
eval.h File 597 bytes December 23 2018 21:37:14.
fileobject.h File 1651 bytes December 23 2018 21:37:14.
fileutils.h File 3524 bytes December 23 2018 21:37:14.
floatobject.h File 4794 bytes December 23 2018 21:37:14.
frameobject.h File 3530 bytes December 23 2018 21:37:14.
funcobject.h File 4079 bytes December 23 2018 21:37:14.
genobject.h File 3583 bytes December 23 2018 21:37:14.
graminit.h File 1966 bytes December 23 2018 21:37:14.
grammar.h File 2074 bytes December 23 2018 21:37:14.
import.h File 4233 bytes December 23 2018 21:37:14.
intrcheck.h File 513 bytes December 23 2018 21:37:14.
iterobject.h File 567 bytes December 23 2018 21:37:14.
listobject.h File 2900 bytes December 23 2018 21:37:14.
longintrepr.h File 3761 bytes December 23 2018 21:37:14.
longobject.h File 9830 bytes July 01 2025 22:09:53.
marshal.h File 803 bytes December 23 2018 21:37:14.
memoryobject.h File 2765 bytes December 23 2018 21:37:14.
metagrammar.h File 253 bytes December 23 2018 21:37:14.
methodobject.h File 3847 bytes December 23 2018 21:37:14.
modsupport.h File 7317 bytes December 23 2018 21:37:14.
moduleobject.h File 2285 bytes December 23 2018 21:37:14.
namespaceobject.h File 349 bytes December 23 2018 21:37:14.
node.h File 1007 bytes December 23 2018 21:37:14.
object.h File 42203 bytes July 01 2025 22:09:53.
objimpl.h File 14244 bytes December 23 2018 21:37:14.
odictobject.h File 1288 bytes December 23 2018 21:37:14.
opcode.h File 5073 bytes December 23 2018 21:37:14.
osdefs.h File 691 bytes December 23 2018 21:37:14.
osmodule.h File 291 bytes December 23 2018 21:37:14.
parsetok.h File 2885 bytes December 23 2018 21:37:14.
patchlevel.h File 1128 bytes December 23 2018 21:37:14.
pgen.h File 253 bytes December 23 2018 21:37:14.
pgenheaders.h File 1180 bytes December 23 2018 21:37:14.
py_curses.h File 4307 bytes December 23 2018 21:37:14.
pyarena.h File 2744 bytes December 23 2018 21:37:14.
pyatomic.h File 8128 bytes December 23 2018 21:37:14.
pycapsule.h File 1726 bytes December 23 2018 21:37:14.
pyconfig-64.h File 44622 bytes July 01 2025 22:10:55.
pyconfig.h File 162 bytes July 01 2025 22:14:40.
pyctype.h File 1320 bytes December 23 2018 21:37:14.
pydebug.h File 1264 bytes July 01 2025 22:09:53.
pydtrace.h File 1970 bytes December 23 2018 21:37:14.
pyerrors.h File 17219 bytes December 23 2018 21:37:14.
pyexpat.h File 2450 bytes December 23 2018 21:37:14.
pyfpe.h File 8471 bytes December 23 2018 21:37:14.
pygetopt.h File 410 bytes December 23 2018 21:37:14.
pyhash.h File 4139 bytes December 23 2018 21:37:14.
pylifecycle.h File 4078 bytes December 23 2018 21:37:14.
pymacconfig.h File 2989 bytes December 23 2018 21:37:14.
pymacro.h File 3500 bytes December 23 2018 21:37:14.
pymath.h File 8312 bytes December 23 2018 21:37:14.
pymem.h File 8557 bytes December 23 2018 21:37:14.
pyport.h File 27573 bytes December 23 2018 21:37:14.
pystate.h File 11146 bytes December 23 2018 21:37:14.
pystrcmp.h File 436 bytes December 23 2018 21:37:14.
pystrhex.h File 495 bytes December 23 2018 21:37:14.
pystrtod.h File 1483 bytes December 23 2018 21:37:14.
pythonrun.h File 6782 bytes December 23 2018 21:37:14.
pythread.h File 2992 bytes December 23 2018 21:37:14.
pytime.h File 7609 bytes December 23 2018 21:37:14.
rangeobject.h File 629 bytes December 23 2018 21:37:14.
setobject.h File 3333 bytes December 23 2018 21:37:14.
sliceobject.h File 2485 bytes December 23 2018 21:37:14.
structmember.h File 2018 bytes December 23 2018 21:37:14.
structseq.h File 1353 bytes December 23 2018 21:37:14.
symtable.h File 4994 bytes December 23 2018 21:37:14.
sysmodule.h File 1355 bytes December 23 2018 21:37:14.
token.h File 1943 bytes December 23 2018 21:37:14.
traceback.h File 3644 bytes December 23 2018 21:37:14.
tupleobject.h File 2444 bytes December 23 2018 21:37:14.
typeslots.h File 2253 bytes December 23 2018 21:37:14.
ucnhash.h File 1056 bytes December 23 2018 21:37:14.
unicodeobject.h File 81779 bytes December 23 2018 21:37:14.
warnings.h File 1693 bytes December 23 2018 21:37:14.
weakrefobject.h File 2866 bytes December 23 2018 21:37:14.

Reading File: //usr/include/python3.6m///pyatomic.h

#ifndef Py_ATOMIC_H
#define Py_ATOMIC_H
#ifdef Py_BUILD_CORE

#include "dynamic_annotations.h"

#include "pyconfig.h"

#if defined(HAVE_STD_ATOMIC)
#include <stdatomic.h>
#endif

/* This is modeled after the atomics interface from C1x, according to
 * the draft at
 * http://www.open-std.org/JTC1/SC22/wg14/www/docs/n1425.pdf.
 * Operations and types are named the same except with a _Py_ prefix
 * and have the same semantics.
 *
 * Beware, the implementations here are deep magic.
 */

#if defined(HAVE_STD_ATOMIC)

typedef enum _Py_memory_order {
    _Py_memory_order_relaxed = memory_order_relaxed,
    _Py_memory_order_acquire = memory_order_acquire,
    _Py_memory_order_release = memory_order_release,
    _Py_memory_order_acq_rel = memory_order_acq_rel,
    _Py_memory_order_seq_cst = memory_order_seq_cst
} _Py_memory_order;

typedef struct _Py_atomic_address {
    atomic_uintptr_t _value;
} _Py_atomic_address;

typedef struct _Py_atomic_int {
    atomic_int _value;
} _Py_atomic_int;

#define _Py_atomic_signal_fence(/*memory_order*/ ORDER) \
    atomic_signal_fence(ORDER)

#define _Py_atomic_thread_fence(/*memory_order*/ ORDER) \
    atomic_thread_fence(ORDER)

#define _Py_atomic_store_explicit(ATOMIC_VAL, NEW_VAL, ORDER) \
    atomic_store_explicit(&(ATOMIC_VAL)->_value, NEW_VAL, ORDER)

#define _Py_atomic_load_explicit(ATOMIC_VAL, ORDER) \
    atomic_load_explicit(&(ATOMIC_VAL)->_value, ORDER)

/* Use builtin atomic operations in GCC >= 4.7 */
#elif defined(HAVE_BUILTIN_ATOMIC)

typedef enum _Py_memory_order {
    _Py_memory_order_relaxed = __ATOMIC_RELAXED,
    _Py_memory_order_acquire = __ATOMIC_ACQUIRE,
    _Py_memory_order_release = __ATOMIC_RELEASE,
    _Py_memory_order_acq_rel = __ATOMIC_ACQ_REL,
    _Py_memory_order_seq_cst = __ATOMIC_SEQ_CST
} _Py_memory_order;

typedef struct _Py_atomic_address {
    uintptr_t _value;
} _Py_atomic_address;

typedef struct _Py_atomic_int {
    int _value;
} _Py_atomic_int;

#define _Py_atomic_signal_fence(/*memory_order*/ ORDER) \
    __atomic_signal_fence(ORDER)

#define _Py_atomic_thread_fence(/*memory_order*/ ORDER) \
    __atomic_thread_fence(ORDER)

#define _Py_atomic_store_explicit(ATOMIC_VAL, NEW_VAL, ORDER) \
    (assert((ORDER) == __ATOMIC_RELAXED                       \
            || (ORDER) == __ATOMIC_SEQ_CST                    \
            || (ORDER) == __ATOMIC_RELEASE),                  \
     __atomic_store_n(&(ATOMIC_VAL)->_value, NEW_VAL, ORDER))

#define _Py_atomic_load_explicit(ATOMIC_VAL, ORDER)           \
    (assert((ORDER) == __ATOMIC_RELAXED                       \
            || (ORDER) == __ATOMIC_SEQ_CST                    \
            || (ORDER) == __ATOMIC_ACQUIRE                    \
            || (ORDER) == __ATOMIC_CONSUME),                  \
     __atomic_load_n(&(ATOMIC_VAL)->_value, ORDER))

#else

typedef enum _Py_memory_order {
    _Py_memory_order_relaxed,
    _Py_memory_order_acquire,
    _Py_memory_order_release,
    _Py_memory_order_acq_rel,
    _Py_memory_order_seq_cst
} _Py_memory_order;

typedef struct _Py_atomic_address {
    uintptr_t _value;
} _Py_atomic_address;

typedef struct _Py_atomic_int {
    int _value;
} _Py_atomic_int;

/* Only support GCC (for expression statements) and x86 (for simple
 * atomic semantics) for now */
#if defined(__GNUC__) && (defined(__i386__) || defined(__amd64))

static __inline__ void
_Py_atomic_signal_fence(_Py_memory_order order)
{
    if (order != _Py_memory_order_relaxed)
        __asm__ volatile("":::"memory");
}

static __inline__ void
_Py_atomic_thread_fence(_Py_memory_order order)
{
    if (order != _Py_memory_order_relaxed)
        __asm__ volatile("mfence":::"memory");
}

/* Tell the race checker about this operation's effects. */
static __inline__ void
_Py_ANNOTATE_MEMORY_ORDER(const volatile void *address, _Py_memory_order order)
{
    (void)address;		/* shut up -Wunused-parameter */
    switch(order) {
    case _Py_memory_order_release:
    case _Py_memory_order_acq_rel:
    case _Py_memory_order_seq_cst:
        _Py_ANNOTATE_HAPPENS_BEFORE(address);
        break;
    case _Py_memory_order_relaxed:
    case _Py_memory_order_acquire:
        break;
    }
    switch(order) {
    case _Py_memory_order_acquire:
    case _Py_memory_order_acq_rel:
    case _Py_memory_order_seq_cst:
        _Py_ANNOTATE_HAPPENS_AFTER(address);
        break;
    case _Py_memory_order_relaxed:
    case _Py_memory_order_release:
        break;
    }
}

#define _Py_atomic_store_explicit(ATOMIC_VAL, NEW_VAL, ORDER) \
    __extension__ ({ \
        __typeof__(ATOMIC_VAL) atomic_val = ATOMIC_VAL; \
        __typeof__(atomic_val->_value) new_val = NEW_VAL;\
        volatile __typeof__(new_val) *volatile_data = &atomic_val->_value; \
        _Py_memory_order order = ORDER; \
        _Py_ANNOTATE_MEMORY_ORDER(atomic_val, order); \
        \
        /* Perform the operation. */ \
        _Py_ANNOTATE_IGNORE_WRITES_BEGIN(); \
        switch(order) { \
        case _Py_memory_order_release: \
            _Py_atomic_signal_fence(_Py_memory_order_release); \
            /* fallthrough */ \
        case _Py_memory_order_relaxed: \
            *volatile_data = new_val; \
            break; \
        \
        case _Py_memory_order_acquire: \
        case _Py_memory_order_acq_rel: \
        case _Py_memory_order_seq_cst: \
            __asm__ volatile("xchg %0, %1" \
                         : "+r"(new_val) \
                         : "m"(atomic_val->_value) \
                         : "memory"); \
            break; \
        } \
        _Py_ANNOTATE_IGNORE_WRITES_END(); \
    })

#define _Py_atomic_load_explicit(ATOMIC_VAL, ORDER) \
    __extension__ ({  \
        __typeof__(ATOMIC_VAL) atomic_val = ATOMIC_VAL; \
        __typeof__(atomic_val->_value) result; \
        volatile __typeof__(result) *volatile_data = &atomic_val->_value; \
        _Py_memory_order order = ORDER; \
        _Py_ANNOTATE_MEMORY_ORDER(atomic_val, order); \
        \
        /* Perform the operation. */ \
        _Py_ANNOTATE_IGNORE_READS_BEGIN(); \
        switch(order) { \
        case _Py_memory_order_release: \
        case _Py_memory_order_acq_rel: \
        case _Py_memory_order_seq_cst: \
            /* Loads on x86 are not releases by default, so need a */ \
            /* thread fence. */ \
            _Py_atomic_thread_fence(_Py_memory_order_release); \
            break; \
        default: \
            /* No fence */ \
            break; \
        } \
        result = *volatile_data; \
        switch(order) { \
        case _Py_memory_order_acquire: \
        case _Py_memory_order_acq_rel: \
        case _Py_memory_order_seq_cst: \
            /* Loads on x86 are automatically acquire operations so */ \
            /* can get by with just a compiler fence. */ \
            _Py_atomic_signal_fence(_Py_memory_order_acquire); \
            break; \
        default: \
            /* No fence */ \
            break; \
        } \
        _Py_ANNOTATE_IGNORE_READS_END(); \
        result; \
    })

#else  /* !gcc x86 */
/* Fall back to other compilers and processors by assuming that simple
   volatile accesses are atomic.  This is false, so people should port
   this. */
#define _Py_atomic_signal_fence(/*memory_order*/ ORDER) ((void)0)
#define _Py_atomic_thread_fence(/*memory_order*/ ORDER) ((void)0)
#define _Py_atomic_store_explicit(ATOMIC_VAL, NEW_VAL, ORDER) \
    ((ATOMIC_VAL)->_value = NEW_VAL)
#define _Py_atomic_load_explicit(ATOMIC_VAL, ORDER) \
    ((ATOMIC_VAL)->_value)

#endif  /* !gcc x86 */
#endif

/* Standardized shortcuts. */
#define _Py_atomic_store(ATOMIC_VAL, NEW_VAL) \
    _Py_atomic_store_explicit(ATOMIC_VAL, NEW_VAL, _Py_memory_order_seq_cst)
#define _Py_atomic_load(ATOMIC_VAL) \
    _Py_atomic_load_explicit(ATOMIC_VAL, _Py_memory_order_seq_cst)

/* Python-local extensions */

#define _Py_atomic_store_relaxed(ATOMIC_VAL, NEW_VAL) \
    _Py_atomic_store_explicit(ATOMIC_VAL, NEW_VAL, _Py_memory_order_relaxed)
#define _Py_atomic_load_relaxed(ATOMIC_VAL) \
    _Py_atomic_load_explicit(ATOMIC_VAL, _Py_memory_order_relaxed)

#endif  /* Py_BUILD_CORE */
#endif  /* Py_ATOMIC_H */

SILENT KILLER Tool