xref: /linux/drivers/s390/cio/chp.h (revision e5854a5839fa426a7873f038080f63587de5f1f1)
1e6b6e10aSPeter Oberparleiter /*
2e6b6e10aSPeter Oberparleiter  *  drivers/s390/cio/chp.h
3e6b6e10aSPeter Oberparleiter  *
4e6b6e10aSPeter Oberparleiter  *    Copyright IBM Corp. 2007
5e6b6e10aSPeter Oberparleiter  *    Author(s): Peter Oberparleiter <peter.oberparleiter@de.ibm.com>
6e6b6e10aSPeter Oberparleiter  */
7e6b6e10aSPeter Oberparleiter 
8e6b6e10aSPeter Oberparleiter #ifndef S390_CHP_H
9e6b6e10aSPeter Oberparleiter #define S390_CHP_H S390_CHP_H
10e6b6e10aSPeter Oberparleiter 
11e6b6e10aSPeter Oberparleiter #include <linux/types.h>
12e6b6e10aSPeter Oberparleiter #include <linux/device.h>
13*e5854a58SPeter Oberparleiter #include <asm/chpid.h>
14e6b6e10aSPeter Oberparleiter #include "chsc.h"
15e6b6e10aSPeter Oberparleiter 
16*e5854a58SPeter Oberparleiter #define CHP_STATUS_STANDBY		0
17*e5854a58SPeter Oberparleiter #define CHP_STATUS_CONFIGURED		1
18*e5854a58SPeter Oberparleiter #define CHP_STATUS_RESERVED		2
19*e5854a58SPeter Oberparleiter #define CHP_STATUS_NOT_RECOGNIZED	3
20*e5854a58SPeter Oberparleiter 
21*e5854a58SPeter Oberparleiter static inline int chp_test_bit(u8 *bitmap, int num)
22*e5854a58SPeter Oberparleiter {
23*e5854a58SPeter Oberparleiter 	int byte = num >> 3;
24*e5854a58SPeter Oberparleiter 	int mask = 128 >> (num & 7);
25*e5854a58SPeter Oberparleiter 
26*e5854a58SPeter Oberparleiter 	return (bitmap[byte] & mask) ? 1 : 0;
27*e5854a58SPeter Oberparleiter }
28*e5854a58SPeter Oberparleiter 
29*e5854a58SPeter Oberparleiter 
30e6b6e10aSPeter Oberparleiter struct channel_path {
31e6b6e10aSPeter Oberparleiter 	struct chp_id chpid;
32e6b6e10aSPeter Oberparleiter 	int state;
33e6b6e10aSPeter Oberparleiter 	struct channel_path_desc desc;
34e6b6e10aSPeter Oberparleiter 	/* Channel-measurement related stuff: */
35e6b6e10aSPeter Oberparleiter 	int cmg;
36e6b6e10aSPeter Oberparleiter 	int shared;
37e6b6e10aSPeter Oberparleiter 	void *cmg_chars;
38e6b6e10aSPeter Oberparleiter 	struct device dev;
39e6b6e10aSPeter Oberparleiter };
40e6b6e10aSPeter Oberparleiter 
41e6b6e10aSPeter Oberparleiter int chp_get_status(struct chp_id chpid);
42e6b6e10aSPeter Oberparleiter u8 chp_get_sch_opm(struct subchannel *sch);
43e6b6e10aSPeter Oberparleiter int chp_is_registered(struct chp_id chpid);
44e6b6e10aSPeter Oberparleiter void *chp_get_chp_desc(struct chp_id chpid);
45e6b6e10aSPeter Oberparleiter int chp_process_crw(int id, int available);
46e6b6e10aSPeter Oberparleiter void chp_remove_cmg_attr(struct channel_path *chp);
47e6b6e10aSPeter Oberparleiter int chp_add_cmg_attr(struct channel_path *chp);
48e6b6e10aSPeter Oberparleiter int chp_new(struct chp_id chpid);
49*e5854a58SPeter Oberparleiter void chp_cfg_schedule(struct chp_id chpid, int configure);
50*e5854a58SPeter Oberparleiter void chp_cfg_cancel_deconfigure(struct chp_id chpid);
51*e5854a58SPeter Oberparleiter int chp_info_get_status(struct chp_id chpid);
52e6b6e10aSPeter Oberparleiter 
53e6b6e10aSPeter Oberparleiter #endif /* S390_CHP_H */
54