Blame view

kernel/linux-imx6_3.14.28/include/linux/ioc3.h 3.14 KB
6b13f685e   김민수   BSP 최초 추가
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
  /*
   * This file is subject to the terms and conditions of the GNU General Public
   * License.  See the file "COPYING" in the main directory of this archive
   * for more details.
   *
   * Copyright (c) 2005 Stanislaw Skowronek <skylark@linux-mips.org>
   */
  
  #ifndef _LINUX_IOC3_H
  #define _LINUX_IOC3_H
  
  #include <asm/sn/ioc3.h>
  
  #define IOC3_MAX_SUBMODULES	32
  
  #define IOC3_CLASS_NONE		0
  #define IOC3_CLASS_BASE_IP27	1
  #define IOC3_CLASS_BASE_IP30	2
  #define IOC3_CLASS_MENET_123	3
  #define IOC3_CLASS_MENET_4	4
  #define IOC3_CLASS_CADDUO	5
  #define IOC3_CLASS_SERIAL	6
  
  /* One of these per IOC3 */
  struct ioc3_driver_data {
  	struct list_head list;
  	int id;				/* IOC3 sequence number */
  	/* PCI mapping */
  	unsigned long pma;		/* physical address */
  	struct ioc3 __iomem *vma;	/* pointer to registers */
  	struct pci_dev *pdev;		/* PCI device */
  	/* IRQ stuff */
  	int dual_irq;			/* set if separate IRQs are used */
  	int irq_io, irq_eth;		/* IRQ numbers */
  	/* GPIO magic */
  	spinlock_t gpio_lock;
  	unsigned int gpdr_shadow;
  	/* NIC identifiers */
  	char nic_part[32];
  	char nic_serial[16];
  	char nic_mac[6];
  	/* submodule set */
  	int class;
  	void *data[IOC3_MAX_SUBMODULES];	/* for submodule use */
  	int active[IOC3_MAX_SUBMODULES];	/* set if probe succeeds */
  	/* is_ir_lock must be held while
  	 * modifying sio_ie values, so
  	 * we can be sure that sio_ie is
  	 * not changing when we read it
  	 * along with sio_ir.
  	 */
  	spinlock_t ir_lock;	/* SIO_IE[SC] mod lock */
  };
  
  /* One per submodule */
  struct ioc3_submodule {
  	char *name;		/* descriptive submodule name */
  	struct module *owner;	/* owning kernel module */
  	int ethernet;		/* set for ethernet drivers */
  	int (*probe) (struct ioc3_submodule *, struct ioc3_driver_data *);
  	int (*remove) (struct ioc3_submodule *, struct ioc3_driver_data *);
  	int id;			/* assigned by IOC3, index for the "data" array */
  	/* IRQ stuff */
  	unsigned int irq_mask;	/* IOC3 IRQ mask, leave clear for Ethernet */
  	int reset_mask;		/* non-zero if you want the ioc3.c module to reset interrupts */
  	int (*intr) (struct ioc3_submodule *, struct ioc3_driver_data *, unsigned int);
  	/* private submodule data */
  	void *data;		/* assigned by submodule */
  };
  
  /**********************************
   * Functions needed by submodules *
   **********************************/
  
  #define IOC3_W_IES		0
  #define IOC3_W_IEC		1
  
  /* registers a submodule for all existing and future IOC3 chips */
  extern int ioc3_register_submodule(struct ioc3_submodule *);
  /* unregisters a submodule */
  extern void ioc3_unregister_submodule(struct ioc3_submodule *);
  /* enables IRQs indicated by irq_mask for a specified IOC3 chip */
  extern void ioc3_enable(struct ioc3_submodule *, struct ioc3_driver_data *, unsigned int);
  /* ackowledges specified IRQs */
  extern void ioc3_ack(struct ioc3_submodule *, struct ioc3_driver_data *, unsigned int);
  /* disables IRQs indicated by irq_mask for a specified IOC3 chip */
  extern void ioc3_disable(struct ioc3_submodule *, struct ioc3_driver_data *, unsigned int);
  /* atomically sets GPCR bits */
  extern void ioc3_gpcr_set(struct ioc3_driver_data *, unsigned int);
  /* general ireg writer */
  extern void ioc3_write_ireg(struct ioc3_driver_data *idd, uint32_t value, int reg);
  
  #endif