!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 

uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/usr/src/linux-headers-5.4.0-216/arch/powerpc/include/asm/book3s/64/   drwxr-xr-x
Free 13 GB of 57.97 GB (22.43%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     kup-radix.h (3.21 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _ASM_POWERPC_BOOK3S_64_KUP_RADIX_H
#define _ASM_POWERPC_BOOK3S_64_KUP_RADIX_H

#include <linux/const.h>

#define AMR_KUAP_BLOCK_READ    UL(0x4000000000000000)
#define AMR_KUAP_BLOCK_WRITE    UL(0x8000000000000000)
#define AMR_KUAP_BLOCKED    (AMR_KUAP_BLOCK_READ | AMR_KUAP_BLOCK_WRITE)
#define AMR_KUAP_SHIFT        62

#ifdef __ASSEMBLY__

#ifdef CONFIG_PPC_KUAP
.macro kuap_restore_amr    gpr
    BEGIN_MMU_FTR_SECTION_NESTED(67)
    ld    \gpr, STACK_REGS_KUAP(r1)
    mtspr    SPRN_AMR, \gpr
    END_MMU_FTR_SECTION_NESTED_IFSET(MMU_FTR_RADIX_KUAP, 67)
.endm

.macro kuap_check_amr gpr1, gpr2
#ifdef CONFIG_PPC_KUAP_DEBUG
    BEGIN_MMU_FTR_SECTION_NESTED(67)
    mfspr    \gpr1, SPRN_AMR
    li    \gpr2, (AMR_KUAP_BLOCKED >> AMR_KUAP_SHIFT)
    sldi    \gpr2, \gpr2, AMR_KUAP_SHIFT
999:    tdne    \gpr1, \gpr2
    EMIT_BUG_ENTRY 999b, __FILE__, __LINE__, (BUGFLAG_WARNING | BUGFLAG_ONCE)
    END_MMU_FTR_SECTION_NESTED_IFSET(MMU_FTR_RADIX_KUAP, 67)
#endif
.endm
#endif

.macro kuap_save_amr_and_lock gpr1, gpr2, use_cr, msr_pr_cr
#ifdef CONFIG_PPC_KUAP
    BEGIN_MMU_FTR_SECTION_NESTED(67)
    .ifnb \msr_pr_cr
    bne    \msr_pr_cr, 99f
    .endif
    mfspr    \gpr1, SPRN_AMR
    std    \gpr1, STACK_REGS_KUAP(r1)
    li    \gpr2, (AMR_KUAP_BLOCKED >> AMR_KUAP_SHIFT)
    sldi    \gpr2, \gpr2, AMR_KUAP_SHIFT
    cmpd    \use_cr, \gpr1, \gpr2
    beq    \use_cr, 99f
    // We don't isync here because we very recently entered via rfid
    mtspr    SPRN_AMR, \gpr2
    isync
99:
    END_MMU_FTR_SECTION_NESTED_IFSET(MMU_FTR_RADIX_KUAP, 67)
#endif
.endm

#else /* !__ASSEMBLY__ */

#include <linux/jump_label.h>

DECLARE_STATIC_KEY_FALSE(uaccess_flush_key);

#ifdef CONFIG_PPC_KUAP

#include <asm/reg.h>

/*
 * We support individually allowing read or write, but we don't support nesting
 * because that would require an expensive read/modify write of the AMR.
 */

static inline void set_kuap(unsigned long value)
{
    if (!early_mmu_has_feature(MMU_FTR_RADIX_KUAP))
        return;

    /*
     * ISA v3.0B says we need a CSI (Context Synchronising Instruction) both
     * before and after the move to AMR. See table 6 on page 1134.
     */
    isync();
    mtspr(SPRN_AMR, value);
    isync();
}

static inline bool
bad_kuap_fault(struct pt_regs *regs, unsigned long address, bool is_write)
{
    return WARN(mmu_has_feature(MMU_FTR_RADIX_KUAP) &&
            (regs->kuap & (is_write ? AMR_KUAP_BLOCK_WRITE : AMR_KUAP_BLOCK_READ)),
            "Bug: %s fault blocked by AMR!", is_write ? "Write" : "Read");
}
#else /* CONFIG_PPC_KUAP */
static inline void kuap_restore_amr(struct pt_regs *regs, unsigned long amr) { }
static inline void set_kuap(unsigned long value) { }
#endif /* !CONFIG_PPC_KUAP */

static __always_inline void allow_user_access(void __user *to, const void __user *from,
                          unsigned long size, unsigned long dir)
{
    // This is written so we can resolve to a single case at build time
    BUILD_BUG_ON(!__builtin_constant_p(dir));
    if (dir == KUAP_READ)
        set_kuap(AMR_KUAP_BLOCK_WRITE);
    else if (dir == KUAP_WRITE)
        set_kuap(AMR_KUAP_BLOCK_READ);
    else
        set_kuap(0);
}

static inline void prevent_user_access(void __user *to, const void __user *from,
                       unsigned long size, unsigned long dir)
{
    set_kuap(AMR_KUAP_BLOCKED);
    if (static_branch_unlikely(&uaccess_flush_key))
        do_uaccess_flush();
}

#endif /* __ASSEMBLY__ */

#endif /* _ASM_POWERPC_BOOK3S_64_KUP_RADIX_H */

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0153 ]--