162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * POWER Data Stream Control Register (DSCR) 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * This header file contains helper functions and macros 662306a36Sopenharmony_ci * required for all the DSCR related test cases. 762306a36Sopenharmony_ci * 862306a36Sopenharmony_ci * Copyright 2012, Anton Blanchard, IBM Corporation. 962306a36Sopenharmony_ci * Copyright 2015, Anshuman Khandual, IBM Corporation. 1062306a36Sopenharmony_ci */ 1162306a36Sopenharmony_ci#ifndef _SELFTESTS_POWERPC_DSCR_DSCR_H 1262306a36Sopenharmony_ci#define _SELFTESTS_POWERPC_DSCR_DSCR_H 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ci#include <unistd.h> 1562306a36Sopenharmony_ci#include <stdio.h> 1662306a36Sopenharmony_ci#include <stdlib.h> 1762306a36Sopenharmony_ci#include <string.h> 1862306a36Sopenharmony_ci#include <fcntl.h> 1962306a36Sopenharmony_ci#include <dirent.h> 2062306a36Sopenharmony_ci#include <pthread.h> 2162306a36Sopenharmony_ci#include <sched.h> 2262306a36Sopenharmony_ci#include <sys/types.h> 2362306a36Sopenharmony_ci#include <sys/stat.h> 2462306a36Sopenharmony_ci#include <sys/wait.h> 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ci#include "reg.h" 2762306a36Sopenharmony_ci#include "utils.h" 2862306a36Sopenharmony_ci 2962306a36Sopenharmony_ci#define THREADS 100 /* Max threads */ 3062306a36Sopenharmony_ci#define COUNT 100 /* Max iterations */ 3162306a36Sopenharmony_ci#define DSCR_MAX 16 /* Max DSCR value */ 3262306a36Sopenharmony_ci#define LEN_MAX 100 /* Max name length */ 3362306a36Sopenharmony_ci 3462306a36Sopenharmony_ci#define DSCR_DEFAULT "/sys/devices/system/cpu/dscr_default" 3562306a36Sopenharmony_ci#define CPU_PATH "/sys/devices/system/cpu/" 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci#define rmb() asm volatile("lwsync":::"memory") 3862306a36Sopenharmony_ci#define wmb() asm volatile("lwsync":::"memory") 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_ci#define READ_ONCE(x) (*(volatile typeof(x) *)&(x)) 4162306a36Sopenharmony_ci 4262306a36Sopenharmony_ci/* Prilvilege state DSCR access */ 4362306a36Sopenharmony_ciinline unsigned long get_dscr(void) 4462306a36Sopenharmony_ci{ 4562306a36Sopenharmony_ci return mfspr(SPRN_DSCR_PRIV); 4662306a36Sopenharmony_ci} 4762306a36Sopenharmony_ci 4862306a36Sopenharmony_ciinline void set_dscr(unsigned long val) 4962306a36Sopenharmony_ci{ 5062306a36Sopenharmony_ci mtspr(SPRN_DSCR_PRIV, val); 5162306a36Sopenharmony_ci} 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_ci/* Problem state DSCR access */ 5462306a36Sopenharmony_ciinline unsigned long get_dscr_usr(void) 5562306a36Sopenharmony_ci{ 5662306a36Sopenharmony_ci return mfspr(SPRN_DSCR); 5762306a36Sopenharmony_ci} 5862306a36Sopenharmony_ci 5962306a36Sopenharmony_ciinline void set_dscr_usr(unsigned long val) 6062306a36Sopenharmony_ci{ 6162306a36Sopenharmony_ci mtspr(SPRN_DSCR, val); 6262306a36Sopenharmony_ci} 6362306a36Sopenharmony_ci 6462306a36Sopenharmony_ci/* Default DSCR access */ 6562306a36Sopenharmony_ciunsigned long get_default_dscr(void) 6662306a36Sopenharmony_ci{ 6762306a36Sopenharmony_ci int err; 6862306a36Sopenharmony_ci unsigned long val; 6962306a36Sopenharmony_ci 7062306a36Sopenharmony_ci err = read_ulong(DSCR_DEFAULT, &val, 16); 7162306a36Sopenharmony_ci if (err) { 7262306a36Sopenharmony_ci perror("read() failed"); 7362306a36Sopenharmony_ci exit(1); 7462306a36Sopenharmony_ci } 7562306a36Sopenharmony_ci return val; 7662306a36Sopenharmony_ci} 7762306a36Sopenharmony_ci 7862306a36Sopenharmony_civoid set_default_dscr(unsigned long val) 7962306a36Sopenharmony_ci{ 8062306a36Sopenharmony_ci int err; 8162306a36Sopenharmony_ci 8262306a36Sopenharmony_ci err = write_ulong(DSCR_DEFAULT, val, 16); 8362306a36Sopenharmony_ci if (err) { 8462306a36Sopenharmony_ci perror("write() failed"); 8562306a36Sopenharmony_ci exit(1); 8662306a36Sopenharmony_ci } 8762306a36Sopenharmony_ci} 8862306a36Sopenharmony_ci 8962306a36Sopenharmony_ci#endif /* _SELFTESTS_POWERPC_DSCR_DSCR_H */ 90