xref: /openbmc/linux/arch/riscv/kvm/vcpu_pmu.c (revision 47aab533)
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * Copyright (c) 2023 Rivos Inc
4  *
5  * Authors:
6  *     Atish Patra <atishp@rivosinc.com>
7  */
8 
9 #define pr_fmt(fmt)	"riscv-kvm-pmu: " fmt
10 #include <linux/errno.h>
11 #include <linux/err.h>
12 #include <linux/kvm_host.h>
13 #include <linux/perf/riscv_pmu.h>
14 #include <asm/csr.h>
15 #include <asm/kvm_vcpu_sbi.h>
16 #include <asm/kvm_vcpu_pmu.h>
17 #include <linux/bitops.h>
18 
19 #define kvm_pmu_num_counters(pmu) ((pmu)->num_hw_ctrs + (pmu)->num_fw_ctrs)
20 #define get_event_type(x) (((x) & SBI_PMU_EVENT_IDX_TYPE_MASK) >> 16)
21 #define get_event_code(x) ((x) & SBI_PMU_EVENT_IDX_CODE_MASK)
22 
23 static enum perf_hw_id hw_event_perf_map[SBI_PMU_HW_GENERAL_MAX] = {
24 	[SBI_PMU_HW_CPU_CYCLES] = PERF_COUNT_HW_CPU_CYCLES,
25 	[SBI_PMU_HW_INSTRUCTIONS] = PERF_COUNT_HW_INSTRUCTIONS,
26 	[SBI_PMU_HW_CACHE_REFERENCES] = PERF_COUNT_HW_CACHE_REFERENCES,
27 	[SBI_PMU_HW_CACHE_MISSES] = PERF_COUNT_HW_CACHE_MISSES,
28 	[SBI_PMU_HW_BRANCH_INSTRUCTIONS] = PERF_COUNT_HW_BRANCH_INSTRUCTIONS,
29 	[SBI_PMU_HW_BRANCH_MISSES] = PERF_COUNT_HW_BRANCH_MISSES,
30 	[SBI_PMU_HW_BUS_CYCLES] = PERF_COUNT_HW_BUS_CYCLES,
31 	[SBI_PMU_HW_STALLED_CYCLES_FRONTEND] = PERF_COUNT_HW_STALLED_CYCLES_FRONTEND,
32 	[SBI_PMU_HW_STALLED_CYCLES_BACKEND] = PERF_COUNT_HW_STALLED_CYCLES_BACKEND,
33 	[SBI_PMU_HW_REF_CPU_CYCLES] = PERF_COUNT_HW_REF_CPU_CYCLES,
34 };
35 
36 static u64 kvm_pmu_get_sample_period(struct kvm_pmc *pmc)
37 {
38 	u64 counter_val_mask = GENMASK(pmc->cinfo.width, 0);
39 	u64 sample_period;
40 
41 	if (!pmc->counter_val)
42 		sample_period = counter_val_mask + 1;
43 	else
44 		sample_period = (-pmc->counter_val) & counter_val_mask;
45 
46 	return sample_period;
47 }
48 
49 static u32 kvm_pmu_get_perf_event_type(unsigned long eidx)
50 {
51 	enum sbi_pmu_event_type etype = get_event_type(eidx);
52 	u32 type = PERF_TYPE_MAX;
53 
54 	switch (etype) {
55 	case SBI_PMU_EVENT_TYPE_HW:
56 		type = PERF_TYPE_HARDWARE;
57 		break;
58 	case SBI_PMU_EVENT_TYPE_CACHE:
59 		type = PERF_TYPE_HW_CACHE;
60 		break;
61 	case SBI_PMU_EVENT_TYPE_RAW:
62 	case SBI_PMU_EVENT_TYPE_FW:
63 		type = PERF_TYPE_RAW;
64 		break;
65 	default:
66 		break;
67 	}
68 
69 	return type;
70 }
71 
72 static bool kvm_pmu_is_fw_event(unsigned long eidx)
73 {
74 	return get_event_type(eidx) == SBI_PMU_EVENT_TYPE_FW;
75 }
76 
77 static void kvm_pmu_release_perf_event(struct kvm_pmc *pmc)
78 {
79 	if (pmc->perf_event) {
80 		perf_event_disable(pmc->perf_event);
81 		perf_event_release_kernel(pmc->perf_event);
82 		pmc->perf_event = NULL;
83 	}
84 }
85 
86 static u64 kvm_pmu_get_perf_event_hw_config(u32 sbi_event_code)
87 {
88 	return hw_event_perf_map[sbi_event_code];
89 }
90 
91 static u64 kvm_pmu_get_perf_event_cache_config(u32 sbi_event_code)
92 {
93 	u64 config = U64_MAX;
94 	unsigned int cache_type, cache_op, cache_result;
95 
96 	/* All the cache event masks lie within 0xFF. No separate masking is necessary */
97 	cache_type = (sbi_event_code & SBI_PMU_EVENT_CACHE_ID_CODE_MASK) >>
98 		      SBI_PMU_EVENT_CACHE_ID_SHIFT;
99 	cache_op = (sbi_event_code & SBI_PMU_EVENT_CACHE_OP_ID_CODE_MASK) >>
100 		    SBI_PMU_EVENT_CACHE_OP_SHIFT;
101 	cache_result = sbi_event_code & SBI_PMU_EVENT_CACHE_RESULT_ID_CODE_MASK;
102 
103 	if (cache_type >= PERF_COUNT_HW_CACHE_MAX ||
104 	    cache_op >= PERF_COUNT_HW_CACHE_OP_MAX ||
105 	    cache_result >= PERF_COUNT_HW_CACHE_RESULT_MAX)
106 		return config;
107 
108 	config = cache_type | (cache_op << 8) | (cache_result << 16);
109 
110 	return config;
111 }
112 
113 static u64 kvm_pmu_get_perf_event_config(unsigned long eidx, uint64_t evt_data)
114 {
115 	enum sbi_pmu_event_type etype = get_event_type(eidx);
116 	u32 ecode = get_event_code(eidx);
117 	u64 config = U64_MAX;
118 
119 	switch (etype) {
120 	case SBI_PMU_EVENT_TYPE_HW:
121 		if (ecode < SBI_PMU_HW_GENERAL_MAX)
122 			config = kvm_pmu_get_perf_event_hw_config(ecode);
123 		break;
124 	case SBI_PMU_EVENT_TYPE_CACHE:
125 		config = kvm_pmu_get_perf_event_cache_config(ecode);
126 		break;
127 	case SBI_PMU_EVENT_TYPE_RAW:
128 		config = evt_data & RISCV_PMU_RAW_EVENT_MASK;
129 		break;
130 	case SBI_PMU_EVENT_TYPE_FW:
131 		if (ecode < SBI_PMU_FW_MAX)
132 			config = (1ULL << 63) | ecode;
133 		break;
134 	default:
135 		break;
136 	}
137 
138 	return config;
139 }
140 
141 static int kvm_pmu_get_fixed_pmc_index(unsigned long eidx)
142 {
143 	u32 etype = kvm_pmu_get_perf_event_type(eidx);
144 	u32 ecode = get_event_code(eidx);
145 
146 	if (etype != SBI_PMU_EVENT_TYPE_HW)
147 		return -EINVAL;
148 
149 	if (ecode == SBI_PMU_HW_CPU_CYCLES)
150 		return 0;
151 	else if (ecode == SBI_PMU_HW_INSTRUCTIONS)
152 		return 2;
153 	else
154 		return -EINVAL;
155 }
156 
157 static int kvm_pmu_get_programmable_pmc_index(struct kvm_pmu *kvpmu, unsigned long eidx,
158 					      unsigned long cbase, unsigned long cmask)
159 {
160 	int ctr_idx = -1;
161 	int i, pmc_idx;
162 	int min, max;
163 
164 	if (kvm_pmu_is_fw_event(eidx)) {
165 		/* Firmware counters are mapped 1:1 starting from num_hw_ctrs for simplicity */
166 		min = kvpmu->num_hw_ctrs;
167 		max = min + kvpmu->num_fw_ctrs;
168 	} else {
169 		/* First 3 counters are reserved for fixed counters */
170 		min = 3;
171 		max = kvpmu->num_hw_ctrs;
172 	}
173 
174 	for_each_set_bit(i, &cmask, BITS_PER_LONG) {
175 		pmc_idx = i + cbase;
176 		if ((pmc_idx >= min && pmc_idx < max) &&
177 		    !test_bit(pmc_idx, kvpmu->pmc_in_use)) {
178 			ctr_idx = pmc_idx;
179 			break;
180 		}
181 	}
182 
183 	return ctr_idx;
184 }
185 
186 static int pmu_get_pmc_index(struct kvm_pmu *pmu, unsigned long eidx,
187 			     unsigned long cbase, unsigned long cmask)
188 {
189 	int ret;
190 
191 	/* Fixed counters need to be have fixed mapping as they have different width */
192 	ret = kvm_pmu_get_fixed_pmc_index(eidx);
193 	if (ret >= 0)
194 		return ret;
195 
196 	return kvm_pmu_get_programmable_pmc_index(pmu, eidx, cbase, cmask);
197 }
198 
199 static int pmu_ctr_read(struct kvm_vcpu *vcpu, unsigned long cidx,
200 			unsigned long *out_val)
201 {
202 	struct kvm_pmu *kvpmu = vcpu_to_pmu(vcpu);
203 	struct kvm_pmc *pmc;
204 	u64 enabled, running;
205 	int fevent_code;
206 
207 	pmc = &kvpmu->pmc[cidx];
208 
209 	if (pmc->cinfo.type == SBI_PMU_CTR_TYPE_FW) {
210 		fevent_code = get_event_code(pmc->event_idx);
211 		pmc->counter_val = kvpmu->fw_event[fevent_code].value;
212 	} else if (pmc->perf_event) {
213 		pmc->counter_val += perf_event_read_value(pmc->perf_event, &enabled, &running);
214 	} else {
215 		return -EINVAL;
216 	}
217 	*out_val = pmc->counter_val;
218 
219 	return 0;
220 }
221 
222 static int kvm_pmu_validate_counter_mask(struct kvm_pmu *kvpmu, unsigned long ctr_base,
223 					 unsigned long ctr_mask)
224 {
225 	/* Make sure the we have a valid counter mask requested from the caller */
226 	if (!ctr_mask || (ctr_base + __fls(ctr_mask) >= kvm_pmu_num_counters(kvpmu)))
227 		return -EINVAL;
228 
229 	return 0;
230 }
231 
232 static int kvm_pmu_create_perf_event(struct kvm_pmc *pmc, struct perf_event_attr *attr,
233 				     unsigned long flags, unsigned long eidx, unsigned long evtdata)
234 {
235 	struct perf_event *event;
236 
237 	kvm_pmu_release_perf_event(pmc);
238 	attr->config = kvm_pmu_get_perf_event_config(eidx, evtdata);
239 	if (flags & SBI_PMU_CFG_FLAG_CLEAR_VALUE) {
240 		//TODO: Do we really want to clear the value in hardware counter
241 		pmc->counter_val = 0;
242 	}
243 
244 	/*
245 	 * Set the default sample_period for now. The guest specified value
246 	 * will be updated in the start call.
247 	 */
248 	attr->sample_period = kvm_pmu_get_sample_period(pmc);
249 
250 	event = perf_event_create_kernel_counter(attr, -1, current, NULL, pmc);
251 	if (IS_ERR(event)) {
252 		pr_err("kvm pmu event creation failed for eidx %lx: %ld\n", eidx, PTR_ERR(event));
253 		return PTR_ERR(event);
254 	}
255 
256 	pmc->perf_event = event;
257 	if (flags & SBI_PMU_CFG_FLAG_AUTO_START)
258 		perf_event_enable(pmc->perf_event);
259 
260 	return 0;
261 }
262 
263 int kvm_riscv_vcpu_pmu_incr_fw(struct kvm_vcpu *vcpu, unsigned long fid)
264 {
265 	struct kvm_pmu *kvpmu = vcpu_to_pmu(vcpu);
266 	struct kvm_fw_event *fevent;
267 
268 	if (!kvpmu || fid >= SBI_PMU_FW_MAX)
269 		return -EINVAL;
270 
271 	fevent = &kvpmu->fw_event[fid];
272 	if (fevent->started)
273 		fevent->value++;
274 
275 	return 0;
276 }
277 
278 int kvm_riscv_vcpu_pmu_read_hpm(struct kvm_vcpu *vcpu, unsigned int csr_num,
279 				unsigned long *val, unsigned long new_val,
280 				unsigned long wr_mask)
281 {
282 	struct kvm_pmu *kvpmu = vcpu_to_pmu(vcpu);
283 	int cidx, ret = KVM_INSN_CONTINUE_NEXT_SEPC;
284 
285 	if (!kvpmu || !kvpmu->init_done) {
286 		/*
287 		 * In absence of sscofpmf in the platform, the guest OS may use
288 		 * the legacy PMU driver to read cycle/instret. In that case,
289 		 * just return 0 to avoid any illegal trap. However, any other
290 		 * hpmcounter access should result in illegal trap as they must
291 		 * be access through SBI PMU only.
292 		 */
293 		if (csr_num == CSR_CYCLE || csr_num == CSR_INSTRET) {
294 			*val = 0;
295 			return ret;
296 		} else {
297 			return KVM_INSN_ILLEGAL_TRAP;
298 		}
299 	}
300 
301 	/* The counter CSR are read only. Thus, any write should result in illegal traps */
302 	if (wr_mask)
303 		return KVM_INSN_ILLEGAL_TRAP;
304 
305 	cidx = csr_num - CSR_CYCLE;
306 
307 	if (pmu_ctr_read(vcpu, cidx, val) < 0)
308 		return KVM_INSN_ILLEGAL_TRAP;
309 
310 	return ret;
311 }
312 
313 int kvm_riscv_vcpu_pmu_num_ctrs(struct kvm_vcpu *vcpu,
314 				struct kvm_vcpu_sbi_return *retdata)
315 {
316 	struct kvm_pmu *kvpmu = vcpu_to_pmu(vcpu);
317 
318 	retdata->out_val = kvm_pmu_num_counters(kvpmu);
319 
320 	return 0;
321 }
322 
323 int kvm_riscv_vcpu_pmu_ctr_info(struct kvm_vcpu *vcpu, unsigned long cidx,
324 				struct kvm_vcpu_sbi_return *retdata)
325 {
326 	struct kvm_pmu *kvpmu = vcpu_to_pmu(vcpu);
327 
328 	if (cidx > RISCV_KVM_MAX_COUNTERS || cidx == 1) {
329 		retdata->err_val = SBI_ERR_INVALID_PARAM;
330 		return 0;
331 	}
332 
333 	retdata->out_val = kvpmu->pmc[cidx].cinfo.value;
334 
335 	return 0;
336 }
337 
338 int kvm_riscv_vcpu_pmu_ctr_start(struct kvm_vcpu *vcpu, unsigned long ctr_base,
339 				 unsigned long ctr_mask, unsigned long flags, u64 ival,
340 				 struct kvm_vcpu_sbi_return *retdata)
341 {
342 	struct kvm_pmu *kvpmu = vcpu_to_pmu(vcpu);
343 	int i, pmc_index, sbiret = 0;
344 	struct kvm_pmc *pmc;
345 	int fevent_code;
346 
347 	if (kvm_pmu_validate_counter_mask(kvpmu, ctr_base, ctr_mask) < 0) {
348 		sbiret = SBI_ERR_INVALID_PARAM;
349 		goto out;
350 	}
351 
352 	/* Start the counters that have been configured and requested by the guest */
353 	for_each_set_bit(i, &ctr_mask, RISCV_MAX_COUNTERS) {
354 		pmc_index = i + ctr_base;
355 		if (!test_bit(pmc_index, kvpmu->pmc_in_use))
356 			continue;
357 		pmc = &kvpmu->pmc[pmc_index];
358 		if (flags & SBI_PMU_START_FLAG_SET_INIT_VALUE)
359 			pmc->counter_val = ival;
360 		if (pmc->cinfo.type == SBI_PMU_CTR_TYPE_FW) {
361 			fevent_code = get_event_code(pmc->event_idx);
362 			if (fevent_code >= SBI_PMU_FW_MAX) {
363 				sbiret = SBI_ERR_INVALID_PARAM;
364 				goto out;
365 			}
366 
367 			/* Check if the counter was already started for some reason */
368 			if (kvpmu->fw_event[fevent_code].started) {
369 				sbiret = SBI_ERR_ALREADY_STARTED;
370 				continue;
371 			}
372 
373 			kvpmu->fw_event[fevent_code].started = true;
374 			kvpmu->fw_event[fevent_code].value = pmc->counter_val;
375 		} else if (pmc->perf_event) {
376 			if (unlikely(pmc->started)) {
377 				sbiret = SBI_ERR_ALREADY_STARTED;
378 				continue;
379 			}
380 			perf_event_period(pmc->perf_event, kvm_pmu_get_sample_period(pmc));
381 			perf_event_enable(pmc->perf_event);
382 			pmc->started = true;
383 		} else {
384 			sbiret = SBI_ERR_INVALID_PARAM;
385 		}
386 	}
387 
388 out:
389 	retdata->err_val = sbiret;
390 
391 	return 0;
392 }
393 
394 int kvm_riscv_vcpu_pmu_ctr_stop(struct kvm_vcpu *vcpu, unsigned long ctr_base,
395 				unsigned long ctr_mask, unsigned long flags,
396 				struct kvm_vcpu_sbi_return *retdata)
397 {
398 	struct kvm_pmu *kvpmu = vcpu_to_pmu(vcpu);
399 	int i, pmc_index, sbiret = 0;
400 	u64 enabled, running;
401 	struct kvm_pmc *pmc;
402 	int fevent_code;
403 
404 	if (kvm_pmu_validate_counter_mask(kvpmu, ctr_base, ctr_mask) < 0) {
405 		sbiret = SBI_ERR_INVALID_PARAM;
406 		goto out;
407 	}
408 
409 	/* Stop the counters that have been configured and requested by the guest */
410 	for_each_set_bit(i, &ctr_mask, RISCV_MAX_COUNTERS) {
411 		pmc_index = i + ctr_base;
412 		if (!test_bit(pmc_index, kvpmu->pmc_in_use))
413 			continue;
414 		pmc = &kvpmu->pmc[pmc_index];
415 		if (pmc->cinfo.type == SBI_PMU_CTR_TYPE_FW) {
416 			fevent_code = get_event_code(pmc->event_idx);
417 			if (fevent_code >= SBI_PMU_FW_MAX) {
418 				sbiret = SBI_ERR_INVALID_PARAM;
419 				goto out;
420 			}
421 
422 			if (!kvpmu->fw_event[fevent_code].started)
423 				sbiret = SBI_ERR_ALREADY_STOPPED;
424 
425 			kvpmu->fw_event[fevent_code].started = false;
426 		} else if (pmc->perf_event) {
427 			if (pmc->started) {
428 				/* Stop counting the counter */
429 				perf_event_disable(pmc->perf_event);
430 				pmc->started = false;
431 			} else {
432 				sbiret = SBI_ERR_ALREADY_STOPPED;
433 			}
434 
435 			if (flags & SBI_PMU_STOP_FLAG_RESET) {
436 				/* Relase the counter if this is a reset request */
437 				pmc->counter_val += perf_event_read_value(pmc->perf_event,
438 									  &enabled, &running);
439 				kvm_pmu_release_perf_event(pmc);
440 			}
441 		} else {
442 			sbiret = SBI_ERR_INVALID_PARAM;
443 		}
444 		if (flags & SBI_PMU_STOP_FLAG_RESET) {
445 			pmc->event_idx = SBI_PMU_EVENT_IDX_INVALID;
446 			clear_bit(pmc_index, kvpmu->pmc_in_use);
447 		}
448 	}
449 
450 out:
451 	retdata->err_val = sbiret;
452 
453 	return 0;
454 }
455 
456 int kvm_riscv_vcpu_pmu_ctr_cfg_match(struct kvm_vcpu *vcpu, unsigned long ctr_base,
457 				     unsigned long ctr_mask, unsigned long flags,
458 				     unsigned long eidx, u64 evtdata,
459 				     struct kvm_vcpu_sbi_return *retdata)
460 {
461 	int ctr_idx, ret, sbiret = 0;
462 	bool is_fevent;
463 	unsigned long event_code;
464 	u32 etype = kvm_pmu_get_perf_event_type(eidx);
465 	struct kvm_pmu *kvpmu = vcpu_to_pmu(vcpu);
466 	struct kvm_pmc *pmc = NULL;
467 	struct perf_event_attr attr = {
468 		.type = etype,
469 		.size = sizeof(struct perf_event_attr),
470 		.pinned = true,
471 		/*
472 		 * It should never reach here if the platform doesn't support the sscofpmf
473 		 * extension as mode filtering won't work without it.
474 		 */
475 		.exclude_host = true,
476 		.exclude_hv = true,
477 		.exclude_user = !!(flags & SBI_PMU_CFG_FLAG_SET_UINH),
478 		.exclude_kernel = !!(flags & SBI_PMU_CFG_FLAG_SET_SINH),
479 		.config1 = RISCV_PMU_CONFIG1_GUEST_EVENTS,
480 	};
481 
482 	if (kvm_pmu_validate_counter_mask(kvpmu, ctr_base, ctr_mask) < 0) {
483 		sbiret = SBI_ERR_INVALID_PARAM;
484 		goto out;
485 	}
486 
487 	event_code = get_event_code(eidx);
488 	is_fevent = kvm_pmu_is_fw_event(eidx);
489 	if (is_fevent && event_code >= SBI_PMU_FW_MAX) {
490 		sbiret = SBI_ERR_NOT_SUPPORTED;
491 		goto out;
492 	}
493 
494 	/*
495 	 * SKIP_MATCH flag indicates the caller is aware of the assigned counter
496 	 * for this event. Just do a sanity check if it already marked used.
497 	 */
498 	if (flags & SBI_PMU_CFG_FLAG_SKIP_MATCH) {
499 		if (!test_bit(ctr_base + __ffs(ctr_mask), kvpmu->pmc_in_use)) {
500 			sbiret = SBI_ERR_FAILURE;
501 			goto out;
502 		}
503 		ctr_idx = ctr_base + __ffs(ctr_mask);
504 	} else  {
505 		ctr_idx = pmu_get_pmc_index(kvpmu, eidx, ctr_base, ctr_mask);
506 		if (ctr_idx < 0) {
507 			sbiret = SBI_ERR_NOT_SUPPORTED;
508 			goto out;
509 		}
510 	}
511 
512 	pmc = &kvpmu->pmc[ctr_idx];
513 	pmc->idx = ctr_idx;
514 
515 	if (is_fevent) {
516 		if (flags & SBI_PMU_CFG_FLAG_AUTO_START)
517 			kvpmu->fw_event[event_code].started = true;
518 	} else {
519 		ret = kvm_pmu_create_perf_event(pmc, &attr, flags, eidx, evtdata);
520 		if (ret)
521 			return ret;
522 	}
523 
524 	set_bit(ctr_idx, kvpmu->pmc_in_use);
525 	pmc->event_idx = eidx;
526 	retdata->out_val = ctr_idx;
527 out:
528 	retdata->err_val = sbiret;
529 
530 	return 0;
531 }
532 
533 int kvm_riscv_vcpu_pmu_ctr_read(struct kvm_vcpu *vcpu, unsigned long cidx,
534 				struct kvm_vcpu_sbi_return *retdata)
535 {
536 	int ret;
537 
538 	ret = pmu_ctr_read(vcpu, cidx, &retdata->out_val);
539 	if (ret == -EINVAL)
540 		retdata->err_val = SBI_ERR_INVALID_PARAM;
541 
542 	return 0;
543 }
544 
545 void kvm_riscv_vcpu_pmu_init(struct kvm_vcpu *vcpu)
546 {
547 	int i = 0, ret, num_hw_ctrs = 0, hpm_width = 0;
548 	struct kvm_pmu *kvpmu = vcpu_to_pmu(vcpu);
549 	struct kvm_pmc *pmc;
550 
551 	/*
552 	 * PMU functionality should be only available to guests if privilege mode
553 	 * filtering is available in the host. Otherwise, guest will always count
554 	 * events while the execution is in hypervisor mode.
555 	 */
556 	if (!riscv_isa_extension_available(NULL, SSCOFPMF))
557 		return;
558 
559 	ret = riscv_pmu_get_hpm_info(&hpm_width, &num_hw_ctrs);
560 	if (ret < 0 || !hpm_width || !num_hw_ctrs)
561 		return;
562 
563 	/*
564 	 * Increase the number of hardware counters to offset the time counter.
565 	 */
566 	kvpmu->num_hw_ctrs = num_hw_ctrs + 1;
567 	kvpmu->num_fw_ctrs = SBI_PMU_FW_MAX;
568 	memset(&kvpmu->fw_event, 0, SBI_PMU_FW_MAX * sizeof(struct kvm_fw_event));
569 
570 	if (kvpmu->num_hw_ctrs > RISCV_KVM_MAX_HW_CTRS) {
571 		pr_warn_once("Limiting the hardware counters to 32 as specified by the ISA");
572 		kvpmu->num_hw_ctrs = RISCV_KVM_MAX_HW_CTRS;
573 	}
574 
575 	/*
576 	 * There is no correlation between the logical hardware counter and virtual counters.
577 	 * However, we need to encode a hpmcounter CSR in the counter info field so that
578 	 * KVM can trap n emulate the read. This works well in the migration use case as
579 	 * KVM doesn't care if the actual hpmcounter is available in the hardware or not.
580 	 */
581 	for (i = 0; i < kvm_pmu_num_counters(kvpmu); i++) {
582 		/* TIME CSR shouldn't be read from perf interface */
583 		if (i == 1)
584 			continue;
585 		pmc = &kvpmu->pmc[i];
586 		pmc->idx = i;
587 		pmc->event_idx = SBI_PMU_EVENT_IDX_INVALID;
588 		if (i < kvpmu->num_hw_ctrs) {
589 			pmc->cinfo.type = SBI_PMU_CTR_TYPE_HW;
590 			if (i < 3)
591 				/* CY, IR counters */
592 				pmc->cinfo.width = 63;
593 			else
594 				pmc->cinfo.width = hpm_width;
595 			/*
596 			 * The CSR number doesn't have any relation with the logical
597 			 * hardware counters. The CSR numbers are encoded sequentially
598 			 * to avoid maintaining a map between the virtual counter
599 			 * and CSR number.
600 			 */
601 			pmc->cinfo.csr = CSR_CYCLE + i;
602 		} else {
603 			pmc->cinfo.type = SBI_PMU_CTR_TYPE_FW;
604 			pmc->cinfo.width = BITS_PER_LONG - 1;
605 		}
606 	}
607 
608 	kvpmu->init_done = true;
609 }
610 
611 void kvm_riscv_vcpu_pmu_deinit(struct kvm_vcpu *vcpu)
612 {
613 	struct kvm_pmu *kvpmu = vcpu_to_pmu(vcpu);
614 	struct kvm_pmc *pmc;
615 	int i;
616 
617 	if (!kvpmu)
618 		return;
619 
620 	for_each_set_bit(i, kvpmu->pmc_in_use, RISCV_MAX_COUNTERS) {
621 		pmc = &kvpmu->pmc[i];
622 		pmc->counter_val = 0;
623 		kvm_pmu_release_perf_event(pmc);
624 		pmc->event_idx = SBI_PMU_EVENT_IDX_INVALID;
625 	}
626 	bitmap_zero(kvpmu->pmc_in_use, RISCV_MAX_COUNTERS);
627 	memset(&kvpmu->fw_event, 0, SBI_PMU_FW_MAX * sizeof(struct kvm_fw_event));
628 }
629 
630 void kvm_riscv_vcpu_pmu_reset(struct kvm_vcpu *vcpu)
631 {
632 	kvm_riscv_vcpu_pmu_deinit(vcpu);
633 }
634