Bug Summary

File:dev/pci/drm/amd/amdgpu/amdgpu_object.h
Warning:line 161, column 24
Value stored to 'adev' during its initialization is never read

Annotated Source Code

Press '?' to see keyboard shortcuts

clang -cc1 -cc1 -triple amd64-unknown-openbsd7.0 -analyze -disable-free -disable-llvm-verifier -discard-value-names -main-file-name amdgpu_display.c -analyzer-store=region -analyzer-opt-analyze-nested-blocks -analyzer-checker=core -analyzer-checker=apiModeling -analyzer-checker=unix -analyzer-checker=deadcode -analyzer-checker=security.insecureAPI.UncheckedReturn -analyzer-checker=security.insecureAPI.getpw -analyzer-checker=security.insecureAPI.gets -analyzer-checker=security.insecureAPI.mktemp -analyzer-checker=security.insecureAPI.mkstemp -analyzer-checker=security.insecureAPI.vfork -analyzer-checker=nullability.NullPassedToNonnull -analyzer-checker=nullability.NullReturnedFromNonnull -analyzer-output plist -w -setup-static-analyzer -mrelocation-model static -mframe-pointer=all -relaxed-aliasing -fno-rounding-math -mconstructor-aliases -ffreestanding -mcmodel=kernel -target-cpu x86-64 -target-feature +retpoline-indirect-calls -target-feature +retpoline-indirect-branches -target-feature -sse2 -target-feature -sse -target-feature -3dnow -target-feature -mmx -target-feature +save-args -disable-red-zone -no-implicit-float -tune-cpu generic -debugger-tuning=gdb -fcoverage-compilation-dir=/usr/src/sys/arch/amd64/compile/GENERIC.MP/obj -nostdsysteminc -nobuiltininc -resource-dir /usr/local/lib/clang/13.0.0 -I /usr/src/sys -I /usr/src/sys/arch/amd64/compile/GENERIC.MP/obj -I /usr/src/sys/arch -I /usr/src/sys/dev/pci/drm/include -I /usr/src/sys/dev/pci/drm/include/uapi -I /usr/src/sys/dev/pci/drm/amd/include/asic_reg -I /usr/src/sys/dev/pci/drm/amd/include -I /usr/src/sys/dev/pci/drm/amd/amdgpu -I /usr/src/sys/dev/pci/drm/amd/display -I /usr/src/sys/dev/pci/drm/amd/display/include -I /usr/src/sys/dev/pci/drm/amd/display/dc -I /usr/src/sys/dev/pci/drm/amd/display/amdgpu_dm -I /usr/src/sys/dev/pci/drm/amd/pm/inc -I /usr/src/sys/dev/pci/drm/amd/pm/swsmu -I /usr/src/sys/dev/pci/drm/amd/pm/swsmu/smu11 -I /usr/src/sys/dev/pci/drm/amd/pm/swsmu/smu12 -I /usr/src/sys/dev/pci/drm/amd/pm/powerplay -I /usr/src/sys/dev/pci/drm/amd/pm/powerplay/hwmgr -I /usr/src/sys/dev/pci/drm/amd/pm/powerplay/smumgr -I /usr/src/sys/dev/pci/drm/amd/display/dc/inc -I /usr/src/sys/dev/pci/drm/amd/display/dc/inc/hw -I /usr/src/sys/dev/pci/drm/amd/display/dc/clk_mgr -I /usr/src/sys/dev/pci/drm/amd/display/modules/inc -I /usr/src/sys/dev/pci/drm/amd/display/modules/hdcp -I /usr/src/sys/dev/pci/drm/amd/display/dmub/inc -I /usr/src/sys/dev/pci/drm/i915 -D DDB -D DIAGNOSTIC -D KTRACE -D ACCOUNTING -D KMEMSTATS -D PTRACE -D POOL_DEBUG -D CRYPTO -D SYSVMSG -D SYSVSEM -D SYSVSHM -D UVM_SWAP_ENCRYPT -D FFS -D FFS2 -D FFS_SOFTUPDATES -D UFS_DIRHASH -D QUOTA -D EXT2FS -D MFS -D NFSCLIENT -D NFSSERVER -D CD9660 -D UDF -D MSDOSFS -D FIFO -D FUSE -D SOCKET_SPLICE -D TCP_ECN -D TCP_SIGNATURE -D INET6 -D IPSEC -D PPP_BSDCOMP -D PPP_DEFLATE -D PIPEX -D MROUTING -D MPLS -D BOOT_CONFIG -D USER_PCICONF -D APERTURE -D MTRR -D NTFS -D HIBERNATE -D PCIVERBOSE -D USBVERBOSE -D WSDISPLAY_COMPAT_USL -D WSDISPLAY_COMPAT_RAWKBD -D WSDISPLAY_DEFAULTSCREENS=6 -D X86EMU -D ONEWIREVERBOSE -D MULTIPROCESSOR -D MAXUSERS=80 -D _KERNEL -D CONFIG_DRM_AMD_DC_DCN3_0 -O2 -Wno-pointer-sign -Wno-address-of-packed-member -Wno-constant-conversion -Wno-unused-but-set-variable -Wno-gnu-folding-constant -fdebug-compilation-dir=/usr/src/sys/arch/amd64/compile/GENERIC.MP/obj -ferror-limit 19 -fwrapv -D_RET_PROTECTOR -ret-protector -fgnuc-version=4.2.1 -vectorize-loops -vectorize-slp -fno-builtin-malloc -fno-builtin-calloc -fno-builtin-realloc -fno-builtin-valloc -fno-builtin-free -fno-builtin-strdup -fno-builtin-strndup -analyzer-output=html -faddrsig -o /usr/obj/sys/arch/amd64/compile/GENERIC.MP/scan-build/2022-01-12-131800-47421-1 -x c /usr/src/sys/dev/pci/drm/amd/amdgpu/amdgpu_display.c
1/*
2 * Copyright 2008 Advanced Micro Devices, Inc.
3 * Copyright 2008 Red Hat Inc.
4 * Copyright 2009 Jerome Glisse.
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the "Software"),
8 * to deal in the Software without restriction, including without limitation
9 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10 * and/or sell copies of the Software, and to permit persons to whom the
11 * Software is furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
20 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
21 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
22 * OTHER DEALINGS IN THE SOFTWARE.
23 *
24 * Authors: Dave Airlie
25 * Alex Deucher
26 * Jerome Glisse
27 */
28#ifndef __AMDGPU_OBJECT_H__
29#define __AMDGPU_OBJECT_H__
30
31#include <drm/amdgpu_drm.h>
32#include "amdgpu.h"
33#ifdef CONFIG_MMU_NOTIFIER
34#include <linux/mmu_notifier.h>
35#endif
36
37#define AMDGPU_BO_INVALID_OFFSET0x7fffffffffffffffL LONG_MAX0x7fffffffffffffffL
38#define AMDGPU_BO_MAX_PLACEMENTS3 3
39
40struct amdgpu_bo_param {
41 unsigned long size;
42 int byte_align;
43 u32 domain;
44 u32 preferred_domain;
45 u64 flags;
46 enum ttm_bo_type type;
47 bool_Bool no_wait_gpu;
48 struct dma_resv *resv;
49};
50
51/* bo virtual addresses in a vm */
52struct amdgpu_bo_va_mapping {
53 struct amdgpu_bo_va *bo_va;
54 struct list_head list;
55 struct rb_node rb;
56 uint64_t start;
57 uint64_t last;
58 uint64_t __subtree_last;
59 uint64_t offset;
60 uint64_t flags;
61};
62
63/* User space allocated BO in a VM */
64struct amdgpu_bo_va {
65 struct amdgpu_vm_bo_base base;
66
67 /* protected by bo being reserved */
68 unsigned ref_count;
69
70 /* all other members protected by the VM PD being reserved */
71 struct dma_fence *last_pt_update;
72
73 /* mappings for this bo_va */
74 struct list_head invalids;
75 struct list_head valids;
76
77 /* If the mappings are cleared or filled */
78 bool_Bool cleared;
79
80 bool_Bool is_xgmi;
81};
82
83struct amdgpu_bo {
84 /* Protected by tbo.reserved */
85 u32 preferred_domains;
86 u32 allowed_domains;
87 struct ttm_place placements[AMDGPU_BO_MAX_PLACEMENTS3];
88 struct ttm_placement placement;
89 struct ttm_buffer_object tbo;
90 struct ttm_bo_kmap_obj kmap;
91 u64 flags;
92 unsigned pin_count;
93 u64 tiling_flags;
94 u64 metadata_flags;
95 void *metadata;
96 u32 metadata_size;
97 unsigned prime_shared_count;
98 /* per VM structure for page tables and with virtual addresses */
99 struct amdgpu_vm_bo_base *vm_bo;
100 /* Constant after initialization */
101 struct amdgpu_device *adev;
102 struct amdgpu_bo *parent;
103 struct amdgpu_bo *shadow;
104
105 struct ttm_bo_kmap_obj dma_buf_vmap;
106 struct amdgpu_mn *mn;
107
108
109#ifdef CONFIG_MMU_NOTIFIER
110 struct mmu_interval_notifier notifier;
111#endif
112
113 struct list_head shadow_list;
114
115 struct kgd_mem *kfd_bo;
116};
117
118static inline struct amdgpu_bo *ttm_to_amdgpu_bo(struct ttm_buffer_object *tbo)
119{
120 return container_of(tbo, struct amdgpu_bo, tbo)({ const __typeof( ((struct amdgpu_bo *)0)->tbo ) *__mptr =
(tbo); (struct amdgpu_bo *)( (char *)__mptr - __builtin_offsetof
(struct amdgpu_bo, tbo) );})
;
121}
122
123/**
124 * amdgpu_mem_type_to_domain - return domain corresponding to mem_type
125 * @mem_type: ttm memory type
126 *
127 * Returns corresponding domain of the ttm mem_type
128 */
129static inline unsigned amdgpu_mem_type_to_domain(u32 mem_type)
130{
131 switch (mem_type) {
132 case TTM_PL_VRAM2:
133 return AMDGPU_GEM_DOMAIN_VRAM0x4;
134 case TTM_PL_TT1:
135 return AMDGPU_GEM_DOMAIN_GTT0x2;
136 case TTM_PL_SYSTEM0:
137 return AMDGPU_GEM_DOMAIN_CPU0x1;
138 case AMDGPU_PL_GDS(3 + 0):
139 return AMDGPU_GEM_DOMAIN_GDS0x8;
140 case AMDGPU_PL_GWS(3 + 1):
141 return AMDGPU_GEM_DOMAIN_GWS0x10;
142 case AMDGPU_PL_OA(3 + 2):
143 return AMDGPU_GEM_DOMAIN_OA0x20;
144 default:
145 break;
146 }
147 return 0;
148}
149
150/**
151 * amdgpu_bo_reserve - reserve bo
152 * @bo: bo structure
153 * @no_intr: don't return -ERESTARTSYS on pending signal
154 *
155 * Returns:
156 * -ERESTARTSYS: A wait for the buffer to become unreserved was interrupted by
157 * a signal. Release all buffer reservations and return to user-space.
158 */
159static inline int amdgpu_bo_reserve(struct amdgpu_bo *bo, bool_Bool no_intr)
160{
161 struct amdgpu_device *adev = amdgpu_ttm_adev(bo->tbo.bdev);
Value stored to 'adev' during its initialization is never read
162 int r;
163
164 r = ttm_bo_reserve(&bo->tbo, !no_intr, false0, NULL((void *)0));
165 if (unlikely(r != 0)__builtin_expect(!!(r != 0), 0)) {
166 if (r != -ERESTARTSYS4)
167 dev_err(adev->dev, "%p reserve failed\n", bo)printf("drm:pid%d:%s *ERROR* " "%p reserve failed\n", ({struct
cpu_info *__ci; asm volatile("movq %%gs:%P1,%0" : "=r" (__ci
) :"n" (__builtin_offsetof(struct cpu_info, ci_self))); __ci;
})->ci_curproc->p_p->ps_pid, __func__ , bo)
;
168 return r;
169 }
170 return 0;
171}
172
173static inline void amdgpu_bo_unreserve(struct amdgpu_bo *bo)
174{
175 ttm_bo_unreserve(&bo->tbo);
176}
177
178static inline unsigned long amdgpu_bo_size(struct amdgpu_bo *bo)
179{
180 return bo->tbo.num_pages << PAGE_SHIFT12;
181}
182
183static inline unsigned amdgpu_bo_ngpu_pages(struct amdgpu_bo *bo)
184{
185 return (bo->tbo.num_pages << PAGE_SHIFT12) / AMDGPU_GPU_PAGE_SIZE4096;
186}
187
188static inline unsigned amdgpu_bo_gpu_page_alignment(struct amdgpu_bo *bo)
189{
190 return (bo->tbo.mem.page_alignment << PAGE_SHIFT12) / AMDGPU_GPU_PAGE_SIZE4096;
191}
192
193/**
194 * amdgpu_bo_mmap_offset - return mmap offset of bo
195 * @bo: amdgpu object for which we query the offset
196 *
197 * Returns mmap offset of the object.
198 */
199static inline u64 amdgpu_bo_mmap_offset(struct amdgpu_bo *bo)
200{
201 return drm_vma_node_offset_addr(&bo->tbo.base.vma_node);
202}
203
204/**
205 * amdgpu_bo_in_cpu_visible_vram - check if BO is (partly) in visible VRAM
206 */
207static inline bool_Bool amdgpu_bo_in_cpu_visible_vram(struct amdgpu_bo *bo)
208{
209 struct amdgpu_device *adev = amdgpu_ttm_adev(bo->tbo.bdev);
210 unsigned fpfn = adev->gmc.visible_vram_size >> PAGE_SHIFT12;
211 struct drm_mm_node *node = bo->tbo.mem.mm_node;
212 unsigned long pages_left;
213
214 if (bo->tbo.mem.mem_type != TTM_PL_VRAM2)
215 return false0;
216
217 for (pages_left = bo->tbo.mem.num_pages; pages_left;
218 pages_left -= node->size, node++)
219 if (node->start < fpfn)
220 return true1;
221
222 return false0;
223}
224
225/**
226 * amdgpu_bo_explicit_sync - return whether the bo is explicitly synced
227 */
228static inline bool_Bool amdgpu_bo_explicit_sync(struct amdgpu_bo *bo)
229{
230 return bo->flags & AMDGPU_GEM_CREATE_EXPLICIT_SYNC(1 << 7);
231}
232
233/**
234 * amdgpu_bo_encrypted - test if the BO is encrypted
235 * @bo: pointer to a buffer object
236 *
237 * Return true if the buffer object is encrypted, false otherwise.
238 */
239static inline bool_Bool amdgpu_bo_encrypted(struct amdgpu_bo *bo)
240{
241 return bo->flags & AMDGPU_GEM_CREATE_ENCRYPTED(1 << 10);
242}
243
244bool_Bool amdgpu_bo_is_amdgpu_bo(struct ttm_buffer_object *bo);
245void amdgpu_bo_placement_from_domain(struct amdgpu_bo *abo, u32 domain);
246
247int amdgpu_bo_create(struct amdgpu_device *adev,
248 struct amdgpu_bo_param *bp,
249 struct amdgpu_bo **bo_ptr);
250int amdgpu_bo_create_reserved(struct amdgpu_device *adev,
251 unsigned long size, int align,
252 u32 domain, struct amdgpu_bo **bo_ptr,
253 u64 *gpu_addr, void **cpu_addr);
254int amdgpu_bo_create_kernel(struct amdgpu_device *adev,
255 unsigned long size, int align,
256 u32 domain, struct amdgpu_bo **bo_ptr,
257 u64 *gpu_addr, void **cpu_addr);
258int amdgpu_bo_create_kernel_at(struct amdgpu_device *adev,
259 uint64_t offset, uint64_t size, uint32_t domain,
260 struct amdgpu_bo **bo_ptr, void **cpu_addr);
261void amdgpu_bo_free_kernel(struct amdgpu_bo **bo, u64 *gpu_addr,
262 void **cpu_addr);
263int amdgpu_bo_kmap(struct amdgpu_bo *bo, void **ptr);
264void *amdgpu_bo_kptr(struct amdgpu_bo *bo);
265void amdgpu_bo_kunmap(struct amdgpu_bo *bo);
266struct amdgpu_bo *amdgpu_bo_ref(struct amdgpu_bo *bo);
267void amdgpu_bo_unref(struct amdgpu_bo **bo);
268int amdgpu_bo_pin(struct amdgpu_bo *bo, u32 domain);
269int amdgpu_bo_pin_restricted(struct amdgpu_bo *bo, u32 domain,
270 u64 min_offset, u64 max_offset);
271int amdgpu_bo_unpin(struct amdgpu_bo *bo);
272int amdgpu_bo_evict_vram(struct amdgpu_device *adev);
273int amdgpu_bo_init(struct amdgpu_device *adev);
274int amdgpu_bo_late_init(struct amdgpu_device *adev);
275void amdgpu_bo_fini(struct amdgpu_device *adev);
276#ifdef notyet
277int amdgpu_bo_fbdev_mmap(struct amdgpu_bo *bo,
278 struct vm_area_struct *vma);
279#endif
280int amdgpu_bo_set_tiling_flags(struct amdgpu_bo *bo, u64 tiling_flags);
281void amdgpu_bo_get_tiling_flags(struct amdgpu_bo *bo, u64 *tiling_flags);
282int amdgpu_bo_set_metadata (struct amdgpu_bo *bo, void *metadata,
283 uint32_t metadata_size, uint64_t flags);
284int amdgpu_bo_get_metadata(struct amdgpu_bo *bo, void *buffer,
285 size_t buffer_size, uint32_t *metadata_size,
286 uint64_t *flags);
287void amdgpu_bo_move_notify(struct ttm_buffer_object *bo,
288 bool_Bool evict,
289 struct ttm_resource *new_mem);
290void amdgpu_bo_release_notify(struct ttm_buffer_object *bo);
291int amdgpu_bo_fault_reserve_notify(struct ttm_buffer_object *bo);
292void amdgpu_bo_fence(struct amdgpu_bo *bo, struct dma_fence *fence,
293 bool_Bool shared);
294int amdgpu_bo_sync_wait_resv(struct amdgpu_device *adev, struct dma_resv *resv,
295 enum amdgpu_sync_mode sync_mode, void *owner,
296 bool_Bool intr);
297int amdgpu_bo_sync_wait(struct amdgpu_bo *bo, void *owner, bool_Bool intr);
298u64 amdgpu_bo_gpu_offset(struct amdgpu_bo *bo);
299u64 amdgpu_bo_gpu_offset_no_check(struct amdgpu_bo *bo);
300int amdgpu_bo_validate(struct amdgpu_bo *bo);
301int amdgpu_bo_restore_shadow(struct amdgpu_bo *shadow,
302 struct dma_fence **fence);
303uint32_t amdgpu_bo_get_preferred_pin_domain(struct amdgpu_device *adev,
304 uint32_t domain);
305
306/*
307 * sub allocation
308 */
309
310static inline uint64_t amdgpu_sa_bo_gpu_addr(struct amdgpu_sa_bo *sa_bo)
311{
312 return sa_bo->manager->gpu_addr + sa_bo->soffset;
313}
314
315static inline void * amdgpu_sa_bo_cpu_addr(struct amdgpu_sa_bo *sa_bo)
316{
317 return sa_bo->manager->cpu_ptr + sa_bo->soffset;
318}
319
320int amdgpu_sa_bo_manager_init(struct amdgpu_device *adev,
321 struct amdgpu_sa_manager *sa_manager,
322 unsigned size, u32 align, u32 domain);
323void amdgpu_sa_bo_manager_fini(struct amdgpu_device *adev,
324 struct amdgpu_sa_manager *sa_manager);
325int amdgpu_sa_bo_manager_start(struct amdgpu_device *adev,
326 struct amdgpu_sa_manager *sa_manager);
327int amdgpu_sa_bo_new(struct amdgpu_sa_manager *sa_manager,
328 struct amdgpu_sa_bo **sa_bo,
329 unsigned size, unsigned align);
330void amdgpu_sa_bo_free(struct amdgpu_device *adev,
331 struct amdgpu_sa_bo **sa_bo,
332 struct dma_fence *fence);
333#if defined(CONFIG_DEBUG_FS)
334void amdgpu_sa_bo_dump_debug_info(struct amdgpu_sa_manager *sa_manager,
335 struct seq_file *m);
336#endif
337int amdgpu_debugfs_sa_init(struct amdgpu_device *adev);
338
339bool_Bool amdgpu_bo_support_uswc(u64 bo_flags);
340
341
342#endif