| /linux/security/selinux/ |
| H A D | ibpkey.c | 56 static unsigned int sel_ib_pkey_hashfn(u16 pkey) in sel_ib_pkey_hashfn() argument 58 return (pkey & (SEL_PKEY_HASH_SIZE - 1)); in sel_ib_pkey_hashfn() 74 struct sel_ib_pkey *pkey; in sel_ib_pkey_find() local 77 list_for_each_entry_rcu(pkey, &sel_ib_pkey_hash[idx].list, list) { in sel_ib_pkey_find() 78 if (pkey->psec.pkey == pkey_num && in sel_ib_pkey_find() 79 pkey->psec.subnet_prefix == subnet_prefix) in sel_ib_pkey_find() 80 return pkey; in sel_ib_pkey_find() 94 static void sel_ib_pkey_insert(struct sel_ib_pkey *pkey) in sel_ib_pkey_insert() argument 101 idx = sel_ib_pkey_hashfn(pkey->psec.pkey); in sel_ib_pkey_insert() 102 list_add_rcu(&pkey->list, &sel_ib_pkey_hash[idx].list); in sel_ib_pkey_insert() [all …]
|
| /linux/tools/testing/selftests/mm/ |
| H A D | protection_keys.c | 184 static u32 hw_pkey_get(int pkey, unsigned long flags) in hw_pkey_get() argument 189 __func__, pkey, flags, 0, 0); in hw_pkey_get() 192 return (u32) get_pkey_bits(pkey_reg, pkey); in hw_pkey_get() 195 static int hw_pkey_set(int pkey, unsigned long rights, unsigned long flags) in hw_pkey_set() argument 205 new_pkey_reg = set_pkey_bits(old_pkey_reg, pkey, rights); in hw_pkey_set() 211 __func__, pkey, rights, flags, 0, __read_pkey_reg(), in hw_pkey_set() 216 static void pkey_disable_set(int pkey, int flags) in pkey_disable_set() argument 223 pkey, flags); in pkey_disable_set() 226 pkey_rights = hw_pkey_get(pkey, syscall_flags); in pkey_disable_set() 229 pkey, pkey, pkey_rights); in pkey_disable_set() [all …]
|
| H A D | pkey_util.c | 16 int sys_pkey_free(unsigned long pkey) in sys_pkey_free() argument 18 int ret = syscall(SYS_pkey_free, pkey); in sys_pkey_free() 19 dprintf1("%s(pkey=%ld) syscall ret: %d\n", __func__, pkey, ret); in sys_pkey_free() 24 unsigned long pkey) in sys_mprotect_pkey() argument 29 ptr, size, orig_prot, pkey); in sys_mprotect_pkey() 32 sret = syscall(__NR_pkey_mprotect, ptr, size, orig_prot, pkey); in sys_mprotect_pkey()
|
| H A D | pkey-powerpc.h | 39 static inline u32 pkey_bit_position(int pkey) in pkey_bit_position() argument 41 return (NR_PKEYS - pkey - 1) * PKEY_BITS_PER_PKEY; in pkey_bit_position() 96 static inline void expect_fault_on_read_execonly_key(void *p1, int pkey) in expect_fault_on_read_execonly_key() argument 120 static inline void *malloc_pkey_with_mprotect_subpage(long size, int prot, u16 pkey) in malloc_pkey_with_mprotect_subpage() argument 126 size, prot, pkey); in malloc_pkey_with_mprotect_subpage() 127 pkey_assert(pkey < NR_PKEYS); in malloc_pkey_with_mprotect_subpage() 137 ret = mprotect_pkey((void *)ptr, PAGE_SIZE, prot, pkey); in malloc_pkey_with_mprotect_subpage() 141 dprintf1("%s() for pkey %d @ %p\n", __func__, pkey, ptr); in malloc_pkey_with_mprotect_subpage()
|
| H A D | pkey-helpers.h | 89 int sys_pkey_free(unsigned long pkey); 91 unsigned long pkey); 95 void expected_pkey_fault(int pkey); 97 unsigned long pkey); 122 static inline u64 set_pkey_bits(u64 reg, int pkey, u64 flags) in set_pkey_bits() argument 124 u32 shift = pkey_bit_position(pkey); in set_pkey_bits() 134 static inline u64 get_pkey_bits(u64 reg, int pkey) in get_pkey_bits() argument 136 u32 shift = pkey_bit_position(pkey); in get_pkey_bits()
|
| H A D | pkey_sighandler_tests.c | 287 int pkey; in test_sigsegv_handler_with_different_pkey_for_stack() local 314 pkey = sys_pkey_alloc(0, PKEY_UNRESTRICTED); in test_sigsegv_handler_with_different_pkey_for_stack() 315 sys_mprotect_pkey(stack, STACK_SIZE, PROT_READ | PROT_WRITE, pkey); in test_sigsegv_handler_with_different_pkey_for_stack() 443 int pkey; in test_pkru_sigreturn() local 487 pkey = sys_pkey_alloc(0, PKEY_UNRESTRICTED); in test_pkru_sigreturn() 488 sys_mprotect_pkey(stack, STACK_SIZE, PROT_READ | PROT_WRITE, pkey); in test_pkru_sigreturn()
|
| H A D | mseal_test.c | 75 unsigned long pkey) in sys_mprotect_pkey() argument 80 sret = syscall(__NR_pkey_mprotect, ptr, size, orig_prot, pkey); in sys_mprotect_pkey() 146 static unsigned long pkey_bit_position(int pkey) in pkey_bit_position() argument 148 return pkey * PKEY_BITS_PER_PKEY; in pkey_bit_position() 151 static u64 set_pkey_bits(u64 reg, int pkey, u64 flags) in set_pkey_bits() argument 153 unsigned long shift = pkey_bit_position(pkey); in set_pkey_bits() 162 static void set_pkey(int pkey, unsigned long pkey_value) in set_pkey() argument 166 new_pkey_reg = set_pkey_bits(__read_pkey_reg(), pkey, pkey_value); in set_pkey() 221 int pkey = sys_pkey_alloc(0, PKEY_UNRESTRICTED); in pkey_supported() local 223 if (pkey > 0) in pkey_supported() [all …]
|
| /linux/drivers/infiniband/core/ |
| H A D | security.c | 48 struct pkey_index_qp_list *pkey = NULL; in get_pkey_idx_qp_list() local 56 pkey = tmp_pkey; in get_pkey_idx_qp_list() 61 return pkey; in get_pkey_idx_qp_list() 65 u16 *pkey, in get_pkey_and_subnet_prefix() argument 71 ret = ib_get_cached_pkey(dev, pp->port_num, pp->pkey_index, pkey); in get_pkey_and_subnet_prefix() 80 static int enforce_qp_pkey_security(u16 pkey, in enforce_qp_pkey_security() argument 87 ret = security_ib_pkey_access(qp_sec->security, subnet_prefix, pkey); in enforce_qp_pkey_security() 96 pkey); in enforce_qp_pkey_security() 115 u16 pkey; in check_qp_port_pkey_settings() local 123 &pkey, in check_qp_port_pkey_settings() [all …]
|
| /linux/drivers/s390/crypto/ |
| H A D | Makefile | 17 pkey-objs := pkey_base.o pkey_api.o pkey_sysfs.o 18 obj-$(CONFIG_PKEY) += pkey.o 21 pkey-cca-objs := pkey_cca.o 22 obj-$(CONFIG_PKEY_CCA) += pkey-cca.o 25 pkey-ep11-objs := pkey_ep11.o 26 obj-$(CONFIG_PKEY_EP11) += pkey-ep11.o 29 pkey-pckmo-objs := pkey_pckmo.o 30 obj-$(CONFIG_PKEY_PCKMO) += pkey-pckmo.o 33 pkey-uv-objs := pkey_uv.o 34 obj-$(CONFIG_PKEY_UV) += pkey-uv.o
|
| /linux/drivers/infiniband/ulp/ipoib/ |
| H A D | ipoib_vlan.c | 72 if (ppriv->pkey == priv->pkey) in is_child_unique() 77 if (tpriv->pkey == priv->pkey && in is_child_unique() 98 u16 pkey, int type) in __ipoib_vlan_add() argument 116 if (pkey == 0 || pkey == 0x8000) { in __ipoib_vlan_add() 124 priv->pkey = pkey; in __ipoib_vlan_add() 168 int ipoib_vlan_add(struct net_device *pdev, unsigned short pkey) in ipoib_vlan_add() argument 193 pkey); in ipoib_vlan_add() 204 result = __ipoib_vlan_add(ppriv, priv, pkey, IPOIB_LEGACY_CHILD); in ipoib_vlan_add() 252 int ipoib_vlan_delete(struct net_device *pdev, unsigned short pkey) in ipoib_vlan_delete() argument 273 if (priv->pkey == pkey && in ipoib_vlan_delete()
|
| /linux/Documentation/translations/zh_CN/core-api/ |
| H A D | protection-keys.rst | 46 int pkey_free(int pkey); 48 unsigned long prot, int pkey); 50 在使用一个pkey之前,必须先用pkey_alloc()分配它。一个应用程序直接调用 55 pkey = pkey_alloc(0, PKEY_DISABLE_WRITE); 57 ret = pkey_mprotect(ptr, PAGE_SIZE, real_prot, pkey); 63 pkey_set(pkey, 0); // clear PKEY_DISABLE_WRITE 65 pkey_set(pkey, PKEY_DISABLE_WRITE); // set PKEY_DISABLE_WRITE again 67 现在,当它释放内存时,它也将释放pkey,因为它不再被使用了:: 70 pkey_free(pkey); 85 pkey = pkey_alloc(0, PKEY_DISABLE_WRITE | PKEY_DISABLE_READ); [all …]
|
| /linux/crypto/asymmetric_keys/ |
| H A D | restrict.c | 138 const struct public_key *pkey; in restrict_link_by_ca() local 143 pkey = payload->data[asym_crypto]; in restrict_link_by_ca() 144 if (!pkey) in restrict_link_by_ca() 146 if (!test_bit(KEY_EFLAG_CA, &pkey->key_eflags)) in restrict_link_by_ca() 148 if (!test_bit(KEY_EFLAG_KEYCERTSIGN, &pkey->key_eflags)) in restrict_link_by_ca() 152 if (test_bit(KEY_EFLAG_DIGITALSIG, &pkey->key_eflags)) in restrict_link_by_ca() 179 const struct public_key *pkey; in restrict_link_by_digsig() local 184 pkey = payload->data[asym_crypto]; in restrict_link_by_digsig() 186 if (!pkey) in restrict_link_by_digsig() 189 if (!test_bit(KEY_EFLAG_DIGITALSIG, &pkey->key_eflags)) in restrict_link_by_digsig() [all …]
|
| /linux/include/net/ |
| H A D | neighbour.h | 214 __u32 (*hash)(const void *pkey, 217 bool (*key_eq)(const struct neighbour *, const void *pkey); 222 int (*is_multicast)(const void *pkey); 289 static inline bool neigh_key_eq32(const struct neighbour *n, const void *pkey) in neigh_key_eq32() argument 291 return *(const u32 *)n->primary_key == *(const u32 *)pkey; in neigh_key_eq32() 294 static inline bool neigh_key_eq128(const struct neighbour *n, const void *pkey) in neigh_key_eq128() argument 297 const u32 *p32 = pkey; in neigh_key_eq128() 305 bool (*key_eq)(const struct neighbour *n, const void *pkey), in ___neigh_lookup_noref() argument 306 __u32 (*hash)(const void *pkey, in ___neigh_lookup_noref() argument 309 const void *pkey, in ___neigh_lookup_noref() [all …]
|
| /linux/drivers/infiniband/hw/hfi1/ |
| H A D | ud.c | 70 u16 pkey; in ud_loopback() local 74 pkey = hfi1_get_pkey(ibp, sqp->s_pkey_index); in ud_loopback() 77 if (unlikely(ingress_pkey_check(ppd, pkey, sc5, in ud_loopback() 80 hfi1_bad_pkey(ibp, pkey, in ud_loopback() 226 u16 *pkey, u32 extra_bytes, bool bypass) in hfi1_make_bth_deth() argument 243 *pkey = hfi1_get_pkey(ibp, rvt_get_swqe_pkey_index(wqe)); in hfi1_make_bth_deth() 245 *pkey = hfi1_get_pkey(ibp, qp->s_pkey_index); in hfi1_make_bth_deth() 247 bth0 |= *pkey; in hfi1_make_bth_deth() 265 u16 len, slid, dlid, pkey; in hfi1_make_ud_req_9B() local 323 hfi1_make_bth_deth(qp, wqe, ohdr, &pkey, extra_bytes, false); in hfi1_make_ud_req_9B() [all …]
|
| H A D | trace_ibhdrs.h | 77 u16 *pkey, u32 *psn, u32 *qpn); 88 u16 *entropy, u16 *len, u16 *pkey, 95 u16 len, u16 pkey, u32 dlid, u32 slid); 100 u8 tver, u16 pkey, u32 psn, u32 qpn, 140 __field(u16, pkey) 168 &__entry->pkey, 207 &__entry->pkey, 238 __entry->pkey, 254 __entry->pkey, 299 __field(u16, pkey) [all …]
|
| H A D | ruc.c | 37 u16 pkey = packet->pkey; in hfi1_ruc_check_hdr() local 62 if (unlikely(rcv_pkey_check(ppd_from_ibp(ibp), pkey, in hfi1_ruc_check_hdr() 64 hfi1_bad_pkey(ibp, pkey, sl, 0, qp->ibqp.qp_num, in hfi1_ruc_check_hdr() 99 if (unlikely(rcv_pkey_check(ppd_from_ibp(ibp), pkey, in hfi1_ruc_check_hdr() 101 hfi1_bad_pkey(ibp, pkey, sl, 0, qp->ibqp.qp_num, in hfi1_ruc_check_hdr() 241 u16 pkey = hfi1_get_pkey(ibp, qp->s_pkey_index); in hfi1_make_ruc_header_16B() local 286 bth0 |= pkey; in hfi1_make_ruc_header_16B() 302 pkey, becn, 0, l4, priv->s_sc); in hfi1_make_ruc_header_16B() 328 u16 pkey = hfi1_get_pkey(ibp, qp->s_pkey_index); in hfi1_make_ruc_header_9B() local 364 bth0 |= pkey; in hfi1_make_ruc_header_9B()
|
| /linux/include/linux/ |
| H A D | pkeys.h | 14 #define arch_override_mprotect_pkey(vma, prot, pkey) (0) argument 23 static inline bool mm_pkey_is_allocated(struct mm_struct *mm, int pkey) in mm_pkey_is_allocated() argument 25 return (pkey == 0); in mm_pkey_is_allocated() 33 static inline int mm_pkey_free(struct mm_struct *mm, int pkey) in mm_pkey_free() argument 38 static inline int arch_set_user_pkey_access(struct task_struct *tsk, int pkey, in arch_set_user_pkey_access() argument
|
| /linux/lib/ |
| H A D | digsig.c | 74 MPI in = NULL, res = NULL, pkey[2]; in digsig_verify_rsa() local 108 pkey[i] = mpi_read_from_buffer(datap, &remaining); in digsig_verify_rsa() 109 if (IS_ERR(pkey[i])) { in digsig_verify_rsa() 110 err = PTR_ERR(pkey[i]); in digsig_verify_rsa() 116 mblen = mpi_get_nbits(pkey[0]); in digsig_verify_rsa() 141 err = mpi_powm(res, in, pkey[1], pkey[0]); in digsig_verify_rsa() 172 mpi_free(pkey[i]); in digsig_verify_rsa()
|
| /linux/Documentation/core-api/ |
| H A D | protection-keys.rst | 56 int pkey_free(int pkey); 58 unsigned long prot, int pkey); 60 Before a pkey can be used, it must first be allocated with pkey_alloc(). An 67 pkey = pkey_alloc(0, PKEY_DISABLE_WRITE); 69 ret = pkey_mprotect(ptr, PAGE_SIZE, real_prot, pkey); 75 pkey_set(pkey, 0); // clear PKEY_DISABLE_WRITE 77 pkey_set(pkey, PKEY_DISABLE_WRITE); // set PKEY_DISABLE_WRITE again 79 Now when it frees the memory, it will also free the pkey since it 83 pkey_free(pkey); 87 tools/testing/selftests/mm/pkey-{arm64,powerpc,x86}.h [all …]
|
| /linux/arch/x86/include/asm/ |
| H A D | pkru.h | 19 static inline bool __pkru_allows_read(u32 pkru, u16 pkey) in __pkru_allows_read() argument 21 int pkru_pkey_bits = pkey * PKRU_BITS_PER_PKEY; in __pkru_allows_read() 25 static inline bool __pkru_allows_write(u32 pkru, u16 pkey) in __pkru_allows_write() argument 27 int pkru_pkey_bits = pkey * PKRU_BITS_PER_PKEY; in __pkru_allows_write()
|
| /linux/tools/testing/selftests/powerpc/ptrace/ |
| H A D | Makefile | 12 TESTS_64 += core-pkey 16 TESTS_64 += ptrace-pkey 41 $(OUTPUT)/ptrace-pkey $(OUTPUT)/core-pkey: LDLIBS += -pthread
|
| H A D | .gitignore | 14 core-pkey 15 ptrace-pkey
|
| /linux/drivers/gpu/drm/nouveau/nvkm/subdev/gsp/ |
| H A D | gh100.c | 106 gsp->fmc.fw.addr, gsp->fmc.hash, gsp->fmc.pkey, gsp->fmc.sig); in gh100_gsp_init() 269 const void *hash, *sig, *pkey, *img; in gh100_gsp_oneinit() local 282 pkey = elf_section(fw, "publickey", &pkey_len); in gh100_gsp_oneinit() 285 if (!hash || !sig || !pkey || !img) { in gh100_gsp_oneinit() 301 gsp->fmc.pkey = kmemdup(pkey, pkey_len, GFP_KERNEL); in gh100_gsp_oneinit() 303 if (!gsp->fmc.hash || !gsp->fmc.pkey || !gsp->fmc.sig) in gh100_gsp_oneinit()
|
| /linux/security/selinux/include/ |
| H A D | ibpkey.h | 22 int sel_ib_pkey_sid(u64 subnet_prefix, u16 pkey, u32 *sid); 28 static inline int sel_ib_pkey_sid(u64 subnet_prefix, u16 pkey, u32 *sid) in sel_ib_pkey_sid() argument
|
| /linux/drivers/infiniband/sw/rxe/ |
| H A D | rxe_hdr.h | 64 __be16 pkey; member 166 return be16_to_cpu(bth->pkey); in __bth_pkey() 169 static inline void __bth_set_pkey(void *arg, u16 pkey) in __bth_set_pkey() argument 173 bth->pkey = cpu_to_be16(pkey); in __bth_set_pkey() 335 static inline void bth_set_pkey(struct rxe_pkt_info *pkt, u16 pkey) in bth_set_pkey() argument 337 __bth_set_pkey(pkt->hdr, pkey); in bth_set_pkey() 406 int mig, int pad, u16 pkey, u32 qpn, int ack_req, in bth_init() argument 417 bth->pkey = cpu_to_be16(pkey); in bth_init()
|