| /linux/Documentation/translations/zh_CN/mm/ |
| H A D | highmem.rst | 64 在本地的kmap区域中采取pagefaults是有效的,除非获取本地映射的上下文由于其他原因不允许 76 虽然它比kmap()快得多,但在高内存的情况下,它对指针的有效性有限制。与kmap()映射相反, 81 kmap(),将页面映射到将被使用的同一线程中,并优先使用kmap_local_page()。 98 * kmap()。这应该被用来对单个页面进行短时间的映射,对抢占或迁移没有限制。它会带来开销, 102 映射变化必须广播到所有CPU(核)上,kmap()还需要在kmap的池被回绕(TLB项用光了,需要从第 104 槽出现。因此,kmap()只能从可抢占的上下文中调用。 107 高内存映射都是短暂的,而且只在一个地方使用。这意味着在这种情况下,kmap()的成本大 108 多被浪费了。kmap()并不是为长期映射而设计的,但是它已经朝着这个方向发展了,在较新 111 在64位系统中,调用kmap_local_page()、kmap_atomic()和kmap()没有实际作用,因为64位
|
| /linux/tools/perf/util/ |
| H A D | map.c | 226 map = calloc(1, sizeof(*map) + (dso__kernel(dso) ? sizeof(struct kmap) : 0)); in map__new2() 244 struct kmap *kmap = __map__kmap((struct map *)map); in __map__is_extra_kernel_map() local 246 return kmap && kmap->name[0]; in __map__is_extra_kernel_map() 419 size += sizeof(struct kmap); in map__clone() 516 static const struct kmap *__map__const_kmap(const struct map *map); 531 const struct kmap *kmap = __map__const_kmap(map); in map__rip_2objdump() local 539 if (kmap && is_entry_trampoline(kmap->name) && kmap->kmaps) { in map__rip_2objdump() 540 struct machine *machine = maps__machine(kmap->kmaps); in map__rip_2objdump() 614 struct kmap *__map__kmap(struct map *map) in __map__kmap() 620 return (struct kmap *)(&RC_CHK_ACCESS(map)[1]); in __map__kmap() [all …]
|
| H A D | bpf_lock_contention.c | 114 struct map *kmap; in init_numa_data() local 144 &kmap); in init_numa_data() 146 skel->rodata->contig_page_data_addr = map__unmap_ip(kmap, sym->start); in init_numa_data() 147 map__put(kmap); in init_numa_data() 158 &kmap); in init_numa_data() 162 skel->rodata->node_data_addr = map__unmap_ip(kmap, sym->start); in init_numa_data() 163 map__put(kmap); in init_numa_data() 243 struct map *kmap; in lock_contention_prepare() local 249 &kmap); in lock_contention_prepare() 263 addrs[con->filters->nr_addrs++] = map__unmap_ip(kmap, sym->start); in lock_contention_prepare() [all …]
|
| H A D | symbol-elf.c | 1320 static bool ref_reloc_sym_not_found(struct kmap *kmap) in ref_reloc_sym_not_found() argument 1322 return kmap && kmap->ref_reloc_sym && kmap->ref_reloc_sym->name && in ref_reloc_sym_not_found() 1323 !kmap->ref_reloc_sym->unrelocated_addr; in ref_reloc_sym_not_found() 1334 static u64 ref_reloc(struct kmap *kmap) in ref_reloc() argument 1336 if (kmap && kmap->ref_reloc_sym && in ref_reloc() 1337 kmap->ref_reloc_sym->unrelocated_addr) in ref_reloc() 1338 return kmap->ref_reloc_sym->addr - in ref_reloc() 1339 kmap->ref_reloc_sym->unrelocated_addr; in ref_reloc() 1348 struct maps *kmaps, struct kmap *kmap, in dso__process_kernel_symbol() argument 1373 map__set_start(map, shdr->sh_addr + ref_reloc(kmap)); in dso__process_kernel_symbol() [all …]
|
| H A D | machine.c | 1042 struct kmap *kmap; in machine__create_extra_kernel_map() local 1053 kmap = map__kmap(map); in machine__create_extra_kernel_map() 1055 strlcpy(kmap->name, xm->name, KMAP_NAME_LEN); in machine__create_extra_kernel_map() 1061 kmap->name, map__start(map), map__end(map)); in machine__create_extra_kernel_map() 1109 struct kmap *kmap = __map__kmap(map); in machine__map_x86_64_entry_trampolines_cb() local 1111 if (!kmap || !is_entry_trampoline(kmap->name)) in machine__map_x86_64_entry_trampolines_cb() 1194 struct kmap *kmap; in machine__destroy_kernel_maps() local 1200 kmap = map__kmap(map); in machine__destroy_kernel_maps() 1202 if (kmap && kmap->ref_reloc_sym) { in machine__destroy_kernel_maps() 1203 zfree((char **)&kmap->ref_reloc_sym->name); in machine__destroy_kernel_maps() [all …]
|
| H A D | symbol.c | 1250 struct kmap *kmap = map__kmap(map); in validate_kcore_addresses() local 1252 if (!kmap) in validate_kcore_addresses() 1255 if (kmap->ref_reloc_sym && kmap->ref_reloc_sym->name) { in validate_kcore_addresses() 1259 kmap->ref_reloc_sym->name, &start)) in validate_kcore_addresses() 1261 if (start != kmap->ref_reloc_sym->addr) in validate_kcore_addresses() 1479 static int kallsyms__delta(struct kmap *kmap, const char *filename, u64 *delta) in kallsyms__delta() argument 1483 if (!kmap->ref_reloc_sym || !kmap->ref_reloc_sym->name) in kallsyms__delta() 1486 if (kallsyms__get_function_start(filename, kmap->ref_reloc_sym->name, &addr)) in kallsyms__delta() 1489 *delta = addr - kmap->ref_reloc_sym->addr; in kallsyms__delta() 1496 struct kmap *kmap = map__kmap(map); in __dso__load_kallsyms() local [all …]
|
| H A D | map.h | 41 struct kmap; 43 struct kmap *__map__kmap(struct map *map); 44 struct kmap *map__kmap(struct map *map);
|
| H A D | maps.h | 17 struct kmap { struct
|
| /linux/tools/perf/arch/x86/util/ |
| H A D | event.c | 28 struct kmap *kmap; in perf_event__synthesize_extra_kmaps_cb() local 34 kmap = map__kmap(map); in perf_event__synthesize_extra_kmaps_cb() 37 PERF_ALIGN(strlen(kmap->name) + 1, sizeof(u64)) + in perf_event__synthesize_extra_kmaps_cb() 60 strlcpy(event->mmap.filename, kmap->name, PATH_MAX); in perf_event__synthesize_extra_kmaps_cb()
|
| /linux/Documentation/mm/ |
| H A D | highmem.rst | 61 These functions should always be used, whereas kmap_atomic() and kmap() have 70 It's valid to take pagefaults in a local kmap region, unless the context 87 While they are significantly faster than kmap(), for the highmem case they 88 come with restrictions about the pointers validity. Contrary to kmap() 95 therefore try to design their code to avoid the use of kmap() by mapping 131 * kmap(). This function has been deprecated; use kmap_local_page(). 146 Mapping changes must be propagated across all the CPUs. kmap() also 147 requires global TLB invalidation when the kmap's pool wraps and it might 149 available. Therefore, kmap() is only callable from preemptible context. 154 kmap() is mostly wasted in such cases. kmap() was not intended for long [all …]
|
| /linux/arch/m68k/mm/ |
| H A D | Makefile | 9 obj-$(CONFIG_MMU_MOTOROLA) += kmap.o memory.o motorola.o hwtest.o 11 obj-$(CONFIG_MMU_COLDFIRE) += kmap.o memory.o mcfmmu.o
|
| /linux/drivers/gpu/drm/nouveau/ |
| H A D | nouveau_chan.c | 174 chan->chan.push.mem.object.map.ptr = chan->push.buffer->kmap.virtual; in nouveau_channel_prep() 440 (u8*)chan->push.buffer->kmap.virtual + 0x10000, 0x2000, in nouveau_channel_init() 441 chan->push.buffer->kmap.virtual, chan->push.addr, 0x10000); in nouveau_channel_init() 447 (u8*)chan->push.buffer->kmap.virtual + 0x10000, 0x2000, in nouveau_channel_init() 448 chan->push.buffer->kmap.virtual, chan->push.addr, 0x10000, in nouveau_channel_init() 449 chan->sema.bo->kmap.virtual, chan->sema.vma->addr); in nouveau_channel_init() 454 (u8*)chan->push.buffer->kmap.virtual + 0x10000, 0x2000, in nouveau_channel_init() 455 chan->push.buffer->kmap.virtual, chan->push.addr, 0x10000, in nouveau_channel_init() 456 chan->sema.bo->kmap.virtual, chan->sema.vma->addr, in nouveau_channel_init()
|
| H A D | nouveau_gem.c | 435 ttm_bo_kunmap(&nvbo->kmap); in validate_fini_no_ticket() 696 if (!nvbo->kmap.virtual) { in nouveau_gem_pushbuf_reloc_apply() 698 &nvbo->kmap); in nouveau_gem_pushbuf_reloc_apply() 901 if (!nvbo->kmap.virtual) { in nouveau_gem_ioctl_pushbuf() 904 &nvbo->kmap); in nouveau_gem_ioctl_pushbuf()
|
| /linux/drivers/gpu/drm/nouveau/include/nvkm/core/ |
| H A D | memory.h | 41 int (*kmap)(struct nvkm_memory *, struct nvkm_memory **); member 68 #define nvkm_memory_kmap(p,i) ((p)->func->kmap ? (p)->func->kmap((p), (i)) : -ENOSYS)
|
| /linux/include/linux/ |
| H A D | highmem-internal.h | 40 static inline void *kmap(struct page *page) in kmap() function 170 static inline void *kmap(struct page *page) in kmap() function
|
| /linux/mm/ |
| H A D | highmem.c | 57 * addresses where physical memory pages are mapped by kmap. 93 * found after checking that many entries, kmap will sleep waiting for 172 /* kmap() mappings */ in __kmap_to_page() 578 void *kmap; in __kmap_local_page_prot() 589 kmap = arch_kmap_local_high_get(page); in __kmap_local_page_prot() 590 if (kmap) in __kmap_local_page_prot() 591 return kmap; in __kmap_local_page_prot() 577 void *kmap; __kmap_local_page_prot() local
|
| /linux/fs/freevxfs/ |
| H A D | vxfs_subr.c | 51 kmap(pp); in vxfs_get_page()
|
| /linux/drivers/gpu/drm/loongson/ |
| H A D | lsdc_ttm.h | 35 struct ttm_bo_kmap_obj kmap; member
|
| H A D | lsdc_ttm.c | 371 err = ttm_bo_kmap(tbo, 0, PFN_UP(lsdc_bo_size(lbo)), &lbo->kmap); in lsdc_bo_kmap() 377 lbo->kptr = ttm_kmap_obj_virtual(&lbo->kmap, &lbo->is_iomem); in lsdc_bo_kmap() 388 ttm_bo_kunmap(&lbo->kmap); in lsdc_bo_kunmap()
|
| /linux/arch/sh/mm/ |
| H A D | Makefile | 19 mmu-$(CONFIG_MMU) := extable_32.o fault.o ioremap.o kmap.o \
|
| /linux/tools/perf/ |
| H A D | builtin-lock.c | 978 struct map *kmap; in report_lock_contention_begin_event() local 996 &kmap); in report_lock_contention_begin_event() 1010 addrs[filters.nr_addrs++] = map__unmap_ip(kmap, sym->start); in report_lock_contention_begin_event() 1022 sym = machine__find_kernel_symbol(machine, key, &kmap); in report_lock_contention_begin_event() 1660 struct map *kmap; in print_lock_stat_stdio() local 1670 sym = machine__find_kernel_symbol(con->machine, ip, &kmap); in print_lock_stat_stdio() 1671 get_symbol_name_offset(kmap, sym, ip, buf, sizeof(buf)); in print_lock_stat_stdio() 1713 struct map *kmap; in print_lock_stat_csv() local 1723 sym = machine__find_kernel_symbol(con->machine, ip, &kmap); in print_lock_stat_csv() 1724 get_symbol_name_offset(kmap, sym, ip, buf, sizeof(buf)); in print_lock_stat_csv()
|
| /linux/drivers/gpu/drm/panthor/ |
| H A D | panthor_sched.c | 441 void *kmap; member 854 if (queue->syncwait.kmap) { in panthor_queue_put_syncwait_obj() 855 struct iosys_map map = IOSYS_MAP_INIT_VADDR(queue->syncwait.kmap); in panthor_queue_put_syncwait_obj() 858 queue->syncwait.kmap = NULL; in panthor_queue_put_syncwait_obj() 873 if (queue->syncwait.kmap) { in panthor_queue_get_syncwait_obj() 890 queue->syncwait.kmap = map.vaddr; in panthor_queue_get_syncwait_obj() 891 if (drm_WARN_ON(&ptdev->base, !queue->syncwait.kmap)) in panthor_queue_get_syncwait_obj() 905 return queue->syncwait.kmap + queue->syncwait.offset; in panthor_queue_get_syncwait_obj() 2192 syncobj = group->syncobjs->kmap + (i * sizeof(*syncobj)); in group_term_post_processing() 3009 struct panthor_job_profiling_data *slots = queue->profiling.slots->kmap; in update_fdinfo_stats() [all …]
|
| /linux/drivers/gpu/drm/radeon/ |
| H A D | radeon_object.c | 234 r = ttm_bo_kmap(&bo->tbo, 0, PFN_UP(bo->tbo.base.size), &bo->kmap); in radeon_bo_kmap() 238 bo->kptr = ttm_kmap_obj_virtual(&bo->kmap, &is_iomem); in radeon_bo_kmap() 252 ttm_bo_kunmap(&bo->kmap); in radeon_bo_kunmap()
|
| /linux/tools/testing/scatterlist/linux/ |
| H A D | mm.h | 78 static inline void *kmap(struct page *page) in kmap() function
|
| /linux/net/ceph/ |
| H A D | pagelist.c | 70 pl->mapped_tail = kmap(page); in ceph_pagelist_addpage()
|