xref: /linux/drivers/s390/cio/chp.h (revision 0ae7a7b250bdf7ee87c8346164ef3c47fb79dfbd)
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>
13e5854a58SPeter Oberparleiter #include <asm/chpid.h>
14e6b6e10aSPeter Oberparleiter #include "chsc.h"
15*0ae7a7b2SCornelia Huck #include "css.h"
16e6b6e10aSPeter Oberparleiter 
17e5854a58SPeter Oberparleiter #define CHP_STATUS_STANDBY		0
18e5854a58SPeter Oberparleiter #define CHP_STATUS_CONFIGURED		1
19e5854a58SPeter Oberparleiter #define CHP_STATUS_RESERVED		2
20e5854a58SPeter Oberparleiter #define CHP_STATUS_NOT_RECOGNIZED	3
21e5854a58SPeter Oberparleiter 
22e5854a58SPeter Oberparleiter static inline int chp_test_bit(u8 *bitmap, int num)
23e5854a58SPeter Oberparleiter {
24e5854a58SPeter Oberparleiter 	int byte = num >> 3;
25e5854a58SPeter Oberparleiter 	int mask = 128 >> (num & 7);
26e5854a58SPeter Oberparleiter 
27e5854a58SPeter Oberparleiter 	return (bitmap[byte] & mask) ? 1 : 0;
28e5854a58SPeter Oberparleiter }
29e5854a58SPeter Oberparleiter 
30e5854a58SPeter Oberparleiter 
31e6b6e10aSPeter Oberparleiter struct channel_path {
32e6b6e10aSPeter Oberparleiter 	struct chp_id chpid;
33e6b6e10aSPeter Oberparleiter 	int state;
34e6b6e10aSPeter Oberparleiter 	struct channel_path_desc desc;
35e6b6e10aSPeter Oberparleiter 	/* Channel-measurement related stuff: */
36e6b6e10aSPeter Oberparleiter 	int cmg;
37e6b6e10aSPeter Oberparleiter 	int shared;
38e6b6e10aSPeter Oberparleiter 	void *cmg_chars;
39e6b6e10aSPeter Oberparleiter 	struct device dev;
40e6b6e10aSPeter Oberparleiter };
41e6b6e10aSPeter Oberparleiter 
42e6b6e10aSPeter Oberparleiter int chp_get_status(struct chp_id chpid);
43e6b6e10aSPeter Oberparleiter u8 chp_get_sch_opm(struct subchannel *sch);
44e6b6e10aSPeter Oberparleiter int chp_is_registered(struct chp_id chpid);
45e6b6e10aSPeter Oberparleiter void *chp_get_chp_desc(struct chp_id chpid);
4683b3370cSPeter Oberparleiter void chp_process_crw(int id, int available);
47e6b6e10aSPeter Oberparleiter void chp_remove_cmg_attr(struct channel_path *chp);
48e6b6e10aSPeter Oberparleiter int chp_add_cmg_attr(struct channel_path *chp);
49e6b6e10aSPeter Oberparleiter int chp_new(struct chp_id chpid);
50e5854a58SPeter Oberparleiter void chp_cfg_schedule(struct chp_id chpid, int configure);
51e5854a58SPeter Oberparleiter void chp_cfg_cancel_deconfigure(struct chp_id chpid);
52e5854a58SPeter Oberparleiter int chp_info_get_status(struct chp_id chpid);
53e6b6e10aSPeter Oberparleiter 
54e6b6e10aSPeter Oberparleiter #endif /* S390_CHP_H */
55