diff options
Diffstat (limited to 'drivers/s390/crypto/ap_bus.h')
| -rw-r--r-- | drivers/s390/crypto/ap_bus.h | 58 | 
1 files changed, 50 insertions, 8 deletions
diff --git a/drivers/s390/crypto/ap_bus.h b/drivers/s390/crypto/ap_bus.h index 4785d07cd44..6405ae24a7a 100644 --- a/drivers/s390/crypto/ap_bus.h +++ b/drivers/s390/crypto/ap_bus.h @@ -1,11 +1,10 @@  /* - * linux/drivers/s390/crypto/ap_bus.h - * - * Copyright (C) 2006 IBM Corporation + * Copyright IBM Corp. 2006, 2012   * Author(s): Cornelia Huck <cornelia.huck@de.ibm.com>   *	      Martin Schwidefsky <schwidefsky@de.ibm.com>   *	      Ralph Wuerthner <rwuerthn@de.ibm.com>   *	      Felix Beck <felix.beck@de.ibm.com> + *	      Holger Dengler <hd@linux.vnet.ibm.com>   *   * Adjunct processor bus header file.   * @@ -34,7 +33,7 @@  #define AP_DEVICES 64		/* Number of AP devices. */  #define AP_DOMAINS 16		/* Number of AP domains. */  #define AP_MAX_RESET 90		/* Maximum number of resets. */ -#define AP_RESET_TIMEOUT (HZ/2)	/* Time in ticks for reset timeouts. */ +#define AP_RESET_TIMEOUT (HZ*0.7)	/* Time in ticks for reset timeouts. */  #define AP_CONFIG_TIME 30	/* Time in seconds between AP bus rescans. */  #define AP_POLL_TIME 1		/* Time in ticks between receive polls. */ @@ -72,7 +71,25 @@ struct ap_queue_status {  	unsigned int int_enabled	: 1;  	unsigned int response_code	: 8;  	unsigned int pad2		: 16; -}; +} __packed; + +#define AP_QUEUE_STATUS_INVALID \ +		{ 1, 1, 1, 0xF, 1, 0xFF, 0xFFFF } + +static inline +int ap_queue_status_invalid_test(struct ap_queue_status *status) +{ +	struct ap_queue_status invalid = AP_QUEUE_STATUS_INVALID; +	return !(memcmp(status, &invalid, sizeof(struct ap_queue_status))); +} + +#define AP_MAX_BITS 31 +static inline int ap_test_bit(unsigned int *ptr, unsigned int nr) +{ +	if (nr > AP_MAX_BITS) +		return 0; +	return (*ptr & (0x80000000u >> nr)) != 0; +}  #define AP_RESPONSE_NORMAL		0x00  #define AP_RESPONSE_Q_NOT_AVAIL		0x01 @@ -99,6 +116,17 @@ struct ap_queue_status {  #define AP_DEVICE_TYPE_CEX2C	7  #define AP_DEVICE_TYPE_CEX3A	8  #define AP_DEVICE_TYPE_CEX3C	9 +#define AP_DEVICE_TYPE_CEX4	10 + +/* + * Known function facilities + */ +#define AP_FUNC_MEX4K 1 +#define AP_FUNC_CRT4K 2 +#define AP_FUNC_COPRO 3 +#define AP_FUNC_ACCEL 4 +#define AP_FUNC_EP11  5 +#define AP_FUNC_APXA  6  /*   * AP reset flag states @@ -116,9 +144,6 @@ struct ap_driver {  	int (*probe)(struct ap_device *);  	void (*remove)(struct ap_device *); -	/* receive is called from tasklet context */ -	void (*receive)(struct ap_device *, struct ap_message *, -			struct ap_message *);  	int request_timeout;		/* request timeout in jiffies */  }; @@ -136,6 +161,7 @@ struct ap_device {  	ap_qid_t qid;			/* AP queue id. */  	int queue_depth;		/* AP queue depth.*/  	int device_type;		/* AP device type. */ +	unsigned int functions;		/* AP device function bitfield. */  	int unregistered;		/* marks AP device as unregistered */  	struct timer_list timeout;	/* Timer for request timeouts. */  	int reset;			/* Reset required after req. timeout. */ @@ -163,8 +189,22 @@ struct ap_message {  	void *private;			/* ap driver private pointer. */  	unsigned int special:1;		/* Used for special commands. */ +	/* receive is called from tasklet context */ +	void (*receive)(struct ap_device *, struct ap_message *, +			struct ap_message *);  }; +struct ap_config_info { +	unsigned int special_command:1; +	unsigned int ap_extended:1; +	unsigned char reserved1:6; +	unsigned char reserved2[15]; +	unsigned int apm[8];		/* AP ID mask */ +	unsigned int aqm[8];		/* AP queue mask */ +	unsigned int adm[8];		/* AP domain mask */ +	unsigned char reserved4[16]; +} __packed; +  #define AP_DEVICE(dt)					\  	.dev_type=(dt),					\  	.match_flags=AP_DEVICE_ID_MATCH_DEVICE_TYPE, @@ -179,6 +219,7 @@ static inline void ap_init_message(struct ap_message *ap_msg)  	ap_msg->psmid = 0;  	ap_msg->length = 0;  	ap_msg->special = 0; +	ap_msg->receive = NULL;  }  /* @@ -192,6 +233,7 @@ int ap_recv(ap_qid_t, unsigned long long *, void *, size_t);  void ap_queue_message(struct ap_device *ap_dev, struct ap_message *ap_msg);  void ap_cancel_message(struct ap_device *ap_dev, struct ap_message *ap_msg);  void ap_flush_queue(struct ap_device *ap_dev); +void ap_bus_force_rescan(void);  int ap_module_init(void);  void ap_module_exit(void);  | 
