xref: /linux/drivers/s390/cio/chp.h (revision c38a90a34cfc880eb2f7234c511cdb7d8bdebc45)
1e6b6e10aSPeter Oberparleiter /*
2e6b6e10aSPeter Oberparleiter  *  drivers/s390/cio/chp.h
3e6b6e10aSPeter Oberparleiter  *
4b730f3a9SSebastian Ott  *    Copyright IBM Corp. 2007,2010
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>
13b730f3a9SSebastian Ott #include <linux/mutex.h>
14e5854a58SPeter Oberparleiter #include <asm/chpid.h>
15e6b6e10aSPeter Oberparleiter #include "chsc.h"
160ae7a7b2SCornelia Huck #include "css.h"
17e6b6e10aSPeter Oberparleiter 
18e5854a58SPeter Oberparleiter #define CHP_STATUS_STANDBY		0
19e5854a58SPeter Oberparleiter #define CHP_STATUS_CONFIGURED		1
20e5854a58SPeter Oberparleiter #define CHP_STATUS_RESERVED		2
21e5854a58SPeter Oberparleiter #define CHP_STATUS_NOT_RECOGNIZED	3
22e5854a58SPeter Oberparleiter 
23c820de39SCornelia Huck #define CHP_ONLINE 0
24c820de39SCornelia Huck #define CHP_OFFLINE 1
25c820de39SCornelia Huck #define CHP_VARY_ON 2
26c820de39SCornelia Huck #define CHP_VARY_OFF 3
27c820de39SCornelia Huck 
2899611f87SCornelia Huck struct chp_link {
29c820de39SCornelia Huck 	struct chp_id chpid;
30c820de39SCornelia Huck 	u32 fla_mask;
31c820de39SCornelia Huck 	u16 fla;
32c820de39SCornelia Huck };
33c820de39SCornelia Huck 
34e5854a58SPeter Oberparleiter static inline int chp_test_bit(u8 *bitmap, int num)
35e5854a58SPeter Oberparleiter {
36e5854a58SPeter Oberparleiter 	int byte = num >> 3;
37e5854a58SPeter Oberparleiter 	int mask = 128 >> (num & 7);
38e5854a58SPeter Oberparleiter 
39e5854a58SPeter Oberparleiter 	return (bitmap[byte] & mask) ? 1 : 0;
40e5854a58SPeter Oberparleiter }
41e5854a58SPeter Oberparleiter 
42e5854a58SPeter Oberparleiter 
43e6b6e10aSPeter Oberparleiter struct channel_path {
44b730f3a9SSebastian Ott 	struct device dev;
45e6b6e10aSPeter Oberparleiter 	struct chp_id chpid;
46b730f3a9SSebastian Ott 	struct mutex lock; /* Serialize access to below members. */
47e6b6e10aSPeter Oberparleiter 	int state;
48e6b6e10aSPeter Oberparleiter 	struct channel_path_desc desc;
49e6b6e10aSPeter Oberparleiter 	/* Channel-measurement related stuff: */
50e6b6e10aSPeter Oberparleiter 	int cmg;
51e6b6e10aSPeter Oberparleiter 	int shared;
52e6b6e10aSPeter Oberparleiter 	void *cmg_chars;
53e6b6e10aSPeter Oberparleiter };
54e6b6e10aSPeter Oberparleiter 
55*c38a90a3SSebastian Ott /* Return channel_path struct for given chpid. */
56*c38a90a3SSebastian Ott static inline struct channel_path *chpid_to_chp(struct chp_id chpid)
57*c38a90a3SSebastian Ott {
58*c38a90a3SSebastian Ott 	return channel_subsystems[chpid.cssid]->chps[chpid.id];
59*c38a90a3SSebastian Ott }
60*c38a90a3SSebastian Ott 
61e6b6e10aSPeter Oberparleiter int chp_get_status(struct chp_id chpid);
62e6b6e10aSPeter Oberparleiter u8 chp_get_sch_opm(struct subchannel *sch);
63e6b6e10aSPeter Oberparleiter int chp_is_registered(struct chp_id chpid);
64e6b6e10aSPeter Oberparleiter void *chp_get_chp_desc(struct chp_id chpid);
65e6b6e10aSPeter Oberparleiter void chp_remove_cmg_attr(struct channel_path *chp);
66e6b6e10aSPeter Oberparleiter int chp_add_cmg_attr(struct channel_path *chp);
67e6b6e10aSPeter Oberparleiter int chp_new(struct chp_id chpid);
68e5854a58SPeter Oberparleiter void chp_cfg_schedule(struct chp_id chpid, int configure);
69e5854a58SPeter Oberparleiter void chp_cfg_cancel_deconfigure(struct chp_id chpid);
70e5854a58SPeter Oberparleiter int chp_info_get_status(struct chp_id chpid);
7199611f87SCornelia Huck int chp_ssd_get_mask(struct chsc_ssd_info *, struct chp_link *);
72e6b6e10aSPeter Oberparleiter #endif /* S390_CHP_H */
73