With the MMCR0 control bit (PMCCEXT) in ISA v3.1, read access to group B registers is restricted when MMCR0 PMCC=0b00. In other platforms (like power9), the older behaviour works where group B PMU SPRs are readable. Patch creates a selftest which verifies that the test takes a SIGILL when attempting to read PMU registers via helper function "dump_ebb_state" for ISA v3.1. Signed-off-by: Athira Rajeev <atrajeev@linux.vnet.ibm.com> Tested-by: Nageswara R Sastry <rnsastry@linux.ibm.com <mailto:rnsastry@linux.ibm.com>> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au> Link: https://lore.kernel.org/r/1621950703-1532-3-git-send-email-atrajeev@linux.vnet.ibm.com
38 lines
1.3 KiB
Makefile
38 lines
1.3 KiB
Makefile
# SPDX-License-Identifier: GPL-2.0
|
|
include ../../../../../build/Build.include
|
|
|
|
noarg:
|
|
$(MAKE) -C ../../
|
|
|
|
# The EBB handler is 64-bit code and everything links against it
|
|
CFLAGS += -m64
|
|
|
|
TMPOUT = $(OUTPUT)/TMPDIR/
|
|
# Toolchains may build PIE by default which breaks the assembly
|
|
no-pie-option := $(call try-run, echo 'int main() { return 0; }' | \
|
|
$(CC) -Werror $(KBUILD_CPPFLAGS) $(CC_OPTION_CFLAGS) -no-pie -x c - -o "$$TMP", -no-pie)
|
|
|
|
LDFLAGS += $(no-pie-option)
|
|
|
|
TEST_GEN_PROGS := reg_access_test event_attributes_test cycles_test \
|
|
cycles_with_freeze_test pmc56_overflow_test \
|
|
ebb_vs_cpu_event_test cpu_event_vs_ebb_test \
|
|
cpu_event_pinned_vs_ebb_test task_event_vs_ebb_test \
|
|
task_event_pinned_vs_ebb_test multi_ebb_procs_test \
|
|
multi_counter_test pmae_handling_test \
|
|
close_clears_pmcc_test instruction_count_test \
|
|
fork_cleanup_test ebb_on_child_test \
|
|
ebb_on_willing_child_test back_to_back_ebbs_test \
|
|
lost_exception_test no_handler_test \
|
|
cycles_with_mmcr2_test regs_access_pmccext_test
|
|
|
|
top_srcdir = ../../../../../..
|
|
include ../../../lib.mk
|
|
|
|
$(TEST_GEN_PROGS): ../../harness.c ../../utils.c ../event.c ../lib.c \
|
|
ebb.c ebb_handler.S trace.c busy_loop.S
|
|
|
|
$(OUTPUT)/instruction_count_test: ../loop.S
|
|
|
|
$(OUTPUT)/lost_exception_test: ../lib.c
|