diff options
Diffstat (limited to 'arch/s390/oprofile/hwsampler.c')
| -rw-r--r-- | arch/s390/oprofile/hwsampler.c | 78 | 
1 files changed, 12 insertions, 66 deletions
| diff --git a/arch/s390/oprofile/hwsampler.c b/arch/s390/oprofile/hwsampler.c index 231cecafc2f1..a32c96761eab 100644 --- a/arch/s390/oprofile/hwsampler.c +++ b/arch/s390/oprofile/hwsampler.c @@ -26,9 +26,6 @@  #define MAX_NUM_SDB 511  #define MIN_NUM_SDB 1 -#define ALERT_REQ_MASK   0x4000000000000000ul -#define BUFFER_FULL_MASK 0x8000000000000000ul -  DECLARE_PER_CPU(struct hws_cpu_buffer, sampler_cpu_buffer);  struct hws_execute_parms { @@ -44,6 +41,7 @@ static DEFINE_MUTEX(hws_sem_oom);  static unsigned char hws_flush_all;  static unsigned int hws_oom; +static unsigned int hws_alert;  static struct workqueue_struct *hws_wq;  static unsigned int hws_state; @@ -65,43 +63,6 @@ static unsigned long interval;  static unsigned long min_sampler_rate;  static unsigned long max_sampler_rate; -static int ssctl(void *buffer) -{ -	int cc; - -	/* set in order to detect a program check */ -	cc = 1; - -	asm volatile( -		"0: .insn s,0xB2870000,0(%1)\n" -		"1: ipm %0\n" -		"   srl %0,28\n" -		"2:\n" -		EX_TABLE(0b, 2b) EX_TABLE(1b, 2b) -		: "+d" (cc), "+a" (buffer) -		: "m" (*((struct hws_ssctl_request_block *)buffer)) -		: "cc", "memory"); - -	return cc ? -EINVAL : 0 ; -} - -static int qsi(void *buffer) -{ -	int cc; -	cc = 1; - -	asm volatile( -		"0: .insn s,0xB2860000,0(%1)\n" -		"1: lhi %0,0\n" -		"2:\n" -		EX_TABLE(0b, 2b) EX_TABLE(1b, 2b) -		: "=d" (cc), "+a" (buffer) -		: "m" (*((struct hws_qsi_info_block *)buffer)) -		: "cc", "memory"); - -	return cc ? -EINVAL : 0; -} -  static void execute_qsi(void *parms)  {  	struct hws_execute_parms *ep = parms; @@ -113,7 +74,7 @@ static void execute_ssctl(void *parms)  {  	struct hws_execute_parms *ep = parms; -	ep->rc = ssctl(ep->buffer); +	ep->rc = lsctl(ep->buffer);  }  static int smp_ctl_ssctl_stop(int cpu) @@ -214,17 +175,6 @@ static int smp_ctl_qsi(int cpu)  	return ep.rc;  } -static inline unsigned long *trailer_entry_ptr(unsigned long v) -{ -	void *ret; - -	ret = (void *)v; -	ret += PAGE_SIZE; -	ret -= sizeof(struct hws_trailer_entry); - -	return (unsigned long *) ret; -} -  static void hws_ext_handler(struct ext_code ext_code,  			    unsigned int param32, unsigned long param64)  { @@ -233,6 +183,9 @@ static void hws_ext_handler(struct ext_code ext_code,  	if (!(param32 & CPU_MF_INT_SF_MASK))  		return; +	if (!hws_alert) +		return; +  	inc_irq_stat(IRQEXT_CMS);  	atomic_xchg(&cb->ext_params, atomic_read(&cb->ext_params) | param32); @@ -256,16 +209,6 @@ static void init_all_cpu_buffers(void)  	}  } -static int is_link_entry(unsigned long *s) -{ -	return *s & 0x1ul ? 1 : 0; -} - -static unsigned long *get_next_sdbt(unsigned long *s) -{ -	return (unsigned long *) (*s & ~0x1ul); -} -  static int prepare_cpu_buffers(void)  {  	int cpu; @@ -353,7 +296,7 @@ static int allocate_sdbt(int cpu)  			}  			*sdbt = sdb;  			trailer = trailer_entry_ptr(*sdbt); -			*trailer = ALERT_REQ_MASK; +			*trailer = SDB_TE_ALERT_REQ_MASK;  			sdbt++;  			mutex_unlock(&hws_sem_oom);  		} @@ -829,7 +772,7 @@ static void worker_on_interrupt(unsigned int cpu)  		trailer = trailer_entry_ptr(*sdbt);  		/* leave loop if no more work to do */ -		if (!(*trailer & BUFFER_FULL_MASK)) { +		if (!(*trailer & SDB_TE_BUFFER_FULL_MASK)) {  			done = 1;  			if (!hws_flush_all)  				continue; @@ -856,7 +799,7 @@ static void worker_on_interrupt(unsigned int cpu)  static void add_samples_to_oprofile(unsigned int cpu, unsigned long *sdbt,  		unsigned long *dear)  { -	struct hws_data_entry *sample_data_ptr; +	struct hws_basic_entry *sample_data_ptr;  	unsigned long *trailer;  	trailer = trailer_entry_ptr(*sdbt); @@ -866,7 +809,7 @@ static void add_samples_to_oprofile(unsigned int cpu, unsigned long *sdbt,  		trailer = dear;  	} -	sample_data_ptr = (struct hws_data_entry *)(*sdbt); +	sample_data_ptr = (struct hws_basic_entry *)(*sdbt);  	while ((unsigned long *)sample_data_ptr < trailer) {  		struct pt_regs *regs = NULL; @@ -1002,6 +945,7 @@ int hwsampler_deallocate(void)  		goto deallocate_exit;  	irq_subclass_unregister(IRQ_SUBCLASS_MEASUREMENT_ALERT); +	hws_alert = 0;  	deallocate_sdbt();  	hws_state = HWS_DEALLOCATED; @@ -1116,6 +1060,7 @@ int hwsampler_shutdown(void)  		if (hws_state == HWS_STOPPED) {  			irq_subclass_unregister(IRQ_SUBCLASS_MEASUREMENT_ALERT); +			hws_alert = 0;  			deallocate_sdbt();  		}  		if (hws_wq) { @@ -1190,6 +1135,7 @@ start_all_exit:  	hws_oom = 1;  	hws_flush_all = 0;  	/* now let them in, 1407 CPUMF external interrupts */ +	hws_alert = 1;  	irq_subclass_register(IRQ_SUBCLASS_MEASUREMENT_ALERT);  	return 0; | 
