1 // SPDX-License-Identifier: GPL-2.0+
3 * Copyright (C) 2023 Loongson Technology Corporation Limited
6 #include <drm/drm_debugfs.h>
8 #include "lsdc_benchmark.h"
13 typedef void (*lsdc_copy_proc_t)(struct lsdc_bo *src_bo,
14 struct lsdc_bo *dst_bo,
18 static void lsdc_copy_gtt_to_vram_cpu(struct lsdc_bo *src_bo,
19 struct lsdc_bo *dst_bo,
27 memcpy_toio(dst_bo->kptr, src_bo->kptr, size);
29 lsdc_bo_kunmap(src_bo);
30 lsdc_bo_kunmap(dst_bo);
33 static void lsdc_copy_vram_to_gtt_cpu(struct lsdc_bo *src_bo,
34 struct lsdc_bo *dst_bo,
42 memcpy_fromio(dst_bo->kptr, src_bo->kptr, size);
44 lsdc_bo_kunmap(src_bo);
45 lsdc_bo_kunmap(dst_bo);
48 static void lsdc_copy_gtt_to_gtt_cpu(struct lsdc_bo *src_bo,
49 struct lsdc_bo *dst_bo,
57 memcpy(dst_bo->kptr, src_bo->kptr, size);
59 lsdc_bo_kunmap(src_bo);
60 lsdc_bo_kunmap(dst_bo);
63 static void lsdc_benchmark_copy(struct lsdc_device *ldev,
68 lsdc_copy_proc_t copy_proc,
69 struct drm_printer *p)
71 struct drm_device *ddev = &ldev->base;
72 struct lsdc_bo *src_bo;
73 struct lsdc_bo *dst_bo;
74 unsigned long start_jiffies;
75 unsigned long end_jiffies;
76 unsigned int throughput;
79 src_bo = lsdc_bo_create_kernel_pinned(ddev, src_domain, size);
80 dst_bo = lsdc_bo_create_kernel_pinned(ddev, dst_domain, size);
82 start_jiffies = jiffies;
84 copy_proc(src_bo, dst_bo, size, n);
86 end_jiffies = jiffies;
88 lsdc_bo_free_kernel_pinned(src_bo);
89 lsdc_bo_free_kernel_pinned(dst_bo);
91 time = jiffies_to_msecs(end_jiffies - start_jiffies);
93 throughput = (n * (size >> 10)) / time;
96 "Copy bo of %uKiB %u times from %s to %s in %ums: %uMB/s\n",
98 lsdc_domain_to_str(src_domain),
99 lsdc_domain_to_str(dst_domain),
103 int lsdc_show_benchmark_copy(struct lsdc_device *ldev, struct drm_printer *p)
105 unsigned int buffer_size = 1920 * 1080 * 4;
106 unsigned int iteration = 60;
108 lsdc_benchmark_copy(ldev,
113 lsdc_copy_gtt_to_gtt_cpu,
116 lsdc_benchmark_copy(ldev,
120 LSDC_GEM_DOMAIN_VRAM,
121 lsdc_copy_gtt_to_vram_cpu,
124 lsdc_benchmark_copy(ldev,
127 LSDC_GEM_DOMAIN_VRAM,
129 lsdc_copy_vram_to_gtt_cpu,