diff options
271 files changed, 9417 insertions, 8196 deletions
diff --git a/Documentation/kernel-parameters.txt b/Documentation/kernel-parameters.txt index e279b7242912..78926aa2531c 100644 --- a/Documentation/kernel-parameters.txt +++ b/Documentation/kernel-parameters.txt | |||
@@ -2680,6 +2680,27 @@ bytes respectively. Such letter suffixes can also be entirely omitted. | |||
2680 | vmpoff= [KNL,S390] Perform z/VM CP command after power off. | 2680 | vmpoff= [KNL,S390] Perform z/VM CP command after power off. |
2681 | Format: <command> | 2681 | Format: <command> |
2682 | 2682 | ||
2683 | vsyscall= [X86-64] | ||
2684 | Controls the behavior of vsyscalls (i.e. calls to | ||
2685 | fixed addresses of 0xffffffffff600x00 from legacy | ||
2686 | code). Most statically-linked binaries and older | ||
2687 | versions of glibc use these calls. Because these | ||
2688 | functions are at fixed addresses, they make nice | ||
2689 | targets for exploits that can control RIP. | ||
2690 | |||
2691 | emulate [default] Vsyscalls turn into traps and are | ||
2692 | emulated reasonably safely. | ||
2693 | |||
2694 | native Vsyscalls are native syscall instructions. | ||
2695 | This is a little bit faster than trapping | ||
2696 | and makes a few dynamic recompilers work | ||
2697 | better than they would in emulation mode. | ||
2698 | It also makes exploits much easier to write. | ||
2699 | |||
2700 | none Vsyscalls don't work at all. This makes | ||
2701 | them quite hard to use for exploits but | ||
2702 | might break your system. | ||
2703 | |||
2683 | vt.cur_default= [VT] Default cursor shape. | 2704 | vt.cur_default= [VT] Default cursor shape. |
2684 | Format: 0xCCBBAA, where AA, BB, and CC are the same as | 2705 | Format: 0xCCBBAA, where AA, BB, and CC are the same as |
2685 | the parameters of the <Esc>[?A;B;Cc escape sequence; | 2706 | the parameters of the <Esc>[?A;B;Cc escape sequence; |
diff --git a/Documentation/networking/00-INDEX b/Documentation/networking/00-INDEX index 4edd78dfb362..bbce1215434a 100644 --- a/Documentation/networking/00-INDEX +++ b/Documentation/networking/00-INDEX | |||
@@ -1,13 +1,21 @@ | |||
1 | 00-INDEX | 1 | 00-INDEX |
2 | - this file | 2 | - this file |
3 | 3c359.txt | ||
4 | - information on the 3Com TokenLink Velocity XL (3c5359) driver. | ||
3 | 3c505.txt | 5 | 3c505.txt |
4 | - information on the 3Com EtherLink Plus (3c505) driver. | 6 | - information on the 3Com EtherLink Plus (3c505) driver. |
7 | 3c509.txt | ||
8 | - information on the 3Com Etherlink III Series Ethernet cards. | ||
5 | 6pack.txt | 9 | 6pack.txt |
6 | - info on the 6pack protocol, an alternative to KISS for AX.25 | 10 | - info on the 6pack protocol, an alternative to KISS for AX.25 |
7 | DLINK.txt | 11 | DLINK.txt |
8 | - info on the D-Link DE-600/DE-620 parallel port pocket adapters | 12 | - info on the D-Link DE-600/DE-620 parallel port pocket adapters |
9 | PLIP.txt | 13 | PLIP.txt |
10 | - PLIP: The Parallel Line Internet Protocol device driver | 14 | - PLIP: The Parallel Line Internet Protocol device driver |
15 | README.ipw2100 | ||
16 | - README for the Intel PRO/Wireless 2100 driver. | ||
17 | README.ipw2200 | ||
18 | - README for the Intel PRO/Wireless 2915ABG and 2200BG driver. | ||
11 | README.sb1000 | 19 | README.sb1000 |
12 | - info on General Instrument/NextLevel SURFboard1000 cable modem. | 20 | - info on General Instrument/NextLevel SURFboard1000 cable modem. |
13 | alias.txt | 21 | alias.txt |
@@ -20,8 +28,12 @@ atm.txt | |||
20 | - info on where to get ATM programs and support for Linux. | 28 | - info on where to get ATM programs and support for Linux. |
21 | ax25.txt | 29 | ax25.txt |
22 | - info on using AX.25 and NET/ROM code for Linux | 30 | - info on using AX.25 and NET/ROM code for Linux |
31 | batman-adv.txt | ||
32 | - B.A.T.M.A.N routing protocol on top of layer 2 Ethernet Frames. | ||
23 | baycom.txt | 33 | baycom.txt |
24 | - info on the driver for Baycom style amateur radio modems | 34 | - info on the driver for Baycom style amateur radio modems |
35 | bonding.txt | ||
36 | - Linux Ethernet Bonding Driver HOWTO: link aggregation in Linux. | ||
25 | bridge.txt | 37 | bridge.txt |
26 | - where to get user space programs for ethernet bridging with Linux. | 38 | - where to get user space programs for ethernet bridging with Linux. |
27 | can.txt | 39 | can.txt |
@@ -34,32 +46,60 @@ cxacru.txt | |||
34 | - Conexant AccessRunner USB ADSL Modem | 46 | - Conexant AccessRunner USB ADSL Modem |
35 | cxacru-cf.py | 47 | cxacru-cf.py |
36 | - Conexant AccessRunner USB ADSL Modem configuration file parser | 48 | - Conexant AccessRunner USB ADSL Modem configuration file parser |
49 | cxgb.txt | ||
50 | - Release Notes for the Chelsio N210 Linux device driver. | ||
51 | dccp.txt | ||
52 | - the Datagram Congestion Control Protocol (DCCP) (RFC 4340..42). | ||
37 | de4x5.txt | 53 | de4x5.txt |
38 | - the Digital EtherWORKS DE4?? and DE5?? PCI Ethernet driver | 54 | - the Digital EtherWORKS DE4?? and DE5?? PCI Ethernet driver |
39 | decnet.txt | 55 | decnet.txt |
40 | - info on using the DECnet networking layer in Linux. | 56 | - info on using the DECnet networking layer in Linux. |
41 | depca.txt | 57 | depca.txt |
42 | - the Digital DEPCA/EtherWORKS DE1?? and DE2?? LANCE Ethernet driver | 58 | - the Digital DEPCA/EtherWORKS DE1?? and DE2?? LANCE Ethernet driver |
59 | dl2k.txt | ||
60 | - README for D-Link DL2000-based Gigabit Ethernet Adapters (dl2k.ko). | ||
61 | dm9000.txt | ||
62 | - README for the Simtec DM9000 Network driver. | ||
43 | dmfe.txt | 63 | dmfe.txt |
44 | - info on the Davicom DM9102(A)/DM9132/DM9801 fast ethernet driver. | 64 | - info on the Davicom DM9102(A)/DM9132/DM9801 fast ethernet driver. |
65 | dns_resolver.txt | ||
66 | - The DNS resolver module allows kernel servies to make DNS queries. | ||
67 | driver.txt | ||
68 | - Softnet driver issues. | ||
45 | e100.txt | 69 | e100.txt |
46 | - info on Intel's EtherExpress PRO/100 line of 10/100 boards | 70 | - info on Intel's EtherExpress PRO/100 line of 10/100 boards |
47 | e1000.txt | 71 | e1000.txt |
48 | - info on Intel's E1000 line of gigabit ethernet boards | 72 | - info on Intel's E1000 line of gigabit ethernet boards |
73 | e1000e.txt | ||
74 | - README for the Intel Gigabit Ethernet Driver (e1000e). | ||
49 | eql.txt | 75 | eql.txt |
50 | - serial IP load balancing | 76 | - serial IP load balancing |
51 | ewrk3.txt | 77 | ewrk3.txt |
52 | - the Digital EtherWORKS 3 DE203/4/5 Ethernet driver | 78 | - the Digital EtherWORKS 3 DE203/4/5 Ethernet driver |
79 | fib_trie.txt | ||
80 | - Level Compressed Trie (LC-trie) notes: a structure for routing. | ||
53 | filter.txt | 81 | filter.txt |
54 | - Linux Socket Filtering | 82 | - Linux Socket Filtering |
55 | fore200e.txt | 83 | fore200e.txt |
56 | - FORE Systems PCA-200E/SBA-200E ATM NIC driver info. | 84 | - FORE Systems PCA-200E/SBA-200E ATM NIC driver info. |
57 | framerelay.txt | 85 | framerelay.txt |
58 | - info on using Frame Relay/Data Link Connection Identifier (DLCI). | 86 | - info on using Frame Relay/Data Link Connection Identifier (DLCI). |
87 | gen_stats.txt | ||
88 | - Generic networking statistics for netlink users. | ||
89 | generic_hdlc.txt | ||
90 | - The generic High Level Data Link Control (HDLC) layer. | ||
59 | generic_netlink.txt | 91 | generic_netlink.txt |
60 | - info on Generic Netlink | 92 | - info on Generic Netlink |
93 | gianfar.txt | ||
94 | - Gianfar Ethernet Driver. | ||
61 | ieee802154.txt | 95 | ieee802154.txt |
62 | - Linux IEEE 802.15.4 implementation, API and drivers | 96 | - Linux IEEE 802.15.4 implementation, API and drivers |
97 | ifenslave.c | ||
98 | - Configure network interfaces for parallel routing (bonding). | ||
99 | igb.txt | ||
100 | - README for the Intel Gigabit Ethernet Driver (igb). | ||
101 | igbvf.txt | ||
102 | - README for the Intel Gigabit Ethernet Driver (igbvf). | ||
63 | ip-sysctl.txt | 103 | ip-sysctl.txt |
64 | - /proc/sys/net/ipv4/* variables | 104 | - /proc/sys/net/ipv4/* variables |
65 | ip_dynaddr.txt | 105 | ip_dynaddr.txt |
@@ -68,41 +108,117 @@ ipddp.txt | |||
68 | - AppleTalk-IP Decapsulation and AppleTalk-IP Encapsulation | 108 | - AppleTalk-IP Decapsulation and AppleTalk-IP Encapsulation |
69 | iphase.txt | 109 | iphase.txt |
70 | - Interphase PCI ATM (i)Chip IA Linux driver info. | 110 | - Interphase PCI ATM (i)Chip IA Linux driver info. |
111 | ipv6.txt | ||
112 | - Options to the ipv6 kernel module. | ||
113 | ipvs-sysctl.txt | ||
114 | - Per-inode explanation of the /proc/sys/net/ipv4/vs interface. | ||
71 | irda.txt | 115 | irda.txt |
72 | - where to get IrDA (infrared) utilities and info for Linux. | 116 | - where to get IrDA (infrared) utilities and info for Linux. |
117 | ixgb.txt | ||
118 | - README for the Intel 10 Gigabit Ethernet Driver (ixgb). | ||
119 | ixgbe.txt | ||
120 | - README for the Intel 10 Gigabit Ethernet Driver (ixgbe). | ||
121 | ixgbevf.txt | ||
122 | - README for the Intel Virtual Function (VF) Driver (ixgbevf). | ||
123 | l2tp.txt | ||
124 | - User guide to the L2TP tunnel protocol. | ||
73 | lapb-module.txt | 125 | lapb-module.txt |
74 | - programming information of the LAPB module. | 126 | - programming information of the LAPB module. |
75 | ltpc.txt | 127 | ltpc.txt |
76 | - the Apple or Farallon LocalTalk PC card driver | 128 | - the Apple or Farallon LocalTalk PC card driver |
129 | mac80211-injection.txt | ||
130 | - HOWTO use packet injection with mac80211 | ||
77 | multicast.txt | 131 | multicast.txt |
78 | - Behaviour of cards under Multicast | 132 | - Behaviour of cards under Multicast |
133 | multiqueue.txt | ||
134 | - HOWTO for multiqueue network device support. | ||
135 | netconsole.txt | ||
136 | - The network console module netconsole.ko: configuration and notes. | ||
137 | netdev-features.txt | ||
138 | - Network interface features API description. | ||
79 | netdevices.txt | 139 | netdevices.txt |
80 | - info on network device driver functions exported to the kernel. | 140 | - info on network device driver functions exported to the kernel. |
141 | netif-msg.txt | ||
142 | - Design of the network interface message level setting (NETIF_MSG_*). | ||
143 | nfc.txt | ||
144 | - The Linux Near Field Communication (NFS) subsystem. | ||
81 | olympic.txt | 145 | olympic.txt |
82 | - IBM PCI Pit/Pit-Phy/Olympic Token Ring driver info. | 146 | - IBM PCI Pit/Pit-Phy/Olympic Token Ring driver info. |
147 | operstates.txt | ||
148 | - Overview of network interface operational states. | ||
149 | packet_mmap.txt | ||
150 | - User guide to memory mapped packet socket rings (PACKET_[RT]X_RING). | ||
151 | phonet.txt | ||
152 | - The Phonet packet protocol used in Nokia cellular modems. | ||
153 | phy.txt | ||
154 | - The PHY abstraction layer. | ||
155 | pktgen.txt | ||
156 | - User guide to the kernel packet generator (pktgen.ko). | ||
83 | policy-routing.txt | 157 | policy-routing.txt |
84 | - IP policy-based routing | 158 | - IP policy-based routing |
159 | ppp_generic.txt | ||
160 | - Information about the generic PPP driver. | ||
161 | proc_net_tcp.txt | ||
162 | - Per inode overview of the /proc/net/tcp and /proc/net/tcp6 interfaces. | ||
163 | radiotap-headers.txt | ||
164 | - Background on radiotap headers. | ||
85 | ray_cs.txt | 165 | ray_cs.txt |
86 | - Raylink Wireless LAN card driver info. | 166 | - Raylink Wireless LAN card driver info. |
167 | rds.txt | ||
168 | - Background on the reliable, ordered datagram delivery method RDS. | ||
169 | regulatory.txt | ||
170 | - Overview of the Linux wireless regulatory infrastructure. | ||
171 | rxrpc.txt | ||
172 | - Guide to the RxRPC protocol. | ||
173 | s2io.txt | ||
174 | - Release notes for Neterion Xframe I/II 10GbE driver. | ||
175 | scaling.txt | ||
176 | - Explanation of network scaling techniques: RSS, RPS, RFS, aRFS, XPS. | ||
177 | sctp.txt | ||
178 | - Notes on the Linux kernel implementation of the SCTP protocol. | ||
179 | secid.txt | ||
180 | - Explanation of the secid member in flow structures. | ||
87 | skfp.txt | 181 | skfp.txt |
88 | - SysKonnect FDDI (SK-5xxx, Compaq Netelligent) driver info. | 182 | - SysKonnect FDDI (SK-5xxx, Compaq Netelligent) driver info. |
89 | smc9.txt | 183 | smc9.txt |
90 | - the driver for SMC's 9000 series of Ethernet cards | 184 | - the driver for SMC's 9000 series of Ethernet cards |
91 | smctr.txt | 185 | smctr.txt |
92 | - SMC TokenCard TokenRing Linux driver info. | 186 | - SMC TokenCard TokenRing Linux driver info. |
187 | spider-net.txt | ||
188 | - README for the Spidernet Driver (as found in PS3 / Cell BE). | ||
189 | stmmac.txt | ||
190 | - README for the STMicro Synopsys Ethernet driver. | ||
191 | tc-actions-env-rules.txt | ||
192 | - rules for traffic control (tc) actions. | ||
193 | timestamping.txt | ||
194 | - overview of network packet timestamping variants. | ||
93 | tcp.txt | 195 | tcp.txt |
94 | - short blurb on how TCP output takes place. | 196 | - short blurb on how TCP output takes place. |
197 | tcp-thin.txt | ||
198 | - kernel tuning options for low rate 'thin' TCP streams. | ||
95 | tlan.txt | 199 | tlan.txt |
96 | - ThunderLAN (Compaq Netelligent 10/100, Olicom OC-2xxx) driver info. | 200 | - ThunderLAN (Compaq Netelligent 10/100, Olicom OC-2xxx) driver info. |
97 | tms380tr.txt | 201 | tms380tr.txt |
98 | - SysKonnect Token Ring ISA/PCI adapter driver info. | 202 | - SysKonnect Token Ring ISA/PCI adapter driver info. |
203 | tproxy.txt | ||
204 | - Transparent proxy support user guide. | ||
99 | tuntap.txt | 205 | tuntap.txt |
100 | - TUN/TAP device driver, allowing user space Rx/Tx of packets. | 206 | - TUN/TAP device driver, allowing user space Rx/Tx of packets. |
207 | udplite.txt | ||
208 | - UDP-Lite protocol (RFC 3828) introduction. | ||
101 | vortex.txt | 209 | vortex.txt |
102 | - info on using 3Com Vortex (3c590, 3c592, 3c595, 3c597) Ethernet cards. | 210 | - info on using 3Com Vortex (3c590, 3c592, 3c595, 3c597) Ethernet cards. |
211 | vxge.txt | ||
212 | - README for the Neterion X3100 PCIe Server Adapter. | ||
103 | x25.txt | 213 | x25.txt |
104 | - general info on X.25 development. | 214 | - general info on X.25 development. |
105 | x25-iface.txt | 215 | x25-iface.txt |
106 | - description of the X.25 Packet Layer to LAPB device interface. | 216 | - description of the X.25 Packet Layer to LAPB device interface. |
217 | xfrm_proc.txt | ||
218 | - description of the statistics package for XFRM. | ||
219 | xfrm_sync.txt | ||
220 | - sync patches for XFRM enable migration of an SA between hosts. | ||
221 | xfrm_sysctl.txt | ||
222 | - description of the XFRM configuration options. | ||
107 | z8530drv.txt | 223 | z8530drv.txt |
108 | - info about Linux driver for Z8530 based HDLC cards for AX.25 | 224 | - info about Linux driver for Z8530 based HDLC cards for AX.25 |
diff --git a/Documentation/networking/scaling.txt b/Documentation/networking/scaling.txt new file mode 100644 index 000000000000..58fd7414e6c0 --- /dev/null +++ b/Documentation/networking/scaling.txt | |||
@@ -0,0 +1,378 @@ | |||
1 | Scaling in the Linux Networking Stack | ||
2 | |||
3 | |||
4 | Introduction | ||
5 | ============ | ||
6 | |||
7 | This document describes a set of complementary techniques in the Linux | ||
8 | networking stack to increase parallelism and improve performance for | ||
9 | multi-processor systems. | ||
10 | |||
11 | The following technologies are described: | ||
12 | |||
13 | RSS: Receive Side Scaling | ||
14 | RPS: Receive Packet Steering | ||
15 | RFS: Receive Flow Steering | ||
16 | Accelerated Receive Flow Steering | ||
17 | XPS: Transmit Packet Steering | ||
18 | |||
19 | |||
20 | RSS: Receive Side Scaling | ||
21 | ========================= | ||
22 | |||
23 | Contemporary NICs support multiple receive and transmit descriptor queues | ||
24 | (multi-queue). On reception, a NIC can send different packets to different | ||
25 | queues to distribute processing among CPUs. The NIC distributes packets by | ||
26 | applying a filter to each packet that assigns it to one of a small number | ||
27 | of logical flows. Packets for each flow are steered to a separate receive | ||
28 | queue, which in turn can be processed by separate CPUs. This mechanism is | ||
29 | generally known as “Receive-side Scaling” (RSS). The goal of RSS and | ||
30 | the other scaling techniques to increase performance uniformly. | ||
31 | Multi-queue distribution can also be used for traffic prioritization, but | ||
32 | that is not the focus of these techniques. | ||
33 | |||
34 | The filter used in RSS is typically a hash function over the network | ||
35 | and/or transport layer headers-- for example, a 4-tuple hash over | ||
36 | IP addresses and TCP ports of a packet. The most common hardware | ||
37 | implementation of RSS uses a 128-entry indirection table where each entry | ||
38 | stores a queue number. The receive queue for a packet is determined | ||
39 | by masking out the low order seven bits of the computed hash for the | ||
40 | packet (usually a Toeplitz hash), taking this number as a key into the | ||
41 | indirection table and reading the corresponding value. | ||
42 | |||
43 | Some advanced NICs allow steering packets to queues based on | ||
44 | programmable filters. For example, webserver bound TCP port 80 packets | ||
45 | can be directed to their own receive queue. Such “n-tuple” filters can | ||
46 | be configured from ethtool (--config-ntuple). | ||
47 | |||
48 | ==== RSS Configuration | ||
49 | |||
50 | The driver for a multi-queue capable NIC typically provides a kernel | ||
51 | module parameter for specifying the number of hardware queues to | ||
52 | configure. In the bnx2x driver, for instance, this parameter is called | ||
53 | num_queues. A typical RSS configuration would be to have one receive queue | ||
54 | for each CPU if the device supports enough queues, or otherwise at least | ||
55 | one for each memory domain, where a memory domain is a set of CPUs that | ||
56 | share a particular memory level (L1, L2, NUMA node, etc.). | ||
57 | |||
58 | The indirection table of an RSS device, which resolves a queue by masked | ||
59 | hash, is usually programmed by the driver at initialization. The | ||
60 | default mapping is to distribute the queues evenly in the table, but the | ||
61 | indirection table can be retrieved and modified at runtime using ethtool | ||
62 | commands (--show-rxfh-indir and --set-rxfh-indir). Modifying the | ||
63 | indirection table could be done to give different queues different | ||
64 | relative weights. | ||
65 | |||
66 | == RSS IRQ Configuration | ||
67 | |||
68 | Each receive queue has a separate IRQ associated with it. The NIC triggers | ||
69 | this to notify a CPU when new packets arrive on the given queue. The | ||
70 | signaling path for PCIe devices uses message signaled interrupts (MSI-X), | ||
71 | that can route each interrupt to a particular CPU. The active mapping | ||
72 | of queues to IRQs can be determined from /proc/interrupts. By default, | ||
73 | an IRQ may be handled on any CPU. Because a non-negligible part of packet | ||
74 | processing takes place in receive interrupt handling, it is advantageous | ||
75 | to spread receive interrupts between CPUs. To manually adjust the IRQ | ||
76 | affinity of each interrupt see Documentation/IRQ-affinity. Some systems | ||
77 | will be running irqbalance, a daemon that dynamically optimizes IRQ | ||
78 | assignments and as a result may override any manual settings. | ||
79 | |||
80 | == Suggested Configuration | ||
81 | |||
82 | RSS should be enabled when latency is a concern or whenever receive | ||
83 | interrupt processing forms a bottleneck. Spreading load between CPUs | ||
84 | decreases queue length. For low latency networking, the optimal setting | ||
85 | is to allocate as many queues as there are CPUs in the system (or the | ||
86 | NIC maximum, if lower). The most efficient high-rate configuration | ||
87 | is likely the one with the smallest number of receive queues where no | ||
88 | receive queue overflows due to a saturated CPU, because in default | ||
89 | mode with interrupt coalescing enabled, the aggregate number of | ||
90 | interrupts (and thus work) grows with each additional queue. | ||
91 | |||
92 | Per-cpu load can be observed using the mpstat utility, but note that on | ||
93 | processors with hyperthreading (HT), each hyperthread is represented as | ||
94 | a separate CPU. For interrupt handling, HT has shown no benefit in | ||
95 | initial tests, so limit the number of queues to the number of CPU cores | ||
96 | in the system. | ||
97 | |||
98 | |||
99 | RPS: Receive Packet Steering | ||
100 | ============================ | ||
101 | |||
102 | Receive Packet Steering (RPS) is logically a software implementation of | ||
103 | RSS. Being in software, it is necessarily called later in the datapath. | ||
104 | Whereas RSS selects the queue and hence CPU that will run the hardware | ||
105 | interrupt handler, RPS selects the CPU to perform protocol processing | ||
106 | above the interrupt handler. This is accomplished by placing the packet | ||
107 | on the desired CPU’s backlog queue and waking up the CPU for processing. | ||
108 | RPS has some advantages over RSS: 1) it can be used with any NIC, | ||
109 | 2) software filters can easily be added to hash over new protocols, | ||
110 | 3) it does not increase hardware device interrupt rate (although it does | ||
111 | introduce inter-processor interrupts (IPIs)). | ||
112 | |||
113 | RPS is called during bottom half of the receive interrupt handler, when | ||
114 | a driver sends a packet up the network stack with netif_rx() or | ||
115 | netif_receive_skb(). These call the get_rps_cpu() function, which | ||
116 | selects the queue that should process a packet. | ||
117 | |||
118 | The first step in determining the target CPU for RPS is to calculate a | ||
119 | flow hash over the packet’s addresses or ports (2-tuple or 4-tuple hash | ||
120 | depending on the protocol). This serves as a consistent hash of the | ||
121 | associated flow of the packet. The hash is either provided by hardware | ||
122 | or will be computed in the stack. Capable hardware can pass the hash in | ||
123 | the receive descriptor for the packet; this would usually be the same | ||
124 | hash used for RSS (e.g. computed Toeplitz hash). The hash is saved in | ||
125 | skb->rx_hash and can be used elsewhere in the stack as a hash of the | ||
126 | packet’s flow. | ||
127 | |||
128 | Each receive hardware queue has an associated list of CPUs to which | ||
129 | RPS may enqueue packets for processing. For each received packet, | ||
130 | an index into the list is computed from the flow hash modulo the size | ||
131 | of the list. The indexed CPU is the target for processing the packet, | ||
132 | and the packet is queued to the tail of that CPU’s backlog queue. At | ||
133 | the end of the bottom half routine, IPIs are sent to any CPUs for which | ||
134 | packets have been queued to their backlog queue. The IPI wakes backlog | ||
135 | processing on the remote CPU, and any queued packets are then processed | ||
136 | up the networking stack. | ||
137 | |||
138 | ==== RPS Configuration | ||
139 | |||
140 | RPS requires a kernel compiled with the CONFIG_RPS kconfig symbol (on | ||
141 | by default for SMP). Even when compiled in, RPS remains disabled until | ||
142 | explicitly configured. The list of CPUs to which RPS may forward traffic | ||
143 | can be configured for each receive queue using a sysfs file entry: | ||
144 | |||
145 | /sys/class/net/<dev>/queues/rx-<n>/rps_cpus | ||
146 | |||
147 | This file implements a bitmap of CPUs. RPS is disabled when it is zero | ||
148 | (the default), in which case packets are processed on the interrupting | ||
149 | CPU. Documentation/IRQ-affinity.txt explains how CPUs are assigned to | ||
150 | the bitmap. | ||
151 | |||
152 | == Suggested Configuration | ||
153 | |||
154 | For a single queue device, a typical RPS configuration would be to set | ||
155 | the rps_cpus to the CPUs in the same memory domain of the interrupting | ||
156 | CPU. If NUMA locality is not an issue, this could also be all CPUs in | ||
157 | the system. At high interrupt rate, it might be wise to exclude the | ||
158 | interrupting CPU from the map since that already performs much work. | ||
159 | |||
160 | For a multi-queue system, if RSS is configured so that a hardware | ||
161 | receive queue is mapped to each CPU, then RPS is probably redundant | ||
162 | and unnecessary. If there are fewer hardware queues than CPUs, then | ||
163 | RPS might be beneficial if the rps_cpus for each queue are the ones that | ||
164 | share the same memory domain as the interrupting CPU for that queue. | ||
165 | |||
166 | |||
167 | RFS: Receive Flow Steering | ||
168 | ========================== | ||
169 | |||
170 | While RPS steers packets solely based on hash, and thus generally | ||
171 | provides good load distribution, it does not take into account | ||
172 | application locality. This is accomplished by Receive Flow Steering | ||
173 | (RFS). The goal of RFS is to increase datacache hitrate by steering | ||
174 | kernel processing of packets to the CPU where the application thread | ||
175 | consuming the packet is running. RFS relies on the same RPS mechanisms | ||
176 | to enqueue packets onto the backlog of another CPU and to wake up that | ||
177 | CPU. | ||
178 | |||
179 | In RFS, packets are not forwarded directly by the value of their hash, | ||
180 | but the hash is used as index into a flow lookup table. This table maps | ||
181 | flows to the CPUs where those flows are being processed. The flow hash | ||
182 | (see RPS section above) is used to calculate the index into this table. | ||
183 | The CPU recorded in each entry is the one which last processed the flow. | ||
184 | If an entry does not hold a valid CPU, then packets mapped to that entry | ||
185 | are steered using plain RPS. Multiple table entries may point to the | ||
186 | same CPU. Indeed, with many flows and few CPUs, it is very likely that | ||
187 | a single application thread handles flows with many different flow hashes. | ||
188 | |||
189 | rps_sock_table is a global flow table that contains the *desired* CPU for | ||
190 | flows: the CPU that is currently processing the flow in userspace. Each | ||
191 | table value is a CPU index that is updated during calls to recvmsg and | ||
192 | sendmsg (specifically, inet_recvmsg(), inet_sendmsg(), inet_sendpage() | ||
193 | and tcp_splice_read()). | ||
194 | |||
195 | When the scheduler moves a thread to a new CPU while it has outstanding | ||
196 | receive packets on the old CPU, packets may arrive out of order. To | ||
197 | avoid this, RFS uses a second flow table to track outstanding packets | ||
198 | for each flow: rps_dev_flow_table is a table specific to each hardware | ||
199 | receive queue of each device. Each table value stores a CPU index and a | ||
200 | counter. The CPU index represents the *current* CPU onto which packets | ||
201 | for this flow are enqueued for further kernel processing. Ideally, kernel | ||
202 | and userspace processing occur on the same CPU, and hence the CPU index | ||
203 | in both tables is identical. This is likely false if the scheduler has | ||
204 | recently migrated a userspace thread while the kernel still has packets | ||
205 | enqueued for kernel processing on the old CPU. | ||
206 | |||
207 | The counter in rps_dev_flow_table values records the length of the current | ||
208 | CPU's backlog when a packet in this flow was last enqueued. Each backlog | ||
209 | queue has a head counter that is incremented on dequeue. A tail counter | ||
210 | is computed as head counter + queue length. In other words, the counter | ||
211 | in rps_dev_flow_table[i] records the last element in flow i that has | ||
212 | been enqueued onto the currently designated CPU for flow i (of course, | ||
213 | entry i is actually selected by hash and multiple flows may hash to the | ||
214 | same entry i). | ||
215 | |||
216 | And now the trick for avoiding out of order packets: when selecting the | ||
217 | CPU for packet processing (from get_rps_cpu()) the rps_sock_flow table | ||
218 | and the rps_dev_flow table of the queue that the packet was received on | ||
219 | are compared. If the desired CPU for the flow (found in the | ||
220 | rps_sock_flow table) matches the current CPU (found in the rps_dev_flow | ||
221 | table), the packet is enqueued onto that CPU’s backlog. If they differ, | ||
222 | the current CPU is updated to match the desired CPU if one of the | ||
223 | following is true: | ||
224 | |||
225 | - The current CPU's queue head counter >= the recorded tail counter | ||
226 | value in rps_dev_flow[i] | ||
227 | - The current CPU is unset (equal to NR_CPUS) | ||
228 | - The current CPU is offline | ||
229 | |||
230 | After this check, the packet is sent to the (possibly updated) current | ||
231 | CPU. These rules aim to ensure that a flow only moves to a new CPU when | ||
232 | there are no packets outstanding on the old CPU, as the outstanding | ||
233 | packets could arrive later than those about to be processed on the new | ||
234 | CPU. | ||
235 | |||
236 | ==== RFS Configuration | ||
237 | |||
238 | RFS is only available if the kconfig symbol CONFIG_RFS is enabled (on | ||
239 | by default for SMP). The functionality remains disabled until explicitly | ||
240 | configured. The number of entries in the global flow table is set through: | ||
241 | |||
242 | /proc/sys/net/core/rps_sock_flow_entries | ||
243 | |||
244 | The number of entries in the per-queue flow table are set through: | ||
245 | |||
246 | /sys/class/net/<dev>/queues/tx-<n>/rps_flow_cnt | ||
247 | |||
248 | == Suggested Configuration | ||
249 | |||
250 | Both of these need to be set before RFS is enabled for a receive queue. | ||
251 | Values for both are rounded up to the nearest power of two. The | ||
252 | suggested flow count depends on the expected number of active connections | ||
253 | at any given time, which may be significantly less than the number of open | ||
254 | connections. We have found that a value of 32768 for rps_sock_flow_entries | ||
255 | works fairly well on a moderately loaded server. | ||
256 | |||
257 | For a single queue device, the rps_flow_cnt value for the single queue | ||
258 | would normally be configured to the same value as rps_sock_flow_entries. | ||
259 | For a multi-queue device, the rps_flow_cnt for each queue might be | ||
260 | configured as rps_sock_flow_entries / N, where N is the number of | ||
261 | queues. So for instance, if rps_flow_entries is set to 32768 and there | ||
262 | are 16 configured receive queues, rps_flow_cnt for each queue might be | ||
263 | configured as 2048. | ||
264 | |||
265 | |||
266 | Accelerated RFS | ||
267 | =============== | ||
268 | |||
269 | Accelerated RFS is to RFS what RSS is to RPS: a hardware-accelerated load | ||
270 | balancing mechanism that uses soft state to steer flows based on where | ||
271 | the application thread consuming the packets of each flow is running. | ||
272 | Accelerated RFS should perform better than RFS since packets are sent | ||
273 | directly to a CPU local to the thread consuming the data. The target CPU | ||
274 | will either be the same CPU where the application runs, or at least a CPU | ||
275 | which is local to the application thread’s CPU in the cache hierarchy. | ||
276 | |||
277 | To enable accelerated RFS, the networking stack calls the | ||
278 | ndo_rx_flow_steer driver function to communicate the desired hardware | ||
279 | queue for packets matching a particular flow. The network stack | ||
280 | automatically calls this function every time a flow entry in | ||
281 | rps_dev_flow_table is updated. The driver in turn uses a device specific | ||
282 | method to program the NIC to steer the packets. | ||
283 | |||
284 | The hardware queue for a flow is derived from the CPU recorded in | ||
285 | rps_dev_flow_table. The stack consults a CPU to hardware queue map which | ||
286 | is maintained by the NIC driver. This is an auto-generated reverse map of | ||
287 | the IRQ affinity table shown by /proc/interrupts. Drivers can use | ||
288 | functions in the cpu_rmap (“CPU affinity reverse map”) kernel library | ||
289 | to populate the map. For each CPU, the corresponding queue in the map is | ||
290 | set to be one whose processing CPU is closest in cache locality. | ||
291 | |||
292 | ==== Accelerated RFS Configuration | ||
293 | |||
294 | Accelerated RFS is only available if the kernel is compiled with | ||
295 | CONFIG_RFS_ACCEL and support is provided by the NIC device and driver. | ||
296 | It also requires that ntuple filtering is enabled via ethtool. The map | ||
297 | of CPU to queues is automatically deduced from the IRQ affinities | ||
298 | configured for each receive queue by the driver, so no additional | ||
299 | configuration should be necessary. | ||
300 | |||
301 | == Suggested Configuration | ||
302 | |||
303 | This technique should be enabled whenever one wants to use RFS and the | ||
304 | NIC supports hardware acceleration. | ||
305 | |||
306 | XPS: Transmit Packet Steering | ||
307 | ============================= | ||
308 | |||
309 | Transmit Packet Steering is a mechanism for intelligently selecting | ||
310 | which transmit queue to use when transmitting a packet on a multi-queue | ||
311 | device. To accomplish this, a mapping from CPU to hardware queue(s) is | ||
312 | recorded. The goal of this mapping is usually to assign queues | ||
313 | exclusively to a subset of CPUs, where the transmit completions for | ||
314 | these queues are processed on a CPU within this set. This choice | ||
315 | provides two benefits. First, contention on the device queue lock is | ||
316 | significantly reduced since fewer CPUs contend for the same queue | ||
317 | (contention can be eliminated completely if each CPU has its own | ||
318 | transmit queue). Secondly, cache miss rate on transmit completion is | ||
319 | reduced, in particular for data cache lines that hold the sk_buff | ||
320 | structures. | ||
321 | |||
322 | XPS is configured per transmit queue by setting a bitmap of CPUs that | ||
323 | may use that queue to transmit. The reverse mapping, from CPUs to | ||
324 | transmit queues, is computed and maintained for each network device. | ||
325 | When transmitting the first packet in a flow, the function | ||
326 | get_xps_queue() is called to select a queue. This function uses the ID | ||
327 | of the running CPU as a key into the CPU-to-queue lookup table. If the | ||
328 | ID matches a single queue, that is used for transmission. If multiple | ||
329 | queues match, one is selected by using the flow hash to compute an index | ||
330 | into the set. | ||
331 | |||
332 | The queue chosen for transmitting a particular flow is saved in the | ||
333 | corresponding socket structure for the flow (e.g. a TCP connection). | ||
334 | This transmit queue is used for subsequent packets sent on the flow to | ||
335 | prevent out of order (ooo) packets. The choice also amortizes the cost | ||
336 | of calling get_xps_queues() over all packets in the flow. To avoid | ||
337 | ooo packets, the queue for a flow can subsequently only be changed if | ||
338 | skb->ooo_okay is set for a packet in the flow. This flag indicates that | ||
339 | there are no outstanding packets in the flow, so the transmit queue can | ||
340 | change without the risk of generating out of order packets. The | ||
341 | transport layer is responsible for setting ooo_okay appropriately. TCP, | ||
342 | for instance, sets the flag when all data for a connection has been | ||
343 | acknowledged. | ||
344 | |||
345 | ==== XPS Configuration | ||
346 | |||
347 | XPS is only available if the kconfig symbol CONFIG_XPS is enabled (on by | ||
348 | default for SMP). The functionality remains disabled until explicitly | ||
349 | configured. To enable XPS, the bitmap of CPUs that may use a transmit | ||
350 | queue is configured using the sysfs file entry: | ||
351 | |||
352 | /sys/class/net/<dev>/queues/tx-<n>/xps_cpus | ||
353 | |||
354 | == Suggested Configuration | ||
355 | |||
356 | For a network device with a single transmission queue, XPS configuration | ||
357 | has no effect, since there is no choice in this case. In a multi-queue | ||
358 | system, XPS is preferably configured so that each CPU maps onto one queue. | ||
359 | If there are as many queues as there are CPUs in the system, then each | ||
360 | queue can also map onto one CPU, resulting in exclusive pairings that | ||
361 | experience no contention. If there are fewer queues than CPUs, then the | ||
362 | best CPUs to share a given queue are probably those that share the cache | ||
363 | with the CPU that processes transmit completions for that queue | ||
364 | (transmit interrupts). | ||
365 | |||
366 | |||
367 | Further Information | ||
368 | =================== | ||
369 | RPS and RFS were introduced in kernel 2.6.35. XPS was incorporated into | ||
370 | 2.6.38. Original patches were submitted by Tom Herbert | ||
371 | (therbert@google.com) | ||
372 | |||
373 | Accelerated RFS was introduced in 2.6.35. Original patches were | ||
374 | submitted by Ben Hutchings (bhutchings@solarflare.com) | ||
375 | |||
376 | Authors: | ||
377 | Tom Herbert (therbert@google.com) | ||
378 | Willem de Bruijn (willemb@google.com) | ||
diff --git a/MAINTAINERS b/MAINTAINERS index ea20bd0aef33..d32e1ca5ba73 100644 --- a/MAINTAINERS +++ b/MAINTAINERS | |||
@@ -3898,9 +3898,9 @@ F: arch/powerpc/platforms/powermac/ | |||
3898 | F: drivers/macintosh/ | 3898 | F: drivers/macintosh/ |
3899 | 3899 | ||
3900 | LINUX FOR POWERPC EMBEDDED MPC5XXX | 3900 | LINUX FOR POWERPC EMBEDDED MPC5XXX |
3901 | M: Grant Likely <grant.likely@secretlab.ca> | 3901 | M: Anatolij Gustschin <agust@denx.de> |
3902 | L: linuxppc-dev@lists.ozlabs.org | 3902 | L: linuxppc-dev@lists.ozlabs.org |
3903 | T: git git://git.secretlab.ca/git/linux-2.6.git | 3903 | T: git git://git.denx.de/linux-2.6-agust.git |
3904 | S: Maintained | 3904 | S: Maintained |
3905 | F: arch/powerpc/platforms/512x/ | 3905 | F: arch/powerpc/platforms/512x/ |
3906 | F: arch/powerpc/platforms/52xx/ | 3906 | F: arch/powerpc/platforms/52xx/ |
@@ -5257,6 +5257,7 @@ S: Supported | |||
5257 | F: drivers/net/ethernet/qlogic/qlcnic/ | 5257 | F: drivers/net/ethernet/qlogic/qlcnic/ |
5258 | 5258 | ||
5259 | QLOGIC QLGE 10Gb ETHERNET DRIVER | 5259 | QLOGIC QLGE 10Gb ETHERNET DRIVER |
5260 | M: Anirban Chakraborty <anirban.chakraborty@qlogic.com> | ||
5260 | M: Jitendra Kalsaria <jitendra.kalsaria@qlogic.com> | 5261 | M: Jitendra Kalsaria <jitendra.kalsaria@qlogic.com> |
5261 | M: Ron Mercer <ron.mercer@qlogic.com> | 5262 | M: Ron Mercer <ron.mercer@qlogic.com> |
5262 | M: linux-driver@qlogic.com | 5263 | M: linux-driver@qlogic.com |
@@ -7350,7 +7351,7 @@ THE REST | |||
7350 | M: Linus Torvalds <torvalds@linux-foundation.org> | 7351 | M: Linus Torvalds <torvalds@linux-foundation.org> |
7351 | L: linux-kernel@vger.kernel.org | 7352 | L: linux-kernel@vger.kernel.org |
7352 | Q: http://patchwork.kernel.org/project/LKML/list/ | 7353 | Q: http://patchwork.kernel.org/project/LKML/list/ |
7353 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git | 7354 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git |
7354 | S: Buried alive in reporters | 7355 | S: Buried alive in reporters |
7355 | F: * | 7356 | F: * |
7356 | F: */ | 7357 | F: */ |
@@ -1,7 +1,7 @@ | |||
1 | VERSION = 3 | 1 | VERSION = 3 |
2 | PATCHLEVEL = 0 | 2 | PATCHLEVEL = 1 |
3 | SUBLEVEL = 0 | 3 | SUBLEVEL = 0 |
4 | EXTRAVERSION = | 4 | EXTRAVERSION = -rc1 |
5 | NAME = Sneaky Weasel | 5 | NAME = Sneaky Weasel |
6 | 6 | ||
7 | # *DOCUMENTATION* | 7 | # *DOCUMENTATION* |
diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index 2c71a8f3535a..5ebc5d922ea1 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig | |||
@@ -195,8 +195,7 @@ config VECTORS_BASE | |||
195 | The base address of exception vectors. | 195 | The base address of exception vectors. |
196 | 196 | ||
197 | config ARM_PATCH_PHYS_VIRT | 197 | config ARM_PATCH_PHYS_VIRT |
198 | bool "Patch physical to virtual translations at runtime (EXPERIMENTAL)" | 198 | bool "Patch physical to virtual translations at runtime" |
199 | depends on EXPERIMENTAL | ||
200 | depends on !XIP_KERNEL && MMU | 199 | depends on !XIP_KERNEL && MMU |
201 | depends on !ARCH_REALVIEW || !SPARSEMEM | 200 | depends on !ARCH_REALVIEW || !SPARSEMEM |
202 | help | 201 | help |
diff --git a/arch/arm/kernel/iwmmxt.S b/arch/arm/kernel/iwmmxt.S index 7fa3bb0d2397..a08783823b32 100644 --- a/arch/arm/kernel/iwmmxt.S +++ b/arch/arm/kernel/iwmmxt.S | |||
@@ -195,10 +195,10 @@ ENTRY(iwmmxt_task_disable) | |||
195 | 195 | ||
196 | @ enable access to CP0 and CP1 | 196 | @ enable access to CP0 and CP1 |
197 | XSC(mrc p15, 0, r4, c15, c1, 0) | 197 | XSC(mrc p15, 0, r4, c15, c1, 0) |
198 | XSC(orr r4, r4, #0xf) | 198 | XSC(orr r4, r4, #0x3) |
199 | XSC(mcr p15, 0, r4, c15, c1, 0) | 199 | XSC(mcr p15, 0, r4, c15, c1, 0) |
200 | PJ4(mrc p15, 0, r4, c1, c0, 2) | 200 | PJ4(mrc p15, 0, r4, c1, c0, 2) |
201 | PJ4(orr r4, r4, #0x3) | 201 | PJ4(orr r4, r4, #0xf) |
202 | PJ4(mcr p15, 0, r4, c1, c0, 2) | 202 | PJ4(mcr p15, 0, r4, c1, c0, 2) |
203 | 203 | ||
204 | mov r0, #0 @ nothing to load | 204 | mov r0, #0 @ nothing to load |
@@ -313,7 +313,7 @@ ENTRY(iwmmxt_task_switch) | |||
313 | teq r2, r3 @ next task owns it? | 313 | teq r2, r3 @ next task owns it? |
314 | movne pc, lr @ no: leave Concan disabled | 314 | movne pc, lr @ no: leave Concan disabled |
315 | 315 | ||
316 | 1: @ flip Conan access | 316 | 1: @ flip Concan access |
317 | XSC(eor r1, r1, #0x3) | 317 | XSC(eor r1, r1, #0x3) |
318 | XSC(mcr p15, 0, r1, c15, c1, 0) | 318 | XSC(mcr p15, 0, r1, c15, c1, 0) |
319 | PJ4(eor r1, r1, #0xf) | 319 | PJ4(eor r1, r1, #0xf) |
diff --git a/arch/arm/kernel/module.c b/arch/arm/kernel/module.c index 05b377616fd5..cc2020c2c709 100644 --- a/arch/arm/kernel/module.c +++ b/arch/arm/kernel/module.c | |||
@@ -323,7 +323,11 @@ int module_finalize(const Elf32_Ehdr *hdr, const Elf_Shdr *sechdrs, | |||
323 | #endif | 323 | #endif |
324 | s = find_mod_section(hdr, sechdrs, ".alt.smp.init"); | 324 | s = find_mod_section(hdr, sechdrs, ".alt.smp.init"); |
325 | if (s && !is_smp()) | 325 | if (s && !is_smp()) |
326 | #ifdef CONFIG_SMP_ON_UP | ||
326 | fixup_smp((void *)s->sh_addr, s->sh_size); | 327 | fixup_smp((void *)s->sh_addr, s->sh_size); |
328 | #else | ||
329 | return -EINVAL; | ||
330 | #endif | ||
327 | return 0; | 331 | return 0; |
328 | } | 332 | } |
329 | 333 | ||
diff --git a/arch/arm/mach-imx/clock-imx25.c b/arch/arm/mach-imx/clock-imx25.c index 0fc7ba56d616..e63e23504fe5 100644 --- a/arch/arm/mach-imx/clock-imx25.c +++ b/arch/arm/mach-imx/clock-imx25.c | |||
@@ -331,6 +331,9 @@ int __init mx25_clocks_init(void) | |||
331 | __raw_writel(__raw_readl(CRM_BASE+0x64) | (1 << 7) | (1 << 0), | 331 | __raw_writel(__raw_readl(CRM_BASE+0x64) | (1 << 7) | (1 << 0), |
332 | CRM_BASE + 0x64); | 332 | CRM_BASE + 0x64); |
333 | 333 | ||
334 | /* Clock source for gpt is ahb_div */ | ||
335 | __raw_writel(__raw_readl(CRM_BASE+0x64) & ~(1 << 5), CRM_BASE + 0x64); | ||
336 | |||
334 | mxc_timer_init(&gpt_clk, MX25_IO_ADDRESS(MX25_GPT1_BASE_ADDR), 54); | 337 | mxc_timer_init(&gpt_clk, MX25_IO_ADDRESS(MX25_GPT1_BASE_ADDR), 54); |
335 | 338 | ||
336 | return 0; | 339 | return 0; |
diff --git a/arch/arm/mach-imx/mach-imx27_visstrim_m10.c b/arch/arm/mach-imx/mach-imx27_visstrim_m10.c index 6707de0ab716..6778f8193bc6 100644 --- a/arch/arm/mach-imx/mach-imx27_visstrim_m10.c +++ b/arch/arm/mach-imx/mach-imx27_visstrim_m10.c | |||
@@ -30,6 +30,7 @@ | |||
30 | #include <linux/input.h> | 30 | #include <linux/input.h> |
31 | #include <linux/gpio.h> | 31 | #include <linux/gpio.h> |
32 | #include <linux/delay.h> | 32 | #include <linux/delay.h> |
33 | #include <sound/tlv320aic32x4.h> | ||
33 | #include <asm/mach-types.h> | 34 | #include <asm/mach-types.h> |
34 | #include <asm/mach/arch.h> | 35 | #include <asm/mach/arch.h> |
35 | #include <asm/mach/time.h> | 36 | #include <asm/mach/time.h> |
@@ -196,6 +197,17 @@ static struct pca953x_platform_data visstrim_m10_pca9555_pdata = { | |||
196 | .invert = 0, | 197 | .invert = 0, |
197 | }; | 198 | }; |
198 | 199 | ||
200 | static struct aic32x4_pdata visstrim_m10_aic32x4_pdata = { | ||
201 | .power_cfg = AIC32X4_PWR_MICBIAS_2075_LDOIN | | ||
202 | AIC32X4_PWR_AVDD_DVDD_WEAK_DISABLE | | ||
203 | AIC32X4_PWR_AIC32X4_LDO_ENABLE | | ||
204 | AIC32X4_PWR_CMMODE_LDOIN_RANGE_18_36 | | ||
205 | AIC32X4_PWR_CMMODE_HP_LDOIN_POWERED, | ||
206 | .micpga_routing = AIC32X4_MICPGA_ROUTE_LMIC_IN2R_10K | | ||
207 | AIC32X4_MICPGA_ROUTE_RMIC_IN1L_10K, | ||
208 | .swapdacs = false, | ||
209 | }; | ||
210 | |||
199 | static struct i2c_board_info visstrim_m10_i2c_devices[] = { | 211 | static struct i2c_board_info visstrim_m10_i2c_devices[] = { |
200 | { | 212 | { |
201 | I2C_BOARD_INFO("pca9555", 0x20), | 213 | I2C_BOARD_INFO("pca9555", 0x20), |
@@ -203,6 +215,7 @@ static struct i2c_board_info visstrim_m10_i2c_devices[] = { | |||
203 | }, | 215 | }, |
204 | { | 216 | { |
205 | I2C_BOARD_INFO("tlv320aic32x4", 0x18), | 217 | I2C_BOARD_INFO("tlv320aic32x4", 0x18), |
218 | .platform_data = &visstrim_m10_aic32x4_pdata, | ||
206 | } | 219 | } |
207 | }; | 220 | }; |
208 | 221 | ||
diff --git a/arch/arm/mach-imx/mach-mx31ads.c b/arch/arm/mach-imx/mach-mx31ads.c index 0ce49478a479..29ca8907a780 100644 --- a/arch/arm/mach-imx/mach-mx31ads.c +++ b/arch/arm/mach-imx/mach-mx31ads.c | |||
@@ -468,7 +468,7 @@ static struct i2c_board_info __initdata mx31ads_i2c1_devices[] = { | |||
468 | #endif | 468 | #endif |
469 | }; | 469 | }; |
470 | 470 | ||
471 | static void mxc_init_i2c(void) | 471 | static void __init mxc_init_i2c(void) |
472 | { | 472 | { |
473 | i2c_register_board_info(1, mx31ads_i2c1_devices, | 473 | i2c_register_board_info(1, mx31ads_i2c1_devices, |
474 | ARRAY_SIZE(mx31ads_i2c1_devices)); | 474 | ARRAY_SIZE(mx31ads_i2c1_devices)); |
@@ -486,7 +486,7 @@ static unsigned int ssi_pins[] = { | |||
486 | MX31_PIN_STXD5__STXD5, | 486 | MX31_PIN_STXD5__STXD5, |
487 | }; | 487 | }; |
488 | 488 | ||
489 | static void mxc_init_audio(void) | 489 | static void __init mxc_init_audio(void) |
490 | { | 490 | { |
491 | imx31_add_imx_ssi(0, NULL); | 491 | imx31_add_imx_ssi(0, NULL); |
492 | mxc_iomux_setup_multiple_pins(ssi_pins, ARRAY_SIZE(ssi_pins), "ssi"); | 492 | mxc_iomux_setup_multiple_pins(ssi_pins, ARRAY_SIZE(ssi_pins), "ssi"); |
diff --git a/arch/arm/mach-imx/mach-mx31lilly.c b/arch/arm/mach-imx/mach-mx31lilly.c index 750368ddf0f9..126913ad106a 100644 --- a/arch/arm/mach-imx/mach-mx31lilly.c +++ b/arch/arm/mach-imx/mach-mx31lilly.c | |||
@@ -192,7 +192,7 @@ static struct mxc_usbh_platform_data usbh2_pdata __initdata = { | |||
192 | .portsc = MXC_EHCI_MODE_ULPI | MXC_EHCI_UTMI_8BIT, | 192 | .portsc = MXC_EHCI_MODE_ULPI | MXC_EHCI_UTMI_8BIT, |
193 | }; | 193 | }; |
194 | 194 | ||
195 | static void lilly1131_usb_init(void) | 195 | static void __init lilly1131_usb_init(void) |
196 | { | 196 | { |
197 | imx31_add_mxc_ehci_hs(1, &usbh1_pdata); | 197 | imx31_add_mxc_ehci_hs(1, &usbh1_pdata); |
198 | 198 | ||
diff --git a/arch/arm/mach-mmp/gplugd.c b/arch/arm/mach-mmp/gplugd.c index c070c24255f4..98e25d9aaab6 100644 --- a/arch/arm/mach-mmp/gplugd.c +++ b/arch/arm/mach-mmp/gplugd.c | |||
@@ -16,16 +16,18 @@ | |||
16 | #include <mach/gpio.h> | 16 | #include <mach/gpio.h> |
17 | #include <mach/pxa168.h> | 17 | #include <mach/pxa168.h> |
18 | #include <mach/mfp-pxa168.h> | 18 | #include <mach/mfp-pxa168.h> |
19 | #include <mach/mfp-gplugd.h> | ||
20 | 19 | ||
21 | #include "common.h" | 20 | #include "common.h" |
22 | 21 | ||
23 | static unsigned long gplugd_pin_config[] __initdata = { | 22 | static unsigned long gplugd_pin_config[] __initdata = { |
24 | /* UART3 */ | 23 | /* UART3 */ |
25 | GPIO8_UART3_SOUT, | 24 | GPIO8_UART3_TXD, |
26 | GPIO9_UART3_SIN, | 25 | GPIO9_UART3_RXD, |
27 | GPI1O_UART3_CTS, | 26 | GPIO1O_UART3_CTS, |
28 | GPI11_UART3_RTS, | 27 | GPIO11_UART3_RTS, |
28 | |||
29 | /* USB OTG PEN */ | ||
30 | GPIO18_GPIO, | ||
29 | 31 | ||
30 | /* MMC2 */ | 32 | /* MMC2 */ |
31 | GPIO28_MMC2_CMD, | 33 | GPIO28_MMC2_CMD, |
@@ -109,6 +111,12 @@ static unsigned long gplugd_pin_config[] __initdata = { | |||
109 | GPIO105_CI2C_SDA, | 111 | GPIO105_CI2C_SDA, |
110 | GPIO106_CI2C_SCL, | 112 | GPIO106_CI2C_SCL, |
111 | 113 | ||
114 | /* SPI NOR Flash on SSP2 */ | ||
115 | GPIO107_SSP2_RXD, | ||
116 | GPIO108_SSP2_TXD, | ||
117 | GPIO110_GPIO, /* SPI_CSn */ | ||
118 | GPIO111_SSP2_CLK, | ||
119 | |||
112 | /* Select JTAG */ | 120 | /* Select JTAG */ |
113 | GPIO109_GPIO, | 121 | GPIO109_GPIO, |
114 | 122 | ||
@@ -154,7 +162,7 @@ static void __init select_disp_freq(void) | |||
154 | "frequency\n"); | 162 | "frequency\n"); |
155 | } else { | 163 | } else { |
156 | gpio_direction_output(35, 1); | 164 | gpio_direction_output(35, 1); |
157 | gpio_free(104); | 165 | gpio_free(35); |
158 | } | 166 | } |
159 | 167 | ||
160 | if (unlikely(gpio_request(85, "DISP_FREQ_SEL_2"))) { | 168 | if (unlikely(gpio_request(85, "DISP_FREQ_SEL_2"))) { |
@@ -162,7 +170,7 @@ static void __init select_disp_freq(void) | |||
162 | "frequency\n"); | 170 | "frequency\n"); |
163 | } else { | 171 | } else { |
164 | gpio_direction_output(85, 0); | 172 | gpio_direction_output(85, 0); |
165 | gpio_free(104); | 173 | gpio_free(85); |
166 | } | 174 | } |
167 | } | 175 | } |
168 | 176 | ||
diff --git a/arch/arm/mach-mmp/include/mach/mfp-gplugd.h b/arch/arm/mach-mmp/include/mach/mfp-gplugd.h deleted file mode 100644 index b8cf38d85600..000000000000 --- a/arch/arm/mach-mmp/include/mach/mfp-gplugd.h +++ /dev/null | |||
@@ -1,52 +0,0 @@ | |||
1 | /* | ||
2 | * linux/arch/arm/mach-mmp/include/mach/mfp-gplugd.h | ||
3 | * | ||
4 | * MFP definitions used in gplugD | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #ifndef __MACH_MFP_GPLUGD_H | ||
12 | #define __MACH_MFP_GPLUGD_H | ||
13 | |||
14 | #include <plat/mfp.h> | ||
15 | #include <mach/mfp.h> | ||
16 | |||
17 | /* UART3 */ | ||
18 | #define GPIO8_UART3_SOUT MFP_CFG(GPIO8, AF2) | ||
19 | #define GPIO9_UART3_SIN MFP_CFG(GPIO9, AF2) | ||
20 | #define GPI1O_UART3_CTS MFP_CFG(GPIO10, AF2) | ||
21 | #define GPI11_UART3_RTS MFP_CFG(GPIO11, AF2) | ||
22 | |||
23 | /* MMC2 */ | ||
24 | #define GPIO28_MMC2_CMD MFP_CFG_DRV(GPIO28, AF6, FAST) | ||
25 | #define GPIO29_MMC2_CLK MFP_CFG_DRV(GPIO29, AF6, FAST) | ||
26 | #define GPIO30_MMC2_DAT0 MFP_CFG_DRV(GPIO30, AF6, FAST) | ||
27 | #define GPIO31_MMC2_DAT1 MFP_CFG_DRV(GPIO31, AF6, FAST) | ||
28 | #define GPIO32_MMC2_DAT2 MFP_CFG_DRV(GPIO32, AF6, FAST) | ||
29 | #define GPIO33_MMC2_DAT3 MFP_CFG_DRV(GPIO33, AF6, FAST) | ||
30 | |||
31 | /* I2S */ | ||
32 | #undef GPIO114_I2S_FRM | ||
33 | #undef GPIO115_I2S_BCLK | ||
34 | |||
35 | #define GPIO114_I2S_FRM MFP_CFG_DRV(GPIO114, AF1, FAST) | ||
36 | #define GPIO115_I2S_BCLK MFP_CFG_DRV(GPIO115, AF1, FAST) | ||
37 | #define GPIO116_I2S_TXD MFP_CFG_DRV(GPIO116, AF1, FAST) | ||
38 | |||
39 | /* MMC4 */ | ||
40 | #define GPIO125_MMC4_DAT3 MFP_CFG_DRV(GPIO125, AF7, FAST) | ||
41 | #define GPIO126_MMC4_DAT2 MFP_CFG_DRV(GPIO126, AF7, FAST) | ||
42 | #define GPIO127_MMC4_DAT1 MFP_CFG_DRV(GPIO127, AF7, FAST) | ||
43 | #define GPIO0_2_MMC4_DAT0 MFP_CFG_DRV(GPIO0_2, AF7, FAST) | ||
44 | #define GPIO1_2_MMC4_CMD MFP_CFG_DRV(GPIO1_2, AF7, FAST) | ||
45 | #define GPIO2_2_MMC4_CLK MFP_CFG_DRV(GPIO2_2, AF7, FAST) | ||
46 | |||
47 | /* OTG GPIO */ | ||
48 | #define GPIO_USB_OTG_PEN 18 | ||
49 | #define GPIO_USB_OIDIR 20 | ||
50 | |||
51 | /* Other GPIOs are 35, 84, 85 */ | ||
52 | #endif /* __MACH_MFP_GPLUGD_H */ | ||
diff --git a/arch/arm/mach-mmp/include/mach/mfp-pxa168.h b/arch/arm/mach-mmp/include/mach/mfp-pxa168.h index 8c782328b21c..92aaa3c19d61 100644 --- a/arch/arm/mach-mmp/include/mach/mfp-pxa168.h +++ b/arch/arm/mach-mmp/include/mach/mfp-pxa168.h | |||
@@ -203,6 +203,10 @@ | |||
203 | #define GPIO33_CF_nCD2 MFP_CFG(GPIO33, AF3) | 203 | #define GPIO33_CF_nCD2 MFP_CFG(GPIO33, AF3) |
204 | 204 | ||
205 | /* UART */ | 205 | /* UART */ |
206 | #define GPIO8_UART3_TXD MFP_CFG(GPIO8, AF2) | ||
207 | #define GPIO9_UART3_RXD MFP_CFG(GPIO9, AF2) | ||
208 | #define GPIO1O_UART3_CTS MFP_CFG(GPIO10, AF2) | ||
209 | #define GPIO11_UART3_RTS MFP_CFG(GPIO11, AF2) | ||
206 | #define GPIO88_UART2_TXD MFP_CFG(GPIO88, AF2) | 210 | #define GPIO88_UART2_TXD MFP_CFG(GPIO88, AF2) |
207 | #define GPIO89_UART2_RXD MFP_CFG(GPIO89, AF2) | 211 | #define GPIO89_UART2_RXD MFP_CFG(GPIO89, AF2) |
208 | #define GPIO107_UART1_TXD MFP_CFG_DRV(GPIO107, AF1, FAST) | 212 | #define GPIO107_UART1_TXD MFP_CFG_DRV(GPIO107, AF1, FAST) |
@@ -232,6 +236,22 @@ | |||
232 | #define GPIO53_MMC1_CD MFP_CFG(GPIO53, AF1) | 236 | #define GPIO53_MMC1_CD MFP_CFG(GPIO53, AF1) |
233 | #define GPIO46_MMC1_WP MFP_CFG(GPIO46, AF1) | 237 | #define GPIO46_MMC1_WP MFP_CFG(GPIO46, AF1) |
234 | 238 | ||
239 | /* MMC2 */ | ||
240 | #define GPIO28_MMC2_CMD MFP_CFG_DRV(GPIO28, AF6, FAST) | ||
241 | #define GPIO29_MMC2_CLK MFP_CFG_DRV(GPIO29, AF6, FAST) | ||
242 | #define GPIO30_MMC2_DAT0 MFP_CFG_DRV(GPIO30, AF6, FAST) | ||
243 | #define GPIO31_MMC2_DAT1 MFP_CFG_DRV(GPIO31, AF6, FAST) | ||
244 | #define GPIO32_MMC2_DAT2 MFP_CFG_DRV(GPIO32, AF6, FAST) | ||
245 | #define GPIO33_MMC2_DAT3 MFP_CFG_DRV(GPIO33, AF6, FAST) | ||
246 | |||
247 | /* MMC4 */ | ||
248 | #define GPIO125_MMC4_DAT3 MFP_CFG_DRV(GPIO125, AF7, FAST) | ||
249 | #define GPIO126_MMC4_DAT2 MFP_CFG_DRV(GPIO126, AF7, FAST) | ||
250 | #define GPIO127_MMC4_DAT1 MFP_CFG_DRV(GPIO127, AF7, FAST) | ||
251 | #define GPIO0_2_MMC4_DAT0 MFP_CFG_DRV(GPIO0_2, AF7, FAST) | ||
252 | #define GPIO1_2_MMC4_CMD MFP_CFG_DRV(GPIO1_2, AF7, FAST) | ||
253 | #define GPIO2_2_MMC4_CLK MFP_CFG_DRV(GPIO2_2, AF7, FAST) | ||
254 | |||
235 | /* LCD */ | 255 | /* LCD */ |
236 | #define GPIO84_LCD_CS MFP_CFG(GPIO84, AF1) | 256 | #define GPIO84_LCD_CS MFP_CFG(GPIO84, AF1) |
237 | #define GPIO60_LCD_DD0 MFP_CFG(GPIO60, AF1) | 257 | #define GPIO60_LCD_DD0 MFP_CFG(GPIO60, AF1) |
@@ -269,11 +289,12 @@ | |||
269 | #define GPIO106_CI2C_SCL MFP_CFG(GPIO106, AF1) | 289 | #define GPIO106_CI2C_SCL MFP_CFG(GPIO106, AF1) |
270 | 290 | ||
271 | /* I2S */ | 291 | /* I2S */ |
272 | #define GPIO113_I2S_MCLK MFP_CFG(GPIO113,AF6) | 292 | #define GPIO113_I2S_MCLK MFP_CFG(GPIO113, AF6) |
273 | #define GPIO114_I2S_FRM MFP_CFG(GPIO114,AF1) | 293 | #define GPIO114_I2S_FRM MFP_CFG(GPIO114, AF1) |
274 | #define GPIO115_I2S_BCLK MFP_CFG(GPIO115,AF1) | 294 | #define GPIO115_I2S_BCLK MFP_CFG(GPIO115, AF1) |
275 | #define GPIO116_I2S_RXD MFP_CFG(GPIO116,AF2) | 295 | #define GPIO116_I2S_RXD MFP_CFG(GPIO116, AF2) |
276 | #define GPIO117_I2S_TXD MFP_CFG(GPIO117,AF2) | 296 | #define GPIO116_I2S_TXD MFP_CFG(GPIO116, AF1) |
297 | #define GPIO117_I2S_TXD MFP_CFG(GPIO117, AF2) | ||
277 | 298 | ||
278 | /* PWM */ | 299 | /* PWM */ |
279 | #define GPIO96_PWM3_OUT MFP_CFG(GPIO96, AF1) | 300 | #define GPIO96_PWM3_OUT MFP_CFG(GPIO96, AF1) |
@@ -324,4 +345,10 @@ | |||
324 | #define GPIO101_MII_MDIO MFP_CFG(GPIO101, AF5) | 345 | #define GPIO101_MII_MDIO MFP_CFG(GPIO101, AF5) |
325 | #define GPIO103_RX_DV MFP_CFG(GPIO103, AF5) | 346 | #define GPIO103_RX_DV MFP_CFG(GPIO103, AF5) |
326 | 347 | ||
348 | /* SSP2 */ | ||
349 | #define GPIO107_SSP2_RXD MFP_CFG(GPIO107, AF4) | ||
350 | #define GPIO108_SSP2_TXD MFP_CFG(GPIO108, AF4) | ||
351 | #define GPIO111_SSP2_CLK MFP_CFG(GPIO111, AF4) | ||
352 | #define GPIO112_SSP2_FRM MFP_CFG(GPIO112, AF4) | ||
353 | |||
327 | #endif /* __ASM_MACH_MFP_PXA168_H */ | 354 | #endif /* __ASM_MACH_MFP_PXA168_H */ |
diff --git a/arch/arm/mach-mmp/time.c b/arch/arm/mach-mmp/time.c index 99833b9485cf..4e91ee6e27c8 100644 --- a/arch/arm/mach-mmp/time.c +++ b/arch/arm/mach-mmp/time.c | |||
@@ -51,12 +51,12 @@ static inline uint32_t timer_read(void) | |||
51 | { | 51 | { |
52 | int delay = 100; | 52 | int delay = 100; |
53 | 53 | ||
54 | __raw_writel(1, TIMERS_VIRT_BASE + TMR_CVWR(0)); | 54 | __raw_writel(1, TIMERS_VIRT_BASE + TMR_CVWR(1)); |
55 | 55 | ||
56 | while (delay--) | 56 | while (delay--) |
57 | cpu_relax(); | 57 | cpu_relax(); |
58 | 58 | ||
59 | return __raw_readl(TIMERS_VIRT_BASE + TMR_CVWR(0)); | 59 | return __raw_readl(TIMERS_VIRT_BASE + TMR_CVWR(1)); |
60 | } | 60 | } |
61 | 61 | ||
62 | unsigned long long notrace sched_clock(void) | 62 | unsigned long long notrace sched_clock(void) |
@@ -75,28 +75,51 @@ static irqreturn_t timer_interrupt(int irq, void *dev_id) | |||
75 | { | 75 | { |
76 | struct clock_event_device *c = dev_id; | 76 | struct clock_event_device *c = dev_id; |
77 | 77 | ||
78 | /* disable and clear pending interrupt status */ | 78 | /* |
79 | __raw_writel(0x0, TIMERS_VIRT_BASE + TMR_IER(0)); | 79 | * Clear pending interrupt status. |
80 | __raw_writel(0x1, TIMERS_VIRT_BASE + TMR_ICR(0)); | 80 | */ |
81 | __raw_writel(0x01, TIMERS_VIRT_BASE + TMR_ICR(0)); | ||
82 | |||
83 | /* | ||
84 | * Disable timer 0. | ||
85 | */ | ||
86 | __raw_writel(0x02, TIMERS_VIRT_BASE + TMR_CER); | ||
87 | |||
81 | c->event_handler(c); | 88 | c->event_handler(c); |
89 | |||
82 | return IRQ_HANDLED; | 90 | return IRQ_HANDLED; |
83 | } | 91 | } |
84 | 92 | ||
85 | static int timer_set_next_event(unsigned long delta, | 93 | static int timer_set_next_event(unsigned long delta, |
86 | struct clock_event_device *dev) | 94 | struct clock_event_device *dev) |
87 | { | 95 | { |
88 | unsigned long flags, next; | 96 | unsigned long flags; |
89 | 97 | ||
90 | local_irq_save(flags); | 98 | local_irq_save(flags); |
91 | 99 | ||
92 | /* clear pending interrupt status and enable */ | 100 | /* |
101 | * Disable timer 0. | ||
102 | */ | ||
103 | __raw_writel(0x02, TIMERS_VIRT_BASE + TMR_CER); | ||
104 | |||
105 | /* | ||
106 | * Clear and enable timer match 0 interrupt. | ||
107 | */ | ||
93 | __raw_writel(0x01, TIMERS_VIRT_BASE + TMR_ICR(0)); | 108 | __raw_writel(0x01, TIMERS_VIRT_BASE + TMR_ICR(0)); |
94 | __raw_writel(0x01, TIMERS_VIRT_BASE + TMR_IER(0)); | 109 | __raw_writel(0x01, TIMERS_VIRT_BASE + TMR_IER(0)); |
95 | 110 | ||
96 | next = timer_read() + delta; | 111 | /* |
97 | __raw_writel(next, TIMERS_VIRT_BASE + TMR_TN_MM(0, 0)); | 112 | * Setup new clockevent timer value. |
113 | */ | ||
114 | __raw_writel(delta - 1, TIMERS_VIRT_BASE + TMR_TN_MM(0, 0)); | ||
115 | |||
116 | /* | ||
117 | * Enable timer 0. | ||
118 | */ | ||
119 | __raw_writel(0x03, TIMERS_VIRT_BASE + TMR_CER); | ||
98 | 120 | ||
99 | local_irq_restore(flags); | 121 | local_irq_restore(flags); |
122 | |||
100 | return 0; | 123 | return 0; |
101 | } | 124 | } |
102 | 125 | ||
@@ -145,23 +168,26 @@ static struct clocksource cksrc = { | |||
145 | static void __init timer_config(void) | 168 | static void __init timer_config(void) |
146 | { | 169 | { |
147 | uint32_t ccr = __raw_readl(TIMERS_VIRT_BASE + TMR_CCR); | 170 | uint32_t ccr = __raw_readl(TIMERS_VIRT_BASE + TMR_CCR); |
148 | uint32_t cer = __raw_readl(TIMERS_VIRT_BASE + TMR_CER); | ||
149 | uint32_t cmr = __raw_readl(TIMERS_VIRT_BASE + TMR_CMR); | ||
150 | 171 | ||
151 | __raw_writel(cer & ~0x1, TIMERS_VIRT_BASE + TMR_CER); /* disable */ | 172 | __raw_writel(0x0, TIMERS_VIRT_BASE + TMR_CER); /* disable */ |
152 | 173 | ||
153 | ccr &= (cpu_is_mmp2()) ? TMR_CCR_CS_0(0) : TMR_CCR_CS_0(3); | 174 | ccr &= (cpu_is_mmp2()) ? (TMR_CCR_CS_0(0) | TMR_CCR_CS_1(0)) : |
175 | (TMR_CCR_CS_0(3) | TMR_CCR_CS_1(3)); | ||
154 | __raw_writel(ccr, TIMERS_VIRT_BASE + TMR_CCR); | 176 | __raw_writel(ccr, TIMERS_VIRT_BASE + TMR_CCR); |
155 | 177 | ||
156 | /* free-running mode */ | 178 | /* set timer 0 to periodic mode, and timer 1 to free-running mode */ |
157 | __raw_writel(cmr | 0x01, TIMERS_VIRT_BASE + TMR_CMR); | 179 | __raw_writel(0x2, TIMERS_VIRT_BASE + TMR_CMR); |
158 | 180 | ||
159 | __raw_writel(0x0, TIMERS_VIRT_BASE + TMR_PLCR(0)); /* free-running */ | 181 | __raw_writel(0x1, TIMERS_VIRT_BASE + TMR_PLCR(0)); /* periodic */ |
160 | __raw_writel(0x7, TIMERS_VIRT_BASE + TMR_ICR(0)); /* clear status */ | 182 | __raw_writel(0x7, TIMERS_VIRT_BASE + TMR_ICR(0)); /* clear status */ |
161 | __raw_writel(0x0, TIMERS_VIRT_BASE + TMR_IER(0)); | 183 | __raw_writel(0x0, TIMERS_VIRT_BASE + TMR_IER(0)); |
162 | 184 | ||
163 | /* enable timer counter */ | 185 | __raw_writel(0x0, TIMERS_VIRT_BASE + TMR_PLCR(1)); /* free-running */ |
164 | __raw_writel(cer | 0x01, TIMERS_VIRT_BASE + TMR_CER); | 186 | __raw_writel(0x7, TIMERS_VIRT_BASE + TMR_ICR(1)); /* clear status */ |
187 | __raw_writel(0x0, TIMERS_VIRT_BASE + TMR_IER(1)); | ||
188 | |||
189 | /* enable timer 1 counter */ | ||
190 | __raw_writel(0x2, TIMERS_VIRT_BASE + TMR_CER); | ||
165 | } | 191 | } |
166 | 192 | ||
167 | static struct irqaction timer_irq = { | 193 | static struct irqaction timer_irq = { |
diff --git a/arch/arm/mach-mx5/board-cpuimx51.c b/arch/arm/mach-mx5/board-cpuimx51.c index 7c893fa70266..68934ea8725a 100644 --- a/arch/arm/mach-mx5/board-cpuimx51.c +++ b/arch/arm/mach-mx5/board-cpuimx51.c | |||
@@ -81,7 +81,7 @@ static struct plat_serial8250_port serial_platform_data[] = { | |||
81 | .flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST | UPF_IOREMAP, | 81 | .flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST | UPF_IOREMAP, |
82 | }, { | 82 | }, { |
83 | .mapbase = (unsigned long)(MX51_CS1_BASE_ADDR + 0x2000000), | 83 | .mapbase = (unsigned long)(MX51_CS1_BASE_ADDR + 0x2000000), |
84 | .irq = irq_to_gpio(CPUIMX51_QUARTD_GPIO), | 84 | .irq = gpio_to_irq(CPUIMX51_QUARTD_GPIO), |
85 | .irqflags = IRQF_TRIGGER_HIGH, | 85 | .irqflags = IRQF_TRIGGER_HIGH, |
86 | .uartclk = CPUIMX51_QUART_XTAL, | 86 | .uartclk = CPUIMX51_QUART_XTAL, |
87 | .regshift = CPUIMX51_QUART_REGSHIFT, | 87 | .regshift = CPUIMX51_QUART_REGSHIFT, |
diff --git a/arch/arm/mach-mx5/board-mx51_babbage.c b/arch/arm/mach-mx5/board-mx51_babbage.c index e400b09109ce..11b0ff67f89d 100644 --- a/arch/arm/mach-mx5/board-mx51_babbage.c +++ b/arch/arm/mach-mx5/board-mx51_babbage.c | |||
@@ -369,7 +369,7 @@ static void __init mx51_babbage_init(void) | |||
369 | ARRAY_SIZE(mx51babbage_pads)); | 369 | ARRAY_SIZE(mx51babbage_pads)); |
370 | 370 | ||
371 | imx51_add_imx_uart(0, &uart_pdata); | 371 | imx51_add_imx_uart(0, &uart_pdata); |
372 | imx51_add_imx_uart(1, &uart_pdata); | 372 | imx51_add_imx_uart(1, NULL); |
373 | imx51_add_imx_uart(2, &uart_pdata); | 373 | imx51_add_imx_uart(2, &uart_pdata); |
374 | 374 | ||
375 | babbage_fec_reset(); | 375 | babbage_fec_reset(); |
diff --git a/arch/arm/mach-mx5/board-mx51_efikamx.c b/arch/arm/mach-mx5/board-mx51_efikamx.c index f70700dc0ec1..551daf85ff8c 100644 --- a/arch/arm/mach-mx5/board-mx51_efikamx.c +++ b/arch/arm/mach-mx5/board-mx51_efikamx.c | |||
@@ -108,9 +108,9 @@ static void __init mx51_efikamx_board_id(void) | |||
108 | gpio_request(EFIKAMX_PCBID2, "pcbid2"); | 108 | gpio_request(EFIKAMX_PCBID2, "pcbid2"); |
109 | gpio_direction_input(EFIKAMX_PCBID2); | 109 | gpio_direction_input(EFIKAMX_PCBID2); |
110 | 110 | ||
111 | id = gpio_get_value(EFIKAMX_PCBID0); | 111 | id = gpio_get_value(EFIKAMX_PCBID0) ? 1 : 0; |
112 | id |= gpio_get_value(EFIKAMX_PCBID1) << 1; | 112 | id |= (gpio_get_value(EFIKAMX_PCBID1) ? 1 : 0) << 1; |
113 | id |= gpio_get_value(EFIKAMX_PCBID2) << 2; | 113 | id |= (gpio_get_value(EFIKAMX_PCBID2) ? 1 : 0) << 2; |
114 | 114 | ||
115 | switch (id) { | 115 | switch (id) { |
116 | case 7: | 116 | case 7: |
diff --git a/arch/arm/mach-mx5/board-mx51_efikasb.c b/arch/arm/mach-mx5/board-mx51_efikasb.c index 2e4d9d32a87c..8a9bca22beb5 100644 --- a/arch/arm/mach-mx5/board-mx51_efikasb.c +++ b/arch/arm/mach-mx5/board-mx51_efikasb.c | |||
@@ -156,23 +156,24 @@ static struct gpio_keys_button mx51_efikasb_keys[] = { | |||
156 | { | 156 | { |
157 | .code = KEY_POWER, | 157 | .code = KEY_POWER, |
158 | .gpio = EFIKASB_PWRKEY, | 158 | .gpio = EFIKASB_PWRKEY, |
159 | .type = EV_PWR, | 159 | .type = EV_KEY, |
160 | .desc = "Power Button", | 160 | .desc = "Power Button", |
161 | .wakeup = 1, | 161 | .wakeup = 1, |
162 | .debounce_interval = 10, /* ms */ | 162 | .active_low = 1, |
163 | }, | 163 | }, |
164 | { | 164 | { |
165 | .code = SW_LID, | 165 | .code = SW_LID, |
166 | .gpio = EFIKASB_LID, | 166 | .gpio = EFIKASB_LID, |
167 | .type = EV_SW, | 167 | .type = EV_SW, |
168 | .desc = "Lid Switch", | 168 | .desc = "Lid Switch", |
169 | .active_low = 1, | ||
169 | }, | 170 | }, |
170 | { | 171 | { |
171 | /* SW_RFKILLALL vs KEY_RFKILL ? */ | 172 | .code = KEY_RFKILL, |
172 | .code = SW_RFKILL_ALL, | ||
173 | .gpio = EFIKASB_RFKILL, | 173 | .gpio = EFIKASB_RFKILL, |
174 | .type = EV_SW, | 174 | .type = EV_KEY, |
175 | .desc = "rfkill", | 175 | .desc = "rfkill", |
176 | .active_low = 1, | ||
176 | }, | 177 | }, |
177 | }; | 178 | }; |
178 | 179 | ||
@@ -224,8 +225,8 @@ static void __init mx51_efikasb_board_id(void) | |||
224 | gpio_request(EFIKASB_PCBID1, "pcb id1"); | 225 | gpio_request(EFIKASB_PCBID1, "pcb id1"); |
225 | gpio_direction_input(EFIKASB_PCBID1); | 226 | gpio_direction_input(EFIKASB_PCBID1); |
226 | 227 | ||
227 | id = gpio_get_value(EFIKASB_PCBID0); | 228 | id = gpio_get_value(EFIKASB_PCBID0) ? 1 : 0; |
228 | id |= gpio_get_value(EFIKASB_PCBID1) << 1; | 229 | id |= (gpio_get_value(EFIKASB_PCBID1) ? 1 : 0) << 1; |
229 | 230 | ||
230 | switch (id) { | 231 | switch (id) { |
231 | default: | 232 | default: |
diff --git a/arch/arm/mach-mx5/clock-mx51-mx53.c b/arch/arm/mach-mx5/clock-mx51-mx53.c index 7f20308c4dbd..f7bf996f463b 100644 --- a/arch/arm/mach-mx5/clock-mx51-mx53.c +++ b/arch/arm/mach-mx5/clock-mx51-mx53.c | |||
@@ -271,7 +271,11 @@ static int _clk_pll_enable(struct clk *clk) | |||
271 | int i = 0; | 271 | int i = 0; |
272 | 272 | ||
273 | pllbase = _get_pll_base(clk); | 273 | pllbase = _get_pll_base(clk); |
274 | reg = __raw_readl(pllbase + MXC_PLL_DP_CTL) | MXC_PLL_DP_CTL_UPEN; | 274 | reg = __raw_readl(pllbase + MXC_PLL_DP_CTL); |
275 | if (reg & MXC_PLL_DP_CTL_UPEN) | ||
276 | return 0; | ||
277 | |||
278 | reg |= MXC_PLL_DP_CTL_UPEN; | ||
275 | __raw_writel(reg, pllbase + MXC_PLL_DP_CTL); | 279 | __raw_writel(reg, pllbase + MXC_PLL_DP_CTL); |
276 | 280 | ||
277 | /* Wait for lock */ | 281 | /* Wait for lock */ |
diff --git a/arch/arm/mach-mx5/mx51_efika.c b/arch/arm/mach-mx5/mx51_efika.c index 4435e03cea5d..c9209454807a 100644 --- a/arch/arm/mach-mx5/mx51_efika.c +++ b/arch/arm/mach-mx5/mx51_efika.c | |||
@@ -186,7 +186,7 @@ static int initialize_usbh1_port(struct platform_device *pdev) | |||
186 | 186 | ||
187 | mdelay(10); | 187 | mdelay(10); |
188 | 188 | ||
189 | return mx51_initialize_usb_hw(0, MXC_EHCI_ITC_NO_THRESHOLD); | 189 | return mx51_initialize_usb_hw(pdev->id, MXC_EHCI_ITC_NO_THRESHOLD); |
190 | } | 190 | } |
191 | 191 | ||
192 | static struct mxc_usbh_platform_data usbh1_config = { | 192 | static struct mxc_usbh_platform_data usbh1_config = { |
diff --git a/arch/arm/mach-omap2/Kconfig b/arch/arm/mach-omap2/Kconfig index 4ae6257b39a4..57b66d590c52 100644 --- a/arch/arm/mach-omap2/Kconfig +++ b/arch/arm/mach-omap2/Kconfig | |||
@@ -7,7 +7,6 @@ config ARCH_OMAP2PLUS_TYPICAL | |||
7 | default y | 7 | default y |
8 | select AEABI | 8 | select AEABI |
9 | select REGULATOR | 9 | select REGULATOR |
10 | select PM | ||
11 | select PM_RUNTIME | 10 | select PM_RUNTIME |
12 | select VFP | 11 | select VFP |
13 | select NEON if ARCH_OMAP3 || ARCH_OMAP4 | 12 | select NEON if ARCH_OMAP3 || ARCH_OMAP4 |
diff --git a/arch/arm/mach-omap2/board-am3517crane.c b/arch/arm/mach-omap2/board-am3517crane.c index 5f2b55ff04ff..933e9353cb37 100644 --- a/arch/arm/mach-omap2/board-am3517crane.c +++ b/arch/arm/mach-omap2/board-am3517crane.c | |||
@@ -45,8 +45,6 @@ static struct omap_board_config_kernel am3517_crane_config[] __initdata = { | |||
45 | static struct omap_board_mux board_mux[] __initdata = { | 45 | static struct omap_board_mux board_mux[] __initdata = { |
46 | { .reg_offset = OMAP_MUX_TERMINATOR }, | 46 | { .reg_offset = OMAP_MUX_TERMINATOR }, |
47 | }; | 47 | }; |
48 | #else | ||
49 | #define board_mux NULL | ||
50 | #endif | 48 | #endif |
51 | 49 | ||
52 | static void __init am3517_crane_init_early(void) | 50 | static void __init am3517_crane_init_early(void) |
diff --git a/arch/arm/mach-omap2/board-omap3beagle.c b/arch/arm/mach-omap2/board-omap3beagle.c index 32f5f895568a..3ae16b4e3f52 100644 --- a/arch/arm/mach-omap2/board-omap3beagle.c +++ b/arch/arm/mach-omap2/board-omap3beagle.c | |||
@@ -491,23 +491,22 @@ static void __init beagle_opp_init(void) | |||
491 | 491 | ||
492 | /* Custom OPP enabled for all xM versions */ | 492 | /* Custom OPP enabled for all xM versions */ |
493 | if (cpu_is_omap3630()) { | 493 | if (cpu_is_omap3630()) { |
494 | struct omap_hwmod *mh = omap_hwmod_lookup("mpu"); | 494 | struct device *mpu_dev, *iva_dev; |
495 | struct omap_hwmod *dh = omap_hwmod_lookup("iva"); | ||
496 | struct device *dev; | ||
497 | 495 | ||
498 | if (!mh || !dh) { | 496 | mpu_dev = omap2_get_mpuss_device(); |
497 | iva_dev = omap2_get_iva_device(); | ||
498 | |||
499 | if (!mpu_dev || !iva_dev) { | ||
499 | pr_err("%s: Aiee.. no mpu/dsp devices? %p %p\n", | 500 | pr_err("%s: Aiee.. no mpu/dsp devices? %p %p\n", |
500 | __func__, mh, dh); | 501 | __func__, mpu_dev, iva_dev); |
501 | return; | 502 | return; |
502 | } | 503 | } |
503 | /* Enable MPU 1GHz and lower opps */ | 504 | /* Enable MPU 1GHz and lower opps */ |
504 | dev = &mh->od->pdev.dev; | 505 | r = opp_enable(mpu_dev, 800000000); |
505 | r = opp_enable(dev, 800000000); | ||
506 | /* TODO: MPU 1GHz needs SR and ABB */ | 506 | /* TODO: MPU 1GHz needs SR and ABB */ |
507 | 507 | ||
508 | /* Enable IVA 800MHz and lower opps */ | 508 | /* Enable IVA 800MHz and lower opps */ |
509 | dev = &dh->od->pdev.dev; | 509 | r |= opp_enable(iva_dev, 660000000); |
510 | r |= opp_enable(dev, 660000000); | ||
511 | /* TODO: DSP 800MHz needs SR and ABB */ | 510 | /* TODO: DSP 800MHz needs SR and ABB */ |
512 | if (r) { | 511 | if (r) { |
513 | pr_err("%s: failed to enable higher opp %d\n", | 512 | pr_err("%s: failed to enable higher opp %d\n", |
@@ -516,10 +515,8 @@ static void __init beagle_opp_init(void) | |||
516 | * Cleanup - disable the higher freqs - we dont care | 515 | * Cleanup - disable the higher freqs - we dont care |
517 | * about the results | 516 | * about the results |
518 | */ | 517 | */ |
519 | dev = &mh->od->pdev.dev; | 518 | opp_disable(mpu_dev, 800000000); |
520 | opp_disable(dev, 800000000); | 519 | opp_disable(iva_dev, 660000000); |
521 | dev = &dh->od->pdev.dev; | ||
522 | opp_disable(dev, 660000000); | ||
523 | } | 520 | } |
524 | } | 521 | } |
525 | return; | 522 | return; |
diff --git a/arch/arm/mach-omap2/cminst44xx.h b/arch/arm/mach-omap2/cminst44xx.h index f2ea6453ade0..a018a7327879 100644 --- a/arch/arm/mach-omap2/cminst44xx.h +++ b/arch/arm/mach-omap2/cminst44xx.h | |||
@@ -18,13 +18,36 @@ extern void omap4_cminst_clkdm_force_sleep(u8 part, s16 inst, u16 cdoffs); | |||
18 | extern void omap4_cminst_clkdm_force_wakeup(u8 part, s16 inst, u16 cdoffs); | 18 | extern void omap4_cminst_clkdm_force_wakeup(u8 part, s16 inst, u16 cdoffs); |
19 | 19 | ||
20 | extern int omap4_cminst_wait_module_ready(u8 part, u16 inst, s16 cdoffs, u16 clkctrl_offs); | 20 | extern int omap4_cminst_wait_module_ready(u8 part, u16 inst, s16 cdoffs, u16 clkctrl_offs); |
21 | extern int omap4_cminst_wait_module_idle(u8 part, u16 inst, s16 cdoffs, u16 clkctrl_offs); | 21 | |
22 | # ifdef CONFIG_ARCH_OMAP4 | ||
23 | extern int omap4_cminst_wait_module_idle(u8 part, u16 inst, s16 cdoffs, | ||
24 | u16 clkctrl_offs); | ||
22 | 25 | ||
23 | extern void omap4_cminst_module_enable(u8 mode, u8 part, u16 inst, s16 cdoffs, | 26 | extern void omap4_cminst_module_enable(u8 mode, u8 part, u16 inst, s16 cdoffs, |
24 | u16 clkctrl_offs); | 27 | u16 clkctrl_offs); |
25 | extern void omap4_cminst_module_disable(u8 part, u16 inst, s16 cdoffs, | 28 | extern void omap4_cminst_module_disable(u8 part, u16 inst, s16 cdoffs, |
26 | u16 clkctrl_offs); | 29 | u16 clkctrl_offs); |
27 | 30 | ||
31 | # else | ||
32 | |||
33 | static inline int omap4_cminst_wait_module_idle(u8 part, u16 inst, s16 cdoffs, | ||
34 | u16 clkctrl_offs) | ||
35 | { | ||
36 | return 0; | ||
37 | } | ||
38 | |||
39 | static inline void omap4_cminst_module_enable(u8 mode, u8 part, u16 inst, | ||
40 | s16 cdoffs, u16 clkctrl_offs) | ||
41 | { | ||
42 | } | ||
43 | |||
44 | static inline void omap4_cminst_module_disable(u8 part, u16 inst, s16 cdoffs, | ||
45 | u16 clkctrl_offs) | ||
46 | { | ||
47 | } | ||
48 | |||
49 | # endif | ||
50 | |||
28 | /* | 51 | /* |
29 | * In an ideal world, we would not export these low-level functions, | 52 | * In an ideal world, we would not export these low-level functions, |
30 | * but this will probably take some time to fix properly | 53 | * but this will probably take some time to fix properly |
diff --git a/arch/arm/mach-omap2/mux.c b/arch/arm/mach-omap2/mux.c index c7fb22abc219..655e9480eb98 100644 --- a/arch/arm/mach-omap2/mux.c +++ b/arch/arm/mach-omap2/mux.c | |||
@@ -821,11 +821,10 @@ static void __init omap_mux_set_cmdline_signals(void) | |||
821 | if (!omap_mux_options) | 821 | if (!omap_mux_options) |
822 | return; | 822 | return; |
823 | 823 | ||
824 | options = kmalloc(strlen(omap_mux_options) + 1, GFP_KERNEL); | 824 | options = kstrdup(omap_mux_options, GFP_KERNEL); |
825 | if (!options) | 825 | if (!options) |
826 | return; | 826 | return; |
827 | 827 | ||
828 | strcpy(options, omap_mux_options); | ||
829 | next_opt = options; | 828 | next_opt = options; |
830 | 829 | ||
831 | while ((token = strsep(&next_opt, ",")) != NULL) { | 830 | while ((token = strsep(&next_opt, ",")) != NULL) { |
@@ -855,24 +854,19 @@ static int __init omap_mux_copy_names(struct omap_mux *src, | |||
855 | 854 | ||
856 | for (i = 0; i < OMAP_MUX_NR_MODES; i++) { | 855 | for (i = 0; i < OMAP_MUX_NR_MODES; i++) { |
857 | if (src->muxnames[i]) { | 856 | if (src->muxnames[i]) { |
858 | dst->muxnames[i] = | 857 | dst->muxnames[i] = kstrdup(src->muxnames[i], |
859 | kmalloc(strlen(src->muxnames[i]) + 1, | 858 | GFP_KERNEL); |
860 | GFP_KERNEL); | ||
861 | if (!dst->muxnames[i]) | 859 | if (!dst->muxnames[i]) |
862 | goto free; | 860 | goto free; |
863 | strcpy(dst->muxnames[i], src->muxnames[i]); | ||
864 | } | 861 | } |
865 | } | 862 | } |
866 | 863 | ||
867 | #ifdef CONFIG_DEBUG_FS | 864 | #ifdef CONFIG_DEBUG_FS |
868 | for (i = 0; i < OMAP_MUX_NR_SIDES; i++) { | 865 | for (i = 0; i < OMAP_MUX_NR_SIDES; i++) { |
869 | if (src->balls[i]) { | 866 | if (src->balls[i]) { |
870 | dst->balls[i] = | 867 | dst->balls[i] = kstrdup(src->balls[i], GFP_KERNEL); |
871 | kmalloc(strlen(src->balls[i]) + 1, | ||
872 | GFP_KERNEL); | ||
873 | if (!dst->balls[i]) | 868 | if (!dst->balls[i]) |
874 | goto free; | 869 | goto free; |
875 | strcpy(dst->balls[i], src->balls[i]); | ||
876 | } | 870 | } |
877 | } | 871 | } |
878 | #endif | 872 | #endif |
diff --git a/arch/arm/mach-omap2/smartreflex.c b/arch/arm/mach-omap2/smartreflex.c index 2ce2fb7664bc..34c01a7de810 100644 --- a/arch/arm/mach-omap2/smartreflex.c +++ b/arch/arm/mach-omap2/smartreflex.c | |||
@@ -621,7 +621,7 @@ void sr_disable(struct voltagedomain *voltdm) | |||
621 | sr_v2_disable(sr); | 621 | sr_v2_disable(sr); |
622 | } | 622 | } |
623 | 623 | ||
624 | pm_runtime_put_sync(&sr->pdev->dev); | 624 | pm_runtime_put_sync_suspend(&sr->pdev->dev); |
625 | } | 625 | } |
626 | 626 | ||
627 | /** | 627 | /** |
@@ -860,6 +860,7 @@ static int __init omap_sr_probe(struct platform_device *pdev) | |||
860 | irq = platform_get_resource(pdev, IORESOURCE_IRQ, 0); | 860 | irq = platform_get_resource(pdev, IORESOURCE_IRQ, 0); |
861 | 861 | ||
862 | pm_runtime_enable(&pdev->dev); | 862 | pm_runtime_enable(&pdev->dev); |
863 | pm_runtime_irq_safe(&pdev->dev); | ||
863 | 864 | ||
864 | sr_info->pdev = pdev; | 865 | sr_info->pdev = pdev; |
865 | sr_info->srid = pdev->id; | 866 | sr_info->srid = pdev->id; |
diff --git a/arch/arm/mach-omap2/timer.c b/arch/arm/mach-omap2/timer.c index e9640728239b..cf1de7d2630d 100644 --- a/arch/arm/mach-omap2/timer.c +++ b/arch/arm/mach-omap2/timer.c | |||
@@ -293,7 +293,8 @@ static void __init omap2_gp_clocksource_init(int gptimer_id, | |||
293 | pr_info("OMAP clocksource: GPTIMER%d at %lu Hz\n", | 293 | pr_info("OMAP clocksource: GPTIMER%d at %lu Hz\n", |
294 | gptimer_id, clksrc.rate); | 294 | gptimer_id, clksrc.rate); |
295 | 295 | ||
296 | __omap_dm_timer_load_start(clksrc.io_base, OMAP_TIMER_CTRL_ST, 0, 1); | 296 | __omap_dm_timer_load_start(clksrc.io_base, |
297 | OMAP_TIMER_CTRL_ST | OMAP_TIMER_CTRL_AR, 0, 1); | ||
297 | init_sched_clock(&cd, dmtimer_update_sched_clock, 32, clksrc.rate); | 298 | init_sched_clock(&cd, dmtimer_update_sched_clock, 32, clksrc.rate); |
298 | 299 | ||
299 | if (clocksource_register_hz(&clocksource_gpt, clksrc.rate)) | 300 | if (clocksource_register_hz(&clocksource_gpt, clksrc.rate)) |
diff --git a/arch/arm/mach-omap2/twl-common.c b/arch/arm/mach-omap2/twl-common.c index 2543342dbccb..daa056ed8738 100644 --- a/arch/arm/mach-omap2/twl-common.c +++ b/arch/arm/mach-omap2/twl-common.c | |||
@@ -48,14 +48,7 @@ void __init omap_pmic_init(int bus, u32 clkrate, | |||
48 | omap_register_i2c_bus(bus, clkrate, &pmic_i2c_board_info, 1); | 48 | omap_register_i2c_bus(bus, clkrate, &pmic_i2c_board_info, 1); |
49 | } | 49 | } |
50 | 50 | ||
51 | static struct twl4030_usb_data omap4_usb_pdata = { | 51 | #if defined(CONFIG_ARCH_OMAP3) |
52 | .phy_init = omap4430_phy_init, | ||
53 | .phy_exit = omap4430_phy_exit, | ||
54 | .phy_power = omap4430_phy_power, | ||
55 | .phy_set_clock = omap4430_phy_set_clk, | ||
56 | .phy_suspend = omap4430_phy_suspend, | ||
57 | }; | ||
58 | |||
59 | static struct twl4030_usb_data omap3_usb_pdata = { | 52 | static struct twl4030_usb_data omap3_usb_pdata = { |
60 | .usb_mode = T2_USB_MODE_ULPI, | 53 | .usb_mode = T2_USB_MODE_ULPI, |
61 | }; | 54 | }; |
@@ -122,6 +115,45 @@ static struct regulator_init_data omap3_vpll2_idata = { | |||
122 | .consumer_supplies = omap3_vpll2_supplies, | 115 | .consumer_supplies = omap3_vpll2_supplies, |
123 | }; | 116 | }; |
124 | 117 | ||
118 | void __init omap3_pmic_get_config(struct twl4030_platform_data *pmic_data, | ||
119 | u32 pdata_flags, u32 regulators_flags) | ||
120 | { | ||
121 | if (!pmic_data->irq_base) | ||
122 | pmic_data->irq_base = TWL4030_IRQ_BASE; | ||
123 | if (!pmic_data->irq_end) | ||
124 | pmic_data->irq_end = TWL4030_IRQ_END; | ||
125 | |||
126 | /* Common platform data configurations */ | ||
127 | if (pdata_flags & TWL_COMMON_PDATA_USB && !pmic_data->usb) | ||
128 | pmic_data->usb = &omap3_usb_pdata; | ||
129 | |||
130 | if (pdata_flags & TWL_COMMON_PDATA_BCI && !pmic_data->bci) | ||
131 | pmic_data->bci = &omap3_bci_pdata; | ||
132 | |||
133 | if (pdata_flags & TWL_COMMON_PDATA_MADC && !pmic_data->madc) | ||
134 | pmic_data->madc = &omap3_madc_pdata; | ||
135 | |||
136 | if (pdata_flags & TWL_COMMON_PDATA_AUDIO && !pmic_data->audio) | ||
137 | pmic_data->audio = &omap3_audio_pdata; | ||
138 | |||
139 | /* Common regulator configurations */ | ||
140 | if (regulators_flags & TWL_COMMON_REGULATOR_VDAC && !pmic_data->vdac) | ||
141 | pmic_data->vdac = &omap3_vdac_idata; | ||
142 | |||
143 | if (regulators_flags & TWL_COMMON_REGULATOR_VPLL2 && !pmic_data->vpll2) | ||
144 | pmic_data->vpll2 = &omap3_vpll2_idata; | ||
145 | } | ||
146 | #endif /* CONFIG_ARCH_OMAP3 */ | ||
147 | |||
148 | #if defined(CONFIG_ARCH_OMAP4) | ||
149 | static struct twl4030_usb_data omap4_usb_pdata = { | ||
150 | .phy_init = omap4430_phy_init, | ||
151 | .phy_exit = omap4430_phy_exit, | ||
152 | .phy_power = omap4430_phy_power, | ||
153 | .phy_set_clock = omap4430_phy_set_clk, | ||
154 | .phy_suspend = omap4430_phy_suspend, | ||
155 | }; | ||
156 | |||
125 | static struct regulator_init_data omap4_vdac_idata = { | 157 | static struct regulator_init_data omap4_vdac_idata = { |
126 | .constraints = { | 158 | .constraints = { |
127 | .min_uV = 1800000, | 159 | .min_uV = 1800000, |
@@ -273,32 +305,4 @@ void __init omap4_pmic_get_config(struct twl4030_platform_data *pmic_data, | |||
273 | !pmic_data->clk32kg) | 305 | !pmic_data->clk32kg) |
274 | pmic_data->clk32kg = &omap4_clk32kg_idata; | 306 | pmic_data->clk32kg = &omap4_clk32kg_idata; |
275 | } | 307 | } |
276 | 308 | #endif /* CONFIG_ARCH_OMAP4 */ | |
277 | void __init omap3_pmic_get_config(struct twl4030_platform_data *pmic_data, | ||
278 | u32 pdata_flags, u32 regulators_flags) | ||
279 | { | ||
280 | if (!pmic_data->irq_base) | ||
281 | pmic_data->irq_base = TWL4030_IRQ_BASE; | ||
282 | if (!pmic_data->irq_end) | ||
283 | pmic_data->irq_end = TWL4030_IRQ_END; | ||
284 | |||
285 | /* Common platform data configurations */ | ||
286 | if (pdata_flags & TWL_COMMON_PDATA_USB && !pmic_data->usb) | ||
287 | pmic_data->usb = &omap3_usb_pdata; | ||
288 | |||
289 | if (pdata_flags & TWL_COMMON_PDATA_BCI && !pmic_data->bci) | ||
290 | pmic_data->bci = &omap3_bci_pdata; | ||
291 | |||
292 | if (pdata_flags & TWL_COMMON_PDATA_MADC && !pmic_data->madc) | ||
293 | pmic_data->madc = &omap3_madc_pdata; | ||
294 | |||
295 | if (pdata_flags & TWL_COMMON_PDATA_AUDIO && !pmic_data->audio) | ||
296 | pmic_data->audio = &omap3_audio_pdata; | ||
297 | |||
298 | /* Common regulator configurations */ | ||
299 | if (regulators_flags & TWL_COMMON_REGULATOR_VDAC && !pmic_data->vdac) | ||
300 | pmic_data->vdac = &omap3_vdac_idata; | ||
301 | |||
302 | if (regulators_flags & TWL_COMMON_REGULATOR_VPLL2 && !pmic_data->vpll2) | ||
303 | pmic_data->vpll2 = &omap3_vpll2_idata; | ||
304 | } | ||
diff --git a/arch/arm/mach-s3c64xx/mach-crag6410.c b/arch/arm/mach-s3c64xx/mach-crag6410.c index 9026249233ad..af0c2fe1ea37 100644 --- a/arch/arm/mach-s3c64xx/mach-crag6410.c +++ b/arch/arm/mach-s3c64xx/mach-crag6410.c | |||
@@ -65,7 +65,7 @@ | |||
65 | #include <plat/iic.h> | 65 | #include <plat/iic.h> |
66 | #include <plat/pm.h> | 66 | #include <plat/pm.h> |
67 | 67 | ||
68 | #include <sound/wm8915.h> | 68 | #include <sound/wm8996.h> |
69 | #include <sound/wm8962.h> | 69 | #include <sound/wm8962.h> |
70 | #include <sound/wm9081.h> | 70 | #include <sound/wm9081.h> |
71 | 71 | ||
@@ -614,7 +614,7 @@ static struct wm831x_pdata glenfarclas_pmic_pdata __initdata = { | |||
614 | .disable_touch = true, | 614 | .disable_touch = true, |
615 | }; | 615 | }; |
616 | 616 | ||
617 | static struct wm8915_retune_mobile_config wm8915_retune[] = { | 617 | static struct wm8996_retune_mobile_config wm8996_retune[] = { |
618 | { | 618 | { |
619 | .name = "Sub LPF", | 619 | .name = "Sub LPF", |
620 | .rate = 48000, | 620 | .rate = 48000, |
@@ -635,12 +635,12 @@ static struct wm8915_retune_mobile_config wm8915_retune[] = { | |||
635 | }, | 635 | }, |
636 | }; | 636 | }; |
637 | 637 | ||
638 | static struct wm8915_pdata wm8915_pdata __initdata = { | 638 | static struct wm8996_pdata wm8996_pdata __initdata = { |
639 | .ldo_ena = S3C64XX_GPN(7), | 639 | .ldo_ena = S3C64XX_GPN(7), |
640 | .gpio_base = CODEC_GPIO_BASE, | 640 | .gpio_base = CODEC_GPIO_BASE, |
641 | .micdet_def = 1, | 641 | .micdet_def = 1, |
642 | .inl_mode = WM8915_DIFFERRENTIAL_1, | 642 | .inl_mode = WM8996_DIFFERRENTIAL_1, |
643 | .inr_mode = WM8915_DIFFERRENTIAL_1, | 643 | .inr_mode = WM8996_DIFFERRENTIAL_1, |
644 | 644 | ||
645 | .irq_flags = IRQF_TRIGGER_RISING, | 645 | .irq_flags = IRQF_TRIGGER_RISING, |
646 | 646 | ||
@@ -652,8 +652,8 @@ static struct wm8915_pdata wm8915_pdata __initdata = { | |||
652 | 0x020e, /* GPIO5 == CLKOUT */ | 652 | 0x020e, /* GPIO5 == CLKOUT */ |
653 | }, | 653 | }, |
654 | 654 | ||
655 | .retune_mobile_cfgs = wm8915_retune, | 655 | .retune_mobile_cfgs = wm8996_retune, |
656 | .num_retune_mobile_cfgs = ARRAY_SIZE(wm8915_retune), | 656 | .num_retune_mobile_cfgs = ARRAY_SIZE(wm8996_retune), |
657 | }; | 657 | }; |
658 | 658 | ||
659 | static struct wm8962_pdata wm8962_pdata __initdata = { | 659 | static struct wm8962_pdata wm8962_pdata __initdata = { |
@@ -679,8 +679,8 @@ static struct i2c_board_info i2c_devs1[] __initdata = { | |||
679 | .platform_data = &glenfarclas_pmic_pdata }, | 679 | .platform_data = &glenfarclas_pmic_pdata }, |
680 | 680 | ||
681 | { I2C_BOARD_INFO("wm1250-ev1", 0x27) }, | 681 | { I2C_BOARD_INFO("wm1250-ev1", 0x27) }, |
682 | { I2C_BOARD_INFO("wm8915", 0x1a), | 682 | { I2C_BOARD_INFO("wm8996", 0x1a), |
683 | .platform_data = &wm8915_pdata, | 683 | .platform_data = &wm8996_pdata, |
684 | .irq = GLENFARCLAS_PMIC_IRQ_BASE + WM831X_IRQ_GPIO_2, | 684 | .irq = GLENFARCLAS_PMIC_IRQ_BASE + WM831X_IRQ_GPIO_2, |
685 | }, | 685 | }, |
686 | { I2C_BOARD_INFO("wm9081", 0x6c), | 686 | { I2C_BOARD_INFO("wm9081", 0x6c), |
diff --git a/arch/arm/mach-sa1100/pci-nanoengine.c b/arch/arm/mach-sa1100/pci-nanoengine.c index 964c6c3cd7a6..dd39fee59549 100644 --- a/arch/arm/mach-sa1100/pci-nanoengine.c +++ b/arch/arm/mach-sa1100/pci-nanoengine.c | |||
@@ -28,6 +28,7 @@ | |||
28 | #include <asm/mach-types.h> | 28 | #include <asm/mach-types.h> |
29 | 29 | ||
30 | #include <mach/nanoengine.h> | 30 | #include <mach/nanoengine.h> |
31 | #include <mach/hardware.h> | ||
31 | 32 | ||
32 | static DEFINE_SPINLOCK(nano_lock); | 33 | static DEFINE_SPINLOCK(nano_lock); |
33 | 34 | ||
diff --git a/arch/arm/mm/alignment.c b/arch/arm/mm/alignment.c index be7c638b648b..cfbcf8b95599 100644 --- a/arch/arm/mm/alignment.c +++ b/arch/arm/mm/alignment.c | |||
@@ -22,6 +22,7 @@ | |||
22 | #include <linux/sched.h> | 22 | #include <linux/sched.h> |
23 | #include <linux/uaccess.h> | 23 | #include <linux/uaccess.h> |
24 | 24 | ||
25 | #include <asm/system.h> | ||
25 | #include <asm/unaligned.h> | 26 | #include <asm/unaligned.h> |
26 | 27 | ||
27 | #include "fault.h" | 28 | #include "fault.h" |
@@ -95,6 +96,33 @@ static const char *usermode_action[] = { | |||
95 | "signal+warn" | 96 | "signal+warn" |
96 | }; | 97 | }; |
97 | 98 | ||
99 | /* Return true if and only if the ARMv6 unaligned access model is in use. */ | ||
100 | static bool cpu_is_v6_unaligned(void) | ||
101 | { | ||
102 | return cpu_architecture() >= CPU_ARCH_ARMv6 && (cr_alignment & CR_U); | ||
103 | } | ||
104 | |||
105 | static int safe_usermode(int new_usermode, bool warn) | ||
106 | { | ||
107 | /* | ||
108 | * ARMv6 and later CPUs can perform unaligned accesses for | ||
109 | * most single load and store instructions up to word size. | ||
110 | * LDM, STM, LDRD and STRD still need to be handled. | ||
111 | * | ||
112 | * Ignoring the alignment fault is not an option on these | ||
113 | * CPUs since we spin re-faulting the instruction without | ||
114 | * making any progress. | ||
115 | */ | ||
116 | if (cpu_is_v6_unaligned() && !(new_usermode & (UM_FIXUP | UM_SIGNAL))) { | ||
117 | new_usermode |= UM_FIXUP; | ||
118 | |||
119 | if (warn) | ||
120 | printk(KERN_WARNING "alignment: ignoring faults is unsafe on this CPU. Defaulting to fixup mode.\n"); | ||
121 | } | ||
122 | |||
123 | return new_usermode; | ||
124 | } | ||
125 | |||
98 | static int alignment_proc_show(struct seq_file *m, void *v) | 126 | static int alignment_proc_show(struct seq_file *m, void *v) |
99 | { | 127 | { |
100 | seq_printf(m, "User:\t\t%lu\n", ai_user); | 128 | seq_printf(m, "User:\t\t%lu\n", ai_user); |
@@ -125,7 +153,7 @@ static ssize_t alignment_proc_write(struct file *file, const char __user *buffer | |||
125 | if (get_user(mode, buffer)) | 153 | if (get_user(mode, buffer)) |
126 | return -EFAULT; | 154 | return -EFAULT; |
127 | if (mode >= '0' && mode <= '5') | 155 | if (mode >= '0' && mode <= '5') |
128 | ai_usermode = mode - '0'; | 156 | ai_usermode = safe_usermode(mode - '0', true); |
129 | } | 157 | } |
130 | return count; | 158 | return count; |
131 | } | 159 | } |
@@ -886,9 +914,16 @@ do_alignment(unsigned long addr, unsigned int fsr, struct pt_regs *regs) | |||
886 | if (ai_usermode & UM_FIXUP) | 914 | if (ai_usermode & UM_FIXUP) |
887 | goto fixup; | 915 | goto fixup; |
888 | 916 | ||
889 | if (ai_usermode & UM_SIGNAL) | 917 | if (ai_usermode & UM_SIGNAL) { |
890 | force_sig(SIGBUS, current); | 918 | siginfo_t si; |
891 | else { | 919 | |
920 | si.si_signo = SIGBUS; | ||
921 | si.si_errno = 0; | ||
922 | si.si_code = BUS_ADRALN; | ||
923 | si.si_addr = (void __user *)addr; | ||
924 | |||
925 | force_sig_info(si.si_signo, &si, current); | ||
926 | } else { | ||
892 | /* | 927 | /* |
893 | * We're about to disable the alignment trap and return to | 928 | * We're about to disable the alignment trap and return to |
894 | * user space. But if an interrupt occurs before actually | 929 | * user space. But if an interrupt occurs before actually |
@@ -926,20 +961,11 @@ static int __init alignment_init(void) | |||
926 | return -ENOMEM; | 961 | return -ENOMEM; |
927 | #endif | 962 | #endif |
928 | 963 | ||
929 | /* | 964 | if (cpu_is_v6_unaligned()) { |
930 | * ARMv6 and later CPUs can perform unaligned accesses for | ||
931 | * most single load and store instructions up to word size. | ||
932 | * LDM, STM, LDRD and STRD still need to be handled. | ||
933 | * | ||
934 | * Ignoring the alignment fault is not an option on these | ||
935 | * CPUs since we spin re-faulting the instruction without | ||
936 | * making any progress. | ||
937 | */ | ||
938 | if (cpu_architecture() >= CPU_ARCH_ARMv6 && (cr_alignment & CR_U)) { | ||
939 | cr_alignment &= ~CR_A; | 965 | cr_alignment &= ~CR_A; |
940 | cr_no_alignment &= ~CR_A; | 966 | cr_no_alignment &= ~CR_A; |
941 | set_cr(cr_alignment); | 967 | set_cr(cr_alignment); |
942 | ai_usermode = UM_FIXUP; | 968 | ai_usermode = safe_usermode(ai_usermode, false); |
943 | } | 969 | } |
944 | 970 | ||
945 | hook_fault_code(1, do_alignment, SIGBUS, BUS_ADRALN, | 971 | hook_fault_code(1, do_alignment, SIGBUS, BUS_ADRALN, |
diff --git a/arch/arm/mm/init.c b/arch/arm/mm/init.c index 2fee782077c1..91bca355cd31 100644 --- a/arch/arm/mm/init.c +++ b/arch/arm/mm/init.c | |||
@@ -441,7 +441,7 @@ static inline int free_area(unsigned long pfn, unsigned long end, char *s) | |||
441 | static inline void poison_init_mem(void *s, size_t count) | 441 | static inline void poison_init_mem(void *s, size_t count) |
442 | { | 442 | { |
443 | u32 *p = (u32 *)s; | 443 | u32 *p = (u32 *)s; |
444 | while ((count = count - 4)) | 444 | for (; count != 0; count -= 4) |
445 | *p++ = 0xe7fddef0; | 445 | *p++ = 0xe7fddef0; |
446 | } | 446 | } |
447 | 447 | ||
diff --git a/arch/arm/mm/proc-arm946.S b/arch/arm/mm/proc-arm946.S index f8f7ea34bfc5..683af3a182b7 100644 --- a/arch/arm/mm/proc-arm946.S +++ b/arch/arm/mm/proc-arm946.S | |||
@@ -410,6 +410,7 @@ __arm946_proc_info: | |||
410 | .long 0x41009460 | 410 | .long 0x41009460 |
411 | .long 0xff00fff0 | 411 | .long 0xff00fff0 |
412 | .long 0 | 412 | .long 0 |
413 | .long 0 | ||
413 | b __arm946_setup | 414 | b __arm946_setup |
414 | .long cpu_arch_name | 415 | .long cpu_arch_name |
415 | .long cpu_elf_name | 416 | .long cpu_elf_name |
@@ -418,6 +419,6 @@ __arm946_proc_info: | |||
418 | .long arm946_processor_functions | 419 | .long arm946_processor_functions |
419 | .long 0 | 420 | .long 0 |
420 | .long 0 | 421 | .long 0 |
421 | .long arm940_cache_fns | 422 | .long arm946_cache_fns |
422 | .size __arm946_proc_info, . - __arm946_proc_info | 423 | .size __arm946_proc_info, . - __arm946_proc_info |
423 | 424 | ||
diff --git a/arch/arm/plat-mxc/include/mach/debug-macro.S b/arch/arm/plat-mxc/include/mach/debug-macro.S index 91fc7cdb5dc9..e4dde91f0231 100644 --- a/arch/arm/plat-mxc/include/mach/debug-macro.S +++ b/arch/arm/plat-mxc/include/mach/debug-macro.S | |||
@@ -44,6 +44,14 @@ | |||
44 | #define UART_PADDR MX51_UART1_BASE_ADDR | 44 | #define UART_PADDR MX51_UART1_BASE_ADDR |
45 | #endif | 45 | #endif |
46 | 46 | ||
47 | /* iMX50/53 have same addresses, but not iMX51 */ | ||
48 | #if defined(CONFIG_SOC_IMX50) || defined(CONFIG_SOC_IMX53) | ||
49 | #ifdef UART_PADDR | ||
50 | #error "CONFIG_DEBUG_LL is incompatible with multiple archs" | ||
51 | #endif | ||
52 | #define UART_PADDR MX53_UART1_BASE_ADDR | ||
53 | #endif | ||
54 | |||
47 | #define UART_VADDR IMX_IO_ADDRESS(UART_PADDR) | 55 | #define UART_VADDR IMX_IO_ADDRESS(UART_PADDR) |
48 | 56 | ||
49 | .macro addruart, rp, rv | 57 | .macro addruart, rp, rv |
diff --git a/arch/arm/plat-mxc/include/mach/iomux-mx53.h b/arch/arm/plat-mxc/include/mach/iomux-mx53.h index 9440b9e00e89..5408fd1fc736 100644 --- a/arch/arm/plat-mxc/include/mach/iomux-mx53.h +++ b/arch/arm/plat-mxc/include/mach/iomux-mx53.h | |||
@@ -30,6 +30,9 @@ | |||
30 | #define MX53_SDHC_PAD_CTRL (PAD_CTL_HYS | PAD_CTL_PKE | PAD_CTL_PUE | \ | 30 | #define MX53_SDHC_PAD_CTRL (PAD_CTL_HYS | PAD_CTL_PKE | PAD_CTL_PUE | \ |
31 | PAD_CTL_PUS_47K_UP | PAD_CTL_DSE_HIGH | \ | 31 | PAD_CTL_PUS_47K_UP | PAD_CTL_DSE_HIGH | \ |
32 | PAD_CTL_SRE_FAST) | 32 | PAD_CTL_SRE_FAST) |
33 | #define PAD_CTRL_I2C (PAD_CTL_SRE_FAST | PAD_CTL_ODE | PAD_CTL_PKE | \ | ||
34 | PAD_CTL_PUE | PAD_CTL_DSE_HIGH | PAD_CTL_PUS_100K_UP \ | ||
35 | | PAD_CTL_HYS) | ||
33 | 36 | ||
34 | #define _MX53_PAD_GPIO_19__KPP_COL_5 IOMUX_PAD(0x348, 0x20, 0, 0x840, 0, 0) | 37 | #define _MX53_PAD_GPIO_19__KPP_COL_5 IOMUX_PAD(0x348, 0x20, 0, 0x840, 0, 0) |
35 | #define _MX53_PAD_GPIO_19__GPIO4_5 IOMUX_PAD(0x348, 0x20, 1, 0x0, 0, 0) | 38 | #define _MX53_PAD_GPIO_19__GPIO4_5 IOMUX_PAD(0x348, 0x20, 1, 0x0, 0, 0) |
@@ -1256,7 +1259,7 @@ | |||
1256 | #define MX53_PAD_KEY_COL3__GPIO4_12 (_MX53_PAD_KEY_COL3__GPIO4_12 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1259 | #define MX53_PAD_KEY_COL3__GPIO4_12 (_MX53_PAD_KEY_COL3__GPIO4_12 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1257 | #define MX53_PAD_KEY_COL3__USBOH3_H2_DP (_MX53_PAD_KEY_COL3__USBOH3_H2_DP | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1260 | #define MX53_PAD_KEY_COL3__USBOH3_H2_DP (_MX53_PAD_KEY_COL3__USBOH3_H2_DP | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1258 | #define MX53_PAD_KEY_COL3__SPDIF_IN1 (_MX53_PAD_KEY_COL3__SPDIF_IN1 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1261 | #define MX53_PAD_KEY_COL3__SPDIF_IN1 (_MX53_PAD_KEY_COL3__SPDIF_IN1 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1259 | #define MX53_PAD_KEY_COL3__I2C2_SCL (_MX53_PAD_KEY_COL3__I2C2_SCL | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1262 | #define MX53_PAD_KEY_COL3__I2C2_SCL (_MX53_PAD_KEY_COL3__I2C2_SCL | MUX_PAD_CTRL(PAD_CTRL_I2C)) |
1260 | #define MX53_PAD_KEY_COL3__ECSPI1_SS3 (_MX53_PAD_KEY_COL3__ECSPI1_SS3 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1263 | #define MX53_PAD_KEY_COL3__ECSPI1_SS3 (_MX53_PAD_KEY_COL3__ECSPI1_SS3 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1261 | #define MX53_PAD_KEY_COL3__FEC_CRS (_MX53_PAD_KEY_COL3__FEC_CRS | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1264 | #define MX53_PAD_KEY_COL3__FEC_CRS (_MX53_PAD_KEY_COL3__FEC_CRS | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1262 | #define MX53_PAD_KEY_COL3__USBPHY1_SIECLOCK (_MX53_PAD_KEY_COL3__USBPHY1_SIECLOCK | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1265 | #define MX53_PAD_KEY_COL3__USBPHY1_SIECLOCK (_MX53_PAD_KEY_COL3__USBPHY1_SIECLOCK | MUX_PAD_CTRL(NO_PAD_CTRL)) |
@@ -1264,7 +1267,7 @@ | |||
1264 | #define MX53_PAD_KEY_ROW3__GPIO4_13 (_MX53_PAD_KEY_ROW3__GPIO4_13 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1267 | #define MX53_PAD_KEY_ROW3__GPIO4_13 (_MX53_PAD_KEY_ROW3__GPIO4_13 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1265 | #define MX53_PAD_KEY_ROW3__USBOH3_H2_DM (_MX53_PAD_KEY_ROW3__USBOH3_H2_DM | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1268 | #define MX53_PAD_KEY_ROW3__USBOH3_H2_DM (_MX53_PAD_KEY_ROW3__USBOH3_H2_DM | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1266 | #define MX53_PAD_KEY_ROW3__CCM_ASRC_EXT_CLK (_MX53_PAD_KEY_ROW3__CCM_ASRC_EXT_CLK | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1269 | #define MX53_PAD_KEY_ROW3__CCM_ASRC_EXT_CLK (_MX53_PAD_KEY_ROW3__CCM_ASRC_EXT_CLK | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1267 | #define MX53_PAD_KEY_ROW3__I2C2_SDA (_MX53_PAD_KEY_ROW3__I2C2_SDA | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1270 | #define MX53_PAD_KEY_ROW3__I2C2_SDA (_MX53_PAD_KEY_ROW3__I2C2_SDA | MUX_PAD_CTRL(PAD_CTRL_I2C)) |
1268 | #define MX53_PAD_KEY_ROW3__OSC32K_32K_OUT (_MX53_PAD_KEY_ROW3__OSC32K_32K_OUT | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1271 | #define MX53_PAD_KEY_ROW3__OSC32K_32K_OUT (_MX53_PAD_KEY_ROW3__OSC32K_32K_OUT | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1269 | #define MX53_PAD_KEY_ROW3__CCM_PLL4_BYP (_MX53_PAD_KEY_ROW3__CCM_PLL4_BYP | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1272 | #define MX53_PAD_KEY_ROW3__CCM_PLL4_BYP (_MX53_PAD_KEY_ROW3__CCM_PLL4_BYP | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1270 | #define MX53_PAD_KEY_ROW3__USBPHY1_LINESTATE_0 (_MX53_PAD_KEY_ROW3__USBPHY1_LINESTATE_0 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1273 | #define MX53_PAD_KEY_ROW3__USBPHY1_LINESTATE_0 (_MX53_PAD_KEY_ROW3__USBPHY1_LINESTATE_0 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
@@ -1536,7 +1539,7 @@ | |||
1536 | #define MX53_PAD_CSI0_DAT8__KPP_COL_7 (_MX53_PAD_CSI0_DAT8__KPP_COL_7 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1539 | #define MX53_PAD_CSI0_DAT8__KPP_COL_7 (_MX53_PAD_CSI0_DAT8__KPP_COL_7 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1537 | #define MX53_PAD_CSI0_DAT8__ECSPI2_SCLK (_MX53_PAD_CSI0_DAT8__ECSPI2_SCLK | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1540 | #define MX53_PAD_CSI0_DAT8__ECSPI2_SCLK (_MX53_PAD_CSI0_DAT8__ECSPI2_SCLK | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1538 | #define MX53_PAD_CSI0_DAT8__USBOH3_USBH3_OC (_MX53_PAD_CSI0_DAT8__USBOH3_USBH3_OC | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1541 | #define MX53_PAD_CSI0_DAT8__USBOH3_USBH3_OC (_MX53_PAD_CSI0_DAT8__USBOH3_USBH3_OC | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1539 | #define MX53_PAD_CSI0_DAT8__I2C1_SDA (_MX53_PAD_CSI0_DAT8__I2C1_SDA | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1542 | #define MX53_PAD_CSI0_DAT8__I2C1_SDA (_MX53_PAD_CSI0_DAT8__I2C1_SDA | MUX_PAD_CTRL(PAD_CTRL_I2C)) |
1540 | #define MX53_PAD_CSI0_DAT8__EMI_EMI_DEBUG_37 (_MX53_PAD_CSI0_DAT8__EMI_EMI_DEBUG_37 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1543 | #define MX53_PAD_CSI0_DAT8__EMI_EMI_DEBUG_37 (_MX53_PAD_CSI0_DAT8__EMI_EMI_DEBUG_37 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1541 | #define MX53_PAD_CSI0_DAT8__TPIU_TRACE_5 (_MX53_PAD_CSI0_DAT8__TPIU_TRACE_5 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1544 | #define MX53_PAD_CSI0_DAT8__TPIU_TRACE_5 (_MX53_PAD_CSI0_DAT8__TPIU_TRACE_5 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1542 | #define MX53_PAD_CSI0_DAT9__IPU_CSI0_D_9 (_MX53_PAD_CSI0_DAT9__IPU_CSI0_D_9 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1545 | #define MX53_PAD_CSI0_DAT9__IPU_CSI0_D_9 (_MX53_PAD_CSI0_DAT9__IPU_CSI0_D_9 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
@@ -1544,7 +1547,7 @@ | |||
1544 | #define MX53_PAD_CSI0_DAT9__KPP_ROW_7 (_MX53_PAD_CSI0_DAT9__KPP_ROW_7 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1547 | #define MX53_PAD_CSI0_DAT9__KPP_ROW_7 (_MX53_PAD_CSI0_DAT9__KPP_ROW_7 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1545 | #define MX53_PAD_CSI0_DAT9__ECSPI2_MOSI (_MX53_PAD_CSI0_DAT9__ECSPI2_MOSI | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1548 | #define MX53_PAD_CSI0_DAT9__ECSPI2_MOSI (_MX53_PAD_CSI0_DAT9__ECSPI2_MOSI | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1546 | #define MX53_PAD_CSI0_DAT9__USBOH3_USBH3_PWR (_MX53_PAD_CSI0_DAT9__USBOH3_USBH3_PWR | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1549 | #define MX53_PAD_CSI0_DAT9__USBOH3_USBH3_PWR (_MX53_PAD_CSI0_DAT9__USBOH3_USBH3_PWR | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1547 | #define MX53_PAD_CSI0_DAT9__I2C1_SCL (_MX53_PAD_CSI0_DAT9__I2C1_SCL | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1550 | #define MX53_PAD_CSI0_DAT9__I2C1_SCL (_MX53_PAD_CSI0_DAT9__I2C1_SCL | MUX_PAD_CTRL(PAD_CTRL_I2C)) |
1548 | #define MX53_PAD_CSI0_DAT9__EMI_EMI_DEBUG_38 (_MX53_PAD_CSI0_DAT9__EMI_EMI_DEBUG_38 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1551 | #define MX53_PAD_CSI0_DAT9__EMI_EMI_DEBUG_38 (_MX53_PAD_CSI0_DAT9__EMI_EMI_DEBUG_38 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1549 | #define MX53_PAD_CSI0_DAT9__TPIU_TRACE_6 (_MX53_PAD_CSI0_DAT9__TPIU_TRACE_6 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1552 | #define MX53_PAD_CSI0_DAT9__TPIU_TRACE_6 (_MX53_PAD_CSI0_DAT9__TPIU_TRACE_6 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1550 | #define MX53_PAD_CSI0_DAT10__IPU_CSI0_D_10 (_MX53_PAD_CSI0_DAT10__IPU_CSI0_D_10 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1553 | #define MX53_PAD_CSI0_DAT10__IPU_CSI0_D_10 (_MX53_PAD_CSI0_DAT10__IPU_CSI0_D_10 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
@@ -1631,25 +1634,25 @@ | |||
1631 | #define MX53_PAD_EIM_EB2__CCM_DI1_EXT_CLK (_MX53_PAD_EIM_EB2__CCM_DI1_EXT_CLK | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1634 | #define MX53_PAD_EIM_EB2__CCM_DI1_EXT_CLK (_MX53_PAD_EIM_EB2__CCM_DI1_EXT_CLK | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1632 | #define MX53_PAD_EIM_EB2__IPU_SER_DISP1_CS (_MX53_PAD_EIM_EB2__IPU_SER_DISP1_CS | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1635 | #define MX53_PAD_EIM_EB2__IPU_SER_DISP1_CS (_MX53_PAD_EIM_EB2__IPU_SER_DISP1_CS | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1633 | #define MX53_PAD_EIM_EB2__ECSPI1_SS0 (_MX53_PAD_EIM_EB2__ECSPI1_SS0 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1636 | #define MX53_PAD_EIM_EB2__ECSPI1_SS0 (_MX53_PAD_EIM_EB2__ECSPI1_SS0 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1634 | #define MX53_PAD_EIM_EB2__I2C2_SCL (_MX53_PAD_EIM_EB2__I2C2_SCL | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1637 | #define MX53_PAD_EIM_EB2__I2C2_SCL (_MX53_PAD_EIM_EB2__I2C2_SCL | MUX_PAD_CTRL(PAD_CTRL_I2C)) |
1635 | #define MX53_PAD_EIM_D16__EMI_WEIM_D_16 (_MX53_PAD_EIM_D16__EMI_WEIM_D_16 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1638 | #define MX53_PAD_EIM_D16__EMI_WEIM_D_16 (_MX53_PAD_EIM_D16__EMI_WEIM_D_16 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1636 | #define MX53_PAD_EIM_D16__GPIO3_16 (_MX53_PAD_EIM_D16__GPIO3_16 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1639 | #define MX53_PAD_EIM_D16__GPIO3_16 (_MX53_PAD_EIM_D16__GPIO3_16 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1637 | #define MX53_PAD_EIM_D16__IPU_DI0_PIN5 (_MX53_PAD_EIM_D16__IPU_DI0_PIN5 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1640 | #define MX53_PAD_EIM_D16__IPU_DI0_PIN5 (_MX53_PAD_EIM_D16__IPU_DI0_PIN5 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1638 | #define MX53_PAD_EIM_D16__IPU_DISPB1_SER_CLK (_MX53_PAD_EIM_D16__IPU_DISPB1_SER_CLK | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1641 | #define MX53_PAD_EIM_D16__IPU_DISPB1_SER_CLK (_MX53_PAD_EIM_D16__IPU_DISPB1_SER_CLK | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1639 | #define MX53_PAD_EIM_D16__ECSPI1_SCLK (_MX53_PAD_EIM_D16__ECSPI1_SCLK | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1642 | #define MX53_PAD_EIM_D16__ECSPI1_SCLK (_MX53_PAD_EIM_D16__ECSPI1_SCLK | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1640 | #define MX53_PAD_EIM_D16__I2C2_SDA (_MX53_PAD_EIM_D16__I2C2_SDA | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1643 | #define MX53_PAD_EIM_D16__I2C2_SDA (_MX53_PAD_EIM_D16__I2C2_SDA | MUX_PAD_CTRL(PAD_CTRL_I2C)) |
1641 | #define MX53_PAD_EIM_D17__EMI_WEIM_D_17 (_MX53_PAD_EIM_D17__EMI_WEIM_D_17 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1644 | #define MX53_PAD_EIM_D17__EMI_WEIM_D_17 (_MX53_PAD_EIM_D17__EMI_WEIM_D_17 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1642 | #define MX53_PAD_EIM_D17__GPIO3_17 (_MX53_PAD_EIM_D17__GPIO3_17 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1645 | #define MX53_PAD_EIM_D17__GPIO3_17 (_MX53_PAD_EIM_D17__GPIO3_17 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1643 | #define MX53_PAD_EIM_D17__IPU_DI0_PIN6 (_MX53_PAD_EIM_D17__IPU_DI0_PIN6 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1646 | #define MX53_PAD_EIM_D17__IPU_DI0_PIN6 (_MX53_PAD_EIM_D17__IPU_DI0_PIN6 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1644 | #define MX53_PAD_EIM_D17__IPU_DISPB1_SER_DIN (_MX53_PAD_EIM_D17__IPU_DISPB1_SER_DIN | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1647 | #define MX53_PAD_EIM_D17__IPU_DISPB1_SER_DIN (_MX53_PAD_EIM_D17__IPU_DISPB1_SER_DIN | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1645 | #define MX53_PAD_EIM_D17__ECSPI1_MISO (_MX53_PAD_EIM_D17__ECSPI1_MISO | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1648 | #define MX53_PAD_EIM_D17__ECSPI1_MISO (_MX53_PAD_EIM_D17__ECSPI1_MISO | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1646 | #define MX53_PAD_EIM_D17__I2C3_SCL (_MX53_PAD_EIM_D17__I2C3_SCL | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1649 | #define MX53_PAD_EIM_D17__I2C3_SCL (_MX53_PAD_EIM_D17__I2C3_SCL | MUX_PAD_CTRL(PAD_CTRL_I2C)) |
1647 | #define MX53_PAD_EIM_D18__EMI_WEIM_D_18 (_MX53_PAD_EIM_D18__EMI_WEIM_D_18 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1650 | #define MX53_PAD_EIM_D18__EMI_WEIM_D_18 (_MX53_PAD_EIM_D18__EMI_WEIM_D_18 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1648 | #define MX53_PAD_EIM_D18__GPIO3_18 (_MX53_PAD_EIM_D18__GPIO3_18 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1651 | #define MX53_PAD_EIM_D18__GPIO3_18 (_MX53_PAD_EIM_D18__GPIO3_18 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1649 | #define MX53_PAD_EIM_D18__IPU_DI0_PIN7 (_MX53_PAD_EIM_D18__IPU_DI0_PIN7 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1652 | #define MX53_PAD_EIM_D18__IPU_DI0_PIN7 (_MX53_PAD_EIM_D18__IPU_DI0_PIN7 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1650 | #define MX53_PAD_EIM_D18__IPU_DISPB1_SER_DIO (_MX53_PAD_EIM_D18__IPU_DISPB1_SER_DIO | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1653 | #define MX53_PAD_EIM_D18__IPU_DISPB1_SER_DIO (_MX53_PAD_EIM_D18__IPU_DISPB1_SER_DIO | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1651 | #define MX53_PAD_EIM_D18__ECSPI1_MOSI (_MX53_PAD_EIM_D18__ECSPI1_MOSI | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1654 | #define MX53_PAD_EIM_D18__ECSPI1_MOSI (_MX53_PAD_EIM_D18__ECSPI1_MOSI | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1652 | #define MX53_PAD_EIM_D18__I2C3_SDA (_MX53_PAD_EIM_D18__I2C3_SDA | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1655 | #define MX53_PAD_EIM_D18__I2C3_SDA (_MX53_PAD_EIM_D18__I2C3_SDA | MUX_PAD_CTRL(PAD_CTRL_I2C)) |
1653 | #define MX53_PAD_EIM_D18__IPU_DI1_D0_CS (_MX53_PAD_EIM_D18__IPU_DI1_D0_CS | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1656 | #define MX53_PAD_EIM_D18__IPU_DI1_D0_CS (_MX53_PAD_EIM_D18__IPU_DI1_D0_CS | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1654 | #define MX53_PAD_EIM_D19__EMI_WEIM_D_19 (_MX53_PAD_EIM_D19__EMI_WEIM_D_19 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1657 | #define MX53_PAD_EIM_D19__EMI_WEIM_D_19 (_MX53_PAD_EIM_D19__EMI_WEIM_D_19 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1655 | #define MX53_PAD_EIM_D19__GPIO3_19 (_MX53_PAD_EIM_D19__GPIO3_19 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1658 | #define MX53_PAD_EIM_D19__GPIO3_19 (_MX53_PAD_EIM_D19__GPIO3_19 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
@@ -1672,7 +1675,7 @@ | |||
1672 | #define MX53_PAD_EIM_D21__IPU_DI0_PIN17 (_MX53_PAD_EIM_D21__IPU_DI0_PIN17 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1675 | #define MX53_PAD_EIM_D21__IPU_DI0_PIN17 (_MX53_PAD_EIM_D21__IPU_DI0_PIN17 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1673 | #define MX53_PAD_EIM_D21__IPU_DISPB0_SER_CLK (_MX53_PAD_EIM_D21__IPU_DISPB0_SER_CLK | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1676 | #define MX53_PAD_EIM_D21__IPU_DISPB0_SER_CLK (_MX53_PAD_EIM_D21__IPU_DISPB0_SER_CLK | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1674 | #define MX53_PAD_EIM_D21__CSPI_SCLK (_MX53_PAD_EIM_D21__CSPI_SCLK | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1677 | #define MX53_PAD_EIM_D21__CSPI_SCLK (_MX53_PAD_EIM_D21__CSPI_SCLK | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1675 | #define MX53_PAD_EIM_D21__I2C1_SCL (_MX53_PAD_EIM_D21__I2C1_SCL | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1678 | #define MX53_PAD_EIM_D21__I2C1_SCL (_MX53_PAD_EIM_D21__I2C1_SCL | MUX_PAD_CTRL(PAD_CTRL_I2C)) |
1676 | #define MX53_PAD_EIM_D21__USBOH3_USBOTG_OC (_MX53_PAD_EIM_D21__USBOH3_USBOTG_OC | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1679 | #define MX53_PAD_EIM_D21__USBOH3_USBOTG_OC (_MX53_PAD_EIM_D21__USBOH3_USBOTG_OC | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1677 | #define MX53_PAD_EIM_D22__EMI_WEIM_D_22 (_MX53_PAD_EIM_D22__EMI_WEIM_D_22 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1680 | #define MX53_PAD_EIM_D22__EMI_WEIM_D_22 (_MX53_PAD_EIM_D22__EMI_WEIM_D_22 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1678 | #define MX53_PAD_EIM_D22__GPIO3_22 (_MX53_PAD_EIM_D22__GPIO3_22 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1681 | #define MX53_PAD_EIM_D22__GPIO3_22 (_MX53_PAD_EIM_D22__GPIO3_22 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
@@ -1732,7 +1735,7 @@ | |||
1732 | #define MX53_PAD_EIM_D28__UART2_CTS (_MX53_PAD_EIM_D28__UART2_CTS | MUX_PAD_CTRL(MX53_UART_PAD_CTRL)) | 1735 | #define MX53_PAD_EIM_D28__UART2_CTS (_MX53_PAD_EIM_D28__UART2_CTS | MUX_PAD_CTRL(MX53_UART_PAD_CTRL)) |
1733 | #define MX53_PAD_EIM_D28__IPU_DISPB0_SER_DIO (_MX53_PAD_EIM_D28__IPU_DISPB0_SER_DIO | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1736 | #define MX53_PAD_EIM_D28__IPU_DISPB0_SER_DIO (_MX53_PAD_EIM_D28__IPU_DISPB0_SER_DIO | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1734 | #define MX53_PAD_EIM_D28__CSPI_MOSI (_MX53_PAD_EIM_D28__CSPI_MOSI | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1737 | #define MX53_PAD_EIM_D28__CSPI_MOSI (_MX53_PAD_EIM_D28__CSPI_MOSI | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1735 | #define MX53_PAD_EIM_D28__I2C1_SDA (_MX53_PAD_EIM_D28__I2C1_SDA | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1738 | #define MX53_PAD_EIM_D28__I2C1_SDA (_MX53_PAD_EIM_D28__I2C1_SDA | MUX_PAD_CTRL(PAD_CTRL_I2C)) |
1736 | #define MX53_PAD_EIM_D28__IPU_EXT_TRIG (_MX53_PAD_EIM_D28__IPU_EXT_TRIG | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1739 | #define MX53_PAD_EIM_D28__IPU_EXT_TRIG (_MX53_PAD_EIM_D28__IPU_EXT_TRIG | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1737 | #define MX53_PAD_EIM_D28__IPU_DI0_PIN13 (_MX53_PAD_EIM_D28__IPU_DI0_PIN13 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1740 | #define MX53_PAD_EIM_D28__IPU_DI0_PIN13 (_MX53_PAD_EIM_D28__IPU_DI0_PIN13 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
1738 | #define MX53_PAD_EIM_D29__EMI_WEIM_D_29 (_MX53_PAD_EIM_D29__EMI_WEIM_D_29 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 1741 | #define MX53_PAD_EIM_D29__EMI_WEIM_D_29 (_MX53_PAD_EIM_D29__EMI_WEIM_D_29 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
@@ -2297,7 +2300,7 @@ | |||
2297 | #define MX53_PAD_GPIO_9__SCC_FAIL_STATE (_MX53_PAD_GPIO_9__SCC_FAIL_STATE | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2300 | #define MX53_PAD_GPIO_9__SCC_FAIL_STATE (_MX53_PAD_GPIO_9__SCC_FAIL_STATE | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2298 | #define MX53_PAD_GPIO_3__ESAI1_HCKR (_MX53_PAD_GPIO_3__ESAI1_HCKR | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2301 | #define MX53_PAD_GPIO_3__ESAI1_HCKR (_MX53_PAD_GPIO_3__ESAI1_HCKR | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2299 | #define MX53_PAD_GPIO_3__GPIO1_3 (_MX53_PAD_GPIO_3__GPIO1_3 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2302 | #define MX53_PAD_GPIO_3__GPIO1_3 (_MX53_PAD_GPIO_3__GPIO1_3 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2300 | #define MX53_PAD_GPIO_3__I2C3_SCL (_MX53_PAD_GPIO_3__I2C3_SCL | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2303 | #define MX53_PAD_GPIO_3__I2C3_SCL (_MX53_PAD_GPIO_3__I2C3_SCL | MUX_PAD_CTRL(PAD_CTRL_I2C)) |
2301 | #define MX53_PAD_GPIO_3__DPLLIP1_TOG_EN (_MX53_PAD_GPIO_3__DPLLIP1_TOG_EN | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2304 | #define MX53_PAD_GPIO_3__DPLLIP1_TOG_EN (_MX53_PAD_GPIO_3__DPLLIP1_TOG_EN | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2302 | #define MX53_PAD_GPIO_3__CCM_CLKO2 (_MX53_PAD_GPIO_3__CCM_CLKO2 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2305 | #define MX53_PAD_GPIO_3__CCM_CLKO2 (_MX53_PAD_GPIO_3__CCM_CLKO2 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2303 | #define MX53_PAD_GPIO_3__OBSERVE_MUX_OBSRV_INT_OUT0 (_MX53_PAD_GPIO_3__OBSERVE_MUX_OBSRV_INT_OUT0 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2306 | #define MX53_PAD_GPIO_3__OBSERVE_MUX_OBSRV_INT_OUT0 (_MX53_PAD_GPIO_3__OBSERVE_MUX_OBSRV_INT_OUT0 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
@@ -2305,7 +2308,7 @@ | |||
2305 | #define MX53_PAD_GPIO_3__MLB_MLBCLK (_MX53_PAD_GPIO_3__MLB_MLBCLK | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2308 | #define MX53_PAD_GPIO_3__MLB_MLBCLK (_MX53_PAD_GPIO_3__MLB_MLBCLK | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2306 | #define MX53_PAD_GPIO_6__ESAI1_SCKT (_MX53_PAD_GPIO_6__ESAI1_SCKT | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2309 | #define MX53_PAD_GPIO_6__ESAI1_SCKT (_MX53_PAD_GPIO_6__ESAI1_SCKT | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2307 | #define MX53_PAD_GPIO_6__GPIO1_6 (_MX53_PAD_GPIO_6__GPIO1_6 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2310 | #define MX53_PAD_GPIO_6__GPIO1_6 (_MX53_PAD_GPIO_6__GPIO1_6 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2308 | #define MX53_PAD_GPIO_6__I2C3_SDA (_MX53_PAD_GPIO_6__I2C3_SDA | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2311 | #define MX53_PAD_GPIO_6__I2C3_SDA (_MX53_PAD_GPIO_6__I2C3_SDA | MUX_PAD_CTRL(PAD_CTRL_I2C)) |
2309 | #define MX53_PAD_GPIO_6__CCM_CCM_OUT_0 (_MX53_PAD_GPIO_6__CCM_CCM_OUT_0 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2312 | #define MX53_PAD_GPIO_6__CCM_CCM_OUT_0 (_MX53_PAD_GPIO_6__CCM_CCM_OUT_0 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2310 | #define MX53_PAD_GPIO_6__CSU_CSU_INT_DEB (_MX53_PAD_GPIO_6__CSU_CSU_INT_DEB | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2313 | #define MX53_PAD_GPIO_6__CSU_CSU_INT_DEB (_MX53_PAD_GPIO_6__CSU_CSU_INT_DEB | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2311 | #define MX53_PAD_GPIO_6__OBSERVE_MUX_OBSRV_INT_OUT1 (_MX53_PAD_GPIO_6__OBSERVE_MUX_OBSRV_INT_OUT1 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2314 | #define MX53_PAD_GPIO_6__OBSERVE_MUX_OBSRV_INT_OUT1 (_MX53_PAD_GPIO_6__OBSERVE_MUX_OBSRV_INT_OUT1 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
@@ -2333,7 +2336,7 @@ | |||
2333 | #define MX53_PAD_GPIO_5__CCM_CLKO (_MX53_PAD_GPIO_5__CCM_CLKO | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2336 | #define MX53_PAD_GPIO_5__CCM_CLKO (_MX53_PAD_GPIO_5__CCM_CLKO | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2334 | #define MX53_PAD_GPIO_5__CSU_CSU_ALARM_AUT_2 (_MX53_PAD_GPIO_5__CSU_CSU_ALARM_AUT_2 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2337 | #define MX53_PAD_GPIO_5__CSU_CSU_ALARM_AUT_2 (_MX53_PAD_GPIO_5__CSU_CSU_ALARM_AUT_2 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2335 | #define MX53_PAD_GPIO_5__OBSERVE_MUX_OBSRV_INT_OUT4 (_MX53_PAD_GPIO_5__OBSERVE_MUX_OBSRV_INT_OUT4 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2338 | #define MX53_PAD_GPIO_5__OBSERVE_MUX_OBSRV_INT_OUT4 (_MX53_PAD_GPIO_5__OBSERVE_MUX_OBSRV_INT_OUT4 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2336 | #define MX53_PAD_GPIO_5__I2C3_SCL (_MX53_PAD_GPIO_5__I2C3_SCL | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2339 | #define MX53_PAD_GPIO_5__I2C3_SCL (_MX53_PAD_GPIO_5__I2C3_SCL | MUX_PAD_CTRL(PAD_CTRL_I2C)) |
2337 | #define MX53_PAD_GPIO_5__CCM_PLL1_BYP (_MX53_PAD_GPIO_5__CCM_PLL1_BYP | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2340 | #define MX53_PAD_GPIO_5__CCM_PLL1_BYP (_MX53_PAD_GPIO_5__CCM_PLL1_BYP | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2338 | #define MX53_PAD_GPIO_7__ESAI1_TX4_RX1 (_MX53_PAD_GPIO_7__ESAI1_TX4_RX1 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2341 | #define MX53_PAD_GPIO_7__ESAI1_TX4_RX1 (_MX53_PAD_GPIO_7__ESAI1_TX4_RX1 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2339 | #define MX53_PAD_GPIO_7__GPIO1_7 (_MX53_PAD_GPIO_7__GPIO1_7 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2342 | #define MX53_PAD_GPIO_7__GPIO1_7 (_MX53_PAD_GPIO_7__GPIO1_7 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
@@ -2356,7 +2359,7 @@ | |||
2356 | #define MX53_PAD_GPIO_16__TZIC_PWRFAIL_INT (_MX53_PAD_GPIO_16__TZIC_PWRFAIL_INT | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2359 | #define MX53_PAD_GPIO_16__TZIC_PWRFAIL_INT (_MX53_PAD_GPIO_16__TZIC_PWRFAIL_INT | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2357 | #define MX53_PAD_GPIO_16__RTC_CE_RTC_EXT_TRIG1 (_MX53_PAD_GPIO_16__RTC_CE_RTC_EXT_TRIG1 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2360 | #define MX53_PAD_GPIO_16__RTC_CE_RTC_EXT_TRIG1 (_MX53_PAD_GPIO_16__RTC_CE_RTC_EXT_TRIG1 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2358 | #define MX53_PAD_GPIO_16__SPDIF_IN1 (_MX53_PAD_GPIO_16__SPDIF_IN1 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2361 | #define MX53_PAD_GPIO_16__SPDIF_IN1 (_MX53_PAD_GPIO_16__SPDIF_IN1 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2359 | #define MX53_PAD_GPIO_16__I2C3_SDA (_MX53_PAD_GPIO_16__I2C3_SDA | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2362 | #define MX53_PAD_GPIO_16__I2C3_SDA (_MX53_PAD_GPIO_16__I2C3_SDA | MUX_PAD_CTRL(PAD_CTRL_I2C)) |
2360 | #define MX53_PAD_GPIO_16__SJC_DE_B (_MX53_PAD_GPIO_16__SJC_DE_B | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2363 | #define MX53_PAD_GPIO_16__SJC_DE_B (_MX53_PAD_GPIO_16__SJC_DE_B | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2361 | #define MX53_PAD_GPIO_17__ESAI1_TX0 (_MX53_PAD_GPIO_17__ESAI1_TX0 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2364 | #define MX53_PAD_GPIO_17__ESAI1_TX0 (_MX53_PAD_GPIO_17__ESAI1_TX0 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
2362 | #define MX53_PAD_GPIO_17__GPIO7_12 (_MX53_PAD_GPIO_17__GPIO7_12 | MUX_PAD_CTRL(NO_PAD_CTRL)) | 2365 | #define MX53_PAD_GPIO_17__GPIO7_12 (_MX53_PAD_GPIO_17__GPIO7_12 | MUX_PAD_CTRL(NO_PAD_CTRL)) |
diff --git a/arch/arm/plat-omap/Kconfig b/arch/arm/plat-omap/Kconfig index 6e6735f04ee3..bb8f4a6b3e37 100644 --- a/arch/arm/plat-omap/Kconfig +++ b/arch/arm/plat-omap/Kconfig | |||
@@ -13,6 +13,7 @@ config ARCH_OMAP1 | |||
13 | bool "TI OMAP1" | 13 | bool "TI OMAP1" |
14 | select CLKDEV_LOOKUP | 14 | select CLKDEV_LOOKUP |
15 | select CLKSRC_MMIO | 15 | select CLKSRC_MMIO |
16 | select GENERIC_IRQ_CHIP | ||
16 | help | 17 | help |
17 | "Systems based on omap7xx, omap15xx or omap16xx" | 18 | "Systems based on omap7xx, omap15xx or omap16xx" |
18 | 19 | ||
diff --git a/arch/arm/plat-omap/include/plat/dma.h b/arch/arm/plat-omap/include/plat/dma.h index d1c916fcf770..dc562a5c0a8a 100644 --- a/arch/arm/plat-omap/include/plat/dma.h +++ b/arch/arm/plat-omap/include/plat/dma.h | |||
@@ -195,6 +195,11 @@ | |||
195 | 195 | ||
196 | #define OMAP36XX_DMA_UART4_TX 81 /* S_DMA_80 */ | 196 | #define OMAP36XX_DMA_UART4_TX 81 /* S_DMA_80 */ |
197 | #define OMAP36XX_DMA_UART4_RX 82 /* S_DMA_81 */ | 197 | #define OMAP36XX_DMA_UART4_RX 82 /* S_DMA_81 */ |
198 | |||
199 | /* Only for AM35xx */ | ||
200 | #define AM35XX_DMA_UART4_TX 54 | ||
201 | #define AM35XX_DMA_UART4_RX 55 | ||
202 | |||
198 | /*----------------------------------------------------------------------------*/ | 203 | /*----------------------------------------------------------------------------*/ |
199 | 204 | ||
200 | #define OMAP1_DMA_TOUT_IRQ (1 << 0) | 205 | #define OMAP1_DMA_TOUT_IRQ (1 << 0) |
diff --git a/arch/arm/plat-omap/include/plat/irqs.h b/arch/arm/plat-omap/include/plat/irqs.h index 926d25c780f3..30e10719b774 100644 --- a/arch/arm/plat-omap/include/plat/irqs.h +++ b/arch/arm/plat-omap/include/plat/irqs.h | |||
@@ -357,6 +357,7 @@ | |||
357 | #define INT_35XX_EMAC_C0_TX_PULSE_IRQ 69 | 357 | #define INT_35XX_EMAC_C0_TX_PULSE_IRQ 69 |
358 | #define INT_35XX_EMAC_C0_MISC_PULSE_IRQ 70 | 358 | #define INT_35XX_EMAC_C0_MISC_PULSE_IRQ 70 |
359 | #define INT_35XX_USBOTG_IRQ 71 | 359 | #define INT_35XX_USBOTG_IRQ 71 |
360 | #define INT_35XX_UART4 84 | ||
360 | #define INT_35XX_CCDC_VD0_IRQ 88 | 361 | #define INT_35XX_CCDC_VD0_IRQ 88 |
361 | #define INT_35XX_CCDC_VD1_IRQ 92 | 362 | #define INT_35XX_CCDC_VD1_IRQ 92 |
362 | #define INT_35XX_CCDC_VD2_IRQ 93 | 363 | #define INT_35XX_CCDC_VD2_IRQ 93 |
diff --git a/arch/arm/plat-omap/include/plat/serial.h b/arch/arm/plat-omap/include/plat/serial.h index 2723f9166ea2..de3b10c18127 100644 --- a/arch/arm/plat-omap/include/plat/serial.h +++ b/arch/arm/plat-omap/include/plat/serial.h | |||
@@ -56,6 +56,9 @@ | |||
56 | #define TI816X_UART2_BASE 0x48022000 | 56 | #define TI816X_UART2_BASE 0x48022000 |
57 | #define TI816X_UART3_BASE 0x48024000 | 57 | #define TI816X_UART3_BASE 0x48024000 |
58 | 58 | ||
59 | /* AM3505/3517 UART4 */ | ||
60 | #define AM35XX_UART4_BASE 0x4809E000 /* Only on AM3505/3517 */ | ||
61 | |||
59 | /* External port on Zoom2/3 */ | 62 | /* External port on Zoom2/3 */ |
60 | #define ZOOM_UART_BASE 0x10000000 | 63 | #define ZOOM_UART_BASE 0x10000000 |
61 | #define ZOOM_UART_VIRT 0xfa400000 | 64 | #define ZOOM_UART_VIRT 0xfa400000 |
diff --git a/arch/arm/plat-omap/iovmm.c b/arch/arm/plat-omap/iovmm.c index c60737c49a32..79e7fedb8602 100644 --- a/arch/arm/plat-omap/iovmm.c +++ b/arch/arm/plat-omap/iovmm.c | |||
@@ -423,9 +423,6 @@ static void sgtable_fill_kmalloc(struct sg_table *sgt, u32 pa, u32 da, | |||
423 | { | 423 | { |
424 | unsigned int i; | 424 | unsigned int i; |
425 | struct scatterlist *sg; | 425 | struct scatterlist *sg; |
426 | void *va; | ||
427 | |||
428 | va = phys_to_virt(pa); | ||
429 | 426 | ||
430 | for_each_sg(sgt->sgl, sg, sgt->nents, i) { | 427 | for_each_sg(sgt->sgl, sg, sgt->nents, i) { |
431 | unsigned bytes; | 428 | unsigned bytes; |
diff --git a/arch/arm/tools/mach-types b/arch/arm/tools/mach-types index 3b3776d0a1a7..fff68d0d521b 100644 --- a/arch/arm/tools/mach-types +++ b/arch/arm/tools/mach-types | |||
@@ -910,7 +910,7 @@ omapl138_case_a3 MACH_OMAPL138_CASE_A3 OMAPL138_CASE_A3 3280 | |||
910 | uemd MACH_UEMD UEMD 3281 | 910 | uemd MACH_UEMD UEMD 3281 |
911 | ccwmx51mut MACH_CCWMX51MUT CCWMX51MUT 3282 | 911 | ccwmx51mut MACH_CCWMX51MUT CCWMX51MUT 3282 |
912 | rockhopper MACH_ROCKHOPPER ROCKHOPPER 3283 | 912 | rockhopper MACH_ROCKHOPPER ROCKHOPPER 3283 |
913 | nookcolor MACH_NOOKCOLOR NOOKCOLOR 3284 | 913 | encore MACH_ENCORE ENCORE 3284 |
914 | hkdkc100 MACH_HKDKC100 HKDKC100 3285 | 914 | hkdkc100 MACH_HKDKC100 HKDKC100 3285 |
915 | ts42xx MACH_TS42XX TS42XX 3286 | 915 | ts42xx MACH_TS42XX TS42XX 3286 |
916 | aebl MACH_AEBL AEBL 3287 | 916 | aebl MACH_AEBL AEBL 3287 |
diff --git a/arch/powerpc/include/asm/jump_label.h b/arch/powerpc/include/asm/jump_label.h index 1f780b95c0f0..938986e412f1 100644 --- a/arch/powerpc/include/asm/jump_label.h +++ b/arch/powerpc/include/asm/jump_label.h | |||
@@ -22,7 +22,6 @@ static __always_inline bool arch_static_branch(struct jump_label_key *key) | |||
22 | asm goto("1:\n\t" | 22 | asm goto("1:\n\t" |
23 | "nop\n\t" | 23 | "nop\n\t" |
24 | ".pushsection __jump_table, \"aw\"\n\t" | 24 | ".pushsection __jump_table, \"aw\"\n\t" |
25 | ".align 4\n\t" | ||
26 | JUMP_ENTRY_TYPE "1b, %l[l_yes], %c0\n\t" | 25 | JUMP_ENTRY_TYPE "1b, %l[l_yes], %c0\n\t" |
27 | ".popsection \n\t" | 26 | ".popsection \n\t" |
28 | : : "i" (key) : : l_yes); | 27 | : : "i" (key) : : l_yes); |
@@ -41,7 +40,6 @@ struct jump_entry { | |||
41 | jump_label_t code; | 40 | jump_label_t code; |
42 | jump_label_t target; | 41 | jump_label_t target; |
43 | jump_label_t key; | 42 | jump_label_t key; |
44 | jump_label_t pad; | ||
45 | }; | 43 | }; |
46 | 44 | ||
47 | #endif /* _ASM_POWERPC_JUMP_LABEL_H */ | 45 | #endif /* _ASM_POWERPC_JUMP_LABEL_H */ |
diff --git a/arch/powerpc/include/asm/kdump.h b/arch/powerpc/include/asm/kdump.h index 6857af58b02e..bffd062adf79 100644 --- a/arch/powerpc/include/asm/kdump.h +++ b/arch/powerpc/include/asm/kdump.h | |||
@@ -3,17 +3,7 @@ | |||
3 | 3 | ||
4 | #include <asm/page.h> | 4 | #include <asm/page.h> |
5 | 5 | ||
6 | /* | ||
7 | * If CONFIG_RELOCATABLE is enabled we can place the kdump kernel anywhere. | ||
8 | * To keep enough space in the RMO for the first stage kernel on 64bit, we | ||
9 | * place it at 64MB. If CONFIG_RELOCATABLE is not enabled we must place | ||
10 | * the second stage at 32MB. | ||
11 | */ | ||
12 | #if defined(CONFIG_RELOCATABLE) && defined(CONFIG_PPC64) | ||
13 | #define KDUMP_KERNELBASE 0x4000000 | ||
14 | #else | ||
15 | #define KDUMP_KERNELBASE 0x2000000 | 6 | #define KDUMP_KERNELBASE 0x2000000 |
16 | #endif | ||
17 | 7 | ||
18 | /* How many bytes to reserve at zero for kdump. The reserve limit should | 8 | /* How many bytes to reserve at zero for kdump. The reserve limit should |
19 | * be greater or equal to the trampoline's end address. | 9 | * be greater or equal to the trampoline's end address. |
diff --git a/arch/powerpc/include/asm/reg.h b/arch/powerpc/include/asm/reg.h index e8aaf6fce38b..559da199edb5 100644 --- a/arch/powerpc/include/asm/reg.h +++ b/arch/powerpc/include/asm/reg.h | |||
@@ -1003,7 +1003,6 @@ | |||
1003 | #define PV_970 0x0039 | 1003 | #define PV_970 0x0039 |
1004 | #define PV_POWER5 0x003A | 1004 | #define PV_POWER5 0x003A |
1005 | #define PV_POWER5p 0x003B | 1005 | #define PV_POWER5p 0x003B |
1006 | #define PV_POWER7 0x003F | ||
1007 | #define PV_970FX 0x003C | 1006 | #define PV_970FX 0x003C |
1008 | #define PV_POWER6 0x003E | 1007 | #define PV_POWER6 0x003E |
1009 | #define PV_POWER7 0x003F | 1008 | #define PV_POWER7 0x003F |
@@ -1024,13 +1023,16 @@ | |||
1024 | #define mtmsrd(v) __mtmsrd((v), 0) | 1023 | #define mtmsrd(v) __mtmsrd((v), 0) |
1025 | #define mtmsr(v) mtmsrd(v) | 1024 | #define mtmsr(v) mtmsrd(v) |
1026 | #else | 1025 | #else |
1027 | #define mtmsr(v) asm volatile("mtmsr %0" : : "r" (v) : "memory") | 1026 | #define mtmsr(v) asm volatile("mtmsr %0" : \ |
1027 | : "r" ((unsigned long)(v)) \ | ||
1028 | : "memory") | ||
1028 | #endif | 1029 | #endif |
1029 | 1030 | ||
1030 | #define mfspr(rn) ({unsigned long rval; \ | 1031 | #define mfspr(rn) ({unsigned long rval; \ |
1031 | asm volatile("mfspr %0," __stringify(rn) \ | 1032 | asm volatile("mfspr %0," __stringify(rn) \ |
1032 | : "=r" (rval)); rval;}) | 1033 | : "=r" (rval)); rval;}) |
1033 | #define mtspr(rn, v) asm volatile("mtspr " __stringify(rn) ",%0" : : "r" (v)\ | 1034 | #define mtspr(rn, v) asm volatile("mtspr " __stringify(rn) ",%0" : \ |
1035 | : "r" ((unsigned long)(v)) \ | ||
1034 | : "memory") | 1036 | : "memory") |
1035 | 1037 | ||
1036 | #ifdef __powerpc64__ | 1038 | #ifdef __powerpc64__ |
diff --git a/arch/powerpc/kernel/cputable.c b/arch/powerpc/kernel/cputable.c index 9fb933248ab6..fa44ff538861 100644 --- a/arch/powerpc/kernel/cputable.c +++ b/arch/powerpc/kernel/cputable.c | |||
@@ -2051,7 +2051,8 @@ static struct cpu_spec __initdata cpu_specs[] = { | |||
2051 | 2051 | ||
2052 | static struct cpu_spec the_cpu_spec; | 2052 | static struct cpu_spec the_cpu_spec; |
2053 | 2053 | ||
2054 | static void __init setup_cpu_spec(unsigned long offset, struct cpu_spec *s) | 2054 | static struct cpu_spec * __init setup_cpu_spec(unsigned long offset, |
2055 | struct cpu_spec *s) | ||
2055 | { | 2056 | { |
2056 | struct cpu_spec *t = &the_cpu_spec; | 2057 | struct cpu_spec *t = &the_cpu_spec; |
2057 | struct cpu_spec old; | 2058 | struct cpu_spec old; |
@@ -2114,6 +2115,8 @@ static void __init setup_cpu_spec(unsigned long offset, struct cpu_spec *s) | |||
2114 | t->cpu_setup(offset, t); | 2115 | t->cpu_setup(offset, t); |
2115 | } | 2116 | } |
2116 | #endif /* CONFIG_PPC64 || CONFIG_BOOKE */ | 2117 | #endif /* CONFIG_PPC64 || CONFIG_BOOKE */ |
2118 | |||
2119 | return t; | ||
2117 | } | 2120 | } |
2118 | 2121 | ||
2119 | struct cpu_spec * __init identify_cpu(unsigned long offset, unsigned int pvr) | 2122 | struct cpu_spec * __init identify_cpu(unsigned long offset, unsigned int pvr) |
@@ -2124,10 +2127,8 @@ struct cpu_spec * __init identify_cpu(unsigned long offset, unsigned int pvr) | |||
2124 | s = PTRRELOC(s); | 2127 | s = PTRRELOC(s); |
2125 | 2128 | ||
2126 | for (i = 0; i < ARRAY_SIZE(cpu_specs); i++,s++) { | 2129 | for (i = 0; i < ARRAY_SIZE(cpu_specs); i++,s++) { |
2127 | if ((pvr & s->pvr_mask) == s->pvr_value) { | 2130 | if ((pvr & s->pvr_mask) == s->pvr_value) |
2128 | setup_cpu_spec(offset, s); | 2131 | return setup_cpu_spec(offset, s); |
2129 | return s; | ||
2130 | } | ||
2131 | } | 2132 | } |
2132 | 2133 | ||
2133 | BUG(); | 2134 | BUG(); |
diff --git a/arch/powerpc/kernel/iomap.c b/arch/powerpc/kernel/iomap.c index 1577434f4088..b25f6325fc70 100644 --- a/arch/powerpc/kernel/iomap.c +++ b/arch/powerpc/kernel/iomap.c | |||
@@ -117,6 +117,7 @@ void ioport_unmap(void __iomem *addr) | |||
117 | EXPORT_SYMBOL(ioport_map); | 117 | EXPORT_SYMBOL(ioport_map); |
118 | EXPORT_SYMBOL(ioport_unmap); | 118 | EXPORT_SYMBOL(ioport_unmap); |
119 | 119 | ||
120 | #ifdef CONFIG_PCI | ||
120 | void __iomem *pci_iomap(struct pci_dev *dev, int bar, unsigned long max) | 121 | void __iomem *pci_iomap(struct pci_dev *dev, int bar, unsigned long max) |
121 | { | 122 | { |
122 | resource_size_t start = pci_resource_start(dev, bar); | 123 | resource_size_t start = pci_resource_start(dev, bar); |
@@ -146,3 +147,4 @@ void pci_iounmap(struct pci_dev *dev, void __iomem *addr) | |||
146 | 147 | ||
147 | EXPORT_SYMBOL(pci_iomap); | 148 | EXPORT_SYMBOL(pci_iomap); |
148 | EXPORT_SYMBOL(pci_iounmap); | 149 | EXPORT_SYMBOL(pci_iounmap); |
150 | #endif /* CONFIG_PCI */ | ||
diff --git a/arch/powerpc/kernel/machine_kexec.c b/arch/powerpc/kernel/machine_kexec.c index 6658a1589955..9ce1672afb59 100644 --- a/arch/powerpc/kernel/machine_kexec.c +++ b/arch/powerpc/kernel/machine_kexec.c | |||
@@ -136,12 +136,16 @@ void __init reserve_crashkernel(void) | |||
136 | crashk_res.start = KDUMP_KERNELBASE; | 136 | crashk_res.start = KDUMP_KERNELBASE; |
137 | #else | 137 | #else |
138 | if (!crashk_res.start) { | 138 | if (!crashk_res.start) { |
139 | #ifdef CONFIG_PPC64 | ||
139 | /* | 140 | /* |
140 | * unspecified address, choose a region of specified size | 141 | * On 64bit we split the RMO in half but cap it at half of |
141 | * can overlap with initrd (ignoring corruption when retained) | 142 | * a small SLB (128MB) since the crash kernel needs to place |
142 | * ppc64 requires kernel and some stacks to be in first segemnt | 143 | * itself and some stacks to be in the first segment. |
143 | */ | 144 | */ |
145 | crashk_res.start = min(0x80000000ULL, (ppc64_rma_size / 2)); | ||
146 | #else | ||
144 | crashk_res.start = KDUMP_KERNELBASE; | 147 | crashk_res.start = KDUMP_KERNELBASE; |
148 | #endif | ||
145 | } | 149 | } |
146 | 150 | ||
147 | crash_base = PAGE_ALIGN(crashk_res.start); | 151 | crash_base = PAGE_ALIGN(crashk_res.start); |
diff --git a/arch/powerpc/kernel/perf_callchain.c b/arch/powerpc/kernel/perf_callchain.c index d05ae4204bbf..564c1d8bdb5c 100644 --- a/arch/powerpc/kernel/perf_callchain.c +++ b/arch/powerpc/kernel/perf_callchain.c | |||
@@ -154,8 +154,12 @@ static int read_user_stack_64(unsigned long __user *ptr, unsigned long *ret) | |||
154 | ((unsigned long)ptr & 7)) | 154 | ((unsigned long)ptr & 7)) |
155 | return -EFAULT; | 155 | return -EFAULT; |
156 | 156 | ||
157 | if (!__get_user_inatomic(*ret, ptr)) | 157 | pagefault_disable(); |
158 | if (!__get_user_inatomic(*ret, ptr)) { | ||
159 | pagefault_enable(); | ||
158 | return 0; | 160 | return 0; |
161 | } | ||
162 | pagefault_enable(); | ||
159 | 163 | ||
160 | return read_user_stack_slow(ptr, ret, 8); | 164 | return read_user_stack_slow(ptr, ret, 8); |
161 | } | 165 | } |
@@ -166,8 +170,12 @@ static int read_user_stack_32(unsigned int __user *ptr, unsigned int *ret) | |||
166 | ((unsigned long)ptr & 3)) | 170 | ((unsigned long)ptr & 3)) |
167 | return -EFAULT; | 171 | return -EFAULT; |
168 | 172 | ||
169 | if (!__get_user_inatomic(*ret, ptr)) | 173 | pagefault_disable(); |
174 | if (!__get_user_inatomic(*ret, ptr)) { | ||
175 | pagefault_enable(); | ||
170 | return 0; | 176 | return 0; |
177 | } | ||
178 | pagefault_enable(); | ||
171 | 179 | ||
172 | return read_user_stack_slow(ptr, ret, 4); | 180 | return read_user_stack_slow(ptr, ret, 4); |
173 | } | 181 | } |
@@ -294,11 +302,17 @@ static inline int current_is_64bit(void) | |||
294 | */ | 302 | */ |
295 | static int read_user_stack_32(unsigned int __user *ptr, unsigned int *ret) | 303 | static int read_user_stack_32(unsigned int __user *ptr, unsigned int *ret) |
296 | { | 304 | { |
305 | int rc; | ||
306 | |||
297 | if ((unsigned long)ptr > TASK_SIZE - sizeof(unsigned int) || | 307 | if ((unsigned long)ptr > TASK_SIZE - sizeof(unsigned int) || |
298 | ((unsigned long)ptr & 3)) | 308 | ((unsigned long)ptr & 3)) |
299 | return -EFAULT; | 309 | return -EFAULT; |
300 | 310 | ||
301 | return __get_user_inatomic(*ret, ptr); | 311 | pagefault_disable(); |
312 | rc = __get_user_inatomic(*ret, ptr); | ||
313 | pagefault_enable(); | ||
314 | |||
315 | return rc; | ||
302 | } | 316 | } |
303 | 317 | ||
304 | static inline void perf_callchain_user_64(struct perf_callchain_entry *entry, | 318 | static inline void perf_callchain_user_64(struct perf_callchain_entry *entry, |
diff --git a/arch/powerpc/kernel/prom_init.c b/arch/powerpc/kernel/prom_init.c index c016033ba78d..a909f4e9343b 100644 --- a/arch/powerpc/kernel/prom_init.c +++ b/arch/powerpc/kernel/prom_init.c | |||
@@ -1020,7 +1020,7 @@ static unsigned long __init alloc_up(unsigned long size, unsigned long align) | |||
1020 | } | 1020 | } |
1021 | if (addr == 0) | 1021 | if (addr == 0) |
1022 | return 0; | 1022 | return 0; |
1023 | RELOC(alloc_bottom) = addr; | 1023 | RELOC(alloc_bottom) = addr + size; |
1024 | 1024 | ||
1025 | prom_debug(" -> %x\n", addr); | 1025 | prom_debug(" -> %x\n", addr); |
1026 | prom_debug(" alloc_bottom : %x\n", RELOC(alloc_bottom)); | 1026 | prom_debug(" alloc_bottom : %x\n", RELOC(alloc_bottom)); |
@@ -1830,11 +1830,13 @@ static void __init *make_room(unsigned long *mem_start, unsigned long *mem_end, | |||
1830 | if (room > DEVTREE_CHUNK_SIZE) | 1830 | if (room > DEVTREE_CHUNK_SIZE) |
1831 | room = DEVTREE_CHUNK_SIZE; | 1831 | room = DEVTREE_CHUNK_SIZE; |
1832 | if (room < PAGE_SIZE) | 1832 | if (room < PAGE_SIZE) |
1833 | prom_panic("No memory for flatten_device_tree (no room)"); | 1833 | prom_panic("No memory for flatten_device_tree " |
1834 | "(no room)\n"); | ||
1834 | chunk = alloc_up(room, 0); | 1835 | chunk = alloc_up(room, 0); |
1835 | if (chunk == 0) | 1836 | if (chunk == 0) |
1836 | prom_panic("No memory for flatten_device_tree (claim failed)"); | 1837 | prom_panic("No memory for flatten_device_tree " |
1837 | *mem_end = RELOC(alloc_top); | 1838 | "(claim failed)\n"); |
1839 | *mem_end = chunk + room; | ||
1838 | } | 1840 | } |
1839 | 1841 | ||
1840 | ret = (void *)*mem_start; | 1842 | ret = (void *)*mem_start; |
@@ -2042,7 +2044,7 @@ static void __init flatten_device_tree(void) | |||
2042 | 2044 | ||
2043 | /* | 2045 | /* |
2044 | * Check how much room we have between alloc top & bottom (+/- a | 2046 | * Check how much room we have between alloc top & bottom (+/- a |
2045 | * few pages), crop to 4Mb, as this is our "chuck" size | 2047 | * few pages), crop to 1MB, as this is our "chunk" size |
2046 | */ | 2048 | */ |
2047 | room = RELOC(alloc_top) - RELOC(alloc_bottom) - 0x4000; | 2049 | room = RELOC(alloc_top) - RELOC(alloc_bottom) - 0x4000; |
2048 | if (room > DEVTREE_CHUNK_SIZE) | 2050 | if (room > DEVTREE_CHUNK_SIZE) |
@@ -2053,7 +2055,7 @@ static void __init flatten_device_tree(void) | |||
2053 | mem_start = (unsigned long)alloc_up(room, PAGE_SIZE); | 2055 | mem_start = (unsigned long)alloc_up(room, PAGE_SIZE); |
2054 | if (mem_start == 0) | 2056 | if (mem_start == 0) |
2055 | prom_panic("Can't allocate initial device-tree chunk\n"); | 2057 | prom_panic("Can't allocate initial device-tree chunk\n"); |
2056 | mem_end = RELOC(alloc_top); | 2058 | mem_end = mem_start + room; |
2057 | 2059 | ||
2058 | /* Get root of tree */ | 2060 | /* Get root of tree */ |
2059 | root = call_prom("peer", 1, 1, (phandle)0); | 2061 | root = call_prom("peer", 1, 1, (phandle)0); |
diff --git a/arch/powerpc/kvm/book3s_hv_rmhandlers.S b/arch/powerpc/kvm/book3s_hv_rmhandlers.S index 6dd33581a228..de2950135e6e 100644 --- a/arch/powerpc/kvm/book3s_hv_rmhandlers.S +++ b/arch/powerpc/kvm/book3s_hv_rmhandlers.S | |||
@@ -1251,7 +1251,7 @@ BEGIN_FTR_SECTION | |||
1251 | reg = 0 | 1251 | reg = 0 |
1252 | .rept 32 | 1252 | .rept 32 |
1253 | li r6,reg*16+VCPU_VSRS | 1253 | li r6,reg*16+VCPU_VSRS |
1254 | stxvd2x reg,r6,r3 | 1254 | STXVD2X(reg,r6,r3) |
1255 | reg = reg + 1 | 1255 | reg = reg + 1 |
1256 | .endr | 1256 | .endr |
1257 | FTR_SECTION_ELSE | 1257 | FTR_SECTION_ELSE |
@@ -1313,7 +1313,7 @@ BEGIN_FTR_SECTION | |||
1313 | reg = 0 | 1313 | reg = 0 |
1314 | .rept 32 | 1314 | .rept 32 |
1315 | li r7,reg*16+VCPU_VSRS | 1315 | li r7,reg*16+VCPU_VSRS |
1316 | lxvd2x reg,r7,r4 | 1316 | LXVD2X(reg,r7,r4) |
1317 | reg = reg + 1 | 1317 | reg = reg + 1 |
1318 | .endr | 1318 | .endr |
1319 | FTR_SECTION_ELSE | 1319 | FTR_SECTION_ELSE |
diff --git a/arch/powerpc/platforms/Kconfig b/arch/powerpc/platforms/Kconfig index d0af7fb2f344..b9ba86191aed 100644 --- a/arch/powerpc/platforms/Kconfig +++ b/arch/powerpc/platforms/Kconfig | |||
@@ -24,7 +24,7 @@ source "arch/powerpc/platforms/wsp/Kconfig" | |||
24 | 24 | ||
25 | config KVM_GUEST | 25 | config KVM_GUEST |
26 | bool "KVM Guest support" | 26 | bool "KVM Guest support" |
27 | default y | 27 | default n |
28 | ---help--- | 28 | ---help--- |
29 | This option enables various optimizations for running under the KVM | 29 | This option enables various optimizations for running under the KVM |
30 | hypervisor. Overhead for the kernel when not running inside KVM should | 30 | hypervisor. Overhead for the kernel when not running inside KVM should |
diff --git a/arch/powerpc/platforms/pseries/dtl.c b/arch/powerpc/platforms/pseries/dtl.c index e9190073bb97..0e8656370063 100644 --- a/arch/powerpc/platforms/pseries/dtl.c +++ b/arch/powerpc/platforms/pseries/dtl.c | |||
@@ -181,7 +181,7 @@ static void dtl_stop(struct dtl *dtl) | |||
181 | 181 | ||
182 | lppaca_of(dtl->cpu).dtl_enable_mask = 0x0; | 182 | lppaca_of(dtl->cpu).dtl_enable_mask = 0x0; |
183 | 183 | ||
184 | unregister_dtl(hwcpu, __pa(dtl->buf)); | 184 | unregister_dtl(hwcpu); |
185 | } | 185 | } |
186 | 186 | ||
187 | static u64 dtl_current_index(struct dtl *dtl) | 187 | static u64 dtl_current_index(struct dtl *dtl) |
diff --git a/arch/powerpc/platforms/pseries/hotplug-cpu.c b/arch/powerpc/platforms/pseries/hotplug-cpu.c index bc0288501f17..83a3ca2fd282 100644 --- a/arch/powerpc/platforms/pseries/hotplug-cpu.c +++ b/arch/powerpc/platforms/pseries/hotplug-cpu.c | |||
@@ -135,7 +135,7 @@ static void pseries_mach_cpu_die(void) | |||
135 | get_lppaca()->idle = 0; | 135 | get_lppaca()->idle = 0; |
136 | 136 | ||
137 | if (get_preferred_offline_state(cpu) == CPU_STATE_ONLINE) { | 137 | if (get_preferred_offline_state(cpu) == CPU_STATE_ONLINE) { |
138 | unregister_slb_shadow(hwcpu, __pa(get_slb_shadow())); | 138 | unregister_slb_shadow(hwcpu); |
139 | 139 | ||
140 | /* | 140 | /* |
141 | * Call to start_secondary_resume() will not return. | 141 | * Call to start_secondary_resume() will not return. |
@@ -150,7 +150,7 @@ static void pseries_mach_cpu_die(void) | |||
150 | WARN_ON(get_preferred_offline_state(cpu) != CPU_STATE_OFFLINE); | 150 | WARN_ON(get_preferred_offline_state(cpu) != CPU_STATE_OFFLINE); |
151 | 151 | ||
152 | set_cpu_current_state(cpu, CPU_STATE_OFFLINE); | 152 | set_cpu_current_state(cpu, CPU_STATE_OFFLINE); |
153 | unregister_slb_shadow(hwcpu, __pa(get_slb_shadow())); | 153 | unregister_slb_shadow(hwcpu); |
154 | rtas_stop_self(); | 154 | rtas_stop_self(); |
155 | 155 | ||
156 | /* Should never get here... */ | 156 | /* Should never get here... */ |
diff --git a/arch/powerpc/platforms/pseries/io_event_irq.c b/arch/powerpc/platforms/pseries/io_event_irq.c index c829e6067d54..2c4dd1fb8333 100644 --- a/arch/powerpc/platforms/pseries/io_event_irq.c +++ b/arch/powerpc/platforms/pseries/io_event_irq.c | |||
@@ -212,17 +212,15 @@ static int __init ioei_init(void) | |||
212 | struct device_node *np; | 212 | struct device_node *np; |
213 | 213 | ||
214 | ioei_check_exception_token = rtas_token("check-exception"); | 214 | ioei_check_exception_token = rtas_token("check-exception"); |
215 | if (ioei_check_exception_token == RTAS_UNKNOWN_SERVICE) { | 215 | if (ioei_check_exception_token == RTAS_UNKNOWN_SERVICE) |
216 | pr_warning("IO Event IRQ not supported on this system !\n"); | ||
217 | return -ENODEV; | 216 | return -ENODEV; |
218 | } | 217 | |
219 | np = of_find_node_by_path("/event-sources/ibm,io-events"); | 218 | np = of_find_node_by_path("/event-sources/ibm,io-events"); |
220 | if (np) { | 219 | if (np) { |
221 | request_event_sources_irqs(np, ioei_interrupt, "IO_EVENT"); | 220 | request_event_sources_irqs(np, ioei_interrupt, "IO_EVENT"); |
221 | pr_info("IBM I/O event interrupts enabled\n"); | ||
222 | of_node_put(np); | 222 | of_node_put(np); |
223 | } else { | 223 | } else { |
224 | pr_err("io_event_irq: No ibm,io-events on system! " | ||
225 | "IO Event interrupt disabled.\n"); | ||
226 | return -ENODEV; | 224 | return -ENODEV; |
227 | } | 225 | } |
228 | return 0; | 226 | return 0; |
diff --git a/arch/powerpc/platforms/pseries/kexec.c b/arch/powerpc/platforms/pseries/kexec.c index 54cf3a4aa16b..7d94bdc63d50 100644 --- a/arch/powerpc/platforms/pseries/kexec.c +++ b/arch/powerpc/platforms/pseries/kexec.c | |||
@@ -25,20 +25,30 @@ static void pseries_kexec_cpu_down(int crash_shutdown, int secondary) | |||
25 | { | 25 | { |
26 | /* Don't risk a hypervisor call if we're crashing */ | 26 | /* Don't risk a hypervisor call if we're crashing */ |
27 | if (firmware_has_feature(FW_FEATURE_SPLPAR) && !crash_shutdown) { | 27 | if (firmware_has_feature(FW_FEATURE_SPLPAR) && !crash_shutdown) { |
28 | unsigned long addr; | 28 | int ret; |
29 | int cpu = smp_processor_id(); | ||
30 | int hwcpu = hard_smp_processor_id(); | ||
29 | 31 | ||
30 | addr = __pa(get_slb_shadow()); | 32 | if (get_lppaca()->dtl_enable_mask) { |
31 | if (unregister_slb_shadow(hard_smp_processor_id(), addr)) | 33 | ret = unregister_dtl(hwcpu); |
32 | printk("SLB shadow buffer deregistration of " | 34 | if (ret) { |
33 | "cpu %u (hw_cpu_id %d) failed\n", | 35 | pr_err("WARNING: DTL deregistration for cpu " |
34 | smp_processor_id(), | 36 | "%d (hw %d) failed with %d\n", |
35 | hard_smp_processor_id()); | 37 | cpu, hwcpu, ret); |
38 | } | ||
39 | } | ||
40 | |||
41 | ret = unregister_slb_shadow(hwcpu); | ||
42 | if (ret) { | ||
43 | pr_err("WARNING: SLB shadow buffer deregistration " | ||
44 | "for cpu %d (hw %d) failed with %d\n", | ||
45 | cpu, hwcpu, ret); | ||
46 | } | ||
36 | 47 | ||
37 | addr = __pa(get_lppaca()); | 48 | ret = unregister_vpa(hwcpu); |
38 | if (unregister_vpa(hard_smp_processor_id(), addr)) { | 49 | if (ret) { |
39 | printk("VPA deregistration of cpu %u (hw_cpu_id %d) " | 50 | pr_err("WARNING: VPA deregistration for cpu %d " |
40 | "failed\n", smp_processor_id(), | 51 | "(hw %d) failed with %d\n", cpu, hwcpu, ret); |
41 | hard_smp_processor_id()); | ||
42 | } | 52 | } |
43 | } | 53 | } |
44 | } | 54 | } |
diff --git a/arch/powerpc/platforms/pseries/lpar.c b/arch/powerpc/platforms/pseries/lpar.c index f7205d344efd..c9a29dae8c05 100644 --- a/arch/powerpc/platforms/pseries/lpar.c +++ b/arch/powerpc/platforms/pseries/lpar.c | |||
@@ -67,9 +67,8 @@ void vpa_init(int cpu) | |||
67 | ret = register_vpa(hwcpu, addr); | 67 | ret = register_vpa(hwcpu, addr); |
68 | 68 | ||
69 | if (ret) { | 69 | if (ret) { |
70 | printk(KERN_ERR "WARNING: vpa_init: VPA registration for " | 70 | pr_err("WARNING: VPA registration for cpu %d (hw %d) of area " |
71 | "cpu %d (hw %d) of area %lx returns %ld\n", | 71 | "%lx failed with %ld\n", cpu, hwcpu, addr, ret); |
72 | cpu, hwcpu, addr, ret); | ||
73 | return; | 72 | return; |
74 | } | 73 | } |
75 | /* | 74 | /* |
@@ -80,10 +79,9 @@ void vpa_init(int cpu) | |||
80 | if (firmware_has_feature(FW_FEATURE_SPLPAR)) { | 79 | if (firmware_has_feature(FW_FEATURE_SPLPAR)) { |
81 | ret = register_slb_shadow(hwcpu, addr); | 80 | ret = register_slb_shadow(hwcpu, addr); |
82 | if (ret) | 81 | if (ret) |
83 | printk(KERN_ERR | 82 | pr_err("WARNING: SLB shadow buffer registration for " |
84 | "WARNING: vpa_init: SLB shadow buffer " | 83 | "cpu %d (hw %d) of area %lx failed with %ld\n", |
85 | "registration for cpu %d (hw %d) of area %lx " | 84 | cpu, hwcpu, addr, ret); |
86 | "returns %ld\n", cpu, hwcpu, addr, ret); | ||
87 | } | 85 | } |
88 | 86 | ||
89 | /* | 87 | /* |
@@ -100,8 +98,9 @@ void vpa_init(int cpu) | |||
100 | dtl->enqueue_to_dispatch_time = DISPATCH_LOG_BYTES; | 98 | dtl->enqueue_to_dispatch_time = DISPATCH_LOG_BYTES; |
101 | ret = register_dtl(hwcpu, __pa(dtl)); | 99 | ret = register_dtl(hwcpu, __pa(dtl)); |
102 | if (ret) | 100 | if (ret) |
103 | pr_warn("DTL registration failed for cpu %d (%ld)\n", | 101 | pr_err("WARNING: DTL registration of cpu %d (hw %d) " |
104 | cpu, ret); | 102 | "failed with %ld\n", smp_processor_id(), |
103 | hwcpu, ret); | ||
105 | lppaca_of(cpu).dtl_enable_mask = 2; | 104 | lppaca_of(cpu).dtl_enable_mask = 2; |
106 | } | 105 | } |
107 | } | 106 | } |
@@ -204,7 +203,7 @@ static void pSeries_lpar_hptab_clear(void) | |||
204 | unsigned long ptel; | 203 | unsigned long ptel; |
205 | } ptes[4]; | 204 | } ptes[4]; |
206 | long lpar_rc; | 205 | long lpar_rc; |
207 | int i, j; | 206 | unsigned long i, j; |
208 | 207 | ||
209 | /* Read in batches of 4, | 208 | /* Read in batches of 4, |
210 | * invalidate only valid entries not in the VRMA | 209 | * invalidate only valid entries not in the VRMA |
diff --git a/arch/powerpc/platforms/pseries/plpar_wrappers.h b/arch/powerpc/platforms/pseries/plpar_wrappers.h index 4bf21207d7d3..41c24c146d6a 100644 --- a/arch/powerpc/platforms/pseries/plpar_wrappers.h +++ b/arch/powerpc/platforms/pseries/plpar_wrappers.h | |||
@@ -53,9 +53,9 @@ static inline long vpa_call(unsigned long flags, unsigned long cpu, | |||
53 | return plpar_hcall_norets(H_REGISTER_VPA, flags, cpu, vpa); | 53 | return plpar_hcall_norets(H_REGISTER_VPA, flags, cpu, vpa); |
54 | } | 54 | } |
55 | 55 | ||
56 | static inline long unregister_vpa(unsigned long cpu, unsigned long vpa) | 56 | static inline long unregister_vpa(unsigned long cpu) |
57 | { | 57 | { |
58 | return vpa_call(0x5, cpu, vpa); | 58 | return vpa_call(0x5, cpu, 0); |
59 | } | 59 | } |
60 | 60 | ||
61 | static inline long register_vpa(unsigned long cpu, unsigned long vpa) | 61 | static inline long register_vpa(unsigned long cpu, unsigned long vpa) |
@@ -63,9 +63,9 @@ static inline long register_vpa(unsigned long cpu, unsigned long vpa) | |||
63 | return vpa_call(0x1, cpu, vpa); | 63 | return vpa_call(0x1, cpu, vpa); |
64 | } | 64 | } |
65 | 65 | ||
66 | static inline long unregister_slb_shadow(unsigned long cpu, unsigned long vpa) | 66 | static inline long unregister_slb_shadow(unsigned long cpu) |
67 | { | 67 | { |
68 | return vpa_call(0x7, cpu, vpa); | 68 | return vpa_call(0x7, cpu, 0); |
69 | } | 69 | } |
70 | 70 | ||
71 | static inline long register_slb_shadow(unsigned long cpu, unsigned long vpa) | 71 | static inline long register_slb_shadow(unsigned long cpu, unsigned long vpa) |
@@ -73,9 +73,9 @@ static inline long register_slb_shadow(unsigned long cpu, unsigned long vpa) | |||
73 | return vpa_call(0x3, cpu, vpa); | 73 | return vpa_call(0x3, cpu, vpa); |
74 | } | 74 | } |
75 | 75 | ||
76 | static inline long unregister_dtl(unsigned long cpu, unsigned long vpa) | 76 | static inline long unregister_dtl(unsigned long cpu) |
77 | { | 77 | { |
78 | return vpa_call(0x6, cpu, vpa); | 78 | return vpa_call(0x6, cpu, 0); |
79 | } | 79 | } |
80 | 80 | ||
81 | static inline long register_dtl(unsigned long cpu, unsigned long vpa) | 81 | static inline long register_dtl(unsigned long cpu, unsigned long vpa) |
diff --git a/arch/powerpc/platforms/pseries/setup.c b/arch/powerpc/platforms/pseries/setup.c index d00e52926b71..0969fd98c4fa 100644 --- a/arch/powerpc/platforms/pseries/setup.c +++ b/arch/powerpc/platforms/pseries/setup.c | |||
@@ -324,8 +324,9 @@ static int alloc_dispatch_logs(void) | |||
324 | dtl->enqueue_to_dispatch_time = DISPATCH_LOG_BYTES; | 324 | dtl->enqueue_to_dispatch_time = DISPATCH_LOG_BYTES; |
325 | ret = register_dtl(hard_smp_processor_id(), __pa(dtl)); | 325 | ret = register_dtl(hard_smp_processor_id(), __pa(dtl)); |
326 | if (ret) | 326 | if (ret) |
327 | pr_warn("DTL registration failed for boot cpu %d (%d)\n", | 327 | pr_err("WARNING: DTL registration of cpu %d (hw %d) failed " |
328 | smp_processor_id(), ret); | 328 | "with %d\n", smp_processor_id(), |
329 | hard_smp_processor_id(), ret); | ||
329 | get_paca()->lppaca_ptr->dtl_enable_mask = 2; | 330 | get_paca()->lppaca_ptr->dtl_enable_mask = 2; |
330 | 331 | ||
331 | return 0; | 332 | return 0; |
diff --git a/arch/powerpc/sysdev/ppc4xx_pci.c b/arch/powerpc/sysdev/ppc4xx_pci.c index a59ba96d2c21..dbfe96bc878a 100644 --- a/arch/powerpc/sysdev/ppc4xx_pci.c +++ b/arch/powerpc/sysdev/ppc4xx_pci.c | |||
@@ -655,8 +655,6 @@ struct ppc4xx_pciex_hwops | |||
655 | 655 | ||
656 | static struct ppc4xx_pciex_hwops *ppc4xx_pciex_hwops; | 656 | static struct ppc4xx_pciex_hwops *ppc4xx_pciex_hwops; |
657 | 657 | ||
658 | #ifdef CONFIG_44x | ||
659 | |||
660 | static int __init ppc4xx_pciex_wait_on_sdr(struct ppc4xx_pciex_port *port, | 658 | static int __init ppc4xx_pciex_wait_on_sdr(struct ppc4xx_pciex_port *port, |
661 | unsigned int sdr_offset, | 659 | unsigned int sdr_offset, |
662 | unsigned int mask, | 660 | unsigned int mask, |
@@ -688,6 +686,7 @@ static int __init ppc4xx_pciex_port_reset_sdr(struct ppc4xx_pciex_port *port) | |||
688 | return 0; | 686 | return 0; |
689 | } | 687 | } |
690 | 688 | ||
689 | |||
691 | static void __init ppc4xx_pciex_check_link_sdr(struct ppc4xx_pciex_port *port) | 690 | static void __init ppc4xx_pciex_check_link_sdr(struct ppc4xx_pciex_port *port) |
692 | { | 691 | { |
693 | printk(KERN_INFO "PCIE%d: Checking link...\n", port->index); | 692 | printk(KERN_INFO "PCIE%d: Checking link...\n", port->index); |
@@ -718,6 +717,8 @@ static void __init ppc4xx_pciex_check_link_sdr(struct ppc4xx_pciex_port *port) | |||
718 | printk(KERN_INFO "PCIE%d: No device detected.\n", port->index); | 717 | printk(KERN_INFO "PCIE%d: No device detected.\n", port->index); |
719 | } | 718 | } |
720 | 719 | ||
720 | #ifdef CONFIG_44x | ||
721 | |||
721 | /* Check various reset bits of the 440SPe PCIe core */ | 722 | /* Check various reset bits of the 440SPe PCIe core */ |
722 | static int __init ppc440spe_pciex_check_reset(struct device_node *np) | 723 | static int __init ppc440spe_pciex_check_reset(struct device_node *np) |
723 | { | 724 | { |
diff --git a/arch/sparc/kernel/ds.c b/arch/sparc/kernel/ds.c index 490e5418740d..7429b47c3aca 100644 --- a/arch/sparc/kernel/ds.c +++ b/arch/sparc/kernel/ds.c | |||
@@ -1256,13 +1256,14 @@ static int __init ds_init(void) | |||
1256 | { | 1256 | { |
1257 | unsigned long hv_ret, major, minor; | 1257 | unsigned long hv_ret, major, minor; |
1258 | 1258 | ||
1259 | hv_ret = sun4v_get_version(HV_GRP_REBOOT_DATA, &major, &minor); | 1259 | if (tlb_type == hypervisor) { |
1260 | if (hv_ret == HV_EOK) { | 1260 | hv_ret = sun4v_get_version(HV_GRP_REBOOT_DATA, &major, &minor); |
1261 | pr_info("SUN4V: Reboot data supported (maj=%lu,min=%lu).\n", | 1261 | if (hv_ret == HV_EOK) { |
1262 | major, minor); | 1262 | pr_info("SUN4V: Reboot data supported (maj=%lu,min=%lu).\n", |
1263 | reboot_data_supported = 1; | 1263 | major, minor); |
1264 | reboot_data_supported = 1; | ||
1265 | } | ||
1264 | } | 1266 | } |
1265 | |||
1266 | kthread_run(ds_thread, NULL, "kldomd"); | 1267 | kthread_run(ds_thread, NULL, "kldomd"); |
1267 | 1268 | ||
1268 | return vio_register_driver(&ds_driver); | 1269 | return vio_register_driver(&ds_driver); |
diff --git a/arch/x86/include/asm/desc.h b/arch/x86/include/asm/desc.h index 7b439d9aea2a..41935fadfdfc 100644 --- a/arch/x86/include/asm/desc.h +++ b/arch/x86/include/asm/desc.h | |||
@@ -27,8 +27,8 @@ static inline void fill_ldt(struct desc_struct *desc, const struct user_desc *in | |||
27 | 27 | ||
28 | desc->base2 = (info->base_addr & 0xff000000) >> 24; | 28 | desc->base2 = (info->base_addr & 0xff000000) >> 24; |
29 | /* | 29 | /* |
30 | * Don't allow setting of the lm bit. It is useless anyway | 30 | * Don't allow setting of the lm bit. It would confuse |
31 | * because 64bit system calls require __USER_CS: | 31 | * user_64bit_mode and would get overridden by sysret anyway. |
32 | */ | 32 | */ |
33 | desc->l = 0; | 33 | desc->l = 0; |
34 | } | 34 | } |
diff --git a/arch/x86/include/asm/irq_vectors.h b/arch/x86/include/asm/irq_vectors.h index f9a320984a10..7e50f06393aa 100644 --- a/arch/x86/include/asm/irq_vectors.h +++ b/arch/x86/include/asm/irq_vectors.h | |||
@@ -17,7 +17,6 @@ | |||
17 | * Vectors 0 ... 31 : system traps and exceptions - hardcoded events | 17 | * Vectors 0 ... 31 : system traps and exceptions - hardcoded events |
18 | * Vectors 32 ... 127 : device interrupts | 18 | * Vectors 32 ... 127 : device interrupts |
19 | * Vector 128 : legacy int80 syscall interface | 19 | * Vector 128 : legacy int80 syscall interface |
20 | * Vector 204 : legacy x86_64 vsyscall emulation | ||
21 | * Vectors 129 ... INVALIDATE_TLB_VECTOR_START-1 except 204 : device interrupts | 20 | * Vectors 129 ... INVALIDATE_TLB_VECTOR_START-1 except 204 : device interrupts |
22 | * Vectors INVALIDATE_TLB_VECTOR_START ... 255 : special interrupts | 21 | * Vectors INVALIDATE_TLB_VECTOR_START ... 255 : special interrupts |
23 | * | 22 | * |
@@ -51,9 +50,6 @@ | |||
51 | #ifdef CONFIG_X86_32 | 50 | #ifdef CONFIG_X86_32 |
52 | # define SYSCALL_VECTOR 0x80 | 51 | # define SYSCALL_VECTOR 0x80 |
53 | #endif | 52 | #endif |
54 | #ifdef CONFIG_X86_64 | ||
55 | # define VSYSCALL_EMU_VECTOR 0xcc | ||
56 | #endif | ||
57 | 53 | ||
58 | /* | 54 | /* |
59 | * Vectors 0x30-0x3f are used for ISA interrupts. | 55 | * Vectors 0x30-0x3f are used for ISA interrupts. |
diff --git a/arch/x86/include/asm/paravirt_types.h b/arch/x86/include/asm/paravirt_types.h index 2c7652163111..8e8b9a4987ee 100644 --- a/arch/x86/include/asm/paravirt_types.h +++ b/arch/x86/include/asm/paravirt_types.h | |||
@@ -41,6 +41,7 @@ | |||
41 | 41 | ||
42 | #include <asm/desc_defs.h> | 42 | #include <asm/desc_defs.h> |
43 | #include <asm/kmap_types.h> | 43 | #include <asm/kmap_types.h> |
44 | #include <asm/pgtable_types.h> | ||
44 | 45 | ||
45 | struct page; | 46 | struct page; |
46 | struct thread_struct; | 47 | struct thread_struct; |
@@ -63,6 +64,11 @@ struct paravirt_callee_save { | |||
63 | struct pv_info { | 64 | struct pv_info { |
64 | unsigned int kernel_rpl; | 65 | unsigned int kernel_rpl; |
65 | int shared_kernel_pmd; | 66 | int shared_kernel_pmd; |
67 | |||
68 | #ifdef CONFIG_X86_64 | ||
69 | u16 extra_user_64bit_cs; /* __USER_CS if none */ | ||
70 | #endif | ||
71 | |||
66 | int paravirt_enabled; | 72 | int paravirt_enabled; |
67 | const char *name; | 73 | const char *name; |
68 | }; | 74 | }; |
diff --git a/arch/x86/include/asm/ptrace.h b/arch/x86/include/asm/ptrace.h index 94e7618fcac8..35664547125b 100644 --- a/arch/x86/include/asm/ptrace.h +++ b/arch/x86/include/asm/ptrace.h | |||
@@ -131,6 +131,9 @@ struct pt_regs { | |||
131 | #ifdef __KERNEL__ | 131 | #ifdef __KERNEL__ |
132 | 132 | ||
133 | #include <linux/init.h> | 133 | #include <linux/init.h> |
134 | #ifdef CONFIG_PARAVIRT | ||
135 | #include <asm/paravirt_types.h> | ||
136 | #endif | ||
134 | 137 | ||
135 | struct cpuinfo_x86; | 138 | struct cpuinfo_x86; |
136 | struct task_struct; | 139 | struct task_struct; |
@@ -187,6 +190,22 @@ static inline int v8086_mode(struct pt_regs *regs) | |||
187 | #endif | 190 | #endif |
188 | } | 191 | } |
189 | 192 | ||
193 | #ifdef CONFIG_X86_64 | ||
194 | static inline bool user_64bit_mode(struct pt_regs *regs) | ||
195 | { | ||
196 | #ifndef CONFIG_PARAVIRT | ||
197 | /* | ||
198 | * On non-paravirt systems, this is the only long mode CPL 3 | ||
199 | * selector. We do not allow long mode selectors in the LDT. | ||
200 | */ | ||
201 | return regs->cs == __USER_CS; | ||
202 | #else | ||
203 | /* Headers are too twisted for this to go in paravirt.h. */ | ||
204 | return regs->cs == __USER_CS || regs->cs == pv_info.extra_user_64bit_cs; | ||
205 | #endif | ||
206 | } | ||
207 | #endif | ||
208 | |||
190 | /* | 209 | /* |
191 | * X86_32 CPUs don't save ss and esp if the CPU is already in kernel mode | 210 | * X86_32 CPUs don't save ss and esp if the CPU is already in kernel mode |
192 | * when it traps. The previous stack will be directly underneath the saved | 211 | * when it traps. The previous stack will be directly underneath the saved |
diff --git a/arch/x86/include/asm/traps.h b/arch/x86/include/asm/traps.h index 2bae0a513b40..0012d0902c5f 100644 --- a/arch/x86/include/asm/traps.h +++ b/arch/x86/include/asm/traps.h | |||
@@ -40,7 +40,6 @@ asmlinkage void alignment_check(void); | |||
40 | asmlinkage void machine_check(void); | 40 | asmlinkage void machine_check(void); |
41 | #endif /* CONFIG_X86_MCE */ | 41 | #endif /* CONFIG_X86_MCE */ |
42 | asmlinkage void simd_coprocessor_error(void); | 42 | asmlinkage void simd_coprocessor_error(void); |
43 | asmlinkage void emulate_vsyscall(void); | ||
44 | 43 | ||
45 | dotraplinkage void do_divide_error(struct pt_regs *, long); | 44 | dotraplinkage void do_divide_error(struct pt_regs *, long); |
46 | dotraplinkage void do_debug(struct pt_regs *, long); | 45 | dotraplinkage void do_debug(struct pt_regs *, long); |
@@ -67,7 +66,6 @@ dotraplinkage void do_alignment_check(struct pt_regs *, long); | |||
67 | dotraplinkage void do_machine_check(struct pt_regs *, long); | 66 | dotraplinkage void do_machine_check(struct pt_regs *, long); |
68 | #endif | 67 | #endif |
69 | dotraplinkage void do_simd_coprocessor_error(struct pt_regs *, long); | 68 | dotraplinkage void do_simd_coprocessor_error(struct pt_regs *, long); |
70 | dotraplinkage void do_emulate_vsyscall(struct pt_regs *, long); | ||
71 | #ifdef CONFIG_X86_32 | 69 | #ifdef CONFIG_X86_32 |
72 | dotraplinkage void do_iret_error(struct pt_regs *, long); | 70 | dotraplinkage void do_iret_error(struct pt_regs *, long); |
73 | #endif | 71 | #endif |
diff --git a/arch/x86/include/asm/unistd_64.h b/arch/x86/include/asm/unistd_64.h index 705bf139288c..d92641cc7acc 100644 --- a/arch/x86/include/asm/unistd_64.h +++ b/arch/x86/include/asm/unistd_64.h | |||
@@ -681,6 +681,8 @@ __SYSCALL(__NR_syncfs, sys_syncfs) | |||
681 | __SYSCALL(__NR_sendmmsg, sys_sendmmsg) | 681 | __SYSCALL(__NR_sendmmsg, sys_sendmmsg) |
682 | #define __NR_setns 308 | 682 | #define __NR_setns 308 |
683 | __SYSCALL(__NR_setns, sys_setns) | 683 | __SYSCALL(__NR_setns, sys_setns) |
684 | #define __NR_getcpu 309 | ||
685 | __SYSCALL(__NR_getcpu, sys_getcpu) | ||
684 | 686 | ||
685 | #ifndef __NO_STUBS | 687 | #ifndef __NO_STUBS |
686 | #define __ARCH_WANT_OLD_READDIR | 688 | #define __ARCH_WANT_OLD_READDIR |
diff --git a/arch/x86/include/asm/vsyscall.h b/arch/x86/include/asm/vsyscall.h index 60107072c28b..eaea1d31f753 100644 --- a/arch/x86/include/asm/vsyscall.h +++ b/arch/x86/include/asm/vsyscall.h | |||
@@ -27,6 +27,12 @@ extern struct timezone sys_tz; | |||
27 | 27 | ||
28 | extern void map_vsyscall(void); | 28 | extern void map_vsyscall(void); |
29 | 29 | ||
30 | /* | ||
31 | * Called on instruction fetch fault in vsyscall page. | ||
32 | * Returns true if handled. | ||
33 | */ | ||
34 | extern bool emulate_vsyscall(struct pt_regs *regs, unsigned long address); | ||
35 | |||
30 | #endif /* __KERNEL__ */ | 36 | #endif /* __KERNEL__ */ |
31 | 37 | ||
32 | #endif /* _ASM_X86_VSYSCALL_H */ | 38 | #endif /* _ASM_X86_VSYSCALL_H */ |
diff --git a/arch/x86/kernel/Makefile b/arch/x86/kernel/Makefile index 04105574c8e9..82f2912155a5 100644 --- a/arch/x86/kernel/Makefile +++ b/arch/x86/kernel/Makefile | |||
@@ -17,19 +17,6 @@ CFLAGS_REMOVE_ftrace.o = -pg | |||
17 | CFLAGS_REMOVE_early_printk.o = -pg | 17 | CFLAGS_REMOVE_early_printk.o = -pg |
18 | endif | 18 | endif |
19 | 19 | ||
20 | # | ||
21 | # vsyscalls (which work on the user stack) should have | ||
22 | # no stack-protector checks: | ||
23 | # | ||
24 | nostackp := $(call cc-option, -fno-stack-protector) | ||
25 | CFLAGS_vsyscall_64.o := $(PROFILING) -g0 $(nostackp) | ||
26 | CFLAGS_hpet.o := $(nostackp) | ||
27 | CFLAGS_paravirt.o := $(nostackp) | ||
28 | GCOV_PROFILE_vsyscall_64.o := n | ||
29 | GCOV_PROFILE_hpet.o := n | ||
30 | GCOV_PROFILE_tsc.o := n | ||
31 | GCOV_PROFILE_paravirt.o := n | ||
32 | |||
33 | obj-y := process_$(BITS).o signal.o entry_$(BITS).o | 20 | obj-y := process_$(BITS).o signal.o entry_$(BITS).o |
34 | obj-y += traps.o irq.o irq_$(BITS).o dumpstack_$(BITS).o | 21 | obj-y += traps.o irq.o irq_$(BITS).o dumpstack_$(BITS).o |
35 | obj-y += time.o ioport.o ldt.o dumpstack.o | 22 | obj-y += time.o ioport.o ldt.o dumpstack.o |
diff --git a/arch/x86/kernel/cpu/perf_event_intel.c b/arch/x86/kernel/cpu/perf_event_intel.c index 45fbb8f7f549..f88af2c2a561 100644 --- a/arch/x86/kernel/cpu/perf_event_intel.c +++ b/arch/x86/kernel/cpu/perf_event_intel.c | |||
@@ -1590,6 +1590,7 @@ static __init int intel_pmu_init(void) | |||
1590 | break; | 1590 | break; |
1591 | 1591 | ||
1592 | case 42: /* SandyBridge */ | 1592 | case 42: /* SandyBridge */ |
1593 | case 45: /* SandyBridge, "Romely-EP" */ | ||
1593 | memcpy(hw_cache_event_ids, snb_hw_cache_event_ids, | 1594 | memcpy(hw_cache_event_ids, snb_hw_cache_event_ids, |
1594 | sizeof(hw_cache_event_ids)); | 1595 | sizeof(hw_cache_event_ids)); |
1595 | 1596 | ||
diff --git a/arch/x86/kernel/entry_64.S b/arch/x86/kernel/entry_64.S index e13329d800c8..6419bb05ecd5 100644 --- a/arch/x86/kernel/entry_64.S +++ b/arch/x86/kernel/entry_64.S | |||
@@ -1111,7 +1111,6 @@ zeroentry spurious_interrupt_bug do_spurious_interrupt_bug | |||
1111 | zeroentry coprocessor_error do_coprocessor_error | 1111 | zeroentry coprocessor_error do_coprocessor_error |
1112 | errorentry alignment_check do_alignment_check | 1112 | errorentry alignment_check do_alignment_check |
1113 | zeroentry simd_coprocessor_error do_simd_coprocessor_error | 1113 | zeroentry simd_coprocessor_error do_simd_coprocessor_error |
1114 | zeroentry emulate_vsyscall do_emulate_vsyscall | ||
1115 | 1114 | ||
1116 | 1115 | ||
1117 | /* Reload gs selector with exception handling */ | 1116 | /* Reload gs selector with exception handling */ |
diff --git a/arch/x86/kernel/paravirt.c b/arch/x86/kernel/paravirt.c index 613a7931ecc1..d90272e6bc40 100644 --- a/arch/x86/kernel/paravirt.c +++ b/arch/x86/kernel/paravirt.c | |||
@@ -307,6 +307,10 @@ struct pv_info pv_info = { | |||
307 | .paravirt_enabled = 0, | 307 | .paravirt_enabled = 0, |
308 | .kernel_rpl = 0, | 308 | .kernel_rpl = 0, |
309 | .shared_kernel_pmd = 1, /* Only used when CONFIG_X86_PAE is set */ | 309 | .shared_kernel_pmd = 1, /* Only used when CONFIG_X86_PAE is set */ |
310 | |||
311 | #ifdef CONFIG_X86_64 | ||
312 | .extra_user_64bit_cs = __USER_CS, | ||
313 | #endif | ||
310 | }; | 314 | }; |
311 | 315 | ||
312 | struct pv_init_ops pv_init_ops = { | 316 | struct pv_init_ops pv_init_ops = { |
diff --git a/arch/x86/kernel/step.c b/arch/x86/kernel/step.c index 7977f0cfe339..c346d1161488 100644 --- a/arch/x86/kernel/step.c +++ b/arch/x86/kernel/step.c | |||
@@ -74,7 +74,7 @@ static int is_setting_trap_flag(struct task_struct *child, struct pt_regs *regs) | |||
74 | 74 | ||
75 | #ifdef CONFIG_X86_64 | 75 | #ifdef CONFIG_X86_64 |
76 | case 0x40 ... 0x4f: | 76 | case 0x40 ... 0x4f: |
77 | if (regs->cs != __USER_CS) | 77 | if (!user_64bit_mode(regs)) |
78 | /* 32-bit mode: register increment */ | 78 | /* 32-bit mode: register increment */ |
79 | return 0; | 79 | return 0; |
80 | /* 64-bit mode: REX prefix */ | 80 | /* 64-bit mode: REX prefix */ |
diff --git a/arch/x86/kernel/traps.c b/arch/x86/kernel/traps.c index 9682ec50180c..6913369c234c 100644 --- a/arch/x86/kernel/traps.c +++ b/arch/x86/kernel/traps.c | |||
@@ -872,12 +872,6 @@ void __init trap_init(void) | |||
872 | set_bit(SYSCALL_VECTOR, used_vectors); | 872 | set_bit(SYSCALL_VECTOR, used_vectors); |
873 | #endif | 873 | #endif |
874 | 874 | ||
875 | #ifdef CONFIG_X86_64 | ||
876 | BUG_ON(test_bit(VSYSCALL_EMU_VECTOR, used_vectors)); | ||
877 | set_system_intr_gate(VSYSCALL_EMU_VECTOR, &emulate_vsyscall); | ||
878 | set_bit(VSYSCALL_EMU_VECTOR, used_vectors); | ||
879 | #endif | ||
880 | |||
881 | /* | 875 | /* |
882 | * Should be a barrier for any external CPU state: | 876 | * Should be a barrier for any external CPU state: |
883 | */ | 877 | */ |
diff --git a/arch/x86/kernel/vmlinux.lds.S b/arch/x86/kernel/vmlinux.lds.S index 4aa9c54a9b76..0f703f10901a 100644 --- a/arch/x86/kernel/vmlinux.lds.S +++ b/arch/x86/kernel/vmlinux.lds.S | |||
@@ -71,7 +71,6 @@ PHDRS { | |||
71 | text PT_LOAD FLAGS(5); /* R_E */ | 71 | text PT_LOAD FLAGS(5); /* R_E */ |
72 | data PT_LOAD FLAGS(6); /* RW_ */ | 72 | data PT_LOAD FLAGS(6); /* RW_ */ |
73 | #ifdef CONFIG_X86_64 | 73 | #ifdef CONFIG_X86_64 |
74 | user PT_LOAD FLAGS(5); /* R_E */ | ||
75 | #ifdef CONFIG_SMP | 74 | #ifdef CONFIG_SMP |
76 | percpu PT_LOAD FLAGS(6); /* RW_ */ | 75 | percpu PT_LOAD FLAGS(6); /* RW_ */ |
77 | #endif | 76 | #endif |
@@ -154,44 +153,16 @@ SECTIONS | |||
154 | 153 | ||
155 | #ifdef CONFIG_X86_64 | 154 | #ifdef CONFIG_X86_64 |
156 | 155 | ||
157 | #define VSYSCALL_ADDR (-10*1024*1024) | 156 | . = ALIGN(PAGE_SIZE); |
158 | |||
159 | #define VLOAD_OFFSET (VSYSCALL_ADDR - __vsyscall_0 + LOAD_OFFSET) | ||
160 | #define VLOAD(x) (ADDR(x) - VLOAD_OFFSET) | ||
161 | |||
162 | #define VVIRT_OFFSET (VSYSCALL_ADDR - __vsyscall_0) | ||
163 | #define VVIRT(x) (ADDR(x) - VVIRT_OFFSET) | ||
164 | |||
165 | . = ALIGN(4096); | ||
166 | __vsyscall_0 = .; | ||
167 | |||
168 | . = VSYSCALL_ADDR; | ||
169 | .vsyscall : AT(VLOAD(.vsyscall)) { | ||
170 | *(.vsyscall_0) | ||
171 | |||
172 | . = 1024; | ||
173 | *(.vsyscall_1) | ||
174 | |||
175 | . = 2048; | ||
176 | *(.vsyscall_2) | ||
177 | |||
178 | . = 4096; /* Pad the whole page. */ | ||
179 | } :user =0xcc | ||
180 | . = ALIGN(__vsyscall_0 + PAGE_SIZE, PAGE_SIZE); | ||
181 | |||
182 | #undef VSYSCALL_ADDR | ||
183 | #undef VLOAD_OFFSET | ||
184 | #undef VLOAD | ||
185 | #undef VVIRT_OFFSET | ||
186 | #undef VVIRT | ||
187 | |||
188 | __vvar_page = .; | 157 | __vvar_page = .; |
189 | 158 | ||
190 | .vvar : AT(ADDR(.vvar) - LOAD_OFFSET) { | 159 | .vvar : AT(ADDR(.vvar) - LOAD_OFFSET) { |
160 | /* work around gold bug 13023 */ | ||
161 | __vvar_beginning_hack = .; | ||
191 | 162 | ||
192 | /* Place all vvars at the offsets in asm/vvar.h. */ | 163 | /* Place all vvars at the offsets in asm/vvar.h. */ |
193 | #define EMIT_VVAR(name, offset) \ | 164 | #define EMIT_VVAR(name, offset) \ |
194 | . = offset; \ | 165 | . = __vvar_beginning_hack + offset; \ |
195 | *(.vvar_ ## name) | 166 | *(.vvar_ ## name) |
196 | #define __VVAR_KERNEL_LDS | 167 | #define __VVAR_KERNEL_LDS |
197 | #include <asm/vvar.h> | 168 | #include <asm/vvar.h> |
diff --git a/arch/x86/kernel/vsyscall_64.c b/arch/x86/kernel/vsyscall_64.c index dda7dff9cef7..18ae83dd1cd7 100644 --- a/arch/x86/kernel/vsyscall_64.c +++ b/arch/x86/kernel/vsyscall_64.c | |||
@@ -18,9 +18,6 @@ | |||
18 | * use the vDSO. | 18 | * use the vDSO. |
19 | */ | 19 | */ |
20 | 20 | ||
21 | /* Disable profiling for userspace code: */ | ||
22 | #define DISABLE_BRANCH_PROFILING | ||
23 | |||
24 | #include <linux/time.h> | 21 | #include <linux/time.h> |
25 | #include <linux/init.h> | 22 | #include <linux/init.h> |
26 | #include <linux/kernel.h> | 23 | #include <linux/kernel.h> |
@@ -50,12 +47,36 @@ | |||
50 | #include <asm/vgtod.h> | 47 | #include <asm/vgtod.h> |
51 | #include <asm/traps.h> | 48 | #include <asm/traps.h> |
52 | 49 | ||
50 | #define CREATE_TRACE_POINTS | ||
51 | #include "vsyscall_trace.h" | ||
52 | |||
53 | DEFINE_VVAR(int, vgetcpu_mode); | 53 | DEFINE_VVAR(int, vgetcpu_mode); |
54 | DEFINE_VVAR(struct vsyscall_gtod_data, vsyscall_gtod_data) = | 54 | DEFINE_VVAR(struct vsyscall_gtod_data, vsyscall_gtod_data) = |
55 | { | 55 | { |
56 | .lock = __SEQLOCK_UNLOCKED(__vsyscall_gtod_data.lock), | 56 | .lock = __SEQLOCK_UNLOCKED(__vsyscall_gtod_data.lock), |
57 | }; | 57 | }; |
58 | 58 | ||
59 | static enum { EMULATE, NATIVE, NONE } vsyscall_mode = EMULATE; | ||
60 | |||
61 | static int __init vsyscall_setup(char *str) | ||
62 | { | ||
63 | if (str) { | ||
64 | if (!strcmp("emulate", str)) | ||
65 | vsyscall_mode = EMULATE; | ||
66 | else if (!strcmp("native", str)) | ||
67 | vsyscall_mode = NATIVE; | ||
68 | else if (!strcmp("none", str)) | ||
69 | vsyscall_mode = NONE; | ||
70 | else | ||
71 | return -EINVAL; | ||
72 | |||
73 | return 0; | ||
74 | } | ||
75 | |||
76 | return -EINVAL; | ||
77 | } | ||
78 | early_param("vsyscall", vsyscall_setup); | ||
79 | |||
59 | void update_vsyscall_tz(void) | 80 | void update_vsyscall_tz(void) |
60 | { | 81 | { |
61 | unsigned long flags; | 82 | unsigned long flags; |
@@ -100,7 +121,7 @@ static void warn_bad_vsyscall(const char *level, struct pt_regs *regs, | |||
100 | 121 | ||
101 | printk("%s%s[%d] %s ip:%lx cs:%lx sp:%lx ax:%lx si:%lx di:%lx\n", | 122 | printk("%s%s[%d] %s ip:%lx cs:%lx sp:%lx ax:%lx si:%lx di:%lx\n", |
102 | level, tsk->comm, task_pid_nr(tsk), | 123 | level, tsk->comm, task_pid_nr(tsk), |
103 | message, regs->ip - 2, regs->cs, | 124 | message, regs->ip, regs->cs, |
104 | regs->sp, regs->ax, regs->si, regs->di); | 125 | regs->sp, regs->ax, regs->si, regs->di); |
105 | } | 126 | } |
106 | 127 | ||
@@ -118,46 +139,39 @@ static int addr_to_vsyscall_nr(unsigned long addr) | |||
118 | return nr; | 139 | return nr; |
119 | } | 140 | } |
120 | 141 | ||
121 | void dotraplinkage do_emulate_vsyscall(struct pt_regs *regs, long error_code) | 142 | bool emulate_vsyscall(struct pt_regs *regs, unsigned long address) |
122 | { | 143 | { |
123 | struct task_struct *tsk; | 144 | struct task_struct *tsk; |
124 | unsigned long caller; | 145 | unsigned long caller; |
125 | int vsyscall_nr; | 146 | int vsyscall_nr; |
126 | long ret; | 147 | long ret; |
127 | 148 | ||
128 | local_irq_enable(); | ||
129 | |||
130 | /* | 149 | /* |
131 | * Real 64-bit user mode code has cs == __USER_CS. Anything else | 150 | * No point in checking CS -- the only way to get here is a user mode |
132 | * is bogus. | 151 | * trap to a high address, which means that we're in 64-bit user code. |
133 | */ | 152 | */ |
134 | if (regs->cs != __USER_CS) { | ||
135 | /* | ||
136 | * If we trapped from kernel mode, we might as well OOPS now | ||
137 | * instead of returning to some random address and OOPSing | ||
138 | * then. | ||
139 | */ | ||
140 | BUG_ON(!user_mode(regs)); | ||
141 | 153 | ||
142 | /* Compat mode and non-compat 32-bit CS should both segfault. */ | 154 | WARN_ON_ONCE(address != regs->ip); |
143 | warn_bad_vsyscall(KERN_WARNING, regs, | 155 | |
144 | "illegal int 0xcc from 32-bit mode"); | 156 | if (vsyscall_mode == NONE) { |
145 | goto sigsegv; | 157 | warn_bad_vsyscall(KERN_INFO, regs, |
158 | "vsyscall attempted with vsyscall=none"); | ||
159 | return false; | ||
146 | } | 160 | } |
147 | 161 | ||
148 | /* | 162 | vsyscall_nr = addr_to_vsyscall_nr(address); |
149 | * x86-ism here: regs->ip points to the instruction after the int 0xcc, | 163 | |
150 | * and int 0xcc is two bytes long. | 164 | trace_emulate_vsyscall(vsyscall_nr); |
151 | */ | 165 | |
152 | vsyscall_nr = addr_to_vsyscall_nr(regs->ip - 2); | ||
153 | if (vsyscall_nr < 0) { | 166 | if (vsyscall_nr < 0) { |
154 | warn_bad_vsyscall(KERN_WARNING, regs, | 167 | warn_bad_vsyscall(KERN_WARNING, regs, |
155 | "illegal int 0xcc (exploit attempt?)"); | 168 | "misaligned vsyscall (exploit attempt or buggy program) -- look up the vsyscall kernel parameter if you need a workaround"); |
156 | goto sigsegv; | 169 | goto sigsegv; |
157 | } | 170 | } |
158 | 171 | ||
159 | if (get_user(caller, (unsigned long __user *)regs->sp) != 0) { | 172 | if (get_user(caller, (unsigned long __user *)regs->sp) != 0) { |
160 | warn_bad_vsyscall(KERN_WARNING, regs, "int 0xcc with bad stack (exploit attempt?)"); | 173 | warn_bad_vsyscall(KERN_WARNING, regs, |
174 | "vsyscall with bad stack (exploit attempt?)"); | ||
161 | goto sigsegv; | 175 | goto sigsegv; |
162 | } | 176 | } |
163 | 177 | ||
@@ -202,13 +216,11 @@ void dotraplinkage do_emulate_vsyscall(struct pt_regs *regs, long error_code) | |||
202 | regs->ip = caller; | 216 | regs->ip = caller; |
203 | regs->sp += 8; | 217 | regs->sp += 8; |
204 | 218 | ||
205 | local_irq_disable(); | 219 | return true; |
206 | return; | ||
207 | 220 | ||
208 | sigsegv: | 221 | sigsegv: |
209 | regs->ip -= 2; /* The faulting instruction should be the int 0xcc. */ | ||
210 | force_sig(SIGSEGV, current); | 222 | force_sig(SIGSEGV, current); |
211 | local_irq_disable(); | 223 | return true; |
212 | } | 224 | } |
213 | 225 | ||
214 | /* | 226 | /* |
@@ -256,15 +268,21 @@ cpu_vsyscall_notifier(struct notifier_block *n, unsigned long action, void *arg) | |||
256 | 268 | ||
257 | void __init map_vsyscall(void) | 269 | void __init map_vsyscall(void) |
258 | { | 270 | { |
259 | extern char __vsyscall_0; | 271 | extern char __vsyscall_page; |
260 | unsigned long physaddr_page0 = __pa_symbol(&__vsyscall_0); | 272 | unsigned long physaddr_vsyscall = __pa_symbol(&__vsyscall_page); |
261 | extern char __vvar_page; | 273 | extern char __vvar_page; |
262 | unsigned long physaddr_vvar_page = __pa_symbol(&__vvar_page); | 274 | unsigned long physaddr_vvar_page = __pa_symbol(&__vvar_page); |
263 | 275 | ||
264 | /* Note that VSYSCALL_MAPPED_PAGES must agree with the code below. */ | 276 | __set_fixmap(VSYSCALL_FIRST_PAGE, physaddr_vsyscall, |
265 | __set_fixmap(VSYSCALL_FIRST_PAGE, physaddr_page0, PAGE_KERNEL_VSYSCALL); | 277 | vsyscall_mode == NATIVE |
278 | ? PAGE_KERNEL_VSYSCALL | ||
279 | : PAGE_KERNEL_VVAR); | ||
280 | BUILD_BUG_ON((unsigned long)__fix_to_virt(VSYSCALL_FIRST_PAGE) != | ||
281 | (unsigned long)VSYSCALL_START); | ||
282 | |||
266 | __set_fixmap(VVAR_PAGE, physaddr_vvar_page, PAGE_KERNEL_VVAR); | 283 | __set_fixmap(VVAR_PAGE, physaddr_vvar_page, PAGE_KERNEL_VVAR); |
267 | BUILD_BUG_ON((unsigned long)__fix_to_virt(VVAR_PAGE) != (unsigned long)VVAR_ADDRESS); | 284 | BUILD_BUG_ON((unsigned long)__fix_to_virt(VVAR_PAGE) != |
285 | (unsigned long)VVAR_ADDRESS); | ||
268 | } | 286 | } |
269 | 287 | ||
270 | static int __init vsyscall_init(void) | 288 | static int __init vsyscall_init(void) |
diff --git a/arch/x86/kernel/vsyscall_emu_64.S b/arch/x86/kernel/vsyscall_emu_64.S index ffa845eae5ca..c9596a9af159 100644 --- a/arch/x86/kernel/vsyscall_emu_64.S +++ b/arch/x86/kernel/vsyscall_emu_64.S | |||
@@ -7,21 +7,31 @@ | |||
7 | */ | 7 | */ |
8 | 8 | ||
9 | #include <linux/linkage.h> | 9 | #include <linux/linkage.h> |
10 | |||
10 | #include <asm/irq_vectors.h> | 11 | #include <asm/irq_vectors.h> |
12 | #include <asm/page_types.h> | ||
13 | #include <asm/unistd_64.h> | ||
14 | |||
15 | __PAGE_ALIGNED_DATA | ||
16 | .globl __vsyscall_page | ||
17 | .balign PAGE_SIZE, 0xcc | ||
18 | .type __vsyscall_page, @object | ||
19 | __vsyscall_page: | ||
20 | |||
21 | mov $__NR_gettimeofday, %rax | ||
22 | syscall | ||
23 | ret | ||
11 | 24 | ||
12 | /* The unused parts of the page are filled with 0xcc by the linker script. */ | 25 | .balign 1024, 0xcc |
26 | mov $__NR_time, %rax | ||
27 | syscall | ||
28 | ret | ||
13 | 29 | ||
14 | .section .vsyscall_0, "a" | 30 | .balign 1024, 0xcc |
15 | ENTRY(vsyscall_0) | 31 | mov $__NR_getcpu, %rax |
16 | int $VSYSCALL_EMU_VECTOR | 32 | syscall |
17 | END(vsyscall_0) | 33 | ret |
18 | 34 | ||
19 | .section .vsyscall_1, "a" | 35 | .balign 4096, 0xcc |
20 | ENTRY(vsyscall_1) | ||
21 | int $VSYSCALL_EMU_VECTOR | ||
22 | END(vsyscall_1) | ||
23 | 36 | ||
24 | .section .vsyscall_2, "a" | 37 | .size __vsyscall_page, 4096 |
25 | ENTRY(vsyscall_2) | ||
26 | int $VSYSCALL_EMU_VECTOR | ||
27 | END(vsyscall_2) | ||
diff --git a/arch/x86/kernel/vsyscall_trace.h b/arch/x86/kernel/vsyscall_trace.h new file mode 100644 index 000000000000..a8b2edec54fe --- /dev/null +++ b/arch/x86/kernel/vsyscall_trace.h | |||
@@ -0,0 +1,29 @@ | |||
1 | #undef TRACE_SYSTEM | ||
2 | #define TRACE_SYSTEM vsyscall | ||
3 | |||
4 | #if !defined(__VSYSCALL_TRACE_H) || defined(TRACE_HEADER_MULTI_READ) | ||
5 | #define __VSYSCALL_TRACE_H | ||
6 | |||
7 | #include <linux/tracepoint.h> | ||
8 | |||
9 | TRACE_EVENT(emulate_vsyscall, | ||
10 | |||
11 | TP_PROTO(int nr), | ||
12 | |||
13 | TP_ARGS(nr), | ||
14 | |||
15 | TP_STRUCT__entry(__field(int, nr)), | ||
16 | |||
17 | TP_fast_assign( | ||
18 | __entry->nr = nr; | ||
19 | ), | ||
20 | |||
21 | TP_printk("nr = %d", __entry->nr) | ||
22 | ); | ||
23 | |||
24 | #endif | ||
25 | |||
26 | #undef TRACE_INCLUDE_PATH | ||
27 | #define TRACE_INCLUDE_PATH ../../arch/x86/kernel | ||
28 | #define TRACE_INCLUDE_FILE vsyscall_trace | ||
29 | #include <trace/define_trace.h> | ||
diff --git a/arch/x86/mm/fault.c b/arch/x86/mm/fault.c index 4d09df054e39..247aae3dc008 100644 --- a/arch/x86/mm/fault.c +++ b/arch/x86/mm/fault.c | |||
@@ -105,7 +105,7 @@ check_prefetch_opcode(struct pt_regs *regs, unsigned char *instr, | |||
105 | * but for now it's good enough to assume that long | 105 | * but for now it's good enough to assume that long |
106 | * mode only uses well known segments or kernel. | 106 | * mode only uses well known segments or kernel. |
107 | */ | 107 | */ |
108 | return (!user_mode(regs)) || (regs->cs == __USER_CS); | 108 | return (!user_mode(regs) || user_64bit_mode(regs)); |
109 | #endif | 109 | #endif |
110 | case 0x60: | 110 | case 0x60: |
111 | /* 0x64 thru 0x67 are valid prefixes in all modes. */ | 111 | /* 0x64 thru 0x67 are valid prefixes in all modes. */ |
@@ -720,6 +720,18 @@ __bad_area_nosemaphore(struct pt_regs *regs, unsigned long error_code, | |||
720 | if (is_errata100(regs, address)) | 720 | if (is_errata100(regs, address)) |
721 | return; | 721 | return; |
722 | 722 | ||
723 | #ifdef CONFIG_X86_64 | ||
724 | /* | ||
725 | * Instruction fetch faults in the vsyscall page might need | ||
726 | * emulation. | ||
727 | */ | ||
728 | if (unlikely((error_code & PF_INSTR) && | ||
729 | ((address & ~0xfff) == VSYSCALL_START))) { | ||
730 | if (emulate_vsyscall(regs, address)) | ||
731 | return; | ||
732 | } | ||
733 | #endif | ||
734 | |||
723 | if (unlikely(show_unhandled_signals)) | 735 | if (unlikely(show_unhandled_signals)) |
724 | show_signal_msg(regs, error_code, address, tsk); | 736 | show_signal_msg(regs, error_code, address, tsk); |
725 | 737 | ||
diff --git a/arch/x86/vdso/vdso.S b/arch/x86/vdso/vdso.S index 1b979c12ba85..01f5e3b4613c 100644 --- a/arch/x86/vdso/vdso.S +++ b/arch/x86/vdso/vdso.S | |||
@@ -9,6 +9,7 @@ __PAGE_ALIGNED_DATA | |||
9 | vdso_start: | 9 | vdso_start: |
10 | .incbin "arch/x86/vdso/vdso.so" | 10 | .incbin "arch/x86/vdso/vdso.so" |
11 | vdso_end: | 11 | vdso_end: |
12 | .align PAGE_SIZE /* extra data here leaks to userspace. */ | ||
12 | 13 | ||
13 | .previous | 14 | .previous |
14 | 15 | ||
diff --git a/arch/x86/xen/enlighten.c b/arch/x86/xen/enlighten.c index 974a528458a0..e2345af01af0 100644 --- a/arch/x86/xen/enlighten.c +++ b/arch/x86/xen/enlighten.c | |||
@@ -951,6 +951,10 @@ static const struct pv_info xen_info __initconst = { | |||
951 | .paravirt_enabled = 1, | 951 | .paravirt_enabled = 1, |
952 | .shared_kernel_pmd = 0, | 952 | .shared_kernel_pmd = 0, |
953 | 953 | ||
954 | #ifdef CONFIG_X86_64 | ||
955 | .extra_user_64bit_cs = FLAT_USER_CS64, | ||
956 | #endif | ||
957 | |||
954 | .name = "Xen", | 958 | .name = "Xen", |
955 | }; | 959 | }; |
956 | 960 | ||
diff --git a/arch/x86/xen/mmu.c b/arch/x86/xen/mmu.c index f987bde77c49..8cce339db5e7 100644 --- a/arch/x86/xen/mmu.c +++ b/arch/x86/xen/mmu.c | |||
@@ -1916,6 +1916,7 @@ static void xen_set_fixmap(unsigned idx, phys_addr_t phys, pgprot_t prot) | |||
1916 | # endif | 1916 | # endif |
1917 | #else | 1917 | #else |
1918 | case VSYSCALL_LAST_PAGE ... VSYSCALL_FIRST_PAGE: | 1918 | case VSYSCALL_LAST_PAGE ... VSYSCALL_FIRST_PAGE: |
1919 | case VVAR_PAGE: | ||
1919 | #endif | 1920 | #endif |
1920 | case FIX_TEXT_POKE0: | 1921 | case FIX_TEXT_POKE0: |
1921 | case FIX_TEXT_POKE1: | 1922 | case FIX_TEXT_POKE1: |
@@ -1956,7 +1957,8 @@ static void xen_set_fixmap(unsigned idx, phys_addr_t phys, pgprot_t prot) | |||
1956 | #ifdef CONFIG_X86_64 | 1957 | #ifdef CONFIG_X86_64 |
1957 | /* Replicate changes to map the vsyscall page into the user | 1958 | /* Replicate changes to map the vsyscall page into the user |
1958 | pagetable vsyscall mapping. */ | 1959 | pagetable vsyscall mapping. */ |
1959 | if (idx >= VSYSCALL_LAST_PAGE && idx <= VSYSCALL_FIRST_PAGE) { | 1960 | if ((idx >= VSYSCALL_LAST_PAGE && idx <= VSYSCALL_FIRST_PAGE) || |
1961 | idx == VVAR_PAGE) { | ||
1960 | unsigned long vaddr = __fix_to_virt(idx); | 1962 | unsigned long vaddr = __fix_to_virt(idx); |
1961 | set_pte_vaddr_pud(level3_user_vsyscall, vaddr, pte); | 1963 | set_pte_vaddr_pud(level3_user_vsyscall, vaddr, pte); |
1962 | } | 1964 | } |
diff --git a/drivers/dma/amba-pl08x.c b/drivers/dma/amba-pl08x.c index 196a7378d332..be21e3f138a8 100644 --- a/drivers/dma/amba-pl08x.c +++ b/drivers/dma/amba-pl08x.c | |||
@@ -80,6 +80,7 @@ | |||
80 | #include <linux/interrupt.h> | 80 | #include <linux/interrupt.h> |
81 | #include <linux/slab.h> | 81 | #include <linux/slab.h> |
82 | #include <linux/delay.h> | 82 | #include <linux/delay.h> |
83 | #include <linux/dma-mapping.h> | ||
83 | #include <linux/dmapool.h> | 84 | #include <linux/dmapool.h> |
84 | #include <linux/dmaengine.h> | 85 | #include <linux/dmaengine.h> |
85 | #include <linux/amba/bus.h> | 86 | #include <linux/amba/bus.h> |
diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c index e61a4e573536..8cb75a6efec3 100644 --- a/drivers/net/bonding/bond_main.c +++ b/drivers/net/bonding/bond_main.c | |||
@@ -3419,9 +3419,27 @@ static int bond_xmit_hash_policy_l2(struct sk_buff *skb, int count) | |||
3419 | static int bond_open(struct net_device *bond_dev) | 3419 | static int bond_open(struct net_device *bond_dev) |
3420 | { | 3420 | { |
3421 | struct bonding *bond = netdev_priv(bond_dev); | 3421 | struct bonding *bond = netdev_priv(bond_dev); |
3422 | struct slave *slave; | ||
3423 | int i; | ||
3422 | 3424 | ||
3423 | bond->kill_timers = 0; | 3425 | bond->kill_timers = 0; |
3424 | 3426 | ||
3427 | /* reset slave->backup and slave->inactive */ | ||
3428 | read_lock(&bond->lock); | ||
3429 | if (bond->slave_cnt > 0) { | ||
3430 | read_lock(&bond->curr_slave_lock); | ||
3431 | bond_for_each_slave(bond, slave, i) { | ||
3432 | if ((bond->params.mode == BOND_MODE_ACTIVEBACKUP) | ||
3433 | && (slave != bond->curr_active_slave)) { | ||
3434 | bond_set_slave_inactive_flags(slave); | ||
3435 | } else { | ||
3436 | bond_set_slave_active_flags(slave); | ||
3437 | } | ||
3438 | } | ||
3439 | read_unlock(&bond->curr_slave_lock); | ||
3440 | } | ||
3441 | read_unlock(&bond->lock); | ||
3442 | |||
3425 | INIT_DELAYED_WORK(&bond->mcast_work, bond_resend_igmp_join_requests_delayed); | 3443 | INIT_DELAYED_WORK(&bond->mcast_work, bond_resend_igmp_join_requests_delayed); |
3426 | 3444 | ||
3427 | if (bond_is_lb(bond)) { | 3445 | if (bond_is_lb(bond)) { |
diff --git a/drivers/net/can/sja1000/plx_pci.c b/drivers/net/can/sja1000/plx_pci.c index 231385b8e08f..c7f3d4ea1167 100644 --- a/drivers/net/can/sja1000/plx_pci.c +++ b/drivers/net/can/sja1000/plx_pci.c | |||
@@ -408,7 +408,7 @@ static void plx_pci_del_card(struct pci_dev *pdev) | |||
408 | struct sja1000_priv *priv; | 408 | struct sja1000_priv *priv; |
409 | int i = 0; | 409 | int i = 0; |
410 | 410 | ||
411 | for (i = 0; i < card->channels; i++) { | 411 | for (i = 0; i < PLX_PCI_MAX_CHAN; i++) { |
412 | dev = card->net_dev[i]; | 412 | dev = card->net_dev[i]; |
413 | if (!dev) | 413 | if (!dev) |
414 | continue; | 414 | continue; |
@@ -536,7 +536,6 @@ static int __devinit plx_pci_add_card(struct pci_dev *pdev, | |||
536 | if (err) { | 536 | if (err) { |
537 | dev_err(&pdev->dev, "Registering device failed " | 537 | dev_err(&pdev->dev, "Registering device failed " |
538 | "(err=%d)\n", err); | 538 | "(err=%d)\n", err); |
539 | free_sja1000dev(dev); | ||
540 | goto failure_cleanup; | 539 | goto failure_cleanup; |
541 | } | 540 | } |
542 | 541 | ||
@@ -549,6 +548,7 @@ static int __devinit plx_pci_add_card(struct pci_dev *pdev, | |||
549 | dev_err(&pdev->dev, "Channel #%d not detected\n", | 548 | dev_err(&pdev->dev, "Channel #%d not detected\n", |
550 | i + 1); | 549 | i + 1); |
551 | free_sja1000dev(dev); | 550 | free_sja1000dev(dev); |
551 | card->net_dev[i] = NULL; | ||
552 | } | 552 | } |
553 | } | 553 | } |
554 | 554 | ||
diff --git a/drivers/net/can/slcan.c b/drivers/net/can/slcan.c index f523f1cc5142..4b70b7e8bdeb 100644 --- a/drivers/net/can/slcan.c +++ b/drivers/net/can/slcan.c | |||
@@ -197,7 +197,7 @@ static void slc_bump(struct slcan *sl) | |||
197 | skb->ip_summed = CHECKSUM_UNNECESSARY; | 197 | skb->ip_summed = CHECKSUM_UNNECESSARY; |
198 | memcpy(skb_put(skb, sizeof(struct can_frame)), | 198 | memcpy(skb_put(skb, sizeof(struct can_frame)), |
199 | &cf, sizeof(struct can_frame)); | 199 | &cf, sizeof(struct can_frame)); |
200 | netif_rx(skb); | 200 | netif_rx_ni(skb); |
201 | 201 | ||
202 | sl->dev->stats.rx_packets++; | 202 | sl->dev->stats.rx_packets++; |
203 | sl->dev->stats.rx_bytes += cf.can_dlc; | 203 | sl->dev->stats.rx_bytes += cf.can_dlc; |
diff --git a/drivers/net/ethernet/amd/pcnet32.c b/drivers/net/ethernet/amd/pcnet32.c index e19c1a73c955..c90fe917090b 100644 --- a/drivers/net/ethernet/amd/pcnet32.c +++ b/drivers/net/ethernet/amd/pcnet32.c | |||
@@ -82,7 +82,7 @@ static int cards_found; | |||
82 | /* | 82 | /* |
83 | * VLB I/O addresses | 83 | * VLB I/O addresses |
84 | */ | 84 | */ |
85 | static unsigned int pcnet32_portlist[] __initdata = | 85 | static unsigned int pcnet32_portlist[] = |
86 | { 0x300, 0x320, 0x340, 0x360, 0 }; | 86 | { 0x300, 0x320, 0x340, 0x360, 0 }; |
87 | 87 | ||
88 | static int pcnet32_debug; | 88 | static int pcnet32_debug; |
diff --git a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_cmn.c b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_cmn.c index 23b37dd79df3..93bff08c87ad 100644 --- a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_cmn.c +++ b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_cmn.c | |||
@@ -65,8 +65,9 @@ static inline void bnx2x_bz_fp(struct bnx2x *bp, int index) | |||
65 | fp->disable_tpa = ((bp->flags & TPA_ENABLE_FLAG) == 0); | 65 | fp->disable_tpa = ((bp->flags & TPA_ENABLE_FLAG) == 0); |
66 | 66 | ||
67 | #ifdef BCM_CNIC | 67 | #ifdef BCM_CNIC |
68 | /* We don't want TPA on FCoE, FWD and OOO L2 rings */ | 68 | /* We don't want TPA on an FCoE L2 ring */ |
69 | bnx2x_fcoe(bp, disable_tpa) = 1; | 69 | if (IS_FCOE_FP(fp)) |
70 | fp->disable_tpa = 1; | ||
70 | #endif | 71 | #endif |
71 | } | 72 | } |
72 | 73 | ||
@@ -1410,10 +1411,9 @@ void bnx2x_netif_stop(struct bnx2x *bp, int disable_hw) | |||
1410 | u16 bnx2x_select_queue(struct net_device *dev, struct sk_buff *skb) | 1411 | u16 bnx2x_select_queue(struct net_device *dev, struct sk_buff *skb) |
1411 | { | 1412 | { |
1412 | struct bnx2x *bp = netdev_priv(dev); | 1413 | struct bnx2x *bp = netdev_priv(dev); |
1414 | |||
1413 | #ifdef BCM_CNIC | 1415 | #ifdef BCM_CNIC |
1414 | if (NO_FCOE(bp)) | 1416 | if (!NO_FCOE(bp)) { |
1415 | return skb_tx_hash(dev, skb); | ||
1416 | else { | ||
1417 | struct ethhdr *hdr = (struct ethhdr *)skb->data; | 1417 | struct ethhdr *hdr = (struct ethhdr *)skb->data; |
1418 | u16 ether_type = ntohs(hdr->h_proto); | 1418 | u16 ether_type = ntohs(hdr->h_proto); |
1419 | 1419 | ||
@@ -1430,8 +1430,7 @@ u16 bnx2x_select_queue(struct net_device *dev, struct sk_buff *skb) | |||
1430 | return bnx2x_fcoe_tx(bp, txq_index); | 1430 | return bnx2x_fcoe_tx(bp, txq_index); |
1431 | } | 1431 | } |
1432 | #endif | 1432 | #endif |
1433 | /* Select a none-FCoE queue: if FCoE is enabled, exclude FCoE L2 ring | 1433 | /* select a non-FCoE queue */ |
1434 | */ | ||
1435 | return __skb_tx_hash(dev, skb, BNX2X_NUM_ETH_QUEUES(bp)); | 1434 | return __skb_tx_hash(dev, skb, BNX2X_NUM_ETH_QUEUES(bp)); |
1436 | } | 1435 | } |
1437 | 1436 | ||
@@ -1454,6 +1453,28 @@ void bnx2x_set_num_queues(struct bnx2x *bp) | |||
1454 | bp->num_queues += NON_ETH_CONTEXT_USE; | 1453 | bp->num_queues += NON_ETH_CONTEXT_USE; |
1455 | } | 1454 | } |
1456 | 1455 | ||
1456 | /** | ||
1457 | * bnx2x_set_real_num_queues - configure netdev->real_num_[tx,rx]_queues | ||
1458 | * | ||
1459 | * @bp: Driver handle | ||
1460 | * | ||
1461 | * We currently support for at most 16 Tx queues for each CoS thus we will | ||
1462 | * allocate a multiple of 16 for ETH L2 rings according to the value of the | ||
1463 | * bp->max_cos. | ||
1464 | * | ||
1465 | * If there is an FCoE L2 queue the appropriate Tx queue will have the next | ||
1466 | * index after all ETH L2 indices. | ||
1467 | * | ||
1468 | * If the actual number of Tx queues (for each CoS) is less than 16 then there | ||
1469 | * will be the holes at the end of each group of 16 ETh L2 indices (0..15, | ||
1470 | * 16..31,...) with indicies that are not coupled with any real Tx queue. | ||
1471 | * | ||
1472 | * The proper configuration of skb->queue_mapping is handled by | ||
1473 | * bnx2x_select_queue() and __skb_tx_hash(). | ||
1474 | * | ||
1475 | * bnx2x_setup_tc() takes care of the proper TC mappings so that __skb_tx_hash() | ||
1476 | * will return a proper Tx index if TC is enabled (netdev->num_tc > 0). | ||
1477 | */ | ||
1457 | static inline int bnx2x_set_real_num_queues(struct bnx2x *bp) | 1478 | static inline int bnx2x_set_real_num_queues(struct bnx2x *bp) |
1458 | { | 1479 | { |
1459 | int rc, tx, rx; | 1480 | int rc, tx, rx; |
diff --git a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_dcb.c b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_dcb.c index 9525b936cf62..0b9bd551580b 100644 --- a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_dcb.c +++ b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_dcb.c | |||
@@ -923,7 +923,7 @@ static void bnx2x_dcbx_admin_mib_updated_params(struct bnx2x *bp, | |||
923 | 923 | ||
924 | void bnx2x_dcbx_set_state(struct bnx2x *bp, bool dcb_on, u32 dcbx_enabled) | 924 | void bnx2x_dcbx_set_state(struct bnx2x *bp, bool dcb_on, u32 dcbx_enabled) |
925 | { | 925 | { |
926 | if (!CHIP_IS_E1x(bp)) { | 926 | if (!CHIP_IS_E1x(bp) && !CHIP_IS_E3(bp)) { |
927 | bp->dcb_state = dcb_on; | 927 | bp->dcb_state = dcb_on; |
928 | bp->dcbx_enabled = dcbx_enabled; | 928 | bp->dcbx_enabled = dcbx_enabled; |
929 | } else { | 929 | } else { |
diff --git a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c index f4ab90c20891..720478993950 100644 --- a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c +++ b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c | |||
@@ -5794,6 +5794,12 @@ static int bnx2x_init_hw_common(struct bnx2x *bp) | |||
5794 | 5794 | ||
5795 | DP(BNX2X_MSG_MCP, "starting common init func %d\n", BP_ABS_FUNC(bp)); | 5795 | DP(BNX2X_MSG_MCP, "starting common init func %d\n", BP_ABS_FUNC(bp)); |
5796 | 5796 | ||
5797 | /* | ||
5798 | * take the UNDI lock to protect undi_unload flow from accessing | ||
5799 | * registers while we're resetting the chip | ||
5800 | */ | ||
5801 | bnx2x_acquire_hw_lock(bp, HW_LOCK_RESOURCE_UNDI); | ||
5802 | |||
5797 | bnx2x_reset_common(bp); | 5803 | bnx2x_reset_common(bp); |
5798 | REG_WR(bp, GRCBASE_MISC + MISC_REGISTERS_RESET_REG_1_SET, 0xffffffff); | 5804 | REG_WR(bp, GRCBASE_MISC + MISC_REGISTERS_RESET_REG_1_SET, 0xffffffff); |
5799 | 5805 | ||
@@ -5804,6 +5810,8 @@ static int bnx2x_init_hw_common(struct bnx2x *bp) | |||
5804 | } | 5810 | } |
5805 | REG_WR(bp, GRCBASE_MISC + MISC_REGISTERS_RESET_REG_2_SET, val); | 5811 | REG_WR(bp, GRCBASE_MISC + MISC_REGISTERS_RESET_REG_2_SET, val); |
5806 | 5812 | ||
5813 | bnx2x_release_hw_lock(bp, HW_LOCK_RESOURCE_UNDI); | ||
5814 | |||
5807 | bnx2x_init_block(bp, BLOCK_MISC, PHASE_COMMON); | 5815 | bnx2x_init_block(bp, BLOCK_MISC, PHASE_COMMON); |
5808 | 5816 | ||
5809 | if (!CHIP_IS_E1x(bp)) { | 5817 | if (!CHIP_IS_E1x(bp)) { |
@@ -10245,10 +10253,17 @@ static int __devinit bnx2x_init_dev(struct pci_dev *pdev, | |||
10245 | /* clean indirect addresses */ | 10253 | /* clean indirect addresses */ |
10246 | pci_write_config_dword(bp->pdev, PCICFG_GRC_ADDRESS, | 10254 | pci_write_config_dword(bp->pdev, PCICFG_GRC_ADDRESS, |
10247 | PCICFG_VENDOR_ID_OFFSET); | 10255 | PCICFG_VENDOR_ID_OFFSET); |
10248 | REG_WR(bp, PXP2_REG_PGL_ADDR_88_F0 + BP_PORT(bp)*16, 0); | 10256 | /* Clean the following indirect addresses for all functions since it |
10249 | REG_WR(bp, PXP2_REG_PGL_ADDR_8C_F0 + BP_PORT(bp)*16, 0); | 10257 | * is not used by the driver. |
10250 | REG_WR(bp, PXP2_REG_PGL_ADDR_90_F0 + BP_PORT(bp)*16, 0); | 10258 | */ |
10251 | REG_WR(bp, PXP2_REG_PGL_ADDR_94_F0 + BP_PORT(bp)*16, 0); | 10259 | REG_WR(bp, PXP2_REG_PGL_ADDR_88_F0, 0); |
10260 | REG_WR(bp, PXP2_REG_PGL_ADDR_8C_F0, 0); | ||
10261 | REG_WR(bp, PXP2_REG_PGL_ADDR_90_F0, 0); | ||
10262 | REG_WR(bp, PXP2_REG_PGL_ADDR_94_F0, 0); | ||
10263 | REG_WR(bp, PXP2_REG_PGL_ADDR_88_F1, 0); | ||
10264 | REG_WR(bp, PXP2_REG_PGL_ADDR_8C_F1, 0); | ||
10265 | REG_WR(bp, PXP2_REG_PGL_ADDR_90_F1, 0); | ||
10266 | REG_WR(bp, PXP2_REG_PGL_ADDR_94_F1, 0); | ||
10252 | 10267 | ||
10253 | /* | 10268 | /* |
10254 | * Enable internal target-read (in case we are probed after PF FLR). | 10269 | * Enable internal target-read (in case we are probed after PF FLR). |
diff --git a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_reg.h b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_reg.h index 27b5ecb11830..40266c14e6dc 100644 --- a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_reg.h +++ b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_reg.h | |||
@@ -3007,11 +3007,27 @@ | |||
3007 | /* [R 6] Debug only: Number of used entries in the data FIFO */ | 3007 | /* [R 6] Debug only: Number of used entries in the data FIFO */ |
3008 | #define PXP2_REG_HST_DATA_FIFO_STATUS 0x12047c | 3008 | #define PXP2_REG_HST_DATA_FIFO_STATUS 0x12047c |
3009 | /* [R 7] Debug only: Number of used entries in the header FIFO */ | 3009 | /* [R 7] Debug only: Number of used entries in the header FIFO */ |
3010 | #define PXP2_REG_HST_HEADER_FIFO_STATUS 0x120478 | 3010 | #define PXP2_REG_HST_HEADER_FIFO_STATUS 0x120478 |
3011 | #define PXP2_REG_PGL_ADDR_88_F0 0x120534 | 3011 | #define PXP2_REG_PGL_ADDR_88_F0 0x120534 |
3012 | #define PXP2_REG_PGL_ADDR_8C_F0 0x120538 | 3012 | /* [R 32] GRC address for configuration access to PCIE config address 0x88. |
3013 | #define PXP2_REG_PGL_ADDR_90_F0 0x12053c | 3013 | * any write to this PCIE address will cause a GRC write access to the |
3014 | #define PXP2_REG_PGL_ADDR_94_F0 0x120540 | 3014 | * address that's in t this register */ |
3015 | #define PXP2_REG_PGL_ADDR_88_F1 0x120544 | ||
3016 | #define PXP2_REG_PGL_ADDR_8C_F0 0x120538 | ||
3017 | /* [R 32] GRC address for configuration access to PCIE config address 0x8c. | ||
3018 | * any write to this PCIE address will cause a GRC write access to the | ||
3019 | * address that's in t this register */ | ||
3020 | #define PXP2_REG_PGL_ADDR_8C_F1 0x120548 | ||
3021 | #define PXP2_REG_PGL_ADDR_90_F0 0x12053c | ||
3022 | /* [R 32] GRC address for configuration access to PCIE config address 0x90. | ||
3023 | * any write to this PCIE address will cause a GRC write access to the | ||
3024 | * address that's in t this register */ | ||
3025 | #define PXP2_REG_PGL_ADDR_90_F1 0x12054c | ||
3026 | #define PXP2_REG_PGL_ADDR_94_F0 0x120540 | ||
3027 | /* [R 32] GRC address for configuration access to PCIE config address 0x94. | ||
3028 | * any write to this PCIE address will cause a GRC write access to the | ||
3029 | * address that's in t this register */ | ||
3030 | #define PXP2_REG_PGL_ADDR_94_F1 0x120550 | ||
3015 | #define PXP2_REG_PGL_CONTROL0 0x120490 | 3031 | #define PXP2_REG_PGL_CONTROL0 0x120490 |
3016 | #define PXP2_REG_PGL_CONTROL1 0x120514 | 3032 | #define PXP2_REG_PGL_CONTROL1 0x120514 |
3017 | #define PXP2_REG_PGL_DEBUG 0x120520 | 3033 | #define PXP2_REG_PGL_DEBUG 0x120520 |
diff --git a/drivers/net/ethernet/broadcom/tg3.c b/drivers/net/ethernet/broadcom/tg3.c index 6da9c57bcce5..0f811115fe2a 100644 --- a/drivers/net/ethernet/broadcom/tg3.c +++ b/drivers/net/ethernet/broadcom/tg3.c | |||
@@ -89,12 +89,11 @@ static inline void _tg3_flag_clear(enum TG3_FLAGS flag, unsigned long *bits) | |||
89 | 89 | ||
90 | #define DRV_MODULE_NAME "tg3" | 90 | #define DRV_MODULE_NAME "tg3" |
91 | #define TG3_MAJ_NUM 3 | 91 | #define TG3_MAJ_NUM 3 |
92 | #define TG3_MIN_NUM 119 | 92 | #define TG3_MIN_NUM 120 |
93 | #define DRV_MODULE_VERSION \ | 93 | #define DRV_MODULE_VERSION \ |
94 | __stringify(TG3_MAJ_NUM) "." __stringify(TG3_MIN_NUM) | 94 | __stringify(TG3_MAJ_NUM) "." __stringify(TG3_MIN_NUM) |
95 | #define DRV_MODULE_RELDATE "May 18, 2011" | 95 | #define DRV_MODULE_RELDATE "August 18, 2011" |
96 | 96 | ||
97 | #define TG3_DEF_MAC_MODE 0 | ||
98 | #define TG3_DEF_RX_MODE 0 | 97 | #define TG3_DEF_RX_MODE 0 |
99 | #define TG3_DEF_TX_MODE 0 | 98 | #define TG3_DEF_TX_MODE 0 |
100 | #define TG3_DEF_MSG_ENABLE \ | 99 | #define TG3_DEF_MSG_ENABLE \ |
@@ -391,12 +390,14 @@ static const struct { | |||
391 | static const struct { | 390 | static const struct { |
392 | const char string[ETH_GSTRING_LEN]; | 391 | const char string[ETH_GSTRING_LEN]; |
393 | } ethtool_test_keys[] = { | 392 | } ethtool_test_keys[] = { |
394 | { "nvram test (online) " }, | 393 | { "nvram test (online) " }, |
395 | { "link test (online) " }, | 394 | { "link test (online) " }, |
396 | { "register test (offline)" }, | 395 | { "register test (offline)" }, |
397 | { "memory test (offline)" }, | 396 | { "memory test (offline)" }, |
398 | { "loopback test (offline)" }, | 397 | { "mac loopback test (offline)" }, |
399 | { "interrupt test (offline)" }, | 398 | { "phy loopback test (offline)" }, |
399 | { "ext loopback test (offline)" }, | ||
400 | { "interrupt test (offline)" }, | ||
400 | }; | 401 | }; |
401 | 402 | ||
402 | #define TG3_NUM_TEST ARRAY_SIZE(ethtool_test_keys) | 403 | #define TG3_NUM_TEST ARRAY_SIZE(ethtool_test_keys) |
@@ -1680,6 +1681,36 @@ static void tg3_phy_fini(struct tg3 *tp) | |||
1680 | } | 1681 | } |
1681 | } | 1682 | } |
1682 | 1683 | ||
1684 | static int tg3_phy_set_extloopbk(struct tg3 *tp) | ||
1685 | { | ||
1686 | int err; | ||
1687 | u32 val; | ||
1688 | |||
1689 | if (tp->phy_flags & TG3_PHYFLG_IS_FET) | ||
1690 | return 0; | ||
1691 | |||
1692 | if ((tp->phy_id & TG3_PHY_ID_MASK) == TG3_PHY_ID_BCM5401) { | ||
1693 | /* Cannot do read-modify-write on 5401 */ | ||
1694 | err = tg3_phy_auxctl_write(tp, | ||
1695 | MII_TG3_AUXCTL_SHDWSEL_AUXCTL, | ||
1696 | MII_TG3_AUXCTL_ACTL_EXTLOOPBK | | ||
1697 | 0x4c20); | ||
1698 | goto done; | ||
1699 | } | ||
1700 | |||
1701 | err = tg3_phy_auxctl_read(tp, | ||
1702 | MII_TG3_AUXCTL_SHDWSEL_AUXCTL, &val); | ||
1703 | if (err) | ||
1704 | return err; | ||
1705 | |||
1706 | val |= MII_TG3_AUXCTL_ACTL_EXTLOOPBK; | ||
1707 | err = tg3_phy_auxctl_write(tp, | ||
1708 | MII_TG3_AUXCTL_SHDWSEL_AUXCTL, val); | ||
1709 | |||
1710 | done: | ||
1711 | return err; | ||
1712 | } | ||
1713 | |||
1683 | static void tg3_phy_fet_toggle_apd(struct tg3 *tp, bool enable) | 1714 | static void tg3_phy_fet_toggle_apd(struct tg3 *tp, bool enable) |
1684 | { | 1715 | { |
1685 | u32 phytest; | 1716 | u32 phytest; |
@@ -6343,6 +6374,127 @@ dma_error: | |||
6343 | return NETDEV_TX_OK; | 6374 | return NETDEV_TX_OK; |
6344 | } | 6375 | } |
6345 | 6376 | ||
6377 | static void tg3_mac_loopback(struct tg3 *tp, bool enable) | ||
6378 | { | ||
6379 | if (enable) { | ||
6380 | tp->mac_mode &= ~(MAC_MODE_HALF_DUPLEX | | ||
6381 | MAC_MODE_PORT_MODE_MASK); | ||
6382 | |||
6383 | tp->mac_mode |= MAC_MODE_PORT_INT_LPBACK; | ||
6384 | |||
6385 | if (!tg3_flag(tp, 5705_PLUS)) | ||
6386 | tp->mac_mode |= MAC_MODE_LINK_POLARITY; | ||
6387 | |||
6388 | if (tp->phy_flags & TG3_PHYFLG_10_100_ONLY) | ||
6389 | tp->mac_mode |= MAC_MODE_PORT_MODE_MII; | ||
6390 | else | ||
6391 | tp->mac_mode |= MAC_MODE_PORT_MODE_GMII; | ||
6392 | } else { | ||
6393 | tp->mac_mode &= ~MAC_MODE_PORT_INT_LPBACK; | ||
6394 | |||
6395 | if (tg3_flag(tp, 5705_PLUS) || | ||
6396 | (tp->phy_flags & TG3_PHYFLG_PHY_SERDES) || | ||
6397 | GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5700) | ||
6398 | tp->mac_mode &= ~MAC_MODE_LINK_POLARITY; | ||
6399 | } | ||
6400 | |||
6401 | tw32(MAC_MODE, tp->mac_mode); | ||
6402 | udelay(40); | ||
6403 | } | ||
6404 | |||
6405 | static int tg3_phy_lpbk_set(struct tg3 *tp, u32 speed, bool extlpbk) | ||
6406 | { | ||
6407 | u32 val, bmcr, mac_mode, ptest = 0; | ||
6408 | |||
6409 | tg3_phy_toggle_apd(tp, false); | ||
6410 | tg3_phy_toggle_automdix(tp, 0); | ||
6411 | |||
6412 | if (extlpbk && tg3_phy_set_extloopbk(tp)) | ||
6413 | return -EIO; | ||
6414 | |||
6415 | bmcr = BMCR_FULLDPLX; | ||
6416 | switch (speed) { | ||
6417 | case SPEED_10: | ||
6418 | break; | ||
6419 | case SPEED_100: | ||
6420 | bmcr |= BMCR_SPEED100; | ||
6421 | break; | ||
6422 | case SPEED_1000: | ||
6423 | default: | ||
6424 | if (tp->phy_flags & TG3_PHYFLG_IS_FET) { | ||
6425 | speed = SPEED_100; | ||
6426 | bmcr |= BMCR_SPEED100; | ||
6427 | } else { | ||
6428 | speed = SPEED_1000; | ||
6429 | bmcr |= BMCR_SPEED1000; | ||
6430 | } | ||
6431 | } | ||
6432 | |||
6433 | if (extlpbk) { | ||
6434 | if (!(tp->phy_flags & TG3_PHYFLG_IS_FET)) { | ||
6435 | tg3_readphy(tp, MII_CTRL1000, &val); | ||
6436 | val |= CTL1000_AS_MASTER | | ||
6437 | CTL1000_ENABLE_MASTER; | ||
6438 | tg3_writephy(tp, MII_CTRL1000, val); | ||
6439 | } else { | ||
6440 | ptest = MII_TG3_FET_PTEST_TRIM_SEL | | ||
6441 | MII_TG3_FET_PTEST_TRIM_2; | ||
6442 | tg3_writephy(tp, MII_TG3_FET_PTEST, ptest); | ||
6443 | } | ||
6444 | } else | ||
6445 | bmcr |= BMCR_LOOPBACK; | ||
6446 | |||
6447 | tg3_writephy(tp, MII_BMCR, bmcr); | ||
6448 | |||
6449 | /* The write needs to be flushed for the FETs */ | ||
6450 | if (tp->phy_flags & TG3_PHYFLG_IS_FET) | ||
6451 | tg3_readphy(tp, MII_BMCR, &bmcr); | ||
6452 | |||
6453 | udelay(40); | ||
6454 | |||
6455 | if ((tp->phy_flags & TG3_PHYFLG_IS_FET) && | ||
6456 | GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5785) { | ||
6457 | tg3_writephy(tp, MII_TG3_FET_PTEST, ptest | | ||
6458 | MII_TG3_FET_PTEST_FRC_TX_LINK | | ||
6459 | MII_TG3_FET_PTEST_FRC_TX_LOCK); | ||
6460 | |||
6461 | /* The write needs to be flushed for the AC131 */ | ||
6462 | tg3_readphy(tp, MII_TG3_FET_PTEST, &val); | ||
6463 | } | ||
6464 | |||
6465 | /* Reset to prevent losing 1st rx packet intermittently */ | ||
6466 | if ((tp->phy_flags & TG3_PHYFLG_MII_SERDES) && | ||
6467 | tg3_flag(tp, 5780_CLASS)) { | ||
6468 | tw32_f(MAC_RX_MODE, RX_MODE_RESET); | ||
6469 | udelay(10); | ||
6470 | tw32_f(MAC_RX_MODE, tp->rx_mode); | ||
6471 | } | ||
6472 | |||
6473 | mac_mode = tp->mac_mode & | ||
6474 | ~(MAC_MODE_PORT_MODE_MASK | MAC_MODE_HALF_DUPLEX); | ||
6475 | if (speed == SPEED_1000) | ||
6476 | mac_mode |= MAC_MODE_PORT_MODE_GMII; | ||
6477 | else | ||
6478 | mac_mode |= MAC_MODE_PORT_MODE_MII; | ||
6479 | |||
6480 | if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5700) { | ||
6481 | u32 masked_phy_id = tp->phy_id & TG3_PHY_ID_MASK; | ||
6482 | |||
6483 | if (masked_phy_id == TG3_PHY_ID_BCM5401) | ||
6484 | mac_mode &= ~MAC_MODE_LINK_POLARITY; | ||
6485 | else if (masked_phy_id == TG3_PHY_ID_BCM5411) | ||
6486 | mac_mode |= MAC_MODE_LINK_POLARITY; | ||
6487 | |||
6488 | tg3_writephy(tp, MII_TG3_EXT_CTRL, | ||
6489 | MII_TG3_EXT_CTRL_LNK3_LED_MODE); | ||
6490 | } | ||
6491 | |||
6492 | tw32(MAC_MODE, mac_mode); | ||
6493 | udelay(40); | ||
6494 | |||
6495 | return 0; | ||
6496 | } | ||
6497 | |||
6346 | static void tg3_set_loopback(struct net_device *dev, u32 features) | 6498 | static void tg3_set_loopback(struct net_device *dev, u32 features) |
6347 | { | 6499 | { |
6348 | struct tg3 *tp = netdev_priv(dev); | 6500 | struct tg3 *tp = netdev_priv(dev); |
@@ -6351,16 +6503,8 @@ static void tg3_set_loopback(struct net_device *dev, u32 features) | |||
6351 | if (tp->mac_mode & MAC_MODE_PORT_INT_LPBACK) | 6503 | if (tp->mac_mode & MAC_MODE_PORT_INT_LPBACK) |
6352 | return; | 6504 | return; |
6353 | 6505 | ||
6354 | /* | ||
6355 | * Clear MAC_MODE_HALF_DUPLEX or you won't get packets back in | ||
6356 | * loopback mode if Half-Duplex mode was negotiated earlier. | ||
6357 | */ | ||
6358 | tp->mac_mode &= ~MAC_MODE_HALF_DUPLEX; | ||
6359 | |||
6360 | /* Enable internal MAC loopback mode */ | ||
6361 | tp->mac_mode |= MAC_MODE_PORT_INT_LPBACK; | ||
6362 | spin_lock_bh(&tp->lock); | 6506 | spin_lock_bh(&tp->lock); |
6363 | tw32(MAC_MODE, tp->mac_mode); | 6507 | tg3_mac_loopback(tp, true); |
6364 | netif_carrier_on(tp->dev); | 6508 | netif_carrier_on(tp->dev); |
6365 | spin_unlock_bh(&tp->lock); | 6509 | spin_unlock_bh(&tp->lock); |
6366 | netdev_info(dev, "Internal MAC loopback mode enabled.\n"); | 6510 | netdev_info(dev, "Internal MAC loopback mode enabled.\n"); |
@@ -6368,10 +6512,8 @@ static void tg3_set_loopback(struct net_device *dev, u32 features) | |||
6368 | if (!(tp->mac_mode & MAC_MODE_PORT_INT_LPBACK)) | 6512 | if (!(tp->mac_mode & MAC_MODE_PORT_INT_LPBACK)) |
6369 | return; | 6513 | return; |
6370 | 6514 | ||
6371 | /* Disable internal MAC loopback mode */ | ||
6372 | tp->mac_mode &= ~MAC_MODE_PORT_INT_LPBACK; | ||
6373 | spin_lock_bh(&tp->lock); | 6515 | spin_lock_bh(&tp->lock); |
6374 | tw32(MAC_MODE, tp->mac_mode); | 6516 | tg3_mac_loopback(tp, false); |
6375 | /* Force link status check */ | 6517 | /* Force link status check */ |
6376 | tg3_setup_phy(tp, 1); | 6518 | tg3_setup_phy(tp, 1); |
6377 | spin_unlock_bh(&tp->lock); | 6519 | spin_unlock_bh(&tp->lock); |
@@ -11219,10 +11361,6 @@ static int tg3_test_memory(struct tg3 *tp) | |||
11219 | return err; | 11361 | return err; |
11220 | } | 11362 | } |
11221 | 11363 | ||
11222 | #define TG3_MAC_LOOPBACK 0 | ||
11223 | #define TG3_PHY_LOOPBACK 1 | ||
11224 | #define TG3_TSO_LOOPBACK 2 | ||
11225 | |||
11226 | #define TG3_TSO_MSS 500 | 11364 | #define TG3_TSO_MSS 500 |
11227 | 11365 | ||
11228 | #define TG3_TSO_IP_HDR_LEN 20 | 11366 | #define TG3_TSO_IP_HDR_LEN 20 |
@@ -11246,9 +11384,9 @@ static const u8 tg3_tso_header[] = { | |||
11246 | 0x11, 0x11, 0x11, 0x11, | 11384 | 0x11, 0x11, 0x11, 0x11, |
11247 | }; | 11385 | }; |
11248 | 11386 | ||
11249 | static int tg3_run_loopback(struct tg3 *tp, u32 pktsz, int loopback_mode) | 11387 | static int tg3_run_loopback(struct tg3 *tp, u32 pktsz, bool tso_loopback) |
11250 | { | 11388 | { |
11251 | u32 mac_mode, rx_start_idx, rx_idx, tx_idx, opaque_key; | 11389 | u32 rx_start_idx, rx_idx, tx_idx, opaque_key; |
11252 | u32 base_flags = 0, mss = 0, desc_idx, coal_now, data_off, val; | 11390 | u32 base_flags = 0, mss = 0, desc_idx, coal_now, data_off, val; |
11253 | u32 budget; | 11391 | u32 budget; |
11254 | struct sk_buff *skb, *rx_skb; | 11392 | struct sk_buff *skb, *rx_skb; |
@@ -11269,76 +11407,6 @@ static int tg3_run_loopback(struct tg3 *tp, u32 pktsz, int loopback_mode) | |||
11269 | } | 11407 | } |
11270 | coal_now = tnapi->coal_now | rnapi->coal_now; | 11408 | coal_now = tnapi->coal_now | rnapi->coal_now; |
11271 | 11409 | ||
11272 | if (loopback_mode == TG3_MAC_LOOPBACK) { | ||
11273 | /* HW errata - mac loopback fails in some cases on 5780. | ||
11274 | * Normal traffic and PHY loopback are not affected by | ||
11275 | * errata. Also, the MAC loopback test is deprecated for | ||
11276 | * all newer ASIC revisions. | ||
11277 | */ | ||
11278 | if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5780 || | ||
11279 | tg3_flag(tp, CPMU_PRESENT)) | ||
11280 | return 0; | ||
11281 | |||
11282 | mac_mode = tp->mac_mode & | ||
11283 | ~(MAC_MODE_PORT_MODE_MASK | MAC_MODE_HALF_DUPLEX); | ||
11284 | mac_mode |= MAC_MODE_PORT_INT_LPBACK; | ||
11285 | if (!tg3_flag(tp, 5705_PLUS)) | ||
11286 | mac_mode |= MAC_MODE_LINK_POLARITY; | ||
11287 | if (tp->phy_flags & TG3_PHYFLG_10_100_ONLY) | ||
11288 | mac_mode |= MAC_MODE_PORT_MODE_MII; | ||
11289 | else | ||
11290 | mac_mode |= MAC_MODE_PORT_MODE_GMII; | ||
11291 | tw32(MAC_MODE, mac_mode); | ||
11292 | } else { | ||
11293 | if (tp->phy_flags & TG3_PHYFLG_IS_FET) { | ||
11294 | tg3_phy_fet_toggle_apd(tp, false); | ||
11295 | val = BMCR_LOOPBACK | BMCR_FULLDPLX | BMCR_SPEED100; | ||
11296 | } else | ||
11297 | val = BMCR_LOOPBACK | BMCR_FULLDPLX | BMCR_SPEED1000; | ||
11298 | |||
11299 | tg3_phy_toggle_automdix(tp, 0); | ||
11300 | |||
11301 | tg3_writephy(tp, MII_BMCR, val); | ||
11302 | udelay(40); | ||
11303 | |||
11304 | mac_mode = tp->mac_mode & | ||
11305 | ~(MAC_MODE_PORT_MODE_MASK | MAC_MODE_HALF_DUPLEX); | ||
11306 | if (tp->phy_flags & TG3_PHYFLG_IS_FET) { | ||
11307 | tg3_writephy(tp, MII_TG3_FET_PTEST, | ||
11308 | MII_TG3_FET_PTEST_FRC_TX_LINK | | ||
11309 | MII_TG3_FET_PTEST_FRC_TX_LOCK); | ||
11310 | /* The write needs to be flushed for the AC131 */ | ||
11311 | if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5785) | ||
11312 | tg3_readphy(tp, MII_TG3_FET_PTEST, &val); | ||
11313 | mac_mode |= MAC_MODE_PORT_MODE_MII; | ||
11314 | } else | ||
11315 | mac_mode |= MAC_MODE_PORT_MODE_GMII; | ||
11316 | |||
11317 | /* reset to prevent losing 1st rx packet intermittently */ | ||
11318 | if (tp->phy_flags & TG3_PHYFLG_MII_SERDES) { | ||
11319 | tw32_f(MAC_RX_MODE, RX_MODE_RESET); | ||
11320 | udelay(10); | ||
11321 | tw32_f(MAC_RX_MODE, tp->rx_mode); | ||
11322 | } | ||
11323 | if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5700) { | ||
11324 | u32 masked_phy_id = tp->phy_id & TG3_PHY_ID_MASK; | ||
11325 | if (masked_phy_id == TG3_PHY_ID_BCM5401) | ||
11326 | mac_mode &= ~MAC_MODE_LINK_POLARITY; | ||
11327 | else if (masked_phy_id == TG3_PHY_ID_BCM5411) | ||
11328 | mac_mode |= MAC_MODE_LINK_POLARITY; | ||
11329 | tg3_writephy(tp, MII_TG3_EXT_CTRL, | ||
11330 | MII_TG3_EXT_CTRL_LNK3_LED_MODE); | ||
11331 | } | ||
11332 | tw32(MAC_MODE, mac_mode); | ||
11333 | |||
11334 | /* Wait for link */ | ||
11335 | for (i = 0; i < 100; i++) { | ||
11336 | if (tr32(MAC_TX_STATUS) & TX_STATUS_LINK_UP) | ||
11337 | break; | ||
11338 | mdelay(1); | ||
11339 | } | ||
11340 | } | ||
11341 | |||
11342 | err = -EIO; | 11410 | err = -EIO; |
11343 | 11411 | ||
11344 | tx_len = pktsz; | 11412 | tx_len = pktsz; |
@@ -11352,7 +11420,7 @@ static int tg3_run_loopback(struct tg3 *tp, u32 pktsz, int loopback_mode) | |||
11352 | 11420 | ||
11353 | tw32(MAC_RX_MTU_SIZE, tx_len + ETH_FCS_LEN); | 11421 | tw32(MAC_RX_MTU_SIZE, tx_len + ETH_FCS_LEN); |
11354 | 11422 | ||
11355 | if (loopback_mode == TG3_TSO_LOOPBACK) { | 11423 | if (tso_loopback) { |
11356 | struct iphdr *iph = (struct iphdr *)&tx_data[ETH_HLEN]; | 11424 | struct iphdr *iph = (struct iphdr *)&tx_data[ETH_HLEN]; |
11357 | 11425 | ||
11358 | u32 hdr_len = TG3_TSO_IP_HDR_LEN + TG3_TSO_TCP_HDR_LEN + | 11426 | u32 hdr_len = TG3_TSO_IP_HDR_LEN + TG3_TSO_TCP_HDR_LEN + |
@@ -11472,7 +11540,7 @@ static int tg3_run_loopback(struct tg3 *tp, u32 pktsz, int loopback_mode) | |||
11472 | rx_len = ((desc->idx_len & RXD_LEN_MASK) >> RXD_LEN_SHIFT) | 11540 | rx_len = ((desc->idx_len & RXD_LEN_MASK) >> RXD_LEN_SHIFT) |
11473 | - ETH_FCS_LEN; | 11541 | - ETH_FCS_LEN; |
11474 | 11542 | ||
11475 | if (loopback_mode != TG3_TSO_LOOPBACK) { | 11543 | if (!tso_loopback) { |
11476 | if (rx_len != tx_len) | 11544 | if (rx_len != tx_len) |
11477 | goto out; | 11545 | goto out; |
11478 | 11546 | ||
@@ -11519,25 +11587,33 @@ out: | |||
11519 | #define TG3_STD_LOOPBACK_FAILED 1 | 11587 | #define TG3_STD_LOOPBACK_FAILED 1 |
11520 | #define TG3_JMB_LOOPBACK_FAILED 2 | 11588 | #define TG3_JMB_LOOPBACK_FAILED 2 |
11521 | #define TG3_TSO_LOOPBACK_FAILED 4 | 11589 | #define TG3_TSO_LOOPBACK_FAILED 4 |
11590 | #define TG3_LOOPBACK_FAILED \ | ||
11591 | (TG3_STD_LOOPBACK_FAILED | \ | ||
11592 | TG3_JMB_LOOPBACK_FAILED | \ | ||
11593 | TG3_TSO_LOOPBACK_FAILED) | ||
11522 | 11594 | ||
11523 | #define TG3_MAC_LOOPBACK_SHIFT 0 | 11595 | static int tg3_test_loopback(struct tg3 *tp, u64 *data, bool do_extlpbk) |
11524 | #define TG3_PHY_LOOPBACK_SHIFT 4 | ||
11525 | #define TG3_LOOPBACK_FAILED 0x00000077 | ||
11526 | |||
11527 | static int tg3_test_loopback(struct tg3 *tp) | ||
11528 | { | 11596 | { |
11529 | int err = 0; | 11597 | int err = -EIO; |
11530 | u32 eee_cap, cpmuctrl = 0; | 11598 | u32 eee_cap; |
11531 | |||
11532 | if (!netif_running(tp->dev)) | ||
11533 | return TG3_LOOPBACK_FAILED; | ||
11534 | 11599 | ||
11535 | eee_cap = tp->phy_flags & TG3_PHYFLG_EEE_CAP; | 11600 | eee_cap = tp->phy_flags & TG3_PHYFLG_EEE_CAP; |
11536 | tp->phy_flags &= ~TG3_PHYFLG_EEE_CAP; | 11601 | tp->phy_flags &= ~TG3_PHYFLG_EEE_CAP; |
11537 | 11602 | ||
11603 | if (!netif_running(tp->dev)) { | ||
11604 | data[0] = TG3_LOOPBACK_FAILED; | ||
11605 | data[1] = TG3_LOOPBACK_FAILED; | ||
11606 | if (do_extlpbk) | ||
11607 | data[2] = TG3_LOOPBACK_FAILED; | ||
11608 | goto done; | ||
11609 | } | ||
11610 | |||
11538 | err = tg3_reset_hw(tp, 1); | 11611 | err = tg3_reset_hw(tp, 1); |
11539 | if (err) { | 11612 | if (err) { |
11540 | err = TG3_LOOPBACK_FAILED; | 11613 | data[0] = TG3_LOOPBACK_FAILED; |
11614 | data[1] = TG3_LOOPBACK_FAILED; | ||
11615 | if (do_extlpbk) | ||
11616 | data[2] = TG3_LOOPBACK_FAILED; | ||
11541 | goto done; | 11617 | goto done; |
11542 | } | 11618 | } |
11543 | 11619 | ||
@@ -11550,68 +11626,72 @@ static int tg3_test_loopback(struct tg3 *tp) | |||
11550 | tw32(i, 0x0); | 11626 | tw32(i, 0x0); |
11551 | } | 11627 | } |
11552 | 11628 | ||
11553 | /* Turn off gphy autopowerdown. */ | 11629 | /* HW errata - mac loopback fails in some cases on 5780. |
11554 | if (tp->phy_flags & TG3_PHYFLG_ENABLE_APD) | 11630 | * Normal traffic and PHY loopback are not affected by |
11555 | tg3_phy_toggle_apd(tp, false); | 11631 | * errata. Also, the MAC loopback test is deprecated for |
11632 | * all newer ASIC revisions. | ||
11633 | */ | ||
11634 | if (GET_ASIC_REV(tp->pci_chip_rev_id) != ASIC_REV_5780 && | ||
11635 | !tg3_flag(tp, CPMU_PRESENT)) { | ||
11636 | tg3_mac_loopback(tp, true); | ||
11556 | 11637 | ||
11557 | if (tg3_flag(tp, CPMU_PRESENT)) { | 11638 | if (tg3_run_loopback(tp, ETH_FRAME_LEN, false)) |
11639 | data[0] |= TG3_STD_LOOPBACK_FAILED; | ||
11640 | |||
11641 | if (tg3_flag(tp, JUMBO_RING_ENABLE) && | ||
11642 | tg3_run_loopback(tp, 9000 + ETH_HLEN, false)) | ||
11643 | data[0] |= TG3_JMB_LOOPBACK_FAILED; | ||
11644 | |||
11645 | tg3_mac_loopback(tp, false); | ||
11646 | } | ||
11647 | |||
11648 | if (!(tp->phy_flags & TG3_PHYFLG_PHY_SERDES) && | ||
11649 | !tg3_flag(tp, USE_PHYLIB)) { | ||
11558 | int i; | 11650 | int i; |
11559 | u32 status; | ||
11560 | 11651 | ||
11561 | tw32(TG3_CPMU_MUTEX_REQ, CPMU_MUTEX_REQ_DRIVER); | 11652 | tg3_phy_lpbk_set(tp, 0, false); |
11562 | 11653 | ||
11563 | /* Wait for up to 40 microseconds to acquire lock. */ | 11654 | /* Wait for link */ |
11564 | for (i = 0; i < 4; i++) { | 11655 | for (i = 0; i < 100; i++) { |
11565 | status = tr32(TG3_CPMU_MUTEX_GNT); | 11656 | if (tr32(MAC_TX_STATUS) & TX_STATUS_LINK_UP) |
11566 | if (status == CPMU_MUTEX_GNT_DRIVER) | ||
11567 | break; | 11657 | break; |
11568 | udelay(10); | 11658 | mdelay(1); |
11569 | } | ||
11570 | |||
11571 | if (status != CPMU_MUTEX_GNT_DRIVER) { | ||
11572 | err = TG3_LOOPBACK_FAILED; | ||
11573 | goto done; | ||
11574 | } | 11659 | } |
11575 | 11660 | ||
11576 | /* Turn off link-based power management. */ | 11661 | if (tg3_run_loopback(tp, ETH_FRAME_LEN, false)) |
11577 | cpmuctrl = tr32(TG3_CPMU_CTRL); | 11662 | data[1] |= TG3_STD_LOOPBACK_FAILED; |
11578 | tw32(TG3_CPMU_CTRL, | 11663 | if (tg3_flag(tp, TSO_CAPABLE) && |
11579 | cpmuctrl & ~(CPMU_CTRL_LINK_SPEED_MODE | | 11664 | tg3_run_loopback(tp, ETH_FRAME_LEN, true)) |
11580 | CPMU_CTRL_LINK_AWARE_MODE)); | 11665 | data[1] |= TG3_TSO_LOOPBACK_FAILED; |
11581 | } | 11666 | if (tg3_flag(tp, JUMBO_RING_ENABLE) && |
11582 | 11667 | tg3_run_loopback(tp, 9000 + ETH_HLEN, false)) | |
11583 | if (tg3_run_loopback(tp, ETH_FRAME_LEN, TG3_MAC_LOOPBACK)) | 11668 | data[1] |= TG3_JMB_LOOPBACK_FAILED; |
11584 | err |= TG3_STD_LOOPBACK_FAILED << TG3_MAC_LOOPBACK_SHIFT; | ||
11585 | 11669 | ||
11586 | if (tg3_flag(tp, JUMBO_RING_ENABLE) && | 11670 | if (do_extlpbk) { |
11587 | tg3_run_loopback(tp, 9000 + ETH_HLEN, TG3_MAC_LOOPBACK)) | 11671 | tg3_phy_lpbk_set(tp, 0, true); |
11588 | err |= TG3_JMB_LOOPBACK_FAILED << TG3_MAC_LOOPBACK_SHIFT; | ||
11589 | 11672 | ||
11590 | if (tg3_flag(tp, CPMU_PRESENT)) { | 11673 | /* All link indications report up, but the hardware |
11591 | tw32(TG3_CPMU_CTRL, cpmuctrl); | 11674 | * isn't really ready for about 20 msec. Double it |
11675 | * to be sure. | ||
11676 | */ | ||
11677 | mdelay(40); | ||
11592 | 11678 | ||
11593 | /* Release the mutex */ | 11679 | if (tg3_run_loopback(tp, ETH_FRAME_LEN, false)) |
11594 | tw32(TG3_CPMU_MUTEX_GNT, CPMU_MUTEX_GNT_DRIVER); | 11680 | data[2] |= TG3_STD_LOOPBACK_FAILED; |
11595 | } | 11681 | if (tg3_flag(tp, TSO_CAPABLE) && |
11682 | tg3_run_loopback(tp, ETH_FRAME_LEN, true)) | ||
11683 | data[2] |= TG3_TSO_LOOPBACK_FAILED; | ||
11684 | if (tg3_flag(tp, JUMBO_RING_ENABLE) && | ||
11685 | tg3_run_loopback(tp, 9000 + ETH_HLEN, false)) | ||
11686 | data[2] |= TG3_JMB_LOOPBACK_FAILED; | ||
11687 | } | ||
11596 | 11688 | ||
11597 | if (!(tp->phy_flags & TG3_PHYFLG_PHY_SERDES) && | 11689 | /* Re-enable gphy autopowerdown. */ |
11598 | !tg3_flag(tp, USE_PHYLIB)) { | 11690 | if (tp->phy_flags & TG3_PHYFLG_ENABLE_APD) |
11599 | if (tg3_run_loopback(tp, ETH_FRAME_LEN, TG3_PHY_LOOPBACK)) | 11691 | tg3_phy_toggle_apd(tp, true); |
11600 | err |= TG3_STD_LOOPBACK_FAILED << | ||
11601 | TG3_PHY_LOOPBACK_SHIFT; | ||
11602 | if (tg3_flag(tp, TSO_CAPABLE) && | ||
11603 | tg3_run_loopback(tp, ETH_FRAME_LEN, TG3_TSO_LOOPBACK)) | ||
11604 | err |= TG3_TSO_LOOPBACK_FAILED << | ||
11605 | TG3_PHY_LOOPBACK_SHIFT; | ||
11606 | if (tg3_flag(tp, JUMBO_RING_ENABLE) && | ||
11607 | tg3_run_loopback(tp, 9000 + ETH_HLEN, TG3_PHY_LOOPBACK)) | ||
11608 | err |= TG3_JMB_LOOPBACK_FAILED << | ||
11609 | TG3_PHY_LOOPBACK_SHIFT; | ||
11610 | } | 11692 | } |
11611 | 11693 | ||
11612 | /* Re-enable gphy autopowerdown. */ | 11694 | err = (data[0] | data[1] | data[2]) ? -EIO : 0; |
11613 | if (tp->phy_flags & TG3_PHYFLG_ENABLE_APD) | ||
11614 | tg3_phy_toggle_apd(tp, true); | ||
11615 | 11695 | ||
11616 | done: | 11696 | done: |
11617 | tp->phy_flags |= eee_cap; | 11697 | tp->phy_flags |= eee_cap; |
@@ -11623,6 +11703,7 @@ static void tg3_self_test(struct net_device *dev, struct ethtool_test *etest, | |||
11623 | u64 *data) | 11703 | u64 *data) |
11624 | { | 11704 | { |
11625 | struct tg3 *tp = netdev_priv(dev); | 11705 | struct tg3 *tp = netdev_priv(dev); |
11706 | bool doextlpbk = etest->flags & ETH_TEST_FL_EXTERNAL_LB; | ||
11626 | 11707 | ||
11627 | if ((tp->phy_flags & TG3_PHYFLG_IS_LOW_POWER) && | 11708 | if ((tp->phy_flags & TG3_PHYFLG_IS_LOW_POWER) && |
11628 | tg3_power_up(tp)) { | 11709 | tg3_power_up(tp)) { |
@@ -11637,7 +11718,7 @@ static void tg3_self_test(struct net_device *dev, struct ethtool_test *etest, | |||
11637 | etest->flags |= ETH_TEST_FL_FAILED; | 11718 | etest->flags |= ETH_TEST_FL_FAILED; |
11638 | data[0] = 1; | 11719 | data[0] = 1; |
11639 | } | 11720 | } |
11640 | if (tg3_test_link(tp) != 0) { | 11721 | if (!doextlpbk && tg3_test_link(tp)) { |
11641 | etest->flags |= ETH_TEST_FL_FAILED; | 11722 | etest->flags |= ETH_TEST_FL_FAILED; |
11642 | data[1] = 1; | 11723 | data[1] = 1; |
11643 | } | 11724 | } |
@@ -11667,18 +11748,23 @@ static void tg3_self_test(struct net_device *dev, struct ethtool_test *etest, | |||
11667 | etest->flags |= ETH_TEST_FL_FAILED; | 11748 | etest->flags |= ETH_TEST_FL_FAILED; |
11668 | data[2] = 1; | 11749 | data[2] = 1; |
11669 | } | 11750 | } |
11751 | |||
11670 | if (tg3_test_memory(tp) != 0) { | 11752 | if (tg3_test_memory(tp) != 0) { |
11671 | etest->flags |= ETH_TEST_FL_FAILED; | 11753 | etest->flags |= ETH_TEST_FL_FAILED; |
11672 | data[3] = 1; | 11754 | data[3] = 1; |
11673 | } | 11755 | } |
11674 | if ((data[4] = tg3_test_loopback(tp)) != 0) | 11756 | |
11757 | if (doextlpbk) | ||
11758 | etest->flags |= ETH_TEST_FL_EXTERNAL_LB_DONE; | ||
11759 | |||
11760 | if (tg3_test_loopback(tp, &data[4], doextlpbk)) | ||
11675 | etest->flags |= ETH_TEST_FL_FAILED; | 11761 | etest->flags |= ETH_TEST_FL_FAILED; |
11676 | 11762 | ||
11677 | tg3_full_unlock(tp); | 11763 | tg3_full_unlock(tp); |
11678 | 11764 | ||
11679 | if (tg3_test_interrupt(tp) != 0) { | 11765 | if (tg3_test_interrupt(tp) != 0) { |
11680 | etest->flags |= ETH_TEST_FL_FAILED; | 11766 | etest->flags |= ETH_TEST_FL_FAILED; |
11681 | data[5] = 1; | 11767 | data[7] = 1; |
11682 | } | 11768 | } |
11683 | 11769 | ||
11684 | tg3_full_lock(tp, 0); | 11770 | tg3_full_lock(tp, 0); |
@@ -14368,7 +14454,7 @@ static int __devinit tg3_get_invariants(struct tg3 *tp) | |||
14368 | if (tg3_flag(tp, ENABLE_APE)) | 14454 | if (tg3_flag(tp, ENABLE_APE)) |
14369 | tp->mac_mode = MAC_MODE_APE_TX_EN | MAC_MODE_APE_RX_EN; | 14455 | tp->mac_mode = MAC_MODE_APE_TX_EN | MAC_MODE_APE_RX_EN; |
14370 | else | 14456 | else |
14371 | tp->mac_mode = TG3_DEF_MAC_MODE; | 14457 | tp->mac_mode = 0; |
14372 | 14458 | ||
14373 | /* these are limited to 10/100 only */ | 14459 | /* these are limited to 10/100 only */ |
14374 | if ((GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5703 && | 14460 | if ((GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5703 && |
diff --git a/drivers/net/ethernet/broadcom/tg3.h b/drivers/net/ethernet/broadcom/tg3.h index 2ea456dd5880..d2976f39b2fc 100644 --- a/drivers/net/ethernet/broadcom/tg3.h +++ b/drivers/net/ethernet/broadcom/tg3.h | |||
@@ -2197,6 +2197,7 @@ | |||
2197 | #define MII_TG3_AUXCTL_ACTL_TX_6DB 0x0400 | 2197 | #define MII_TG3_AUXCTL_ACTL_TX_6DB 0x0400 |
2198 | #define MII_TG3_AUXCTL_ACTL_SMDSP_ENA 0x0800 | 2198 | #define MII_TG3_AUXCTL_ACTL_SMDSP_ENA 0x0800 |
2199 | #define MII_TG3_AUXCTL_ACTL_EXTPKTLEN 0x4000 | 2199 | #define MII_TG3_AUXCTL_ACTL_EXTPKTLEN 0x4000 |
2200 | #define MII_TG3_AUXCTL_ACTL_EXTLOOPBK 0x8000 | ||
2200 | 2201 | ||
2201 | #define MII_TG3_AUXCTL_SHDWSEL_PWRCTL 0x0002 | 2202 | #define MII_TG3_AUXCTL_SHDWSEL_PWRCTL 0x0002 |
2202 | #define MII_TG3_AUXCTL_PCTL_WOL_EN 0x0008 | 2203 | #define MII_TG3_AUXCTL_PCTL_WOL_EN 0x0008 |
@@ -2262,6 +2263,8 @@ | |||
2262 | 2263 | ||
2263 | /* Fast Ethernet Tranceiver definitions */ | 2264 | /* Fast Ethernet Tranceiver definitions */ |
2264 | #define MII_TG3_FET_PTEST 0x17 | 2265 | #define MII_TG3_FET_PTEST 0x17 |
2266 | #define MII_TG3_FET_PTEST_TRIM_SEL 0x0010 | ||
2267 | #define MII_TG3_FET_PTEST_TRIM_2 0x0002 | ||
2265 | #define MII_TG3_FET_PTEST_FRC_TX_LINK 0x1000 | 2268 | #define MII_TG3_FET_PTEST_FRC_TX_LINK 0x1000 |
2266 | #define MII_TG3_FET_PTEST_FRC_TX_LOCK 0x0800 | 2269 | #define MII_TG3_FET_PTEST_FRC_TX_LOCK 0x0800 |
2267 | 2270 | ||
diff --git a/drivers/net/ethernet/davicom/Kconfig b/drivers/net/ethernet/davicom/Kconfig index 1809d25d6eda..73c5d2080f24 100644 --- a/drivers/net/ethernet/davicom/Kconfig +++ b/drivers/net/ethernet/davicom/Kconfig | |||
@@ -13,14 +13,6 @@ config DM9000 | |||
13 | To compile this driver as a module, choose M here. The module | 13 | To compile this driver as a module, choose M here. The module |
14 | will be called dm9000. | 14 | will be called dm9000. |
15 | 15 | ||
16 | config DM9000_DEBUGLEVEL | ||
17 | int "DM9000 maximum debug level" | ||
18 | depends on DM9000 | ||
19 | default 4 | ||
20 | ---help--- | ||
21 | The maximum level of debugging code compiled into the DM9000 | ||
22 | driver. | ||
23 | |||
24 | config DM9000_FORCE_SIMPLE_PHY_POLL | 16 | config DM9000_FORCE_SIMPLE_PHY_POLL |
25 | bool "Force simple NSR based PHY polling" | 17 | bool "Force simple NSR based PHY polling" |
26 | depends on DM9000 | 18 | depends on DM9000 |
diff --git a/drivers/net/ethernet/davicom/dm9000.c b/drivers/net/ethernet/davicom/dm9000.c index 24d61e14f9cd..438f4580bf66 100644 --- a/drivers/net/ethernet/davicom/dm9000.c +++ b/drivers/net/ethernet/davicom/dm9000.c | |||
@@ -56,6 +56,13 @@ static int watchdog = 5000; | |||
56 | module_param(watchdog, int, 0400); | 56 | module_param(watchdog, int, 0400); |
57 | MODULE_PARM_DESC(watchdog, "transmit timeout in milliseconds"); | 57 | MODULE_PARM_DESC(watchdog, "transmit timeout in milliseconds"); |
58 | 58 | ||
59 | /* | ||
60 | * Debug messages level | ||
61 | */ | ||
62 | static int debug; | ||
63 | module_param(debug, int, 0644); | ||
64 | MODULE_PARM_DESC(debug, "dm9000 debug level (0-4)"); | ||
65 | |||
59 | /* DM9000 register address locking. | 66 | /* DM9000 register address locking. |
60 | * | 67 | * |
61 | * The DM9000 uses an address register to control where data written | 68 | * The DM9000 uses an address register to control where data written |
@@ -103,7 +110,6 @@ typedef struct board_info { | |||
103 | unsigned int flags; | 110 | unsigned int flags; |
104 | unsigned int in_suspend :1; | 111 | unsigned int in_suspend :1; |
105 | unsigned int wake_supported :1; | 112 | unsigned int wake_supported :1; |
106 | int debug_level; | ||
107 | 113 | ||
108 | enum dm9000_type type; | 114 | enum dm9000_type type; |
109 | 115 | ||
@@ -138,8 +144,7 @@ typedef struct board_info { | |||
138 | /* debug code */ | 144 | /* debug code */ |
139 | 145 | ||
140 | #define dm9000_dbg(db, lev, msg...) do { \ | 146 | #define dm9000_dbg(db, lev, msg...) do { \ |
141 | if ((lev) < CONFIG_DM9000_DEBUGLEVEL && \ | 147 | if ((lev) < debug) { \ |
142 | (lev) < db->debug_level) { \ | ||
143 | dev_dbg(db->dev, msg); \ | 148 | dev_dbg(db->dev, msg); \ |
144 | } \ | 149 | } \ |
145 | } while (0) | 150 | } while (0) |
diff --git a/drivers/net/ethernet/freescale/gianfar.c b/drivers/net/ethernet/freescale/gianfar.c index 29dff1ec7f2d..81d409d08c97 100644 --- a/drivers/net/ethernet/freescale/gianfar.c +++ b/drivers/net/ethernet/freescale/gianfar.c | |||
@@ -2710,8 +2710,13 @@ static int gfar_process_frame(struct net_device *dev, struct sk_buff *skb, | |||
2710 | /* Tell the skb what kind of packet this is */ | 2710 | /* Tell the skb what kind of packet this is */ |
2711 | skb->protocol = eth_type_trans(skb, dev); | 2711 | skb->protocol = eth_type_trans(skb, dev); |
2712 | 2712 | ||
2713 | /* Set vlan tag */ | 2713 | /* |
2714 | if (fcb->flags & RXFCB_VLN) | 2714 | * There's need to check for NETIF_F_HW_VLAN_RX here. |
2715 | * Even if vlan rx accel is disabled, on some chips | ||
2716 | * RXFCB_VLN is pseudo randomly set. | ||
2717 | */ | ||
2718 | if (dev->features & NETIF_F_HW_VLAN_RX && | ||
2719 | fcb->flags & RXFCB_VLN) | ||
2715 | __vlan_hwaccel_put_tag(skb, fcb->vlctl); | 2720 | __vlan_hwaccel_put_tag(skb, fcb->vlctl); |
2716 | 2721 | ||
2717 | /* Send the packet up the stack */ | 2722 | /* Send the packet up the stack */ |
diff --git a/drivers/net/ethernet/freescale/gianfar_ethtool.c b/drivers/net/ethernet/freescale/gianfar_ethtool.c index 6e350692d118..25a8c2adb001 100644 --- a/drivers/net/ethernet/freescale/gianfar_ethtool.c +++ b/drivers/net/ethernet/freescale/gianfar_ethtool.c | |||
@@ -686,10 +686,21 @@ static int gfar_ethflow_to_filer_table(struct gfar_private *priv, u64 ethflow, u | |||
686 | { | 686 | { |
687 | unsigned int last_rule_idx = priv->cur_filer_idx; | 687 | unsigned int last_rule_idx = priv->cur_filer_idx; |
688 | unsigned int cmp_rqfpr; | 688 | unsigned int cmp_rqfpr; |
689 | unsigned int local_rqfpr[MAX_FILER_IDX + 1]; | 689 | unsigned int *local_rqfpr; |
690 | unsigned int local_rqfcr[MAX_FILER_IDX + 1]; | 690 | unsigned int *local_rqfcr; |
691 | int i = 0x0, k = 0x0; | 691 | int i = 0x0, k = 0x0; |
692 | int j = MAX_FILER_IDX, l = 0x0; | 692 | int j = MAX_FILER_IDX, l = 0x0; |
693 | int ret = 1; | ||
694 | |||
695 | local_rqfpr = kmalloc(sizeof(unsigned int) * (MAX_FILER_IDX + 1), | ||
696 | GFP_KERNEL); | ||
697 | local_rqfcr = kmalloc(sizeof(unsigned int) * (MAX_FILER_IDX + 1), | ||
698 | GFP_KERNEL); | ||
699 | if (!local_rqfpr || !local_rqfcr) { | ||
700 | pr_err("Out of memory\n"); | ||
701 | ret = 0; | ||
702 | goto err; | ||
703 | } | ||
693 | 704 | ||
694 | switch (class) { | 705 | switch (class) { |
695 | case TCP_V4_FLOW: | 706 | case TCP_V4_FLOW: |
@@ -706,7 +717,8 @@ static int gfar_ethflow_to_filer_table(struct gfar_private *priv, u64 ethflow, u | |||
706 | break; | 717 | break; |
707 | default: | 718 | default: |
708 | pr_err("Right now this class is not supported\n"); | 719 | pr_err("Right now this class is not supported\n"); |
709 | return 0; | 720 | ret = 0; |
721 | goto err; | ||
710 | } | 722 | } |
711 | 723 | ||
712 | for (i = 0; i < MAX_FILER_IDX + 1; i++) { | 724 | for (i = 0; i < MAX_FILER_IDX + 1; i++) { |
@@ -721,7 +733,8 @@ static int gfar_ethflow_to_filer_table(struct gfar_private *priv, u64 ethflow, u | |||
721 | 733 | ||
722 | if (i == MAX_FILER_IDX + 1) { | 734 | if (i == MAX_FILER_IDX + 1) { |
723 | pr_err("No parse rule found, can't create hash rules\n"); | 735 | pr_err("No parse rule found, can't create hash rules\n"); |
724 | return 0; | 736 | ret = 0; |
737 | goto err; | ||
725 | } | 738 | } |
726 | 739 | ||
727 | /* If a match was found, then it begins the starting of a cluster rule | 740 | /* If a match was found, then it begins the starting of a cluster rule |
@@ -765,7 +778,10 @@ static int gfar_ethflow_to_filer_table(struct gfar_private *priv, u64 ethflow, u | |||
765 | priv->cur_filer_idx = priv->cur_filer_idx - 1; | 778 | priv->cur_filer_idx = priv->cur_filer_idx - 1; |
766 | } | 779 | } |
767 | 780 | ||
768 | return 1; | 781 | err: |
782 | kfree(local_rqfcr); | ||
783 | kfree(local_rqfpr); | ||
784 | return ret; | ||
769 | } | 785 | } |
770 | 786 | ||
771 | static int gfar_set_hash_opts(struct gfar_private *priv, struct ethtool_rxnfc *cmd) | 787 | static int gfar_set_hash_opts(struct gfar_private *priv, struct ethtool_rxnfc *cmd) |
diff --git a/drivers/net/ethernet/intel/e1000e/82571.c b/drivers/net/ethernet/intel/e1000e/82571.c index 480f2592f8a5..536b3a55c45f 100644 --- a/drivers/net/ethernet/intel/e1000e/82571.c +++ b/drivers/net/ethernet/intel/e1000e/82571.c | |||
@@ -2085,7 +2085,8 @@ struct e1000_info e1000_82574_info = { | |||
2085 | | FLAG_HAS_AMT | 2085 | | FLAG_HAS_AMT |
2086 | | FLAG_HAS_CTRLEXT_ON_LOAD, | 2086 | | FLAG_HAS_CTRLEXT_ON_LOAD, |
2087 | .flags2 = FLAG2_CHECK_PHY_HANG | 2087 | .flags2 = FLAG2_CHECK_PHY_HANG |
2088 | | FLAG2_DISABLE_ASPM_L0S, | 2088 | | FLAG2_DISABLE_ASPM_L0S |
2089 | | FLAG2_NO_DISABLE_RX, | ||
2089 | .pba = 32, | 2090 | .pba = 32, |
2090 | .max_hw_frame_size = DEFAULT_JUMBO, | 2091 | .max_hw_frame_size = DEFAULT_JUMBO, |
2091 | .get_variants = e1000_get_variants_82571, | 2092 | .get_variants = e1000_get_variants_82571, |
@@ -2104,7 +2105,8 @@ struct e1000_info e1000_82583_info = { | |||
2104 | | FLAG_HAS_AMT | 2105 | | FLAG_HAS_AMT |
2105 | | FLAG_HAS_JUMBO_FRAMES | 2106 | | FLAG_HAS_JUMBO_FRAMES |
2106 | | FLAG_HAS_CTRLEXT_ON_LOAD, | 2107 | | FLAG_HAS_CTRLEXT_ON_LOAD, |
2107 | .flags2 = FLAG2_DISABLE_ASPM_L0S, | 2108 | .flags2 = FLAG2_DISABLE_ASPM_L0S |
2109 | | FLAG2_NO_DISABLE_RX, | ||
2108 | .pba = 32, | 2110 | .pba = 32, |
2109 | .max_hw_frame_size = DEFAULT_JUMBO, | 2111 | .max_hw_frame_size = DEFAULT_JUMBO, |
2110 | .get_variants = e1000_get_variants_82571, | 2112 | .get_variants = e1000_get_variants_82571, |
diff --git a/drivers/net/ethernet/intel/e1000e/e1000.h b/drivers/net/ethernet/intel/e1000e/e1000.h index cbbbff4627ac..fa72052a0031 100644 --- a/drivers/net/ethernet/intel/e1000e/e1000.h +++ b/drivers/net/ethernet/intel/e1000e/e1000.h | |||
@@ -155,6 +155,9 @@ struct e1000_info; | |||
155 | #define HV_M_STATUS_SPEED_1000 0x0200 | 155 | #define HV_M_STATUS_SPEED_1000 0x0200 |
156 | #define HV_M_STATUS_LINK_UP 0x0040 | 156 | #define HV_M_STATUS_LINK_UP 0x0040 |
157 | 157 | ||
158 | #define E1000_ICH_FWSM_PCIM2PCI 0x01000000 /* ME PCIm-to-PCI active */ | ||
159 | #define E1000_ICH_FWSM_PCIM2PCI_COUNT 2000 | ||
160 | |||
158 | /* Time to wait before putting the device into D3 if there's no link (in ms). */ | 161 | /* Time to wait before putting the device into D3 if there's no link (in ms). */ |
159 | #define LINK_TIMEOUT 100 | 162 | #define LINK_TIMEOUT 100 |
160 | 163 | ||
@@ -453,6 +456,8 @@ struct e1000_info { | |||
453 | #define FLAG2_DISABLE_ASPM_L0S (1 << 7) | 456 | #define FLAG2_DISABLE_ASPM_L0S (1 << 7) |
454 | #define FLAG2_DISABLE_AIM (1 << 8) | 457 | #define FLAG2_DISABLE_AIM (1 << 8) |
455 | #define FLAG2_CHECK_PHY_HANG (1 << 9) | 458 | #define FLAG2_CHECK_PHY_HANG (1 << 9) |
459 | #define FLAG2_NO_DISABLE_RX (1 << 10) | ||
460 | #define FLAG2_PCIM2PCI_ARBITER_WA (1 << 11) | ||
456 | 461 | ||
457 | #define E1000_RX_DESC_PS(R, i) \ | 462 | #define E1000_RX_DESC_PS(R, i) \ |
458 | (&(((union e1000_rx_desc_packet_split *)((R).desc))[i])) | 463 | (&(((union e1000_rx_desc_packet_split *)((R).desc))[i])) |
diff --git a/drivers/net/ethernet/intel/e1000e/ethtool.c b/drivers/net/ethernet/intel/e1000e/ethtool.c index 8d3ca85ae039..e0cbd6a0bde8 100644 --- a/drivers/net/ethernet/intel/e1000e/ethtool.c +++ b/drivers/net/ethernet/intel/e1000e/ethtool.c | |||
@@ -1206,7 +1206,8 @@ static int e1000_setup_desc_rings(struct e1000_adapter *adapter) | |||
1206 | rx_ring->next_to_clean = 0; | 1206 | rx_ring->next_to_clean = 0; |
1207 | 1207 | ||
1208 | rctl = er32(RCTL); | 1208 | rctl = er32(RCTL); |
1209 | ew32(RCTL, rctl & ~E1000_RCTL_EN); | 1209 | if (!(adapter->flags2 & FLAG2_NO_DISABLE_RX)) |
1210 | ew32(RCTL, rctl & ~E1000_RCTL_EN); | ||
1210 | ew32(RDBAL, ((u64) rx_ring->dma & 0xFFFFFFFF)); | 1211 | ew32(RDBAL, ((u64) rx_ring->dma & 0xFFFFFFFF)); |
1211 | ew32(RDBAH, ((u64) rx_ring->dma >> 32)); | 1212 | ew32(RDBAH, ((u64) rx_ring->dma >> 32)); |
1212 | ew32(RDLEN, rx_ring->size); | 1213 | ew32(RDLEN, rx_ring->size); |
diff --git a/drivers/net/ethernet/intel/e1000e/ich8lan.c b/drivers/net/ethernet/intel/e1000e/ich8lan.c index 4e36978b8fd8..54add27c8f76 100644 --- a/drivers/net/ethernet/intel/e1000e/ich8lan.c +++ b/drivers/net/ethernet/intel/e1000e/ich8lan.c | |||
@@ -137,8 +137,9 @@ | |||
137 | #define HV_PM_CTRL PHY_REG(770, 17) | 137 | #define HV_PM_CTRL PHY_REG(770, 17) |
138 | 138 | ||
139 | /* PHY Low Power Idle Control */ | 139 | /* PHY Low Power Idle Control */ |
140 | #define I82579_LPI_CTRL PHY_REG(772, 20) | 140 | #define I82579_LPI_CTRL PHY_REG(772, 20) |
141 | #define I82579_LPI_CTRL_ENABLE_MASK 0x6000 | 141 | #define I82579_LPI_CTRL_ENABLE_MASK 0x6000 |
142 | #define I82579_LPI_CTRL_FORCE_PLL_LOCK_COUNT 0x80 | ||
142 | 143 | ||
143 | /* EMI Registers */ | 144 | /* EMI Registers */ |
144 | #define I82579_EMI_ADDR 0x10 | 145 | #define I82579_EMI_ADDR 0x10 |
@@ -163,6 +164,11 @@ | |||
163 | #define HV_KMRN_MODE_CTRL PHY_REG(769, 16) | 164 | #define HV_KMRN_MODE_CTRL PHY_REG(769, 16) |
164 | #define HV_KMRN_MDIO_SLOW 0x0400 | 165 | #define HV_KMRN_MDIO_SLOW 0x0400 |
165 | 166 | ||
167 | /* KMRN FIFO Control and Status */ | ||
168 | #define HV_KMRN_FIFO_CTRLSTA PHY_REG(770, 16) | ||
169 | #define HV_KMRN_FIFO_CTRLSTA_PREAMBLE_MASK 0x7000 | ||
170 | #define HV_KMRN_FIFO_CTRLSTA_PREAMBLE_SHIFT 12 | ||
171 | |||
166 | /* ICH GbE Flash Hardware Sequencing Flash Status Register bit breakdown */ | 172 | /* ICH GbE Flash Hardware Sequencing Flash Status Register bit breakdown */ |
167 | /* Offset 04h HSFSTS */ | 173 | /* Offset 04h HSFSTS */ |
168 | union ich8_hws_flash_status { | 174 | union ich8_hws_flash_status { |
@@ -657,6 +663,7 @@ static s32 e1000_check_for_copper_link_ich8lan(struct e1000_hw *hw) | |||
657 | struct e1000_mac_info *mac = &hw->mac; | 663 | struct e1000_mac_info *mac = &hw->mac; |
658 | s32 ret_val; | 664 | s32 ret_val; |
659 | bool link; | 665 | bool link; |
666 | u16 phy_reg; | ||
660 | 667 | ||
661 | /* | 668 | /* |
662 | * We only want to go out to the PHY registers to see if Auto-Neg | 669 | * We only want to go out to the PHY registers to see if Auto-Neg |
@@ -689,16 +696,35 @@ static s32 e1000_check_for_copper_link_ich8lan(struct e1000_hw *hw) | |||
689 | 696 | ||
690 | mac->get_link_status = false; | 697 | mac->get_link_status = false; |
691 | 698 | ||
692 | if (hw->phy.type == e1000_phy_82578) { | 699 | switch (hw->mac.type) { |
693 | ret_val = e1000_link_stall_workaround_hv(hw); | 700 | case e1000_pch2lan: |
694 | if (ret_val) | ||
695 | goto out; | ||
696 | } | ||
697 | |||
698 | if (hw->mac.type == e1000_pch2lan) { | ||
699 | ret_val = e1000_k1_workaround_lv(hw); | 701 | ret_val = e1000_k1_workaround_lv(hw); |
700 | if (ret_val) | 702 | if (ret_val) |
701 | goto out; | 703 | goto out; |
704 | /* fall-thru */ | ||
705 | case e1000_pchlan: | ||
706 | if (hw->phy.type == e1000_phy_82578) { | ||
707 | ret_val = e1000_link_stall_workaround_hv(hw); | ||
708 | if (ret_val) | ||
709 | goto out; | ||
710 | } | ||
711 | |||
712 | /* | ||
713 | * Workaround for PCHx parts in half-duplex: | ||
714 | * Set the number of preambles removed from the packet | ||
715 | * when it is passed from the PHY to the MAC to prevent | ||
716 | * the MAC from misinterpreting the packet type. | ||
717 | */ | ||
718 | e1e_rphy(hw, HV_KMRN_FIFO_CTRLSTA, &phy_reg); | ||
719 | phy_reg &= ~HV_KMRN_FIFO_CTRLSTA_PREAMBLE_MASK; | ||
720 | |||
721 | if ((er32(STATUS) & E1000_STATUS_FD) != E1000_STATUS_FD) | ||
722 | phy_reg |= (1 << HV_KMRN_FIFO_CTRLSTA_PREAMBLE_SHIFT); | ||
723 | |||
724 | e1e_wphy(hw, HV_KMRN_FIFO_CTRLSTA, phy_reg); | ||
725 | break; | ||
726 | default: | ||
727 | break; | ||
702 | } | 728 | } |
703 | 729 | ||
704 | /* | 730 | /* |
@@ -788,6 +814,11 @@ static s32 e1000_get_variants_ich8lan(struct e1000_adapter *adapter) | |||
788 | (adapter->hw.phy.type == e1000_phy_igp_3)) | 814 | (adapter->hw.phy.type == e1000_phy_igp_3)) |
789 | adapter->flags |= FLAG_LSC_GIG_SPEED_DROP; | 815 | adapter->flags |= FLAG_LSC_GIG_SPEED_DROP; |
790 | 816 | ||
817 | /* Enable workaround for 82579 w/ ME enabled */ | ||
818 | if ((adapter->hw.mac.type == e1000_pch2lan) && | ||
819 | (er32(FWSM) & E1000_ICH_FWSM_FW_VALID)) | ||
820 | adapter->flags2 |= FLAG2_PCIM2PCI_ARBITER_WA; | ||
821 | |||
791 | /* Disable EEE by default until IEEE802.3az spec is finalized */ | 822 | /* Disable EEE by default until IEEE802.3az spec is finalized */ |
792 | if (adapter->flags2 & FLAG2_HAS_EEE) | 823 | if (adapter->flags2 & FLAG2_HAS_EEE) |
793 | adapter->hw.dev_spec.ich8lan.eee_disable = true; | 824 | adapter->hw.dev_spec.ich8lan.eee_disable = true; |
@@ -1355,7 +1386,7 @@ static s32 e1000_hv_phy_workarounds_ich8lan(struct e1000_hw *hw) | |||
1355 | return ret_val; | 1386 | return ret_val; |
1356 | 1387 | ||
1357 | /* Preamble tuning for SSC */ | 1388 | /* Preamble tuning for SSC */ |
1358 | ret_val = e1e_wphy(hw, PHY_REG(770, 16), 0xA204); | 1389 | ret_val = e1e_wphy(hw, HV_KMRN_FIFO_CTRLSTA, 0xA204); |
1359 | if (ret_val) | 1390 | if (ret_val) |
1360 | return ret_val; | 1391 | return ret_val; |
1361 | } | 1392 | } |
@@ -1645,6 +1676,7 @@ static s32 e1000_k1_workaround_lv(struct e1000_hw *hw) | |||
1645 | s32 ret_val = 0; | 1676 | s32 ret_val = 0; |
1646 | u16 status_reg = 0; | 1677 | u16 status_reg = 0; |
1647 | u32 mac_reg; | 1678 | u32 mac_reg; |
1679 | u16 phy_reg; | ||
1648 | 1680 | ||
1649 | if (hw->mac.type != e1000_pch2lan) | 1681 | if (hw->mac.type != e1000_pch2lan) |
1650 | goto out; | 1682 | goto out; |
@@ -1659,12 +1691,19 @@ static s32 e1000_k1_workaround_lv(struct e1000_hw *hw) | |||
1659 | mac_reg = er32(FEXTNVM4); | 1691 | mac_reg = er32(FEXTNVM4); |
1660 | mac_reg &= ~E1000_FEXTNVM4_BEACON_DURATION_MASK; | 1692 | mac_reg &= ~E1000_FEXTNVM4_BEACON_DURATION_MASK; |
1661 | 1693 | ||
1662 | if (status_reg & HV_M_STATUS_SPEED_1000) | 1694 | ret_val = e1e_rphy(hw, I82579_LPI_CTRL, &phy_reg); |
1695 | if (ret_val) | ||
1696 | goto out; | ||
1697 | |||
1698 | if (status_reg & HV_M_STATUS_SPEED_1000) { | ||
1663 | mac_reg |= E1000_FEXTNVM4_BEACON_DURATION_8USEC; | 1699 | mac_reg |= E1000_FEXTNVM4_BEACON_DURATION_8USEC; |
1664 | else | 1700 | phy_reg &= ~I82579_LPI_CTRL_FORCE_PLL_LOCK_COUNT; |
1701 | } else { | ||
1665 | mac_reg |= E1000_FEXTNVM4_BEACON_DURATION_16USEC; | 1702 | mac_reg |= E1000_FEXTNVM4_BEACON_DURATION_16USEC; |
1666 | 1703 | phy_reg |= I82579_LPI_CTRL_FORCE_PLL_LOCK_COUNT; | |
1704 | } | ||
1667 | ew32(FEXTNVM4, mac_reg); | 1705 | ew32(FEXTNVM4, mac_reg); |
1706 | ret_val = e1e_wphy(hw, I82579_LPI_CTRL, phy_reg); | ||
1668 | } | 1707 | } |
1669 | 1708 | ||
1670 | out: | 1709 | out: |
diff --git a/drivers/net/ethernet/intel/e1000e/lib.c b/drivers/net/ethernet/intel/e1000e/lib.c index 7898a67d6505..0893ab107adf 100644 --- a/drivers/net/ethernet/intel/e1000e/lib.c +++ b/drivers/net/ethernet/intel/e1000e/lib.c | |||
@@ -190,7 +190,8 @@ s32 e1000_check_alt_mac_addr_generic(struct e1000_hw *hw) | |||
190 | /* Check for LOM (vs. NIC) or one of two valid mezzanine cards */ | 190 | /* Check for LOM (vs. NIC) or one of two valid mezzanine cards */ |
191 | if (!((nvm_data & NVM_COMPAT_LOM) || | 191 | if (!((nvm_data & NVM_COMPAT_LOM) || |
192 | (hw->adapter->pdev->device == E1000_DEV_ID_82571EB_SERDES_DUAL) || | 192 | (hw->adapter->pdev->device == E1000_DEV_ID_82571EB_SERDES_DUAL) || |
193 | (hw->adapter->pdev->device == E1000_DEV_ID_82571EB_SERDES_QUAD))) | 193 | (hw->adapter->pdev->device == E1000_DEV_ID_82571EB_SERDES_QUAD) || |
194 | (hw->adapter->pdev->device == E1000_DEV_ID_82571EB_SERDES))) | ||
194 | goto out; | 195 | goto out; |
195 | 196 | ||
196 | ret_val = e1000_read_nvm(hw, NVM_ALT_MAC_ADDR_PTR, 1, | 197 | ret_val = e1000_read_nvm(hw, NVM_ALT_MAC_ADDR_PTR, 1, |
@@ -200,10 +201,10 @@ s32 e1000_check_alt_mac_addr_generic(struct e1000_hw *hw) | |||
200 | goto out; | 201 | goto out; |
201 | } | 202 | } |
202 | 203 | ||
203 | if (nvm_alt_mac_addr_offset == 0xFFFF) { | 204 | if ((nvm_alt_mac_addr_offset == 0xFFFF) || |
205 | (nvm_alt_mac_addr_offset == 0x0000)) | ||
204 | /* There is no Alternate MAC Address */ | 206 | /* There is no Alternate MAC Address */ |
205 | goto out; | 207 | goto out; |
206 | } | ||
207 | 208 | ||
208 | if (hw->bus.func == E1000_FUNC_1) | 209 | if (hw->bus.func == E1000_FUNC_1) |
209 | nvm_alt_mac_addr_offset += E1000_ALT_MAC_ADDRESS_OFFSET_LAN1; | 210 | nvm_alt_mac_addr_offset += E1000_ALT_MAC_ADDRESS_OFFSET_LAN1; |
diff --git a/drivers/net/ethernet/intel/e1000e/netdev.c b/drivers/net/ethernet/intel/e1000e/netdev.c index 6ea342e8e158..9742bc603cad 100644 --- a/drivers/net/ethernet/intel/e1000e/netdev.c +++ b/drivers/net/ethernet/intel/e1000e/netdev.c | |||
@@ -548,6 +548,63 @@ static void e1000_rx_checksum(struct e1000_adapter *adapter, u32 status_err, | |||
548 | } | 548 | } |
549 | 549 | ||
550 | /** | 550 | /** |
551 | * e1000e_update_tail_wa - helper function for e1000e_update_[rt]dt_wa() | ||
552 | * @hw: pointer to the HW structure | ||
553 | * @tail: address of tail descriptor register | ||
554 | * @i: value to write to tail descriptor register | ||
555 | * | ||
556 | * When updating the tail register, the ME could be accessing Host CSR | ||
557 | * registers at the same time. Normally, this is handled in h/w by an | ||
558 | * arbiter but on some parts there is a bug that acknowledges Host accesses | ||
559 | * later than it should which could result in the descriptor register to | ||
560 | * have an incorrect value. Workaround this by checking the FWSM register | ||
561 | * which has bit 24 set while ME is accessing Host CSR registers, wait | ||
562 | * if it is set and try again a number of times. | ||
563 | **/ | ||
564 | static inline s32 e1000e_update_tail_wa(struct e1000_hw *hw, u8 __iomem * tail, | ||
565 | unsigned int i) | ||
566 | { | ||
567 | unsigned int j = 0; | ||
568 | |||
569 | while ((j++ < E1000_ICH_FWSM_PCIM2PCI_COUNT) && | ||
570 | (er32(FWSM) & E1000_ICH_FWSM_PCIM2PCI)) | ||
571 | udelay(50); | ||
572 | |||
573 | writel(i, tail); | ||
574 | |||
575 | if ((j == E1000_ICH_FWSM_PCIM2PCI_COUNT) && (i != readl(tail))) | ||
576 | return E1000_ERR_SWFW_SYNC; | ||
577 | |||
578 | return 0; | ||
579 | } | ||
580 | |||
581 | static void e1000e_update_rdt_wa(struct e1000_adapter *adapter, unsigned int i) | ||
582 | { | ||
583 | u8 __iomem *tail = (adapter->hw.hw_addr + adapter->rx_ring->tail); | ||
584 | struct e1000_hw *hw = &adapter->hw; | ||
585 | |||
586 | if (e1000e_update_tail_wa(hw, tail, i)) { | ||
587 | u32 rctl = er32(RCTL); | ||
588 | ew32(RCTL, rctl & ~E1000_RCTL_EN); | ||
589 | e_err("ME firmware caused invalid RDT - resetting\n"); | ||
590 | schedule_work(&adapter->reset_task); | ||
591 | } | ||
592 | } | ||
593 | |||
594 | static void e1000e_update_tdt_wa(struct e1000_adapter *adapter, unsigned int i) | ||
595 | { | ||
596 | u8 __iomem *tail = (adapter->hw.hw_addr + adapter->tx_ring->tail); | ||
597 | struct e1000_hw *hw = &adapter->hw; | ||
598 | |||
599 | if (e1000e_update_tail_wa(hw, tail, i)) { | ||
600 | u32 tctl = er32(TCTL); | ||
601 | ew32(TCTL, tctl & ~E1000_TCTL_EN); | ||
602 | e_err("ME firmware caused invalid TDT - resetting\n"); | ||
603 | schedule_work(&adapter->reset_task); | ||
604 | } | ||
605 | } | ||
606 | |||
607 | /** | ||
551 | * e1000_alloc_rx_buffers - Replace used receive buffers | 608 | * e1000_alloc_rx_buffers - Replace used receive buffers |
552 | * @adapter: address of board private structure | 609 | * @adapter: address of board private structure |
553 | **/ | 610 | **/ |
@@ -602,7 +659,10 @@ map_skb: | |||
602 | * such as IA-64). | 659 | * such as IA-64). |
603 | */ | 660 | */ |
604 | wmb(); | 661 | wmb(); |
605 | writel(i, adapter->hw.hw_addr + rx_ring->tail); | 662 | if (adapter->flags2 & FLAG2_PCIM2PCI_ARBITER_WA) |
663 | e1000e_update_rdt_wa(adapter, i); | ||
664 | else | ||
665 | writel(i, adapter->hw.hw_addr + rx_ring->tail); | ||
606 | } | 666 | } |
607 | i++; | 667 | i++; |
608 | if (i == rx_ring->count) | 668 | if (i == rx_ring->count) |
@@ -702,7 +762,11 @@ static void e1000_alloc_rx_buffers_ps(struct e1000_adapter *adapter, | |||
702 | * such as IA-64). | 762 | * such as IA-64). |
703 | */ | 763 | */ |
704 | wmb(); | 764 | wmb(); |
705 | writel(i << 1, adapter->hw.hw_addr + rx_ring->tail); | 765 | if (adapter->flags2 & FLAG2_PCIM2PCI_ARBITER_WA) |
766 | e1000e_update_rdt_wa(adapter, i << 1); | ||
767 | else | ||
768 | writel(i << 1, | ||
769 | adapter->hw.hw_addr + rx_ring->tail); | ||
706 | } | 770 | } |
707 | 771 | ||
708 | i++; | 772 | i++; |
@@ -785,7 +849,10 @@ check_page: | |||
785 | * applicable for weak-ordered memory model archs, | 849 | * applicable for weak-ordered memory model archs, |
786 | * such as IA-64). */ | 850 | * such as IA-64). */ |
787 | wmb(); | 851 | wmb(); |
788 | writel(i, adapter->hw.hw_addr + rx_ring->tail); | 852 | if (adapter->flags2 & FLAG2_PCIM2PCI_ARBITER_WA) |
853 | e1000e_update_rdt_wa(adapter, i); | ||
854 | else | ||
855 | writel(i, adapter->hw.hw_addr + rx_ring->tail); | ||
789 | } | 856 | } |
790 | } | 857 | } |
791 | 858 | ||
@@ -2944,7 +3011,8 @@ static void e1000_configure_rx(struct e1000_adapter *adapter) | |||
2944 | 3011 | ||
2945 | /* disable receives while setting up the descriptors */ | 3012 | /* disable receives while setting up the descriptors */ |
2946 | rctl = er32(RCTL); | 3013 | rctl = er32(RCTL); |
2947 | ew32(RCTL, rctl & ~E1000_RCTL_EN); | 3014 | if (!(adapter->flags2 & FLAG2_NO_DISABLE_RX)) |
3015 | ew32(RCTL, rctl & ~E1000_RCTL_EN); | ||
2948 | e1e_flush(); | 3016 | e1e_flush(); |
2949 | usleep_range(10000, 20000); | 3017 | usleep_range(10000, 20000); |
2950 | 3018 | ||
@@ -3423,7 +3491,8 @@ void e1000e_down(struct e1000_adapter *adapter) | |||
3423 | 3491 | ||
3424 | /* disable receives in the hardware */ | 3492 | /* disable receives in the hardware */ |
3425 | rctl = er32(RCTL); | 3493 | rctl = er32(RCTL); |
3426 | ew32(RCTL, rctl & ~E1000_RCTL_EN); | 3494 | if (!(adapter->flags2 & FLAG2_NO_DISABLE_RX)) |
3495 | ew32(RCTL, rctl & ~E1000_RCTL_EN); | ||
3427 | /* flush and sleep below */ | 3496 | /* flush and sleep below */ |
3428 | 3497 | ||
3429 | netif_stop_queue(netdev); | 3498 | netif_stop_queue(netdev); |
@@ -3432,6 +3501,7 @@ void e1000e_down(struct e1000_adapter *adapter) | |||
3432 | tctl = er32(TCTL); | 3501 | tctl = er32(TCTL); |
3433 | tctl &= ~E1000_TCTL_EN; | 3502 | tctl &= ~E1000_TCTL_EN; |
3434 | ew32(TCTL, tctl); | 3503 | ew32(TCTL, tctl); |
3504 | |||
3435 | /* flush both disables and wait for them to finish */ | 3505 | /* flush both disables and wait for them to finish */ |
3436 | e1e_flush(); | 3506 | e1e_flush(); |
3437 | usleep_range(10000, 20000); | 3507 | usleep_range(10000, 20000); |
@@ -4715,7 +4785,12 @@ static void e1000_tx_queue(struct e1000_adapter *adapter, | |||
4715 | wmb(); | 4785 | wmb(); |
4716 | 4786 | ||
4717 | tx_ring->next_to_use = i; | 4787 | tx_ring->next_to_use = i; |
4718 | writel(i, adapter->hw.hw_addr + tx_ring->tail); | 4788 | |
4789 | if (adapter->flags2 & FLAG2_PCIM2PCI_ARBITER_WA) | ||
4790 | e1000e_update_tdt_wa(adapter, i); | ||
4791 | else | ||
4792 | writel(i, adapter->hw.hw_addr + tx_ring->tail); | ||
4793 | |||
4719 | /* | 4794 | /* |
4720 | * we need this if more than one processor can write to our tail | 4795 | * we need this if more than one processor can write to our tail |
4721 | * at a time, it synchronizes IO on IA64/Altix systems | 4796 | * at a time, it synchronizes IO on IA64/Altix systems |
diff --git a/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c b/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c index 44ded0c092da..e8aad76fa530 100644 --- a/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c +++ b/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c | |||
@@ -1480,8 +1480,10 @@ static void ixgbe_clean_rx_irq(struct ixgbe_q_vector *q_vector, | |||
1480 | if (ixgbe_rx_is_fcoe(adapter, rx_desc)) { | 1480 | if (ixgbe_rx_is_fcoe(adapter, rx_desc)) { |
1481 | ddp_bytes = ixgbe_fcoe_ddp(adapter, rx_desc, skb, | 1481 | ddp_bytes = ixgbe_fcoe_ddp(adapter, rx_desc, skb, |
1482 | staterr); | 1482 | staterr); |
1483 | if (!ddp_bytes) | 1483 | if (!ddp_bytes) { |
1484 | dev_kfree_skb_any(skb); | ||
1484 | goto next_desc; | 1485 | goto next_desc; |
1486 | } | ||
1485 | } | 1487 | } |
1486 | #endif /* IXGBE_FCOE */ | 1488 | #endif /* IXGBE_FCOE */ |
1487 | ixgbe_receive_skb(q_vector, skb, staterr, rx_ring, rx_desc); | 1489 | ixgbe_receive_skb(q_vector, skb, staterr, rx_ring, rx_desc); |
diff --git a/drivers/net/ethernet/nvidia/forcedeth.c b/drivers/net/ethernet/nvidia/forcedeth.c index 3784a727692e..98bb64bc24d9 100644 --- a/drivers/net/ethernet/nvidia/forcedeth.c +++ b/drivers/net/ethernet/nvidia/forcedeth.c | |||
@@ -5615,7 +5615,8 @@ static int __devinit nv_probe(struct pci_dev *pci_dev, const struct pci_device_i | |||
5615 | goto out_error; | 5615 | goto out_error; |
5616 | } | 5616 | } |
5617 | 5617 | ||
5618 | nv_vlan_mode(dev, dev->features); | 5618 | if (id->driver_data & DEV_HAS_VLAN) |
5619 | nv_vlan_mode(dev, dev->features); | ||
5619 | 5620 | ||
5620 | netif_carrier_off(dev); | 5621 | netif_carrier_off(dev); |
5621 | 5622 | ||
diff --git a/drivers/net/ethernet/renesas/sh_eth.c b/drivers/net/ethernet/renesas/sh_eth.c index ef3a3521b835..bf2404ae3b87 100644 --- a/drivers/net/ethernet/renesas/sh_eth.c +++ b/drivers/net/ethernet/renesas/sh_eth.c | |||
@@ -21,6 +21,7 @@ | |||
21 | */ | 21 | */ |
22 | 22 | ||
23 | #include <linux/init.h> | 23 | #include <linux/init.h> |
24 | #include <linux/interrupt.h> | ||
24 | #include <linux/dma-mapping.h> | 25 | #include <linux/dma-mapping.h> |
25 | #include <linux/etherdevice.h> | 26 | #include <linux/etherdevice.h> |
26 | #include <linux/delay.h> | 27 | #include <linux/delay.h> |
diff --git a/drivers/net/ethernet/via/via-velocity.c b/drivers/net/ethernet/via/via-velocity.c index 095ab566d082..086463b141b6 100644 --- a/drivers/net/ethernet/via/via-velocity.c +++ b/drivers/net/ethernet/via/via-velocity.c | |||
@@ -513,10 +513,6 @@ static void velocity_init_cam_filter(struct velocity_info *vptr) | |||
513 | mac_set_cam_mask(regs, vptr->mCAMmask); | 513 | mac_set_cam_mask(regs, vptr->mCAMmask); |
514 | 514 | ||
515 | /* Enable VCAMs */ | 515 | /* Enable VCAMs */ |
516 | |||
517 | if (test_bit(0, vptr->active_vlans)) | ||
518 | WORD_REG_BITS_ON(MCFG_RTGOPT, ®s->MCFG); | ||
519 | |||
520 | for_each_set_bit(vid, vptr->active_vlans, VLAN_N_VID) { | 516 | for_each_set_bit(vid, vptr->active_vlans, VLAN_N_VID) { |
521 | mac_set_vlan_cam(regs, i, (u8 *) &vid); | 517 | mac_set_vlan_cam(regs, i, (u8 *) &vid); |
522 | vptr->vCAMmask[i / 8] |= 0x1 << (i % 8); | 518 | vptr->vCAMmask[i / 8] |= 0x1 << (i % 8); |
diff --git a/drivers/net/irda/sh_irda.c b/drivers/net/irda/sh_irda.c index 4488bd581eca..82660672dcd9 100644 --- a/drivers/net/irda/sh_irda.c +++ b/drivers/net/irda/sh_irda.c | |||
@@ -22,6 +22,8 @@ | |||
22 | * - DMA transfer support | 22 | * - DMA transfer support |
23 | * - FIFO mode support | 23 | * - FIFO mode support |
24 | */ | 24 | */ |
25 | #include <linux/io.h> | ||
26 | #include <linux/interrupt.h> | ||
25 | #include <linux/module.h> | 27 | #include <linux/module.h> |
26 | #include <linux/platform_device.h> | 28 | #include <linux/platform_device.h> |
27 | #include <linux/clk.h> | 29 | #include <linux/clk.h> |
diff --git a/drivers/net/irda/sh_sir.c b/drivers/net/irda/sh_sir.c index 52a7c86af663..ed7d7d62bf68 100644 --- a/drivers/net/irda/sh_sir.c +++ b/drivers/net/irda/sh_sir.c | |||
@@ -12,6 +12,8 @@ | |||
12 | * published by the Free Software Foundation. | 12 | * published by the Free Software Foundation. |
13 | */ | 13 | */ |
14 | 14 | ||
15 | #include <linux/io.h> | ||
16 | #include <linux/interrupt.h> | ||
15 | #include <linux/module.h> | 17 | #include <linux/module.h> |
16 | #include <linux/platform_device.h> | 18 | #include <linux/platform_device.h> |
17 | #include <linux/slab.h> | 19 | #include <linux/slab.h> |
@@ -511,7 +513,7 @@ static void sh_sir_tx(struct sh_sir_self *self, int phase) | |||
511 | 513 | ||
512 | static int sh_sir_read_data(struct sh_sir_self *self) | 514 | static int sh_sir_read_data(struct sh_sir_self *self) |
513 | { | 515 | { |
514 | u16 val; | 516 | u16 val = 0; |
515 | int timeout = 1024; | 517 | int timeout = 1024; |
516 | 518 | ||
517 | while (timeout--) { | 519 | while (timeout--) { |
diff --git a/drivers/net/usb/cdc_ncm.c b/drivers/net/usb/cdc_ncm.c index a03336e086d5..f06fb78383a1 100644 --- a/drivers/net/usb/cdc_ncm.c +++ b/drivers/net/usb/cdc_ncm.c | |||
@@ -228,23 +228,40 @@ static u8 cdc_ncm_setup(struct cdc_ncm_ctx *ctx) | |||
228 | if (ctx->rx_max != le32_to_cpu(ctx->ncm_parm.dwNtbInMaxSize)) { | 228 | if (ctx->rx_max != le32_to_cpu(ctx->ncm_parm.dwNtbInMaxSize)) { |
229 | 229 | ||
230 | if (flags & USB_CDC_NCM_NCAP_NTB_INPUT_SIZE) { | 230 | if (flags & USB_CDC_NCM_NCAP_NTB_INPUT_SIZE) { |
231 | struct usb_cdc_ncm_ndp_input_size ndp_in_sz; | 231 | struct usb_cdc_ncm_ndp_input_size *ndp_in_sz; |
232 | |||
233 | ndp_in_sz = kzalloc(sizeof(*ndp_in_sz), GFP_KERNEL); | ||
234 | if (!ndp_in_sz) { | ||
235 | err = -ENOMEM; | ||
236 | goto size_err; | ||
237 | } | ||
238 | |||
232 | err = usb_control_msg(ctx->udev, | 239 | err = usb_control_msg(ctx->udev, |
233 | usb_sndctrlpipe(ctx->udev, 0), | 240 | usb_sndctrlpipe(ctx->udev, 0), |
234 | USB_CDC_SET_NTB_INPUT_SIZE, | 241 | USB_CDC_SET_NTB_INPUT_SIZE, |
235 | USB_TYPE_CLASS | USB_DIR_OUT | 242 | USB_TYPE_CLASS | USB_DIR_OUT |
236 | | USB_RECIP_INTERFACE, | 243 | | USB_RECIP_INTERFACE, |
237 | 0, iface_no, &ndp_in_sz, 8, 1000); | 244 | 0, iface_no, ndp_in_sz, 8, 1000); |
245 | kfree(ndp_in_sz); | ||
238 | } else { | 246 | } else { |
239 | __le32 dwNtbInMaxSize = cpu_to_le32(ctx->rx_max); | 247 | __le32 *dwNtbInMaxSize; |
248 | dwNtbInMaxSize = kzalloc(sizeof(*dwNtbInMaxSize), | ||
249 | GFP_KERNEL); | ||
250 | if (!dwNtbInMaxSize) { | ||
251 | err = -ENOMEM; | ||
252 | goto size_err; | ||
253 | } | ||
254 | *dwNtbInMaxSize = cpu_to_le32(ctx->rx_max); | ||
255 | |||
240 | err = usb_control_msg(ctx->udev, | 256 | err = usb_control_msg(ctx->udev, |
241 | usb_sndctrlpipe(ctx->udev, 0), | 257 | usb_sndctrlpipe(ctx->udev, 0), |
242 | USB_CDC_SET_NTB_INPUT_SIZE, | 258 | USB_CDC_SET_NTB_INPUT_SIZE, |
243 | USB_TYPE_CLASS | USB_DIR_OUT | 259 | USB_TYPE_CLASS | USB_DIR_OUT |
244 | | USB_RECIP_INTERFACE, | 260 | | USB_RECIP_INTERFACE, |
245 | 0, iface_no, &dwNtbInMaxSize, 4, 1000); | 261 | 0, iface_no, dwNtbInMaxSize, 4, 1000); |
262 | kfree(dwNtbInMaxSize); | ||
246 | } | 263 | } |
247 | 264 | size_err: | |
248 | if (err < 0) | 265 | if (err < 0) |
249 | pr_debug("Setting NTB Input Size failed\n"); | 266 | pr_debug("Setting NTB Input Size failed\n"); |
250 | } | 267 | } |
@@ -325,19 +342,29 @@ static u8 cdc_ncm_setup(struct cdc_ncm_ctx *ctx) | |||
325 | 342 | ||
326 | /* set Max Datagram Size (MTU) */ | 343 | /* set Max Datagram Size (MTU) */ |
327 | if (flags & USB_CDC_NCM_NCAP_MAX_DATAGRAM_SIZE) { | 344 | if (flags & USB_CDC_NCM_NCAP_MAX_DATAGRAM_SIZE) { |
328 | __le16 max_datagram_size; | 345 | __le16 *max_datagram_size; |
329 | u16 eth_max_sz = le16_to_cpu(ctx->ether_desc->wMaxSegmentSize); | 346 | u16 eth_max_sz = le16_to_cpu(ctx->ether_desc->wMaxSegmentSize); |
347 | |||
348 | max_datagram_size = kzalloc(sizeof(*max_datagram_size), | ||
349 | GFP_KERNEL); | ||
350 | if (!max_datagram_size) { | ||
351 | err = -ENOMEM; | ||
352 | goto max_dgram_err; | ||
353 | } | ||
354 | |||
330 | err = usb_control_msg(ctx->udev, usb_rcvctrlpipe(ctx->udev, 0), | 355 | err = usb_control_msg(ctx->udev, usb_rcvctrlpipe(ctx->udev, 0), |
331 | USB_CDC_GET_MAX_DATAGRAM_SIZE, | 356 | USB_CDC_GET_MAX_DATAGRAM_SIZE, |
332 | USB_TYPE_CLASS | USB_DIR_IN | 357 | USB_TYPE_CLASS | USB_DIR_IN |
333 | | USB_RECIP_INTERFACE, | 358 | | USB_RECIP_INTERFACE, |
334 | 0, iface_no, &max_datagram_size, | 359 | 0, iface_no, max_datagram_size, |
335 | 2, 1000); | 360 | 2, 1000); |
336 | if (err < 0) { | 361 | if (err < 0) { |
337 | pr_debug("GET_MAX_DATAGRAM_SIZE failed, use size=%u\n", | 362 | pr_debug("GET_MAX_DATAGRAM_SIZE failed, use size=%u\n", |
338 | CDC_NCM_MIN_DATAGRAM_SIZE); | 363 | CDC_NCM_MIN_DATAGRAM_SIZE); |
364 | kfree(max_datagram_size); | ||
339 | } else { | 365 | } else { |
340 | ctx->max_datagram_size = le16_to_cpu(max_datagram_size); | 366 | ctx->max_datagram_size = |
367 | le16_to_cpu(*max_datagram_size); | ||
341 | /* Check Eth descriptor value */ | 368 | /* Check Eth descriptor value */ |
342 | if (eth_max_sz < CDC_NCM_MAX_DATAGRAM_SIZE) { | 369 | if (eth_max_sz < CDC_NCM_MAX_DATAGRAM_SIZE) { |
343 | if (ctx->max_datagram_size > eth_max_sz) | 370 | if (ctx->max_datagram_size > eth_max_sz) |
@@ -360,8 +387,10 @@ static u8 cdc_ncm_setup(struct cdc_ncm_ctx *ctx) | |||
360 | USB_TYPE_CLASS | USB_DIR_OUT | 387 | USB_TYPE_CLASS | USB_DIR_OUT |
361 | | USB_RECIP_INTERFACE, | 388 | | USB_RECIP_INTERFACE, |
362 | 0, | 389 | 0, |
363 | iface_no, &max_datagram_size, | 390 | iface_no, max_datagram_size, |
364 | 2, 1000); | 391 | 2, 1000); |
392 | kfree(max_datagram_size); | ||
393 | max_dgram_err: | ||
365 | if (err < 0) | 394 | if (err < 0) |
366 | pr_debug("SET_MAX_DATAGRAM_SIZE failed\n"); | 395 | pr_debug("SET_MAX_DATAGRAM_SIZE failed\n"); |
367 | } | 396 | } |
diff --git a/drivers/net/vmxnet3/vmxnet3_drv.c b/drivers/net/vmxnet3/vmxnet3_drv.c index f530c57151b2..759c1a49cc7b 100644 --- a/drivers/net/vmxnet3/vmxnet3_drv.c +++ b/drivers/net/vmxnet3/vmxnet3_drv.c | |||
@@ -1929,14 +1929,17 @@ static void | |||
1929 | vmxnet3_vlan_rx_add_vid(struct net_device *netdev, u16 vid) | 1929 | vmxnet3_vlan_rx_add_vid(struct net_device *netdev, u16 vid) |
1930 | { | 1930 | { |
1931 | struct vmxnet3_adapter *adapter = netdev_priv(netdev); | 1931 | struct vmxnet3_adapter *adapter = netdev_priv(netdev); |
1932 | u32 *vfTable = adapter->shared->devRead.rxFilterConf.vfTable; | ||
1933 | unsigned long flags; | ||
1934 | 1932 | ||
1935 | VMXNET3_SET_VFTABLE_ENTRY(vfTable, vid); | 1933 | if (!(netdev->flags & IFF_PROMISC)) { |
1936 | spin_lock_irqsave(&adapter->cmd_lock, flags); | 1934 | u32 *vfTable = adapter->shared->devRead.rxFilterConf.vfTable; |
1937 | VMXNET3_WRITE_BAR1_REG(adapter, VMXNET3_REG_CMD, | 1935 | unsigned long flags; |
1938 | VMXNET3_CMD_UPDATE_VLAN_FILTERS); | 1936 | |
1939 | spin_unlock_irqrestore(&adapter->cmd_lock, flags); | 1937 | VMXNET3_SET_VFTABLE_ENTRY(vfTable, vid); |
1938 | spin_lock_irqsave(&adapter->cmd_lock, flags); | ||
1939 | VMXNET3_WRITE_BAR1_REG(adapter, VMXNET3_REG_CMD, | ||
1940 | VMXNET3_CMD_UPDATE_VLAN_FILTERS); | ||
1941 | spin_unlock_irqrestore(&adapter->cmd_lock, flags); | ||
1942 | } | ||
1940 | 1943 | ||
1941 | set_bit(vid, adapter->active_vlans); | 1944 | set_bit(vid, adapter->active_vlans); |
1942 | } | 1945 | } |
@@ -1946,14 +1949,17 @@ static void | |||
1946 | vmxnet3_vlan_rx_kill_vid(struct net_device *netdev, u16 vid) | 1949 | vmxnet3_vlan_rx_kill_vid(struct net_device *netdev, u16 vid) |
1947 | { | 1950 | { |
1948 | struct vmxnet3_adapter *adapter = netdev_priv(netdev); | 1951 | struct vmxnet3_adapter *adapter = netdev_priv(netdev); |
1949 | u32 *vfTable = adapter->shared->devRead.rxFilterConf.vfTable; | ||
1950 | unsigned long flags; | ||
1951 | 1952 | ||
1952 | VMXNET3_CLEAR_VFTABLE_ENTRY(vfTable, vid); | 1953 | if (!(netdev->flags & IFF_PROMISC)) { |
1953 | spin_lock_irqsave(&adapter->cmd_lock, flags); | 1954 | u32 *vfTable = adapter->shared->devRead.rxFilterConf.vfTable; |
1954 | VMXNET3_WRITE_BAR1_REG(adapter, VMXNET3_REG_CMD, | 1955 | unsigned long flags; |
1955 | VMXNET3_CMD_UPDATE_VLAN_FILTERS); | 1956 | |
1956 | spin_unlock_irqrestore(&adapter->cmd_lock, flags); | 1957 | VMXNET3_CLEAR_VFTABLE_ENTRY(vfTable, vid); |
1958 | spin_lock_irqsave(&adapter->cmd_lock, flags); | ||
1959 | VMXNET3_WRITE_BAR1_REG(adapter, VMXNET3_REG_CMD, | ||
1960 | VMXNET3_CMD_UPDATE_VLAN_FILTERS); | ||
1961 | spin_unlock_irqrestore(&adapter->cmd_lock, flags); | ||
1962 | } | ||
1957 | 1963 | ||
1958 | clear_bit(vid, adapter->active_vlans); | 1964 | clear_bit(vid, adapter->active_vlans); |
1959 | } | 1965 | } |
diff --git a/drivers/net/wireless/ath/ath5k/base.c b/drivers/net/wireless/ath/ath5k/base.c index f54dff44ed50..c3119a6caace 100644 --- a/drivers/net/wireless/ath/ath5k/base.c +++ b/drivers/net/wireless/ath/ath5k/base.c | |||
@@ -1735,6 +1735,8 @@ ath5k_beacon_setup(struct ath5k_hw *ah, struct ath5k_buf *bf) | |||
1735 | 1735 | ||
1736 | if (dma_mapping_error(ah->dev, bf->skbaddr)) { | 1736 | if (dma_mapping_error(ah->dev, bf->skbaddr)) { |
1737 | ATH5K_ERR(ah, "beacon DMA mapping failed\n"); | 1737 | ATH5K_ERR(ah, "beacon DMA mapping failed\n"); |
1738 | dev_kfree_skb_any(skb); | ||
1739 | bf->skb = NULL; | ||
1738 | return -EIO; | 1740 | return -EIO; |
1739 | } | 1741 | } |
1740 | 1742 | ||
@@ -1819,8 +1821,6 @@ ath5k_beacon_update(struct ieee80211_hw *hw, struct ieee80211_vif *vif) | |||
1819 | ath5k_txbuf_free_skb(ah, avf->bbuf); | 1821 | ath5k_txbuf_free_skb(ah, avf->bbuf); |
1820 | avf->bbuf->skb = skb; | 1822 | avf->bbuf->skb = skb; |
1821 | ret = ath5k_beacon_setup(ah, avf->bbuf); | 1823 | ret = ath5k_beacon_setup(ah, avf->bbuf); |
1822 | if (ret) | ||
1823 | avf->bbuf->skb = NULL; | ||
1824 | out: | 1824 | out: |
1825 | return ret; | 1825 | return ret; |
1826 | } | 1826 | } |
@@ -1840,6 +1840,7 @@ ath5k_beacon_send(struct ath5k_hw *ah) | |||
1840 | struct ath5k_vif *avf; | 1840 | struct ath5k_vif *avf; |
1841 | struct ath5k_buf *bf; | 1841 | struct ath5k_buf *bf; |
1842 | struct sk_buff *skb; | 1842 | struct sk_buff *skb; |
1843 | int err; | ||
1843 | 1844 | ||
1844 | ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_BEACON, "in beacon_send\n"); | 1845 | ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_BEACON, "in beacon_send\n"); |
1845 | 1846 | ||
@@ -1888,11 +1889,6 @@ ath5k_beacon_send(struct ath5k_hw *ah) | |||
1888 | 1889 | ||
1889 | avf = (void *)vif->drv_priv; | 1890 | avf = (void *)vif->drv_priv; |
1890 | bf = avf->bbuf; | 1891 | bf = avf->bbuf; |
1891 | if (unlikely(bf->skb == NULL || ah->opmode == NL80211_IFTYPE_STATION || | ||
1892 | ah->opmode == NL80211_IFTYPE_MONITOR)) { | ||
1893 | ATH5K_WARN(ah, "bf=%p bf_skb=%p\n", bf, bf ? bf->skb : NULL); | ||
1894 | return; | ||
1895 | } | ||
1896 | 1892 | ||
1897 | /* | 1893 | /* |
1898 | * Stop any current dma and put the new frame on the queue. | 1894 | * Stop any current dma and put the new frame on the queue. |
@@ -1906,8 +1902,17 @@ ath5k_beacon_send(struct ath5k_hw *ah) | |||
1906 | 1902 | ||
1907 | /* refresh the beacon for AP or MESH mode */ | 1903 | /* refresh the beacon for AP or MESH mode */ |
1908 | if (ah->opmode == NL80211_IFTYPE_AP || | 1904 | if (ah->opmode == NL80211_IFTYPE_AP || |
1909 | ah->opmode == NL80211_IFTYPE_MESH_POINT) | 1905 | ah->opmode == NL80211_IFTYPE_MESH_POINT) { |
1910 | ath5k_beacon_update(ah->hw, vif); | 1906 | err = ath5k_beacon_update(ah->hw, vif); |
1907 | if (err) | ||
1908 | return; | ||
1909 | } | ||
1910 | |||
1911 | if (unlikely(bf->skb == NULL || ah->opmode == NL80211_IFTYPE_STATION || | ||
1912 | ah->opmode == NL80211_IFTYPE_MONITOR)) { | ||
1913 | ATH5K_WARN(ah, "bf=%p bf_skb=%p\n", bf, bf->skb); | ||
1914 | return; | ||
1915 | } | ||
1911 | 1916 | ||
1912 | trace_ath5k_tx(ah, bf->skb, &ah->txqs[ah->bhalq]); | 1917 | trace_ath5k_tx(ah, bf->skb, &ah->txqs[ah->bhalq]); |
1913 | 1918 | ||
diff --git a/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c b/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c index d109c25417f4..c34bef1bf2b0 100644 --- a/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c +++ b/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c | |||
@@ -307,7 +307,7 @@ static const struct ar9300_eeprom ar9300_default = { | |||
307 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, | 307 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, |
308 | { { CTL(60, 1), CTL(60, 0), CTL(60, 0), CTL(60, 1) } }, | 308 | { { CTL(60, 1), CTL(60, 0), CTL(60, 0), CTL(60, 1) } }, |
309 | 309 | ||
310 | { { CTL(60, 1), CTL(60, 0), CTL(0, 0), CTL(0, 0) } }, | 310 | { { CTL(60, 1), CTL(60, 0), CTL(60, 0), CTL(60, 0) } }, |
311 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, | 311 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, |
312 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, | 312 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, |
313 | 313 | ||
@@ -884,7 +884,7 @@ static const struct ar9300_eeprom ar9300_x113 = { | |||
884 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, | 884 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, |
885 | { { CTL(60, 1), CTL(60, 0), CTL(60, 0), CTL(60, 1) } }, | 885 | { { CTL(60, 1), CTL(60, 0), CTL(60, 0), CTL(60, 1) } }, |
886 | 886 | ||
887 | { { CTL(60, 1), CTL(60, 0), CTL(0, 0), CTL(0, 0) } }, | 887 | { { CTL(60, 1), CTL(60, 0), CTL(60, 0), CTL(60, 0) } }, |
888 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, | 888 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, |
889 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, | 889 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, |
890 | 890 | ||
@@ -2040,7 +2040,7 @@ static const struct ar9300_eeprom ar9300_x112 = { | |||
2040 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, | 2040 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, |
2041 | { { CTL(60, 1), CTL(60, 0), CTL(60, 0), CTL(60, 1) } }, | 2041 | { { CTL(60, 1), CTL(60, 0), CTL(60, 0), CTL(60, 1) } }, |
2042 | 2042 | ||
2043 | { { CTL(60, 1), CTL(60, 0), CTL(0, 0), CTL(0, 0) } }, | 2043 | { { CTL(60, 1), CTL(60, 0), CTL(60, 0), CTL(60, 0) } }, |
2044 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, | 2044 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, |
2045 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, | 2045 | { { CTL(60, 0), CTL(60, 1), CTL(60, 0), CTL(60, 0) } }, |
2046 | 2046 | ||
@@ -3734,7 +3734,7 @@ static void ar9003_hw_internal_regulator_apply(struct ath_hw *ah) | |||
3734 | } | 3734 | } |
3735 | } else { | 3735 | } else { |
3736 | reg_pmu_set = (5 << 1) | (7 << 4) | | 3736 | reg_pmu_set = (5 << 1) | (7 << 4) | |
3737 | (1 << 8) | (2 << 14) | | 3737 | (2 << 8) | (2 << 14) | |
3738 | (6 << 17) | (1 << 20) | | 3738 | (6 << 17) | (1 << 20) | |
3739 | (3 << 24) | (1 << 28); | 3739 | (3 << 24) | (1 << 28); |
3740 | } | 3740 | } |
diff --git a/drivers/net/wireless/ath/ath9k/ar9003_phy.h b/drivers/net/wireless/ath/ath9k/ar9003_phy.h index 6de3f0bc18e6..5c590429f120 100644 --- a/drivers/net/wireless/ath/ath9k/ar9003_phy.h +++ b/drivers/net/wireless/ath/ath9k/ar9003_phy.h | |||
@@ -850,7 +850,7 @@ | |||
850 | #define AR_PHY_TPC_11_B1 (AR_SM1_BASE + 0x220) | 850 | #define AR_PHY_TPC_11_B1 (AR_SM1_BASE + 0x220) |
851 | #define AR_PHY_PDADC_TAB_1 (AR_SM1_BASE + 0x240) | 851 | #define AR_PHY_PDADC_TAB_1 (AR_SM1_BASE + 0x240) |
852 | #define AR_PHY_TX_IQCAL_STATUS_B1 (AR_SM1_BASE + 0x48c) | 852 | #define AR_PHY_TX_IQCAL_STATUS_B1 (AR_SM1_BASE + 0x48c) |
853 | #define AR_PHY_TX_IQCAL_CORR_COEFF_B1(_i) (AR_SM_BASE + 0x450 + ((_i) << 2)) | 853 | #define AR_PHY_TX_IQCAL_CORR_COEFF_B1(_i) (AR_SM1_BASE + 0x450 + ((_i) << 2)) |
854 | 854 | ||
855 | /* | 855 | /* |
856 | * Channel 2 Register Map | 856 | * Channel 2 Register Map |
diff --git a/drivers/net/wireless/b43/dma.c b/drivers/net/wireless/b43/dma.c index 83cba22ac6e8..481e534534eb 100644 --- a/drivers/net/wireless/b43/dma.c +++ b/drivers/net/wireless/b43/dma.c | |||
@@ -795,9 +795,23 @@ static u64 supported_dma_mask(struct b43_wldev *dev) | |||
795 | u32 tmp; | 795 | u32 tmp; |
796 | u16 mmio_base; | 796 | u16 mmio_base; |
797 | 797 | ||
798 | tmp = b43_read32(dev, SSB_TMSHIGH); | 798 | switch (dev->dev->bus_type) { |
799 | if (tmp & SSB_TMSHIGH_DMA64) | 799 | #ifdef CONFIG_B43_BCMA |
800 | return DMA_BIT_MASK(64); | 800 | case B43_BUS_BCMA: |
801 | tmp = bcma_aread32(dev->dev->bdev, BCMA_IOST); | ||
802 | if (tmp & BCMA_IOST_DMA64) | ||
803 | return DMA_BIT_MASK(64); | ||
804 | break; | ||
805 | #endif | ||
806 | #ifdef CONFIG_B43_SSB | ||
807 | case B43_BUS_SSB: | ||
808 | tmp = ssb_read32(dev->dev->sdev, SSB_TMSHIGH); | ||
809 | if (tmp & SSB_TMSHIGH_DMA64) | ||
810 | return DMA_BIT_MASK(64); | ||
811 | break; | ||
812 | #endif | ||
813 | } | ||
814 | |||
801 | mmio_base = b43_dmacontroller_base(0, 0); | 815 | mmio_base = b43_dmacontroller_base(0, 0); |
802 | b43_write32(dev, mmio_base + B43_DMA32_TXCTL, B43_DMA32_TXADDREXT_MASK); | 816 | b43_write32(dev, mmio_base + B43_DMA32_TXCTL, B43_DMA32_TXADDREXT_MASK); |
803 | tmp = b43_read32(dev, mmio_base + B43_DMA32_TXCTL); | 817 | tmp = b43_read32(dev, mmio_base + B43_DMA32_TXCTL); |
diff --git a/drivers/net/wireless/rt2x00/rt2800usb.c b/drivers/net/wireless/rt2x00/rt2800usb.c index 507559361d87..939563162fb3 100644 --- a/drivers/net/wireless/rt2x00/rt2800usb.c +++ b/drivers/net/wireless/rt2x00/rt2800usb.c | |||
@@ -921,6 +921,8 @@ static struct usb_device_id rt2800usb_device_table[] = { | |||
921 | { USB_DEVICE(0x07d1, 0x3c16) }, | 921 | { USB_DEVICE(0x07d1, 0x3c16) }, |
922 | /* Draytek */ | 922 | /* Draytek */ |
923 | { USB_DEVICE(0x07fa, 0x7712) }, | 923 | { USB_DEVICE(0x07fa, 0x7712) }, |
924 | /* DVICO */ | ||
925 | { USB_DEVICE(0x0fe9, 0xb307) }, | ||
924 | /* Edimax */ | 926 | /* Edimax */ |
925 | { USB_DEVICE(0x7392, 0x7711) }, | 927 | { USB_DEVICE(0x7392, 0x7711) }, |
926 | { USB_DEVICE(0x7392, 0x7717) }, | 928 | { USB_DEVICE(0x7392, 0x7717) }, |
diff --git a/drivers/net/wireless/rt2x00/rt73usb.c b/drivers/net/wireless/rt2x00/rt73usb.c index 6a93939f44e8..0baeb894f093 100644 --- a/drivers/net/wireless/rt2x00/rt73usb.c +++ b/drivers/net/wireless/rt2x00/rt73usb.c | |||
@@ -2420,6 +2420,7 @@ static struct usb_device_id rt73usb_device_table[] = { | |||
2420 | /* Buffalo */ | 2420 | /* Buffalo */ |
2421 | { USB_DEVICE(0x0411, 0x00d8) }, | 2421 | { USB_DEVICE(0x0411, 0x00d8) }, |
2422 | { USB_DEVICE(0x0411, 0x00d9) }, | 2422 | { USB_DEVICE(0x0411, 0x00d9) }, |
2423 | { USB_DEVICE(0x0411, 0x00e6) }, | ||
2423 | { USB_DEVICE(0x0411, 0x00f4) }, | 2424 | { USB_DEVICE(0x0411, 0x00f4) }, |
2424 | { USB_DEVICE(0x0411, 0x0116) }, | 2425 | { USB_DEVICE(0x0411, 0x0116) }, |
2425 | { USB_DEVICE(0x0411, 0x0119) }, | 2426 | { USB_DEVICE(0x0411, 0x0119) }, |
diff --git a/drivers/net/wireless/rtlwifi/rtl8192cu/sw.c b/drivers/net/wireless/rtlwifi/rtl8192cu/sw.c index 942f7a3969a7..ef63c0df006a 100644 --- a/drivers/net/wireless/rtlwifi/rtl8192cu/sw.c +++ b/drivers/net/wireless/rtlwifi/rtl8192cu/sw.c | |||
@@ -281,6 +281,8 @@ static struct usb_device_id rtl8192c_usb_ids[] = { | |||
281 | {RTL_USB_DEVICE(USB_VENDER_ID_REALTEK, 0x817d, rtl92cu_hal_cfg)}, | 281 | {RTL_USB_DEVICE(USB_VENDER_ID_REALTEK, 0x817d, rtl92cu_hal_cfg)}, |
282 | /* 8188CE-VAU USB minCard (b/g mode only) */ | 282 | /* 8188CE-VAU USB minCard (b/g mode only) */ |
283 | {RTL_USB_DEVICE(USB_VENDER_ID_REALTEK, 0x817e, rtl92cu_hal_cfg)}, | 283 | {RTL_USB_DEVICE(USB_VENDER_ID_REALTEK, 0x817e, rtl92cu_hal_cfg)}, |
284 | /* 8188RU in Alfa AWUS036NHR */ | ||
285 | {RTL_USB_DEVICE(USB_VENDER_ID_REALTEK, 0x817f, rtl92cu_hal_cfg)}, | ||
284 | /* 8188 Combo for BC4 */ | 286 | /* 8188 Combo for BC4 */ |
285 | {RTL_USB_DEVICE(USB_VENDER_ID_REALTEK, 0x8754, rtl92cu_hal_cfg)}, | 287 | {RTL_USB_DEVICE(USB_VENDER_ID_REALTEK, 0x8754, rtl92cu_hal_cfg)}, |
286 | 288 | ||
@@ -303,20 +305,23 @@ static struct usb_device_id rtl8192c_usb_ids[] = { | |||
303 | {RTL_USB_DEVICE(0x0eb0, 0x9071, rtl92cu_hal_cfg)}, /*NO Brand - Etop*/ | 305 | {RTL_USB_DEVICE(0x0eb0, 0x9071, rtl92cu_hal_cfg)}, /*NO Brand - Etop*/ |
304 | /* HP - Lite-On ,8188CUS Slim Combo */ | 306 | /* HP - Lite-On ,8188CUS Slim Combo */ |
305 | {RTL_USB_DEVICE(0x103c, 0x1629, rtl92cu_hal_cfg)}, | 307 | {RTL_USB_DEVICE(0x103c, 0x1629, rtl92cu_hal_cfg)}, |
308 | {RTL_USB_DEVICE(0x13d3, 0x3357, rtl92cu_hal_cfg)}, /* AzureWave */ | ||
306 | {RTL_USB_DEVICE(0x2001, 0x3308, rtl92cu_hal_cfg)}, /*D-Link - Alpha*/ | 309 | {RTL_USB_DEVICE(0x2001, 0x3308, rtl92cu_hal_cfg)}, /*D-Link - Alpha*/ |
307 | {RTL_USB_DEVICE(0x2019, 0xab2a, rtl92cu_hal_cfg)}, /*Planex - Abocom*/ | 310 | {RTL_USB_DEVICE(0x2019, 0xab2a, rtl92cu_hal_cfg)}, /*Planex - Abocom*/ |
308 | {RTL_USB_DEVICE(0x2019, 0xed17, rtl92cu_hal_cfg)}, /*PCI - Edimax*/ | 311 | {RTL_USB_DEVICE(0x2019, 0xed17, rtl92cu_hal_cfg)}, /*PCI - Edimax*/ |
309 | {RTL_USB_DEVICE(0x20f4, 0x648b, rtl92cu_hal_cfg)}, /*TRENDnet - Cameo*/ | 312 | {RTL_USB_DEVICE(0x20f4, 0x648b, rtl92cu_hal_cfg)}, /*TRENDnet - Cameo*/ |
310 | {RTL_USB_DEVICE(0x7392, 0x7811, rtl92cu_hal_cfg)}, /*Edimax - Edimax*/ | 313 | {RTL_USB_DEVICE(0x7392, 0x7811, rtl92cu_hal_cfg)}, /*Edimax - Edimax*/ |
311 | {RTL_USB_DEVICE(0x3358, 0x13d3, rtl92cu_hal_cfg)}, /*Azwave 8188CE-VAU*/ | 314 | {RTL_USB_DEVICE(0x13d3, 0x3358, rtl92cu_hal_cfg)}, /*Azwave 8188CE-VAU*/ |
312 | /* Russian customer -Azwave (8188CE-VAU b/g mode only) */ | 315 | /* Russian customer -Azwave (8188CE-VAU b/g mode only) */ |
313 | {RTL_USB_DEVICE(0x3359, 0x13d3, rtl92cu_hal_cfg)}, | 316 | {RTL_USB_DEVICE(0x13d3, 0x3359, rtl92cu_hal_cfg)}, |
317 | {RTL_USB_DEVICE(0x4855, 0x0090, rtl92cu_hal_cfg)}, /* Feixun */ | ||
318 | {RTL_USB_DEVICE(0x4855, 0x0091, rtl92cu_hal_cfg)}, /* NetweeN-Feixun */ | ||
319 | {RTL_USB_DEVICE(0x9846, 0x9041, rtl92cu_hal_cfg)}, /* Netgear Cameo */ | ||
314 | 320 | ||
315 | /****** 8192CU ********/ | 321 | /****** 8192CU ********/ |
316 | {RTL_USB_DEVICE(0x0586, 0x341f, rtl92cu_hal_cfg)}, /*Zyxel -Abocom*/ | 322 | {RTL_USB_DEVICE(0x0586, 0x341f, rtl92cu_hal_cfg)}, /*Zyxel -Abocom*/ |
317 | {RTL_USB_DEVICE(0x07aa, 0x0056, rtl92cu_hal_cfg)}, /*ATKK-Gemtek*/ | 323 | {RTL_USB_DEVICE(0x07aa, 0x0056, rtl92cu_hal_cfg)}, /*ATKK-Gemtek*/ |
318 | {RTL_USB_DEVICE(0x07b8, 0x8178, rtl92cu_hal_cfg)}, /*Funai -Abocom*/ | 324 | {RTL_USB_DEVICE(0x07b8, 0x8178, rtl92cu_hal_cfg)}, /*Funai -Abocom*/ |
319 | {RTL_USB_DEVICE(0x07b8, 0x8178, rtl92cu_hal_cfg)}, /*Abocom -Abocom*/ | ||
320 | {RTL_USB_DEVICE(0x2001, 0x3307, rtl92cu_hal_cfg)}, /*D-Link-Cameo*/ | 325 | {RTL_USB_DEVICE(0x2001, 0x3307, rtl92cu_hal_cfg)}, /*D-Link-Cameo*/ |
321 | {RTL_USB_DEVICE(0x2001, 0x3309, rtl92cu_hal_cfg)}, /*D-Link-Alpha*/ | 326 | {RTL_USB_DEVICE(0x2001, 0x3309, rtl92cu_hal_cfg)}, /*D-Link-Alpha*/ |
322 | {RTL_USB_DEVICE(0x2001, 0x330a, rtl92cu_hal_cfg)}, /*D-Link-Alpha*/ | 327 | {RTL_USB_DEVICE(0x2001, 0x330a, rtl92cu_hal_cfg)}, /*D-Link-Alpha*/ |
diff --git a/drivers/net/wireless/wl1251/acx.c b/drivers/net/wireless/wl1251/acx.c index ef8370edace7..ad87a1ac6462 100644 --- a/drivers/net/wireless/wl1251/acx.c +++ b/drivers/net/wireless/wl1251/acx.c | |||
@@ -140,8 +140,6 @@ int wl1251_acx_sleep_auth(struct wl1251 *wl, u8 sleep_auth) | |||
140 | auth->sleep_auth = sleep_auth; | 140 | auth->sleep_auth = sleep_auth; |
141 | 141 | ||
142 | ret = wl1251_cmd_configure(wl, ACX_SLEEP_AUTH, auth, sizeof(*auth)); | 142 | ret = wl1251_cmd_configure(wl, ACX_SLEEP_AUTH, auth, sizeof(*auth)); |
143 | if (ret < 0) | ||
144 | return ret; | ||
145 | 143 | ||
146 | out: | 144 | out: |
147 | kfree(auth); | 145 | kfree(auth); |
@@ -681,10 +679,8 @@ int wl1251_acx_cca_threshold(struct wl1251 *wl) | |||
681 | 679 | ||
682 | ret = wl1251_cmd_configure(wl, ACX_CCA_THRESHOLD, | 680 | ret = wl1251_cmd_configure(wl, ACX_CCA_THRESHOLD, |
683 | detection, sizeof(*detection)); | 681 | detection, sizeof(*detection)); |
684 | if (ret < 0) { | 682 | if (ret < 0) |
685 | wl1251_warning("failed to set cca threshold: %d", ret); | 683 | wl1251_warning("failed to set cca threshold: %d", ret); |
686 | return ret; | ||
687 | } | ||
688 | 684 | ||
689 | out: | 685 | out: |
690 | kfree(detection); | 686 | kfree(detection); |
diff --git a/drivers/net/wireless/wl1251/cmd.c b/drivers/net/wireless/wl1251/cmd.c index 81f164bc4888..d14d69d733a0 100644 --- a/drivers/net/wireless/wl1251/cmd.c +++ b/drivers/net/wireless/wl1251/cmd.c | |||
@@ -241,7 +241,7 @@ int wl1251_cmd_data_path(struct wl1251 *wl, u8 channel, bool enable) | |||
241 | if (ret < 0) { | 241 | if (ret < 0) { |
242 | wl1251_error("tx %s cmd for channel %d failed", | 242 | wl1251_error("tx %s cmd for channel %d failed", |
243 | enable ? "start" : "stop", channel); | 243 | enable ? "start" : "stop", channel); |
244 | return ret; | 244 | goto out; |
245 | } | 245 | } |
246 | 246 | ||
247 | wl1251_debug(DEBUG_BOOT, "tx %s cmd channel %d", | 247 | wl1251_debug(DEBUG_BOOT, "tx %s cmd channel %d", |
diff --git a/drivers/staging/ath6kl/miscdrv/ar3kps/ar3kpsparser.c b/drivers/staging/ath6kl/miscdrv/ar3kps/ar3kpsparser.c index c01c0cb0af4e..b99a11a9dd69 100644 --- a/drivers/staging/ath6kl/miscdrv/ar3kps/ar3kpsparser.c +++ b/drivers/staging/ath6kl/miscdrv/ar3kps/ar3kpsparser.c | |||
@@ -812,7 +812,7 @@ int AthCreateCommandList(struct ps_cmd_packet **HciPacketList, u32 *numPackets) | |||
812 | for(count = 0; count < Patch_Count; count++) { | 812 | for(count = 0; count < Patch_Count; count++) { |
813 | 813 | ||
814 | AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Freeing Patch Buffer %d \r\n",count)); | 814 | AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Freeing Patch Buffer %d \r\n",count)); |
815 | kfree(RamPatch[Patch_Count].Data); | 815 | kfree(RamPatch[count].Data); |
816 | } | 816 | } |
817 | 817 | ||
818 | for(count = 0; count < Tag_Count; count++) { | 818 | for(count = 0; count < Tag_Count; count++) { |
diff --git a/drivers/staging/dt3155v4l/dt3155v4l.c b/drivers/staging/dt3155v4l/dt3155v4l.c index fe02d22274b4..05aa41cf875b 100644 --- a/drivers/staging/dt3155v4l/dt3155v4l.c +++ b/drivers/staging/dt3155v4l/dt3155v4l.c | |||
@@ -22,6 +22,7 @@ | |||
22 | #include <linux/stringify.h> | 22 | #include <linux/stringify.h> |
23 | #include <linux/delay.h> | 23 | #include <linux/delay.h> |
24 | #include <linux/kthread.h> | 24 | #include <linux/kthread.h> |
25 | #include <linux/slab.h> | ||
25 | #include <media/v4l2-dev.h> | 26 | #include <media/v4l2-dev.h> |
26 | #include <media/v4l2-ioctl.h> | 27 | #include <media/v4l2-ioctl.h> |
27 | #include <media/videobuf2-dma-contig.h> | 28 | #include <media/videobuf2-dma-contig.h> |
diff --git a/drivers/staging/ft1000/ft1000-pcmcia/ft1000_proc.c b/drivers/staging/ft1000/ft1000-pcmcia/ft1000_proc.c index 627a98b4ec30..9e728b3415e3 100644 --- a/drivers/staging/ft1000/ft1000-pcmcia/ft1000_proc.c +++ b/drivers/staging/ft1000/ft1000-pcmcia/ft1000_proc.c | |||
@@ -22,6 +22,7 @@ | |||
22 | #include <linux/string.h> | 22 | #include <linux/string.h> |
23 | #include <linux/vmalloc.h> | 23 | #include <linux/vmalloc.h> |
24 | #include <linux/netdevice.h> | 24 | #include <linux/netdevice.h> |
25 | #include <asm/io.h> | ||
25 | #include <asm/uaccess.h> | 26 | #include <asm/uaccess.h> |
26 | #include "ft1000.h" | 27 | #include "ft1000.h" |
27 | 28 | ||
diff --git a/drivers/staging/gma500/gem_glue.c b/drivers/staging/gma500/gem_glue.c index 779ac1a12d24..daac12120653 100644 --- a/drivers/staging/gma500/gem_glue.c +++ b/drivers/staging/gma500/gem_glue.c | |||
@@ -20,26 +20,6 @@ | |||
20 | #include <drm/drmP.h> | 20 | #include <drm/drmP.h> |
21 | #include <drm/drm.h> | 21 | #include <drm/drm.h> |
22 | 22 | ||
23 | /** | ||
24 | * Initialize an already allocated GEM object of the specified size with | ||
25 | * no GEM provided backing store. Instead the caller is responsible for | ||
26 | * backing the object and handling it. | ||
27 | */ | ||
28 | int drm_gem_private_object_init(struct drm_device *dev, | ||
29 | struct drm_gem_object *obj, size_t size) | ||
30 | { | ||
31 | BUG_ON((size & (PAGE_SIZE - 1)) != 0); | ||
32 | |||
33 | obj->dev = dev; | ||
34 | obj->filp = NULL; | ||
35 | |||
36 | kref_init(&obj->refcount); | ||
37 | atomic_set(&obj->handle_count, 0); | ||
38 | obj->size = size; | ||
39 | |||
40 | return 0; | ||
41 | } | ||
42 | |||
43 | void drm_gem_object_release_wrap(struct drm_gem_object *obj) | 23 | void drm_gem_object_release_wrap(struct drm_gem_object *obj) |
44 | { | 24 | { |
45 | /* Remove the list map if one is present */ | 25 | /* Remove the list map if one is present */ |
@@ -51,8 +31,7 @@ void drm_gem_object_release_wrap(struct drm_gem_object *obj) | |||
51 | kfree(list->map); | 31 | kfree(list->map); |
52 | list->map = NULL; | 32 | list->map = NULL; |
53 | } | 33 | } |
54 | if (obj->filp) | 34 | drm_gem_object_release(obj); |
55 | drm_gem_object_release(obj); | ||
56 | } | 35 | } |
57 | 36 | ||
58 | /** | 37 | /** |
diff --git a/drivers/staging/gma500/gem_glue.h b/drivers/staging/gma500/gem_glue.h index a0f2bc4e4ae7..ce5ce30f74db 100644 --- a/drivers/staging/gma500/gem_glue.h +++ b/drivers/staging/gma500/gem_glue.h | |||
@@ -1,4 +1,2 @@ | |||
1 | extern void drm_gem_object_release_wrap(struct drm_gem_object *obj); | 1 | extern void drm_gem_object_release_wrap(struct drm_gem_object *obj); |
2 | extern int drm_gem_private_object_init(struct drm_device *dev, | ||
3 | struct drm_gem_object *obj, size_t size); | ||
4 | extern int gem_create_mmap_offset(struct drm_gem_object *obj); | 2 | extern int gem_create_mmap_offset(struct drm_gem_object *obj); |
diff --git a/drivers/staging/hv/blkvsc_drv.c b/drivers/staging/hv/blkvsc_drv.c index 3612574ca520..d286b2223181 100644 --- a/drivers/staging/hv/blkvsc_drv.c +++ b/drivers/staging/hv/blkvsc_drv.c | |||
@@ -325,7 +325,7 @@ static int blkvsc_do_operation(struct block_device_context *blkdev, | |||
325 | 325 | ||
326 | page_buf = alloc_page(GFP_KERNEL); | 326 | page_buf = alloc_page(GFP_KERNEL); |
327 | if (!page_buf) { | 327 | if (!page_buf) { |
328 | kmem_cache_free(blkvsc_req->dev->request_pool, blkvsc_req); | 328 | kmem_cache_free(blkdev->request_pool, blkvsc_req); |
329 | return -ENOMEM; | 329 | return -ENOMEM; |
330 | } | 330 | } |
331 | 331 | ||
@@ -422,7 +422,7 @@ cleanup: | |||
422 | 422 | ||
423 | __free_page(page_buf); | 423 | __free_page(page_buf); |
424 | 424 | ||
425 | kmem_cache_free(blkvsc_req->dev->request_pool, blkvsc_req); | 425 | kmem_cache_free(blkdev->request_pool, blkvsc_req); |
426 | 426 | ||
427 | return ret; | 427 | return ret; |
428 | } | 428 | } |
diff --git a/drivers/staging/iio/accel/adis16203_core.c b/drivers/staging/iio/accel/adis16203_core.c index bf1988884e93..cf5d15da76ad 100644 --- a/drivers/staging/iio/accel/adis16203_core.c +++ b/drivers/staging/iio/accel/adis16203_core.c | |||
@@ -311,13 +311,17 @@ static int adis16203_read_raw(struct iio_dev *indio_dev, | |||
311 | mutex_lock(&indio_dev->mlock); | 311 | mutex_lock(&indio_dev->mlock); |
312 | addr = adis16203_addresses[chan->address][0]; | 312 | addr = adis16203_addresses[chan->address][0]; |
313 | ret = adis16203_spi_read_reg_16(indio_dev, addr, &val16); | 313 | ret = adis16203_spi_read_reg_16(indio_dev, addr, &val16); |
314 | if (ret) | 314 | if (ret) { |
315 | mutex_unlock(&indio_dev->mlock); | ||
315 | return ret; | 316 | return ret; |
317 | } | ||
316 | 318 | ||
317 | if (val16 & ADIS16203_ERROR_ACTIVE) { | 319 | if (val16 & ADIS16203_ERROR_ACTIVE) { |
318 | ret = adis16203_check_status(indio_dev); | 320 | ret = adis16203_check_status(indio_dev); |
319 | if (ret) | 321 | if (ret) { |
322 | mutex_unlock(&indio_dev->mlock); | ||
320 | return ret; | 323 | return ret; |
324 | } | ||
321 | } | 325 | } |
322 | val16 = val16 & ((1 << chan->scan_type.realbits) - 1); | 326 | val16 = val16 & ((1 << chan->scan_type.realbits) - 1); |
323 | if (chan->scan_type.sign == 's') | 327 | if (chan->scan_type.sign == 's') |
diff --git a/drivers/staging/iio/accel/adis16204_core.c b/drivers/staging/iio/accel/adis16204_core.c index cfd09b3b9937..3e2b62654b7d 100644 --- a/drivers/staging/iio/accel/adis16204_core.c +++ b/drivers/staging/iio/accel/adis16204_core.c | |||
@@ -341,13 +341,17 @@ static int adis16204_read_raw(struct iio_dev *indio_dev, | |||
341 | mutex_lock(&indio_dev->mlock); | 341 | mutex_lock(&indio_dev->mlock); |
342 | addr = adis16204_addresses[chan->address][0]; | 342 | addr = adis16204_addresses[chan->address][0]; |
343 | ret = adis16204_spi_read_reg_16(indio_dev, addr, &val16); | 343 | ret = adis16204_spi_read_reg_16(indio_dev, addr, &val16); |
344 | if (ret) | 344 | if (ret) { |
345 | mutex_unlock(&indio_dev->mlock); | ||
345 | return ret; | 346 | return ret; |
347 | } | ||
346 | 348 | ||
347 | if (val16 & ADIS16204_ERROR_ACTIVE) { | 349 | if (val16 & ADIS16204_ERROR_ACTIVE) { |
348 | ret = adis16204_check_status(indio_dev); | 350 | ret = adis16204_check_status(indio_dev); |
349 | if (ret) | 351 | if (ret) { |
352 | mutex_unlock(&indio_dev->mlock); | ||
350 | return ret; | 353 | return ret; |
354 | } | ||
351 | } | 355 | } |
352 | val16 = val16 & ((1 << chan->scan_type.realbits) - 1); | 356 | val16 = val16 & ((1 << chan->scan_type.realbits) - 1); |
353 | if (chan->scan_type.sign == 's') | 357 | if (chan->scan_type.sign == 's') |
diff --git a/drivers/staging/iio/accel/adis16209_core.c b/drivers/staging/iio/accel/adis16209_core.c index 55f3a7bcaf0a..bec1fa8de9b9 100644 --- a/drivers/staging/iio/accel/adis16209_core.c +++ b/drivers/staging/iio/accel/adis16209_core.c | |||
@@ -337,13 +337,17 @@ static int adis16209_read_raw(struct iio_dev *indio_dev, | |||
337 | mutex_lock(&indio_dev->mlock); | 337 | mutex_lock(&indio_dev->mlock); |
338 | addr = adis16209_addresses[chan->address][0]; | 338 | addr = adis16209_addresses[chan->address][0]; |
339 | ret = adis16209_spi_read_reg_16(indio_dev, addr, &val16); | 339 | ret = adis16209_spi_read_reg_16(indio_dev, addr, &val16); |
340 | if (ret) | 340 | if (ret) { |
341 | mutex_unlock(&indio_dev->mlock); | ||
341 | return ret; | 342 | return ret; |
343 | } | ||
342 | 344 | ||
343 | if (val16 & ADIS16209_ERROR_ACTIVE) { | 345 | if (val16 & ADIS16209_ERROR_ACTIVE) { |
344 | ret = adis16209_check_status(indio_dev); | 346 | ret = adis16209_check_status(indio_dev); |
345 | if (ret) | 347 | if (ret) { |
348 | mutex_unlock(&indio_dev->mlock); | ||
346 | return ret; | 349 | return ret; |
350 | } | ||
347 | } | 351 | } |
348 | val16 = val16 & ((1 << chan->scan_type.realbits) - 1); | 352 | val16 = val16 & ((1 << chan->scan_type.realbits) - 1); |
349 | if (chan->scan_type.sign == 's') | 353 | if (chan->scan_type.sign == 's') |
diff --git a/drivers/staging/iio/accel/adis16240_core.c b/drivers/staging/iio/accel/adis16240_core.c index 4a4eafc58630..aee8b69173c4 100644 --- a/drivers/staging/iio/accel/adis16240_core.c +++ b/drivers/staging/iio/accel/adis16240_core.c | |||
@@ -370,13 +370,17 @@ static int adis16240_read_raw(struct iio_dev *indio_dev, | |||
370 | mutex_lock(&indio_dev->mlock); | 370 | mutex_lock(&indio_dev->mlock); |
371 | addr = adis16240_addresses[chan->address][0]; | 371 | addr = adis16240_addresses[chan->address][0]; |
372 | ret = adis16240_spi_read_reg_16(indio_dev, addr, &val16); | 372 | ret = adis16240_spi_read_reg_16(indio_dev, addr, &val16); |
373 | if (ret) | 373 | if (ret) { |
374 | mutex_unlock(&indio_dev->mlock); | ||
374 | return ret; | 375 | return ret; |
376 | } | ||
375 | 377 | ||
376 | if (val16 & ADIS16240_ERROR_ACTIVE) { | 378 | if (val16 & ADIS16240_ERROR_ACTIVE) { |
377 | ret = adis16240_check_status(indio_dev); | 379 | ret = adis16240_check_status(indio_dev); |
378 | if (ret) | 380 | if (ret) { |
381 | mutex_unlock(&indio_dev->mlock); | ||
379 | return ret; | 382 | return ret; |
383 | } | ||
380 | } | 384 | } |
381 | val16 = val16 & ((1 << chan->scan_type.realbits) - 1); | 385 | val16 = val16 & ((1 << chan->scan_type.realbits) - 1); |
382 | if (chan->scan_type.sign == 's') | 386 | if (chan->scan_type.sign == 's') |
diff --git a/drivers/staging/iio/gyro/adis16260_core.c b/drivers/staging/iio/gyro/adis16260_core.c index 05797f404bea..f2d43cfcc493 100644 --- a/drivers/staging/iio/gyro/adis16260_core.c +++ b/drivers/staging/iio/gyro/adis16260_core.c | |||
@@ -446,13 +446,17 @@ static int adis16260_read_raw(struct iio_dev *indio_dev, | |||
446 | mutex_lock(&indio_dev->mlock); | 446 | mutex_lock(&indio_dev->mlock); |
447 | addr = adis16260_addresses[chan->address][0]; | 447 | addr = adis16260_addresses[chan->address][0]; |
448 | ret = adis16260_spi_read_reg_16(indio_dev, addr, &val16); | 448 | ret = adis16260_spi_read_reg_16(indio_dev, addr, &val16); |
449 | if (ret) | 449 | if (ret) { |
450 | mutex_unlock(&indio_dev->mlock); | ||
450 | return ret; | 451 | return ret; |
452 | } | ||
451 | 453 | ||
452 | if (val16 & ADIS16260_ERROR_ACTIVE) { | 454 | if (val16 & ADIS16260_ERROR_ACTIVE) { |
453 | ret = adis16260_check_status(indio_dev); | 455 | ret = adis16260_check_status(indio_dev); |
454 | if (ret) | 456 | if (ret) { |
457 | mutex_unlock(&indio_dev->mlock); | ||
455 | return ret; | 458 | return ret; |
459 | } | ||
456 | } | 460 | } |
457 | val16 = val16 & ((1 << chan->scan_type.realbits) - 1); | 461 | val16 = val16 & ((1 << chan->scan_type.realbits) - 1); |
458 | if (chan->scan_type.sign == 's') | 462 | if (chan->scan_type.sign == 's') |
diff --git a/drivers/staging/nvec/TODO b/drivers/staging/nvec/TODO index 77b47f763f22..649d6b70deaa 100644 --- a/drivers/staging/nvec/TODO +++ b/drivers/staging/nvec/TODO | |||
@@ -4,5 +4,7 @@ ToDo list (incomplete, unordered) | |||
4 | - add compile as module support | 4 | - add compile as module support |
5 | - move nvec devices to mfd cells? | 5 | - move nvec devices to mfd cells? |
6 | - adjust to kernel style | 6 | - adjust to kernel style |
7 | 7 | - fix clk usage | |
8 | 8 | should not be using clk_get_sys(), but clk_get(&pdev->dev, conn) | |
9 | where conn is either NULL if the device only has one clock, or | ||
10 | the device specific name if it has multiple clocks. | ||
diff --git a/drivers/staging/rtl8192u/r819xU_firmware.c b/drivers/staging/rtl8192u/r819xU_firmware.c index 6766f468639f..4bb5fffca5b9 100644 --- a/drivers/staging/rtl8192u/r819xU_firmware.c +++ b/drivers/staging/rtl8192u/r819xU_firmware.c | |||
@@ -399,10 +399,7 @@ download_firmware_fail: | |||
399 | 399 | ||
400 | } | 400 | } |
401 | 401 | ||
402 | 402 | MODULE_FIRMWARE("RTL8192U/boot.img"); | |
403 | 403 | MODULE_FIRMWARE("RTL8192U/main.img"); | |
404 | 404 | MODULE_FIRMWARE("RTL8192U/data.img"); | |
405 | |||
406 | |||
407 | |||
408 | 405 | ||
diff --git a/drivers/staging/rts_pstor/rtsx.c b/drivers/staging/rts_pstor/rtsx.c index 5ff59f27d101..16c73fbff51f 100644 --- a/drivers/staging/rts_pstor/rtsx.c +++ b/drivers/staging/rts_pstor/rtsx.c | |||
@@ -66,12 +66,6 @@ static int msi_en; | |||
66 | module_param(msi_en, int, S_IRUGO | S_IWUSR); | 66 | module_param(msi_en, int, S_IRUGO | S_IWUSR); |
67 | MODULE_PARM_DESC(msi_en, "enable msi"); | 67 | MODULE_PARM_DESC(msi_en, "enable msi"); |
68 | 68 | ||
69 | /* These are used to make sure the module doesn't unload before all the | ||
70 | * threads have exited. | ||
71 | */ | ||
72 | static atomic_t total_threads = ATOMIC_INIT(0); | ||
73 | static DECLARE_COMPLETION(threads_gone); | ||
74 | |||
75 | static irqreturn_t rtsx_interrupt(int irq, void *dev_id); | 69 | static irqreturn_t rtsx_interrupt(int irq, void *dev_id); |
76 | 70 | ||
77 | /*********************************************************************** | 71 | /*********************************************************************** |
@@ -192,7 +186,7 @@ static int queuecommand_lck(struct scsi_cmnd *srb, | |||
192 | /* enqueue the command and wake up the control thread */ | 186 | /* enqueue the command and wake up the control thread */ |
193 | srb->scsi_done = done; | 187 | srb->scsi_done = done; |
194 | chip->srb = srb; | 188 | chip->srb = srb; |
195 | up(&(dev->sema)); | 189 | complete(&dev->cmnd_ready); |
196 | 190 | ||
197 | return 0; | 191 | return 0; |
198 | } | 192 | } |
@@ -475,7 +469,7 @@ static int rtsx_control_thread(void *__dev) | |||
475 | current->flags |= PF_NOFREEZE; | 469 | current->flags |= PF_NOFREEZE; |
476 | 470 | ||
477 | for (;;) { | 471 | for (;;) { |
478 | if (down_interruptible(&dev->sema)) | 472 | if (wait_for_completion_interruptible(&dev->cmnd_ready)) |
479 | break; | 473 | break; |
480 | 474 | ||
481 | /* lock the device pointers */ | 475 | /* lock the device pointers */ |
@@ -557,8 +551,6 @@ SkipForAbort: | |||
557 | mutex_unlock(&dev->dev_mutex); | 551 | mutex_unlock(&dev->dev_mutex); |
558 | } /* for (;;) */ | 552 | } /* for (;;) */ |
559 | 553 | ||
560 | scsi_host_put(host); | ||
561 | |||
562 | /* notify the exit routine that we're actually exiting now | 554 | /* notify the exit routine that we're actually exiting now |
563 | * | 555 | * |
564 | * complete()/wait_for_completion() is similar to up()/down(), | 556 | * complete()/wait_for_completion() is similar to up()/down(), |
@@ -573,7 +565,7 @@ SkipForAbort: | |||
573 | * This is important in preemption kernels, which transfer the flow | 565 | * This is important in preemption kernels, which transfer the flow |
574 | * of execution immediately upon a complete(). | 566 | * of execution immediately upon a complete(). |
575 | */ | 567 | */ |
576 | complete_and_exit(&threads_gone, 0); | 568 | complete_and_exit(&dev->control_exit, 0); |
577 | } | 569 | } |
578 | 570 | ||
579 | 571 | ||
@@ -581,7 +573,6 @@ static int rtsx_polling_thread(void *__dev) | |||
581 | { | 573 | { |
582 | struct rtsx_dev *dev = (struct rtsx_dev *)__dev; | 574 | struct rtsx_dev *dev = (struct rtsx_dev *)__dev; |
583 | struct rtsx_chip *chip = dev->chip; | 575 | struct rtsx_chip *chip = dev->chip; |
584 | struct Scsi_Host *host = rtsx_to_host(dev); | ||
585 | struct sd_info *sd_card = &(chip->sd_card); | 576 | struct sd_info *sd_card = &(chip->sd_card); |
586 | struct xd_info *xd_card = &(chip->xd_card); | 577 | struct xd_info *xd_card = &(chip->xd_card); |
587 | struct ms_info *ms_card = &(chip->ms_card); | 578 | struct ms_info *ms_card = &(chip->ms_card); |
@@ -621,8 +612,7 @@ static int rtsx_polling_thread(void *__dev) | |||
621 | mutex_unlock(&dev->dev_mutex); | 612 | mutex_unlock(&dev->dev_mutex); |
622 | } | 613 | } |
623 | 614 | ||
624 | scsi_host_put(host); | 615 | complete_and_exit(&dev->polling_exit, 0); |
625 | complete_and_exit(&threads_gone, 0); | ||
626 | } | 616 | } |
627 | 617 | ||
628 | /* | 618 | /* |
@@ -699,29 +689,38 @@ static void rtsx_release_resources(struct rtsx_dev *dev) | |||
699 | { | 689 | { |
700 | printk(KERN_INFO "-- %s\n", __func__); | 690 | printk(KERN_INFO "-- %s\n", __func__); |
701 | 691 | ||
692 | /* Tell the control thread to exit. The SCSI host must | ||
693 | * already have been removed so it won't try to queue | ||
694 | * any more commands. | ||
695 | */ | ||
696 | printk(KERN_INFO "-- sending exit command to thread\n"); | ||
697 | complete(&dev->cmnd_ready); | ||
698 | if (dev->ctl_thread) | ||
699 | wait_for_completion(&dev->control_exit); | ||
700 | if (dev->polling_thread) | ||
701 | wait_for_completion(&dev->polling_exit); | ||
702 | |||
703 | wait_timeout(200); | ||
704 | |||
702 | if (dev->rtsx_resv_buf) { | 705 | if (dev->rtsx_resv_buf) { |
703 | dma_free_coherent(&(dev->pci->dev), HOST_CMDS_BUF_LEN, | 706 | dma_free_coherent(&(dev->pci->dev), RTSX_RESV_BUF_LEN, |
704 | dev->rtsx_resv_buf, dev->rtsx_resv_buf_addr); | 707 | dev->rtsx_resv_buf, dev->rtsx_resv_buf_addr); |
705 | dev->chip->host_cmds_ptr = NULL; | 708 | dev->chip->host_cmds_ptr = NULL; |
706 | dev->chip->host_sg_tbl_ptr = NULL; | 709 | dev->chip->host_sg_tbl_ptr = NULL; |
707 | } | 710 | } |
708 | 711 | ||
709 | pci_disable_device(dev->pci); | 712 | if (dev->irq > 0) |
710 | pci_release_regions(dev->pci); | ||
711 | |||
712 | if (dev->irq > 0) { | ||
713 | free_irq(dev->irq, (void *)dev); | 713 | free_irq(dev->irq, (void *)dev); |
714 | } | 714 | if (dev->chip->msi_en) |
715 | if (dev->chip->msi_en) { | ||
716 | pci_disable_msi(dev->pci); | 715 | pci_disable_msi(dev->pci); |
717 | } | 716 | if (dev->remap_addr) |
717 | iounmap(dev->remap_addr); | ||
718 | 718 | ||
719 | /* Tell the control thread to exit. The SCSI host must | 719 | pci_disable_device(dev->pci); |
720 | * already have been removed so it won't try to queue | 720 | pci_release_regions(dev->pci); |
721 | * any more commands. | 721 | |
722 | */ | 722 | rtsx_release_chip(dev->chip); |
723 | printk(KERN_INFO "-- sending exit command to thread\n"); | 723 | kfree(dev->chip); |
724 | up(&dev->sema); | ||
725 | } | 724 | } |
726 | 725 | ||
727 | /* First stage of disconnect processing: stop all commands and remove | 726 | /* First stage of disconnect processing: stop all commands and remove |
@@ -739,6 +738,7 @@ static void quiesce_and_remove_host(struct rtsx_dev *dev) | |||
739 | scsi_unlock(host); | 738 | scsi_unlock(host); |
740 | mutex_unlock(&dev->dev_mutex); | 739 | mutex_unlock(&dev->dev_mutex); |
741 | wake_up(&dev->delay_wait); | 740 | wake_up(&dev->delay_wait); |
741 | wait_for_completion(&dev->scanning_done); | ||
742 | 742 | ||
743 | /* Wait some time to let other threads exist */ | 743 | /* Wait some time to let other threads exist */ |
744 | wait_timeout(100); | 744 | wait_timeout(100); |
@@ -793,8 +793,7 @@ static int rtsx_scan_thread(void *__dev) | |||
793 | /* Should we unbind if no devices were detected? */ | 793 | /* Should we unbind if no devices were detected? */ |
794 | } | 794 | } |
795 | 795 | ||
796 | scsi_host_put(rtsx_to_host(dev)); | 796 | complete_and_exit(&dev->scanning_done, 0); |
797 | complete_and_exit(&threads_gone, 0); | ||
798 | } | 797 | } |
799 | 798 | ||
800 | static void rtsx_init_options(struct rtsx_chip *chip) | 799 | static void rtsx_init_options(struct rtsx_chip *chip) |
@@ -941,8 +940,11 @@ static int __devinit rtsx_probe(struct pci_dev *pci, const struct pci_device_id | |||
941 | 940 | ||
942 | spin_lock_init(&dev->reg_lock); | 941 | spin_lock_init(&dev->reg_lock); |
943 | mutex_init(&(dev->dev_mutex)); | 942 | mutex_init(&(dev->dev_mutex)); |
944 | sema_init(&(dev->sema), 0); | 943 | init_completion(&dev->cmnd_ready); |
944 | init_completion(&dev->control_exit); | ||
945 | init_completion(&dev->polling_exit); | ||
945 | init_completion(&(dev->notify)); | 946 | init_completion(&(dev->notify)); |
947 | init_completion(&dev->scanning_done); | ||
946 | init_waitqueue_head(&dev->delay_wait); | 948 | init_waitqueue_head(&dev->delay_wait); |
947 | 949 | ||
948 | dev->pci = pci; | 950 | dev->pci = pci; |
@@ -992,28 +994,22 @@ static int __devinit rtsx_probe(struct pci_dev *pci, const struct pci_device_id | |||
992 | pci_set_master(pci); | 994 | pci_set_master(pci); |
993 | synchronize_irq(dev->irq); | 995 | synchronize_irq(dev->irq); |
994 | 996 | ||
995 | err = scsi_add_host(host, &pci->dev); | ||
996 | if (err) { | ||
997 | printk(KERN_ERR "Unable to add the scsi host\n"); | ||
998 | goto errout; | ||
999 | } | ||
1000 | |||
1001 | rtsx_init_chip(dev->chip); | 997 | rtsx_init_chip(dev->chip); |
1002 | 998 | ||
1003 | /* Start up our control thread */ | 999 | /* Start up our control thread */ |
1004 | th = kthread_create(rtsx_control_thread, dev, CR_DRIVER_NAME); | 1000 | th = kthread_run(rtsx_control_thread, dev, CR_DRIVER_NAME); |
1005 | if (IS_ERR(th)) { | 1001 | if (IS_ERR(th)) { |
1006 | printk(KERN_ERR "Unable to start control thread\n"); | 1002 | printk(KERN_ERR "Unable to start control thread\n"); |
1007 | err = PTR_ERR(th); | 1003 | err = PTR_ERR(th); |
1008 | goto errout; | 1004 | goto errout; |
1009 | } | 1005 | } |
1006 | dev->ctl_thread = th; | ||
1010 | 1007 | ||
1011 | /* Take a reference to the host for the control thread and | 1008 | err = scsi_add_host(host, &pci->dev); |
1012 | * count it among all the threads we have launched. Then | 1009 | if (err) { |
1013 | * start it up. */ | 1010 | printk(KERN_ERR "Unable to add the scsi host\n"); |
1014 | scsi_host_get(rtsx_to_host(dev)); | 1011 | goto errout; |
1015 | atomic_inc(&total_threads); | 1012 | } |
1016 | wake_up_process(th); | ||
1017 | 1013 | ||
1018 | /* Start up the thread for delayed SCSI-device scanning */ | 1014 | /* Start up the thread for delayed SCSI-device scanning */ |
1019 | th = kthread_create(rtsx_scan_thread, dev, "rtsx-scan"); | 1015 | th = kthread_create(rtsx_scan_thread, dev, "rtsx-scan"); |
@@ -1024,28 +1020,17 @@ static int __devinit rtsx_probe(struct pci_dev *pci, const struct pci_device_id | |||
1024 | goto errout; | 1020 | goto errout; |
1025 | } | 1021 | } |
1026 | 1022 | ||
1027 | /* Take a reference to the host for the scanning thread and | ||
1028 | * count it among all the threads we have launched. Then | ||
1029 | * start it up. */ | ||
1030 | scsi_host_get(rtsx_to_host(dev)); | ||
1031 | atomic_inc(&total_threads); | ||
1032 | wake_up_process(th); | 1023 | wake_up_process(th); |
1033 | 1024 | ||
1034 | /* Start up the thread for polling thread */ | 1025 | /* Start up the thread for polling thread */ |
1035 | th = kthread_create(rtsx_polling_thread, dev, "rtsx-polling"); | 1026 | th = kthread_run(rtsx_polling_thread, dev, "rtsx-polling"); |
1036 | if (IS_ERR(th)) { | 1027 | if (IS_ERR(th)) { |
1037 | printk(KERN_ERR "Unable to start the device-polling thread\n"); | 1028 | printk(KERN_ERR "Unable to start the device-polling thread\n"); |
1038 | quiesce_and_remove_host(dev); | 1029 | quiesce_and_remove_host(dev); |
1039 | err = PTR_ERR(th); | 1030 | err = PTR_ERR(th); |
1040 | goto errout; | 1031 | goto errout; |
1041 | } | 1032 | } |
1042 | 1033 | dev->polling_thread = th; | |
1043 | /* Take a reference to the host for the polling thread and | ||
1044 | * count it among all the threads we have launched. Then | ||
1045 | * start it up. */ | ||
1046 | scsi_host_get(rtsx_to_host(dev)); | ||
1047 | atomic_inc(&total_threads); | ||
1048 | wake_up_process(th); | ||
1049 | 1034 | ||
1050 | pci_set_drvdata(pci, dev); | 1035 | pci_set_drvdata(pci, dev); |
1051 | 1036 | ||
@@ -1108,16 +1093,6 @@ static void __exit rtsx_exit(void) | |||
1108 | 1093 | ||
1109 | pci_unregister_driver(&driver); | 1094 | pci_unregister_driver(&driver); |
1110 | 1095 | ||
1111 | /* Don't return until all of our control and scanning threads | ||
1112 | * have exited. Since each thread signals threads_gone as its | ||
1113 | * last act, we have to call wait_for_completion the right number | ||
1114 | * of times. | ||
1115 | */ | ||
1116 | while (atomic_read(&total_threads) > 0) { | ||
1117 | wait_for_completion(&threads_gone); | ||
1118 | atomic_dec(&total_threads); | ||
1119 | } | ||
1120 | |||
1121 | printk(KERN_INFO "%s module exit\n", CR_DRIVER_NAME); | 1096 | printk(KERN_INFO "%s module exit\n", CR_DRIVER_NAME); |
1122 | } | 1097 | } |
1123 | 1098 | ||
diff --git a/drivers/staging/rts_pstor/rtsx.h b/drivers/staging/rts_pstor/rtsx.h index 247615ba1d2a..86e47c2e3e3c 100644 --- a/drivers/staging/rts_pstor/rtsx.h +++ b/drivers/staging/rts_pstor/rtsx.h | |||
@@ -112,9 +112,16 @@ struct rtsx_dev { | |||
112 | /* locks */ | 112 | /* locks */ |
113 | spinlock_t reg_lock; | 113 | spinlock_t reg_lock; |
114 | 114 | ||
115 | struct task_struct *ctl_thread; /* the control thread */ | ||
116 | struct task_struct *polling_thread; /* the polling thread */ | ||
117 | |||
115 | /* mutual exclusion and synchronization structures */ | 118 | /* mutual exclusion and synchronization structures */ |
116 | struct semaphore sema; /* to sleep thread on */ | 119 | struct completion cmnd_ready; /* to sleep thread on */ |
120 | struct completion control_exit; /* control thread exit */ | ||
121 | struct completion polling_exit; /* polling thread exit */ | ||
117 | struct completion notify; /* thread begin/end */ | 122 | struct completion notify; /* thread begin/end */ |
123 | struct completion scanning_done; /* wait for scan thread */ | ||
124 | |||
118 | wait_queue_head_t delay_wait; /* wait during scan, reset */ | 125 | wait_queue_head_t delay_wait; /* wait during scan, reset */ |
119 | struct mutex dev_mutex; | 126 | struct mutex dev_mutex; |
120 | 127 | ||
diff --git a/drivers/staging/solo6x10/core.c b/drivers/staging/solo6x10/core.c index 76779949f141..f974f6412ad7 100644 --- a/drivers/staging/solo6x10/core.c +++ b/drivers/staging/solo6x10/core.c | |||
@@ -21,6 +21,7 @@ | |||
21 | #include <linux/module.h> | 21 | #include <linux/module.h> |
22 | #include <linux/pci.h> | 22 | #include <linux/pci.h> |
23 | #include <linux/interrupt.h> | 23 | #include <linux/interrupt.h> |
24 | #include <linux/slab.h> | ||
24 | #include <linux/videodev2.h> | 25 | #include <linux/videodev2.h> |
25 | #include "solo6x10.h" | 26 | #include "solo6x10.h" |
26 | #include "tw28.h" | 27 | #include "tw28.h" |
diff --git a/drivers/staging/solo6x10/enc.c b/drivers/staging/solo6x10/enc.c index 285f7f350062..de502599bb19 100644 --- a/drivers/staging/solo6x10/enc.c +++ b/drivers/staging/solo6x10/enc.c | |||
@@ -18,6 +18,7 @@ | |||
18 | */ | 18 | */ |
19 | 19 | ||
20 | #include <linux/kernel.h> | 20 | #include <linux/kernel.h> |
21 | #include <linux/slab.h> | ||
21 | #include "solo6x10.h" | 22 | #include "solo6x10.h" |
22 | #include "osd-font.h" | 23 | #include "osd-font.h" |
23 | 24 | ||
diff --git a/drivers/staging/solo6x10/g723.c b/drivers/staging/solo6x10/g723.c index bd8eb92c94b1..59274bfca95b 100644 --- a/drivers/staging/solo6x10/g723.c +++ b/drivers/staging/solo6x10/g723.c | |||
@@ -21,6 +21,7 @@ | |||
21 | #include <linux/mempool.h> | 21 | #include <linux/mempool.h> |
22 | #include <linux/poll.h> | 22 | #include <linux/poll.h> |
23 | #include <linux/kthread.h> | 23 | #include <linux/kthread.h> |
24 | #include <linux/slab.h> | ||
24 | #include <linux/freezer.h> | 25 | #include <linux/freezer.h> |
25 | #include <sound/core.h> | 26 | #include <sound/core.h> |
26 | #include <sound/initval.h> | 27 | #include <sound/initval.h> |
diff --git a/drivers/staging/solo6x10/p2m.c b/drivers/staging/solo6x10/p2m.c index 5717eabb04a4..56210f0fc5ec 100644 --- a/drivers/staging/solo6x10/p2m.c +++ b/drivers/staging/solo6x10/p2m.c | |||
@@ -18,6 +18,7 @@ | |||
18 | */ | 18 | */ |
19 | 19 | ||
20 | #include <linux/kernel.h> | 20 | #include <linux/kernel.h> |
21 | #include <linux/slab.h> | ||
21 | #include <linux/scatterlist.h> | 22 | #include <linux/scatterlist.h> |
22 | #include "solo6x10.h" | 23 | #include "solo6x10.h" |
23 | 24 | ||
diff --git a/drivers/staging/solo6x10/solo6x10.h b/drivers/staging/solo6x10/solo6x10.h index 17c06bd6cc91..abee7213202f 100644 --- a/drivers/staging/solo6x10/solo6x10.h +++ b/drivers/staging/solo6x10/solo6x10.h | |||
@@ -28,6 +28,7 @@ | |||
28 | #include <linux/list.h> | 28 | #include <linux/list.h> |
29 | #include <linux/wait.h> | 29 | #include <linux/wait.h> |
30 | #include <linux/delay.h> | 30 | #include <linux/delay.h> |
31 | #include <linux/slab.h> | ||
31 | #include <asm/io.h> | 32 | #include <asm/io.h> |
32 | #include <linux/atomic.h> | 33 | #include <linux/atomic.h> |
33 | #include <linux/videodev2.h> | 34 | #include <linux/videodev2.h> |
diff --git a/drivers/staging/speakup/devsynth.c b/drivers/staging/speakup/devsynth.c index 39dc586fc8bb..940769ef883f 100644 --- a/drivers/staging/speakup/devsynth.c +++ b/drivers/staging/speakup/devsynth.c | |||
@@ -18,13 +18,14 @@ static ssize_t speakup_file_write(struct file *fp, const char *buffer, | |||
18 | { | 18 | { |
19 | size_t count = nbytes; | 19 | size_t count = nbytes; |
20 | const char *ptr = buffer; | 20 | const char *ptr = buffer; |
21 | int bytes; | 21 | size_t bytes; |
22 | unsigned long flags; | 22 | unsigned long flags; |
23 | u_char buf[256]; | 23 | u_char buf[256]; |
24 | |||
24 | if (synth == NULL) | 25 | if (synth == NULL) |
25 | return -ENODEV; | 26 | return -ENODEV; |
26 | while (count > 0) { | 27 | while (count > 0) { |
27 | bytes = min_t(size_t, count, sizeof(buf)); | 28 | bytes = min(count, sizeof(buf)); |
28 | if (copy_from_user(buf, ptr, bytes)) | 29 | if (copy_from_user(buf, ptr, bytes)) |
29 | return -EFAULT; | 30 | return -EFAULT; |
30 | count -= bytes; | 31 | count -= bytes; |
diff --git a/drivers/staging/zcache/Makefile b/drivers/staging/zcache/Makefile index f5ec64f94470..60daa272c204 100644 --- a/drivers/staging/zcache/Makefile +++ b/drivers/staging/zcache/Makefile | |||
@@ -1,3 +1,3 @@ | |||
1 | zcache-y := tmem.o | 1 | zcache-y := zcache-main.o tmem.o |
2 | 2 | ||
3 | obj-$(CONFIG_ZCACHE) += zcache.o | 3 | obj-$(CONFIG_ZCACHE) += zcache.o |
diff --git a/drivers/staging/zcache/zcache.c b/drivers/staging/zcache/zcache-main.c index 65a81a0d7c49..855a5bb56a47 100644 --- a/drivers/staging/zcache/zcache.c +++ b/drivers/staging/zcache/zcache-main.c | |||
@@ -19,6 +19,7 @@ | |||
19 | * http://marc.info/?l=linux-mm&m=127811271605009 | 19 | * http://marc.info/?l=linux-mm&m=127811271605009 |
20 | */ | 20 | */ |
21 | 21 | ||
22 | #include <linux/module.h> | ||
22 | #include <linux/cpu.h> | 23 | #include <linux/cpu.h> |
23 | #include <linux/highmem.h> | 24 | #include <linux/highmem.h> |
24 | #include <linux/list.h> | 25 | #include <linux/list.h> |
@@ -27,6 +28,7 @@ | |||
27 | #include <linux/spinlock.h> | 28 | #include <linux/spinlock.h> |
28 | #include <linux/types.h> | 29 | #include <linux/types.h> |
29 | #include <linux/atomic.h> | 30 | #include <linux/atomic.h> |
31 | #include <linux/math64.h> | ||
30 | #include "tmem.h" | 32 | #include "tmem.h" |
31 | 33 | ||
32 | #include "../zram/xvmalloc.h" /* if built in drivers/staging */ | 34 | #include "../zram/xvmalloc.h" /* if built in drivers/staging */ |
@@ -53,6 +55,9 @@ | |||
53 | 55 | ||
54 | #define MAX_CLIENTS 16 | 56 | #define MAX_CLIENTS 16 |
55 | #define LOCAL_CLIENT ((uint16_t)-1) | 57 | #define LOCAL_CLIENT ((uint16_t)-1) |
58 | |||
59 | MODULE_LICENSE("GPL"); | ||
60 | |||
56 | struct zcache_client { | 61 | struct zcache_client { |
57 | struct tmem_pool *tmem_pools[MAX_POOLS_PER_CLIENT]; | 62 | struct tmem_pool *tmem_pools[MAX_POOLS_PER_CLIENT]; |
58 | struct xv_pool *xvpool; | 63 | struct xv_pool *xvpool; |
@@ -1158,6 +1163,7 @@ static void *zcache_pampd_create(char *data, size_t size, bool raw, int eph, | |||
1158 | uint16_t client_id = get_client_id_from_client(cli); | 1163 | uint16_t client_id = get_client_id_from_client(cli); |
1159 | unsigned long zv_mean_zsize; | 1164 | unsigned long zv_mean_zsize; |
1160 | unsigned long curr_pers_pampd_count; | 1165 | unsigned long curr_pers_pampd_count; |
1166 | u64 total_zsize; | ||
1161 | 1167 | ||
1162 | if (eph) { | 1168 | if (eph) { |
1163 | ret = zcache_compress(page, &cdata, &clen); | 1169 | ret = zcache_compress(page, &cdata, &clen); |
@@ -1190,8 +1196,9 @@ static void *zcache_pampd_create(char *data, size_t size, bool raw, int eph, | |||
1190 | } | 1196 | } |
1191 | /* reject if mean compression is too poor */ | 1197 | /* reject if mean compression is too poor */ |
1192 | if ((clen > zv_max_mean_zsize) && (curr_pers_pampd_count > 0)) { | 1198 | if ((clen > zv_max_mean_zsize) && (curr_pers_pampd_count > 0)) { |
1193 | zv_mean_zsize = xv_get_total_size_bytes(cli->xvpool) / | 1199 | total_zsize = xv_get_total_size_bytes(cli->xvpool); |
1194 | curr_pers_pampd_count; | 1200 | zv_mean_zsize = div_u64(total_zsize, |
1201 | curr_pers_pampd_count); | ||
1195 | if (zv_mean_zsize > zv_max_mean_zsize) { | 1202 | if (zv_mean_zsize > zv_max_mean_zsize) { |
1196 | zcache_mean_compress_poor++; | 1203 | zcache_mean_compress_poor++; |
1197 | goto out; | 1204 | goto out; |
@@ -1929,9 +1936,9 @@ __setup("nofrontswap", no_frontswap); | |||
1929 | 1936 | ||
1930 | static int __init zcache_init(void) | 1937 | static int __init zcache_init(void) |
1931 | { | 1938 | { |
1932 | #ifdef CONFIG_SYSFS | ||
1933 | int ret = 0; | 1939 | int ret = 0; |
1934 | 1940 | ||
1941 | #ifdef CONFIG_SYSFS | ||
1935 | ret = sysfs_create_group(mm_kobj, &zcache_attr_group); | 1942 | ret = sysfs_create_group(mm_kobj, &zcache_attr_group); |
1936 | if (ret) { | 1943 | if (ret) { |
1937 | pr_err("zcache: can't create sysfs\n"); | 1944 | pr_err("zcache: can't create sysfs\n"); |
diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c index 385acb895ab3..3f94ac34dce3 100644 --- a/drivers/usb/class/usbtmc.c +++ b/drivers/usb/class/usbtmc.c | |||
@@ -268,7 +268,7 @@ usbtmc_abort_bulk_in_status: | |||
268 | dev_err(dev, "usb_bulk_msg returned %d\n", rv); | 268 | dev_err(dev, "usb_bulk_msg returned %d\n", rv); |
269 | goto exit; | 269 | goto exit; |
270 | } | 270 | } |
271 | } while ((actual = max_size) && | 271 | } while ((actual == max_size) && |
272 | (n < USBTMC_MAX_READS_TO_CLEAR_BULK_IN)); | 272 | (n < USBTMC_MAX_READS_TO_CLEAR_BULK_IN)); |
273 | 273 | ||
274 | if (actual == max_size) { | 274 | if (actual == max_size) { |
diff --git a/drivers/usb/core/config.c b/drivers/usb/core/config.c index c962608b4b9a..26678cadfb21 100644 --- a/drivers/usb/core/config.c +++ b/drivers/usb/core/config.c | |||
@@ -123,10 +123,11 @@ static void usb_parse_ss_endpoint_companion(struct device *ddev, int cfgno, | |||
123 | } | 123 | } |
124 | 124 | ||
125 | if (usb_endpoint_xfer_isoc(&ep->desc)) | 125 | if (usb_endpoint_xfer_isoc(&ep->desc)) |
126 | max_tx = ep->desc.wMaxPacketSize * (desc->bMaxBurst + 1) * | 126 | max_tx = (desc->bMaxBurst + 1) * (desc->bmAttributes + 1) * |
127 | (desc->bmAttributes + 1); | 127 | le16_to_cpu(ep->desc.wMaxPacketSize); |
128 | else if (usb_endpoint_xfer_int(&ep->desc)) | 128 | else if (usb_endpoint_xfer_int(&ep->desc)) |
129 | max_tx = ep->desc.wMaxPacketSize * (desc->bMaxBurst + 1); | 129 | max_tx = le16_to_cpu(ep->desc.wMaxPacketSize) * |
130 | (desc->bMaxBurst + 1); | ||
130 | else | 131 | else |
131 | max_tx = 999999; | 132 | max_tx = 999999; |
132 | if (le16_to_cpu(desc->wBytesPerInterval) > max_tx) { | 133 | if (le16_to_cpu(desc->wBytesPerInterval) > max_tx) { |
@@ -134,10 +135,10 @@ static void usb_parse_ss_endpoint_companion(struct device *ddev, int cfgno, | |||
134 | "config %d interface %d altsetting %d ep %d: " | 135 | "config %d interface %d altsetting %d ep %d: " |
135 | "setting to %d\n", | 136 | "setting to %d\n", |
136 | usb_endpoint_xfer_isoc(&ep->desc) ? "Isoc" : "Int", | 137 | usb_endpoint_xfer_isoc(&ep->desc) ? "Isoc" : "Int", |
137 | desc->wBytesPerInterval, | 138 | le16_to_cpu(desc->wBytesPerInterval), |
138 | cfgno, inum, asnum, ep->desc.bEndpointAddress, | 139 | cfgno, inum, asnum, ep->desc.bEndpointAddress, |
139 | max_tx); | 140 | max_tx); |
140 | ep->ss_ep_comp.wBytesPerInterval = max_tx; | 141 | ep->ss_ep_comp.wBytesPerInterval = cpu_to_le16(max_tx); |
141 | } | 142 | } |
142 | } | 143 | } |
143 | 144 | ||
diff --git a/drivers/usb/gadget/Kconfig b/drivers/usb/gadget/Kconfig index 44b6b40aafb4..5a084b9cfa3c 100644 --- a/drivers/usb/gadget/Kconfig +++ b/drivers/usb/gadget/Kconfig | |||
@@ -310,7 +310,7 @@ config USB_PXA_U2O | |||
310 | # musb builds in ../musb along with host support | 310 | # musb builds in ../musb along with host support |
311 | config USB_GADGET_MUSB_HDRC | 311 | config USB_GADGET_MUSB_HDRC |
312 | tristate "Inventra HDRC USB Peripheral (TI, ADI, ...)" | 312 | tristate "Inventra HDRC USB Peripheral (TI, ADI, ...)" |
313 | depends on USB_MUSB_HDRC && (USB_MUSB_PERIPHERAL || USB_MUSB_OTG) | 313 | depends on USB_MUSB_HDRC |
314 | select USB_GADGET_DUALSPEED | 314 | select USB_GADGET_DUALSPEED |
315 | help | 315 | help |
316 | This OTG-capable silicon IP is used in dual designs including | 316 | This OTG-capable silicon IP is used in dual designs including |
diff --git a/drivers/usb/gadget/at91_udc.c b/drivers/usb/gadget/at91_udc.c index 98cbc06c30fd..ddb118a76807 100644 --- a/drivers/usb/gadget/at91_udc.c +++ b/drivers/usb/gadget/at91_udc.c | |||
@@ -35,6 +35,7 @@ | |||
35 | #include <linux/list.h> | 35 | #include <linux/list.h> |
36 | #include <linux/interrupt.h> | 36 | #include <linux/interrupt.h> |
37 | #include <linux/proc_fs.h> | 37 | #include <linux/proc_fs.h> |
38 | #include <linux/prefetch.h> | ||
38 | #include <linux/clk.h> | 39 | #include <linux/clk.h> |
39 | #include <linux/usb/ch9.h> | 40 | #include <linux/usb/ch9.h> |
40 | #include <linux/usb/gadget.h> | 41 | #include <linux/usb/gadget.h> |
diff --git a/drivers/usb/gadget/composite.c b/drivers/usb/gadget/composite.c index 5ef87794fd32..aef47414f5d5 100644 --- a/drivers/usb/gadget/composite.c +++ b/drivers/usb/gadget/composite.c | |||
@@ -1079,10 +1079,12 @@ composite_setup(struct usb_gadget *gadget, const struct usb_ctrlrequest *ctrl) | |||
1079 | cdev->desc.bMaxPacketSize0 = | 1079 | cdev->desc.bMaxPacketSize0 = |
1080 | cdev->gadget->ep0->maxpacket; | 1080 | cdev->gadget->ep0->maxpacket; |
1081 | if (gadget_is_superspeed(gadget)) { | 1081 | if (gadget_is_superspeed(gadget)) { |
1082 | if (gadget->speed >= USB_SPEED_SUPER) | 1082 | if (gadget->speed >= USB_SPEED_SUPER) { |
1083 | cdev->desc.bcdUSB = cpu_to_le16(0x0300); | 1083 | cdev->desc.bcdUSB = cpu_to_le16(0x0300); |
1084 | else | 1084 | cdev->desc.bMaxPacketSize0 = 9; |
1085 | } else { | ||
1085 | cdev->desc.bcdUSB = cpu_to_le16(0x0210); | 1086 | cdev->desc.bcdUSB = cpu_to_le16(0x0210); |
1087 | } | ||
1086 | } | 1088 | } |
1087 | 1089 | ||
1088 | value = min(w_length, (u16) sizeof cdev->desc); | 1090 | value = min(w_length, (u16) sizeof cdev->desc); |
diff --git a/drivers/usb/gadget/f_hid.c b/drivers/usb/gadget/f_hid.c index 403a48bcf560..83a266bdb40e 100644 --- a/drivers/usb/gadget/f_hid.c +++ b/drivers/usb/gadget/f_hid.c | |||
@@ -367,6 +367,13 @@ static int hidg_setup(struct usb_function *f, | |||
367 | case ((USB_DIR_IN | USB_TYPE_STANDARD | USB_RECIP_INTERFACE) << 8 | 367 | case ((USB_DIR_IN | USB_TYPE_STANDARD | USB_RECIP_INTERFACE) << 8 |
368 | | USB_REQ_GET_DESCRIPTOR): | 368 | | USB_REQ_GET_DESCRIPTOR): |
369 | switch (value >> 8) { | 369 | switch (value >> 8) { |
370 | case HID_DT_HID: | ||
371 | VDBG(cdev, "USB_REQ_GET_DESCRIPTOR: HID\n"); | ||
372 | length = min_t(unsigned short, length, | ||
373 | hidg_desc.bLength); | ||
374 | memcpy(req->buf, &hidg_desc, length); | ||
375 | goto respond; | ||
376 | break; | ||
370 | case HID_DT_REPORT: | 377 | case HID_DT_REPORT: |
371 | VDBG(cdev, "USB_REQ_GET_DESCRIPTOR: REPORT\n"); | 378 | VDBG(cdev, "USB_REQ_GET_DESCRIPTOR: REPORT\n"); |
372 | length = min_t(unsigned short, length, | 379 | length = min_t(unsigned short, length, |
diff --git a/drivers/usb/gadget/fusb300_udc.c b/drivers/usb/gadget/fusb300_udc.c index 24a924330c81..4ec888f90002 100644 --- a/drivers/usb/gadget/fusb300_udc.c +++ b/drivers/usb/gadget/fusb300_udc.c | |||
@@ -609,107 +609,6 @@ void fusb300_rdcxf(struct fusb300 *fusb300, | |||
609 | } | 609 | } |
610 | } | 610 | } |
611 | 611 | ||
612 | #if 0 | ||
613 | static void fusb300_dbg_fifo(struct fusb300_ep *ep, | ||
614 | u8 entry, u16 length) | ||
615 | { | ||
616 | u32 reg; | ||
617 | u32 i = 0; | ||
618 | u32 j = 0; | ||
619 | |||
620 | reg = ioread32(ep->fusb300->reg + FUSB300_OFFSET_GTM); | ||
621 | reg &= ~(FUSB300_GTM_TST_EP_ENTRY(0xF) | | ||
622 | FUSB300_GTM_TST_EP_NUM(0xF) | FUSB300_GTM_TST_FIFO_DEG); | ||
623 | reg |= (FUSB300_GTM_TST_EP_ENTRY(entry) | | ||
624 | FUSB300_GTM_TST_EP_NUM(ep->epnum) | FUSB300_GTM_TST_FIFO_DEG); | ||
625 | iowrite32(reg, ep->fusb300->reg + FUSB300_OFFSET_GTM); | ||
626 | |||
627 | for (i = 0; i < (length >> 2); i++) { | ||
628 | if (i * 4 == 1024) | ||
629 | break; | ||
630 | reg = ioread32(ep->fusb300->reg + | ||
631 | FUSB300_OFFSET_BUFDBG_START + i * 4); | ||
632 | printk(KERN_DEBUG" 0x%-8x", reg); | ||
633 | j++; | ||
634 | if ((j % 4) == 0) | ||
635 | printk(KERN_DEBUG "\n"); | ||
636 | } | ||
637 | |||
638 | if (length % 4) { | ||
639 | reg = ioread32(ep->fusb300->reg + | ||
640 | FUSB300_OFFSET_BUFDBG_START + i * 4); | ||
641 | printk(KERN_DEBUG " 0x%x\n", reg); | ||
642 | } | ||
643 | |||
644 | if ((j % 4) != 0) | ||
645 | printk(KERN_DEBUG "\n"); | ||
646 | |||
647 | fusb300_disable_bit(ep->fusb300, FUSB300_OFFSET_GTM, | ||
648 | FUSB300_GTM_TST_FIFO_DEG); | ||
649 | } | ||
650 | |||
651 | static void fusb300_cmp_dbg_fifo(struct fusb300_ep *ep, | ||
652 | u8 entry, u16 length, u8 *golden) | ||
653 | { | ||
654 | u32 reg; | ||
655 | u32 i = 0; | ||
656 | u32 golden_value; | ||
657 | u8 *tmp; | ||
658 | |||
659 | tmp = golden; | ||
660 | |||
661 | printk(KERN_DEBUG "fusb300_cmp_dbg_fifo (entry %d) : start\n", entry); | ||
662 | |||
663 | reg = ioread32(ep->fusb300->reg + FUSB300_OFFSET_GTM); | ||
664 | reg &= ~(FUSB300_GTM_TST_EP_ENTRY(0xF) | | ||
665 | FUSB300_GTM_TST_EP_NUM(0xF) | FUSB300_GTM_TST_FIFO_DEG); | ||
666 | reg |= (FUSB300_GTM_TST_EP_ENTRY(entry) | | ||
667 | FUSB300_GTM_TST_EP_NUM(ep->epnum) | FUSB300_GTM_TST_FIFO_DEG); | ||
668 | iowrite32(reg, ep->fusb300->reg + FUSB300_OFFSET_GTM); | ||
669 | |||
670 | for (i = 0; i < (length >> 2); i++) { | ||
671 | if (i * 4 == 1024) | ||
672 | break; | ||
673 | golden_value = *tmp | *(tmp + 1) << 8 | | ||
674 | *(tmp + 2) << 16 | *(tmp + 3) << 24; | ||
675 | |||
676 | reg = ioread32(ep->fusb300->reg + | ||
677 | FUSB300_OFFSET_BUFDBG_START + i*4); | ||
678 | |||
679 | if (reg != golden_value) { | ||
680 | printk(KERN_DEBUG "0x%x : ", (u32)(ep->fusb300->reg + | ||
681 | FUSB300_OFFSET_BUFDBG_START + i*4)); | ||
682 | printk(KERN_DEBUG " golden = 0x%x, reg = 0x%x\n", | ||
683 | golden_value, reg); | ||
684 | } | ||
685 | tmp += 4; | ||
686 | } | ||
687 | |||
688 | switch (length % 4) { | ||
689 | case 1: | ||
690 | golden_value = *tmp; | ||
691 | case 2: | ||
692 | golden_value = *tmp | *(tmp + 1) << 8; | ||
693 | case 3: | ||
694 | golden_value = *tmp | *(tmp + 1) << 8 | *(tmp + 2) << 16; | ||
695 | default: | ||
696 | break; | ||
697 | |||
698 | reg = ioread32(ep->fusb300->reg + FUSB300_OFFSET_BUFDBG_START + i*4); | ||
699 | if (reg != golden_value) { | ||
700 | printk(KERN_DEBUG "0x%x:", (u32)(ep->fusb300->reg + | ||
701 | FUSB300_OFFSET_BUFDBG_START + i*4)); | ||
702 | printk(KERN_DEBUG " golden = 0x%x, reg = 0x%x\n", | ||
703 | golden_value, reg); | ||
704 | } | ||
705 | } | ||
706 | |||
707 | printk(KERN_DEBUG "fusb300_cmp_dbg_fifo : end\n"); | ||
708 | fusb300_disable_bit(ep->fusb300, FUSB300_OFFSET_GTM, | ||
709 | FUSB300_GTM_TST_FIFO_DEG); | ||
710 | } | ||
711 | #endif | ||
712 | |||
713 | static void fusb300_rdfifo(struct fusb300_ep *ep, | 612 | static void fusb300_rdfifo(struct fusb300_ep *ep, |
714 | struct fusb300_request *req, | 613 | struct fusb300_request *req, |
715 | u32 length) | 614 | u32 length) |
diff --git a/drivers/usb/gadget/net2272.c b/drivers/usb/gadget/net2272.c index 7c7b0e120d88..ab98ea926a11 100644 --- a/drivers/usb/gadget/net2272.c +++ b/drivers/usb/gadget/net2272.c | |||
@@ -27,13 +27,13 @@ | |||
27 | #include <linux/interrupt.h> | 27 | #include <linux/interrupt.h> |
28 | #include <linux/io.h> | 28 | #include <linux/io.h> |
29 | #include <linux/ioport.h> | 29 | #include <linux/ioport.h> |
30 | #include <linux/irq.h> | ||
31 | #include <linux/kernel.h> | 30 | #include <linux/kernel.h> |
32 | #include <linux/list.h> | 31 | #include <linux/list.h> |
33 | #include <linux/module.h> | 32 | #include <linux/module.h> |
34 | #include <linux/moduleparam.h> | 33 | #include <linux/moduleparam.h> |
35 | #include <linux/pci.h> | 34 | #include <linux/pci.h> |
36 | #include <linux/platform_device.h> | 35 | #include <linux/platform_device.h> |
36 | #include <linux/prefetch.h> | ||
37 | #include <linux/sched.h> | 37 | #include <linux/sched.h> |
38 | #include <linux/slab.h> | 38 | #include <linux/slab.h> |
39 | #include <linux/timer.h> | 39 | #include <linux/timer.h> |
diff --git a/drivers/usb/gadget/s3c2410_udc.c b/drivers/usb/gadget/s3c2410_udc.c index 85c1b0d66293..8d31848aab09 100644 --- a/drivers/usb/gadget/s3c2410_udc.c +++ b/drivers/usb/gadget/s3c2410_udc.c | |||
@@ -2060,6 +2060,7 @@ static int s3c2410_udc_resume(struct platform_device *pdev) | |||
2060 | static const struct platform_device_id s3c_udc_ids[] = { | 2060 | static const struct platform_device_id s3c_udc_ids[] = { |
2061 | { "s3c2410-usbgadget", }, | 2061 | { "s3c2410-usbgadget", }, |
2062 | { "s3c2440-usbgadget", }, | 2062 | { "s3c2440-usbgadget", }, |
2063 | { } | ||
2063 | }; | 2064 | }; |
2064 | MODULE_DEVICE_TABLE(platform, s3c_udc_ids); | 2065 | MODULE_DEVICE_TABLE(platform, s3c_udc_ids); |
2065 | 2066 | ||
diff --git a/drivers/usb/host/ehci-hub.c b/drivers/usb/host/ehci-hub.c index bf2c8f65e1ae..e051b30c1847 100644 --- a/drivers/usb/host/ehci-hub.c +++ b/drivers/usb/host/ehci-hub.c | |||
@@ -1046,7 +1046,19 @@ static int ehci_hub_control ( | |||
1046 | if (!selector || selector > 5) | 1046 | if (!selector || selector > 5) |
1047 | goto error; | 1047 | goto error; |
1048 | ehci_quiesce(ehci); | 1048 | ehci_quiesce(ehci); |
1049 | |||
1050 | /* Put all enabled ports into suspend */ | ||
1051 | while (ports--) { | ||
1052 | u32 __iomem *sreg = | ||
1053 | &ehci->regs->port_status[ports]; | ||
1054 | |||
1055 | temp = ehci_readl(ehci, sreg) & ~PORT_RWC_BITS; | ||
1056 | if (temp & PORT_PE) | ||
1057 | ehci_writel(ehci, temp | PORT_SUSPEND, | ||
1058 | sreg); | ||
1059 | } | ||
1049 | ehci_halt(ehci); | 1060 | ehci_halt(ehci); |
1061 | temp = ehci_readl(ehci, status_reg); | ||
1050 | temp |= selector << 16; | 1062 | temp |= selector << 16; |
1051 | ehci_writel(ehci, temp, status_reg); | 1063 | ehci_writel(ehci, temp, status_reg); |
1052 | break; | 1064 | break; |
diff --git a/drivers/usb/host/ehci-mxc.c b/drivers/usb/host/ehci-mxc.c index 0c058be35a38..555a73c864b5 100644 --- a/drivers/usb/host/ehci-mxc.c +++ b/drivers/usb/host/ehci-mxc.c | |||
@@ -24,6 +24,7 @@ | |||
24 | #include <linux/usb/ulpi.h> | 24 | #include <linux/usb/ulpi.h> |
25 | #include <linux/slab.h> | 25 | #include <linux/slab.h> |
26 | 26 | ||
27 | #include <mach/hardware.h> | ||
27 | #include <mach/mxc_ehci.h> | 28 | #include <mach/mxc_ehci.h> |
28 | 29 | ||
29 | #include <asm/mach-types.h> | 30 | #include <asm/mach-types.h> |
diff --git a/drivers/usb/host/ehci-omap.c b/drivers/usb/host/ehci-omap.c index 55a57c23dd0f..45240321ca09 100644 --- a/drivers/usb/host/ehci-omap.c +++ b/drivers/usb/host/ehci-omap.c | |||
@@ -98,6 +98,18 @@ static void omap_ehci_soft_phy_reset(struct platform_device *pdev, u8 port) | |||
98 | } | 98 | } |
99 | } | 99 | } |
100 | 100 | ||
101 | static void disable_put_regulator( | ||
102 | struct ehci_hcd_omap_platform_data *pdata) | ||
103 | { | ||
104 | int i; | ||
105 | |||
106 | for (i = 0 ; i < OMAP3_HS_USB_PORTS ; i++) { | ||
107 | if (pdata->regulator[i]) { | ||
108 | regulator_disable(pdata->regulator[i]); | ||
109 | regulator_put(pdata->regulator[i]); | ||
110 | } | ||
111 | } | ||
112 | } | ||
101 | 113 | ||
102 | /* configure so an HC device and id are always provided */ | 114 | /* configure so an HC device and id are always provided */ |
103 | /* always called with process context; sleeping is OK */ | 115 | /* always called with process context; sleeping is OK */ |
@@ -231,9 +243,11 @@ err_add_hcd: | |||
231 | omap_usbhs_disable(dev); | 243 | omap_usbhs_disable(dev); |
232 | 244 | ||
233 | err_enable: | 245 | err_enable: |
246 | disable_put_regulator(pdata); | ||
234 | usb_put_hcd(hcd); | 247 | usb_put_hcd(hcd); |
235 | 248 | ||
236 | err_io: | 249 | err_io: |
250 | iounmap(regs); | ||
237 | return ret; | 251 | return ret; |
238 | } | 252 | } |
239 | 253 | ||
@@ -253,6 +267,8 @@ static int ehci_hcd_omap_remove(struct platform_device *pdev) | |||
253 | 267 | ||
254 | usb_remove_hcd(hcd); | 268 | usb_remove_hcd(hcd); |
255 | omap_usbhs_disable(dev); | 269 | omap_usbhs_disable(dev); |
270 | disable_put_regulator(dev->platform_data); | ||
271 | iounmap(hcd->regs); | ||
256 | usb_put_hcd(hcd); | 272 | usb_put_hcd(hcd); |
257 | return 0; | 273 | return 0; |
258 | } | 274 | } |
diff --git a/drivers/usb/host/isp1760-hcd.c b/drivers/usb/host/isp1760-hcd.c index 55d3d5859ac5..840beda66dd9 100644 --- a/drivers/usb/host/isp1760-hcd.c +++ b/drivers/usb/host/isp1760-hcd.c | |||
@@ -1583,6 +1583,9 @@ static int isp1760_urb_dequeue(struct usb_hcd *hcd, struct urb *urb, | |||
1583 | int retval = 0; | 1583 | int retval = 0; |
1584 | 1584 | ||
1585 | spin_lock_irqsave(&priv->lock, spinflags); | 1585 | spin_lock_irqsave(&priv->lock, spinflags); |
1586 | retval = usb_hcd_check_unlink_urb(hcd, urb, status); | ||
1587 | if (retval) | ||
1588 | goto out; | ||
1586 | 1589 | ||
1587 | qh = urb->ep->hcpriv; | 1590 | qh = urb->ep->hcpriv; |
1588 | if (!qh) { | 1591 | if (!qh) { |
diff --git a/drivers/usb/host/pci-quirks.c b/drivers/usb/host/pci-quirks.c index a9d315906e3d..629a96813fd6 100644 --- a/drivers/usb/host/pci-quirks.c +++ b/drivers/usb/host/pci-quirks.c | |||
@@ -535,7 +535,7 @@ static void __devinit quirk_usb_handoff_ohci(struct pci_dev *pdev) | |||
535 | iounmap(base); | 535 | iounmap(base); |
536 | } | 536 | } |
537 | 537 | ||
538 | static const struct dmi_system_id __initconst ehci_dmi_nohandoff_table[] = { | 538 | static const struct dmi_system_id __devinitconst ehci_dmi_nohandoff_table[] = { |
539 | { | 539 | { |
540 | /* Pegatron Lucid (ExoPC) */ | 540 | /* Pegatron Lucid (ExoPC) */ |
541 | .matches = { | 541 | .matches = { |
@@ -817,7 +817,7 @@ static void __devinit quirk_usb_handoff_xhci(struct pci_dev *pdev) | |||
817 | 817 | ||
818 | /* If the BIOS owns the HC, signal that the OS wants it, and wait */ | 818 | /* If the BIOS owns the HC, signal that the OS wants it, and wait */ |
819 | if (val & XHCI_HC_BIOS_OWNED) { | 819 | if (val & XHCI_HC_BIOS_OWNED) { |
820 | writel(val & XHCI_HC_OS_OWNED, base + ext_cap_offset); | 820 | writel(val | XHCI_HC_OS_OWNED, base + ext_cap_offset); |
821 | 821 | ||
822 | /* Wait for 5 seconds with 10 microsecond polling interval */ | 822 | /* Wait for 5 seconds with 10 microsecond polling interval */ |
823 | timeout = handshake(base + ext_cap_offset, XHCI_HC_BIOS_OWNED, | 823 | timeout = handshake(base + ext_cap_offset, XHCI_HC_BIOS_OWNED, |
diff --git a/drivers/usb/host/xhci.c b/drivers/usb/host/xhci.c index 763f484bc092..1c4432d8fc10 100644 --- a/drivers/usb/host/xhci.c +++ b/drivers/usb/host/xhci.c | |||
@@ -345,7 +345,8 @@ static void xhci_event_ring_work(unsigned long arg) | |||
345 | spin_lock_irqsave(&xhci->lock, flags); | 345 | spin_lock_irqsave(&xhci->lock, flags); |
346 | temp = xhci_readl(xhci, &xhci->op_regs->status); | 346 | temp = xhci_readl(xhci, &xhci->op_regs->status); |
347 | xhci_dbg(xhci, "op reg status = 0x%x\n", temp); | 347 | xhci_dbg(xhci, "op reg status = 0x%x\n", temp); |
348 | if (temp == 0xffffffff || (xhci->xhc_state & XHCI_STATE_DYING)) { | 348 | if (temp == 0xffffffff || (xhci->xhc_state & XHCI_STATE_DYING) || |
349 | (xhci->xhc_state & XHCI_STATE_HALTED)) { | ||
349 | xhci_dbg(xhci, "HW died, polling stopped.\n"); | 350 | xhci_dbg(xhci, "HW died, polling stopped.\n"); |
350 | spin_unlock_irqrestore(&xhci->lock, flags); | 351 | spin_unlock_irqrestore(&xhci->lock, flags); |
351 | return; | 352 | return; |
@@ -939,8 +940,11 @@ static int xhci_check_args(struct usb_hcd *hcd, struct usb_device *udev, | |||
939 | return 0; | 940 | return 0; |
940 | } | 941 | } |
941 | 942 | ||
943 | xhci = hcd_to_xhci(hcd); | ||
944 | if (xhci->xhc_state & XHCI_STATE_HALTED) | ||
945 | return -ENODEV; | ||
946 | |||
942 | if (check_virt_dev) { | 947 | if (check_virt_dev) { |
943 | xhci = hcd_to_xhci(hcd); | ||
944 | if (!udev->slot_id || !xhci->devs | 948 | if (!udev->slot_id || !xhci->devs |
945 | || !xhci->devs[udev->slot_id]) { | 949 | || !xhci->devs[udev->slot_id]) { |
946 | printk(KERN_DEBUG "xHCI %s called with unaddressed " | 950 | printk(KERN_DEBUG "xHCI %s called with unaddressed " |
@@ -1242,7 +1246,8 @@ int xhci_urb_dequeue(struct usb_hcd *hcd, struct urb *urb, int status) | |||
1242 | xhci_urb_free_priv(xhci, urb_priv); | 1246 | xhci_urb_free_priv(xhci, urb_priv); |
1243 | return ret; | 1247 | return ret; |
1244 | } | 1248 | } |
1245 | if (xhci->xhc_state & XHCI_STATE_DYING) { | 1249 | if ((xhci->xhc_state & XHCI_STATE_DYING) || |
1250 | (xhci->xhc_state & XHCI_STATE_HALTED)) { | ||
1246 | xhci_dbg(xhci, "Ep 0x%x: URB %p to be canceled on " | 1251 | xhci_dbg(xhci, "Ep 0x%x: URB %p to be canceled on " |
1247 | "non-responsive xHCI host.\n", | 1252 | "non-responsive xHCI host.\n", |
1248 | urb->ep->desc.bEndpointAddress, urb); | 1253 | urb->ep->desc.bEndpointAddress, urb); |
@@ -2665,7 +2670,10 @@ void xhci_free_dev(struct usb_hcd *hcd, struct usb_device *udev) | |||
2665 | int i, ret; | 2670 | int i, ret; |
2666 | 2671 | ||
2667 | ret = xhci_check_args(hcd, udev, NULL, 0, true, __func__); | 2672 | ret = xhci_check_args(hcd, udev, NULL, 0, true, __func__); |
2668 | if (ret <= 0) | 2673 | /* If the host is halted due to driver unload, we still need to free the |
2674 | * device. | ||
2675 | */ | ||
2676 | if (ret <= 0 && ret != -ENODEV) | ||
2669 | return; | 2677 | return; |
2670 | 2678 | ||
2671 | virt_dev = xhci->devs[udev->slot_id]; | 2679 | virt_dev = xhci->devs[udev->slot_id]; |
@@ -2679,7 +2687,8 @@ void xhci_free_dev(struct usb_hcd *hcd, struct usb_device *udev) | |||
2679 | spin_lock_irqsave(&xhci->lock, flags); | 2687 | spin_lock_irqsave(&xhci->lock, flags); |
2680 | /* Don't disable the slot if the host controller is dead. */ | 2688 | /* Don't disable the slot if the host controller is dead. */ |
2681 | state = xhci_readl(xhci, &xhci->op_regs->status); | 2689 | state = xhci_readl(xhci, &xhci->op_regs->status); |
2682 | if (state == 0xffffffff || (xhci->xhc_state & XHCI_STATE_DYING)) { | 2690 | if (state == 0xffffffff || (xhci->xhc_state & XHCI_STATE_DYING) || |
2691 | (xhci->xhc_state & XHCI_STATE_HALTED)) { | ||
2683 | xhci_free_virt_device(xhci, udev->slot_id); | 2692 | xhci_free_virt_device(xhci, udev->slot_id); |
2684 | spin_unlock_irqrestore(&xhci->lock, flags); | 2693 | spin_unlock_irqrestore(&xhci->lock, flags); |
2685 | return; | 2694 | return; |
diff --git a/drivers/usb/musb/Kconfig b/drivers/usb/musb/Kconfig index 6192b45959f4..fc34b8b11910 100644 --- a/drivers/usb/musb/Kconfig +++ b/drivers/usb/musb/Kconfig | |||
@@ -3,9 +3,6 @@ | |||
3 | # for silicon based on Mentor Graphics INVENTRA designs | 3 | # for silicon based on Mentor Graphics INVENTRA designs |
4 | # | 4 | # |
5 | 5 | ||
6 | comment "Enable Host or Gadget support to see Inventra options" | ||
7 | depends on !USB && USB_GADGET=n | ||
8 | |||
9 | # (M)HDRC = (Multipoint) Highspeed Dual-Role Controller | 6 | # (M)HDRC = (Multipoint) Highspeed Dual-Role Controller |
10 | config USB_MUSB_HDRC | 7 | config USB_MUSB_HDRC |
11 | depends on USB && USB_GADGET | 8 | depends on USB && USB_GADGET |
diff --git a/drivers/usb/musb/musb_gadget.c b/drivers/usb/musb/musb_gadget.c index b67a062f556b..8c41a2e6ea77 100644 --- a/drivers/usb/musb/musb_gadget.c +++ b/drivers/usb/musb/musb_gadget.c | |||
@@ -1698,6 +1698,8 @@ static int musb_gadget_pullup(struct usb_gadget *gadget, int is_on) | |||
1698 | 1698 | ||
1699 | is_on = !!is_on; | 1699 | is_on = !!is_on; |
1700 | 1700 | ||
1701 | pm_runtime_get_sync(musb->controller); | ||
1702 | |||
1701 | /* NOTE: this assumes we are sensing vbus; we'd rather | 1703 | /* NOTE: this assumes we are sensing vbus; we'd rather |
1702 | * not pullup unless the B-session is active. | 1704 | * not pullup unless the B-session is active. |
1703 | */ | 1705 | */ |
@@ -1707,6 +1709,9 @@ static int musb_gadget_pullup(struct usb_gadget *gadget, int is_on) | |||
1707 | musb_pullup(musb, is_on); | 1709 | musb_pullup(musb, is_on); |
1708 | } | 1710 | } |
1709 | spin_unlock_irqrestore(&musb->lock, flags); | 1711 | spin_unlock_irqrestore(&musb->lock, flags); |
1712 | |||
1713 | pm_runtime_put(musb->controller); | ||
1714 | |||
1710 | return 0; | 1715 | return 0; |
1711 | } | 1716 | } |
1712 | 1717 | ||
diff --git a/drivers/usb/musb/tusb6010_omap.c b/drivers/usb/musb/tusb6010_omap.c index c784e6c03aac..07c8a73dfe41 100644 --- a/drivers/usb/musb/tusb6010_omap.c +++ b/drivers/usb/musb/tusb6010_omap.c | |||
@@ -89,7 +89,7 @@ static inline int tusb_omap_use_shared_dmareq(struct tusb_omap_dma_ch *chdat) | |||
89 | u32 reg = musb_readl(chdat->tbase, TUSB_DMA_EP_MAP); | 89 | u32 reg = musb_readl(chdat->tbase, TUSB_DMA_EP_MAP); |
90 | 90 | ||
91 | if (reg != 0) { | 91 | if (reg != 0) { |
92 | dev_dbg(musb->controller, "ep%i dmareq0 is busy for ep%i\n", | 92 | dev_dbg(chdat->musb->controller, "ep%i dmareq0 is busy for ep%i\n", |
93 | chdat->epnum, reg & 0xf); | 93 | chdat->epnum, reg & 0xf); |
94 | return -EAGAIN; | 94 | return -EAGAIN; |
95 | } | 95 | } |
diff --git a/drivers/usb/renesas_usbhs/mod_gadget.c b/drivers/usb/renesas_usbhs/mod_gadget.c index ba79dbf5adbc..cb2d451d511e 100644 --- a/drivers/usb/renesas_usbhs/mod_gadget.c +++ b/drivers/usb/renesas_usbhs/mod_gadget.c | |||
@@ -14,6 +14,7 @@ | |||
14 | * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA | 14 | * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
15 | * | 15 | * |
16 | */ | 16 | */ |
17 | #include <linux/dma-mapping.h> | ||
17 | #include <linux/io.h> | 18 | #include <linux/io.h> |
18 | #include <linux/module.h> | 19 | #include <linux/module.h> |
19 | #include <linux/platform_device.h> | 20 | #include <linux/platform_device.h> |
@@ -76,7 +77,7 @@ struct usbhsg_recip_handle { | |||
76 | struct usbhsg_gpriv, mod) | 77 | struct usbhsg_gpriv, mod) |
77 | 78 | ||
78 | #define __usbhsg_for_each_uep(start, pos, g, i) \ | 79 | #define __usbhsg_for_each_uep(start, pos, g, i) \ |
79 | for (i = start, pos = (g)->uep; \ | 80 | for (i = start, pos = (g)->uep + i; \ |
80 | i < (g)->uep_size; \ | 81 | i < (g)->uep_size; \ |
81 | i++, pos = (g)->uep + i) | 82 | i++, pos = (g)->uep + i) |
82 | 83 | ||
diff --git a/drivers/usb/serial/ftdi_sio.c b/drivers/usb/serial/ftdi_sio.c index 2e06b90aa1f8..78a2cf9551cc 100644 --- a/drivers/usb/serial/ftdi_sio.c +++ b/drivers/usb/serial/ftdi_sio.c | |||
@@ -151,6 +151,7 @@ static struct ftdi_sio_quirk ftdi_stmclite_quirk = { | |||
151 | * /sys/bus/usb/ftdi_sio/new_id, then send patch/report! | 151 | * /sys/bus/usb/ftdi_sio/new_id, then send patch/report! |
152 | */ | 152 | */ |
153 | static struct usb_device_id id_table_combined [] = { | 153 | static struct usb_device_id id_table_combined [] = { |
154 | { USB_DEVICE(FTDI_VID, FTDI_ZEITCONTROL_TAGTRACE_MIFARE_PID) }, | ||
154 | { USB_DEVICE(FTDI_VID, FTDI_CTI_MINI_PID) }, | 155 | { USB_DEVICE(FTDI_VID, FTDI_CTI_MINI_PID) }, |
155 | { USB_DEVICE(FTDI_VID, FTDI_CTI_NANO_PID) }, | 156 | { USB_DEVICE(FTDI_VID, FTDI_CTI_NANO_PID) }, |
156 | { USB_DEVICE(FTDI_VID, FTDI_AMC232_PID) }, | 157 | { USB_DEVICE(FTDI_VID, FTDI_AMC232_PID) }, |
@@ -1171,7 +1172,7 @@ static __u32 get_ftdi_divisor(struct tty_struct *tty, | |||
1171 | case FT2232H: /* FT2232H chip */ | 1172 | case FT2232H: /* FT2232H chip */ |
1172 | case FT4232H: /* FT4232H chip */ | 1173 | case FT4232H: /* FT4232H chip */ |
1173 | case FT232H: /* FT232H chip */ | 1174 | case FT232H: /* FT232H chip */ |
1174 | if ((baud <= 12000000) & (baud >= 1200)) { | 1175 | if ((baud <= 12000000) && (baud >= 1200)) { |
1175 | div_value = ftdi_2232h_baud_to_divisor(baud); | 1176 | div_value = ftdi_2232h_baud_to_divisor(baud); |
1176 | } else if (baud < 1200) { | 1177 | } else if (baud < 1200) { |
1177 | div_value = ftdi_232bm_baud_to_divisor(baud); | 1178 | div_value = ftdi_232bm_baud_to_divisor(baud); |
@@ -1205,7 +1206,10 @@ static int change_speed(struct tty_struct *tty, struct usb_serial_port *port) | |||
1205 | urb_index_value = get_ftdi_divisor(tty, port); | 1206 | urb_index_value = get_ftdi_divisor(tty, port); |
1206 | urb_value = (__u16)urb_index_value; | 1207 | urb_value = (__u16)urb_index_value; |
1207 | urb_index = (__u16)(urb_index_value >> 16); | 1208 | urb_index = (__u16)(urb_index_value >> 16); |
1208 | if (priv->interface) { /* FT2232C */ | 1209 | if ((priv->chip_type == FT2232C) || (priv->chip_type == FT2232H) || |
1210 | (priv->chip_type == FT4232H) || (priv->chip_type == FT232H)) { | ||
1211 | /* Probably the BM type needs the MSB of the encoded fractional | ||
1212 | * divider also moved like for the chips above. Any infos? */ | ||
1209 | urb_index = (__u16)((urb_index << 8) | priv->interface); | 1213 | urb_index = (__u16)((urb_index << 8) | priv->interface); |
1210 | } | 1214 | } |
1211 | 1215 | ||
diff --git a/drivers/usb/serial/ftdi_sio_ids.h b/drivers/usb/serial/ftdi_sio_ids.h index 19156d1049fe..bf5227ad3ef7 100644 --- a/drivers/usb/serial/ftdi_sio_ids.h +++ b/drivers/usb/serial/ftdi_sio_ids.h | |||
@@ -1159,4 +1159,8 @@ | |||
1159 | /* USB-Nano-485*/ | 1159 | /* USB-Nano-485*/ |
1160 | #define FTDI_CTI_NANO_PID 0xF60B | 1160 | #define FTDI_CTI_NANO_PID 0xF60B |
1161 | 1161 | ||
1162 | 1162 | /* | |
1163 | * ZeitControl cardsystems GmbH rfid-readers http://zeitconrol.de | ||
1164 | */ | ||
1165 | /* TagTracer MIFARE*/ | ||
1166 | #define FTDI_ZEITCONTROL_TAGTRACE_MIFARE_PID 0xF7C0 | ||
diff --git a/drivers/usb/serial/option.c b/drivers/usb/serial/option.c index 60b25d8ea0e2..815656198914 100644 --- a/drivers/usb/serial/option.c +++ b/drivers/usb/serial/option.c | |||
@@ -148,6 +148,10 @@ static void option_instat_callback(struct urb *urb); | |||
148 | #define HUAWEI_PRODUCT_K4505 0x1464 | 148 | #define HUAWEI_PRODUCT_K4505 0x1464 |
149 | #define HUAWEI_PRODUCT_K3765 0x1465 | 149 | #define HUAWEI_PRODUCT_K3765 0x1465 |
150 | #define HUAWEI_PRODUCT_E14AC 0x14AC | 150 | #define HUAWEI_PRODUCT_E14AC 0x14AC |
151 | #define HUAWEI_PRODUCT_K3770 0x14C9 | ||
152 | #define HUAWEI_PRODUCT_K3771 0x14CA | ||
153 | #define HUAWEI_PRODUCT_K4510 0x14CB | ||
154 | #define HUAWEI_PRODUCT_K4511 0x14CC | ||
151 | #define HUAWEI_PRODUCT_ETS1220 0x1803 | 155 | #define HUAWEI_PRODUCT_ETS1220 0x1803 |
152 | #define HUAWEI_PRODUCT_E353 0x1506 | 156 | #define HUAWEI_PRODUCT_E353 0x1506 |
153 | 157 | ||
@@ -547,6 +551,14 @@ static const struct usb_device_id option_ids[] = { | |||
547 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_K3765, 0xff, 0xff, 0xff) }, | 551 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_K3765, 0xff, 0xff, 0xff) }, |
548 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_ETS1220, 0xff, 0xff, 0xff) }, | 552 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_ETS1220, 0xff, 0xff, 0xff) }, |
549 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_E14AC, 0xff, 0xff, 0xff) }, | 553 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_E14AC, 0xff, 0xff, 0xff) }, |
554 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_K3770, 0xff, 0x02, 0x31) }, | ||
555 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_K3770, 0xff, 0x02, 0x32) }, | ||
556 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_K3771, 0xff, 0x02, 0x31) }, | ||
557 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_K3771, 0xff, 0x02, 0x32) }, | ||
558 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_K4510, 0xff, 0x01, 0x31) }, | ||
559 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_K4510, 0xff, 0x01, 0x32) }, | ||
560 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_K4511, 0xff, 0x01, 0x31) }, | ||
561 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_K4511, 0xff, 0x01, 0x32) }, | ||
550 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_E353, 0xff, 0x01, 0x01) }, | 562 | { USB_DEVICE_AND_INTERFACE_INFO(HUAWEI_VENDOR_ID, HUAWEI_PRODUCT_E353, 0xff, 0x01, 0x01) }, |
551 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_V640) }, | 563 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_V640) }, |
552 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_V620) }, | 564 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_V620) }, |
diff --git a/drivers/usb/serial/qcserial.c b/drivers/usb/serial/qcserial.c index 54a9dab1f33b..aeccc7f0a93c 100644 --- a/drivers/usb/serial/qcserial.c +++ b/drivers/usb/serial/qcserial.c | |||
@@ -45,6 +45,7 @@ static const struct usb_device_id id_table[] = { | |||
45 | {USB_DEVICE(0x05c6, 0x9203)}, /* Generic Gobi Modem device */ | 45 | {USB_DEVICE(0x05c6, 0x9203)}, /* Generic Gobi Modem device */ |
46 | {USB_DEVICE(0x05c6, 0x9222)}, /* Generic Gobi Modem device */ | 46 | {USB_DEVICE(0x05c6, 0x9222)}, /* Generic Gobi Modem device */ |
47 | {USB_DEVICE(0x05c6, 0x9008)}, /* Generic Gobi QDL device */ | 47 | {USB_DEVICE(0x05c6, 0x9008)}, /* Generic Gobi QDL device */ |
48 | {USB_DEVICE(0x05c6, 0x9009)}, /* Generic Gobi Modem device */ | ||
48 | {USB_DEVICE(0x05c6, 0x9201)}, /* Generic Gobi QDL device */ | 49 | {USB_DEVICE(0x05c6, 0x9201)}, /* Generic Gobi QDL device */ |
49 | {USB_DEVICE(0x05c6, 0x9221)}, /* Generic Gobi QDL device */ | 50 | {USB_DEVICE(0x05c6, 0x9221)}, /* Generic Gobi QDL device */ |
50 | {USB_DEVICE(0x05c6, 0x9231)}, /* Generic Gobi QDL device */ | 51 | {USB_DEVICE(0x05c6, 0x9231)}, /* Generic Gobi QDL device */ |
@@ -78,6 +79,7 @@ static const struct usb_device_id id_table[] = { | |||
78 | {USB_DEVICE(0x1199, 0x9008)}, /* Sierra Wireless Gobi 2000 Modem device (VT773) */ | 79 | {USB_DEVICE(0x1199, 0x9008)}, /* Sierra Wireless Gobi 2000 Modem device (VT773) */ |
79 | {USB_DEVICE(0x1199, 0x9009)}, /* Sierra Wireless Gobi 2000 Modem device (VT773) */ | 80 | {USB_DEVICE(0x1199, 0x9009)}, /* Sierra Wireless Gobi 2000 Modem device (VT773) */ |
80 | {USB_DEVICE(0x1199, 0x900a)}, /* Sierra Wireless Gobi 2000 Modem device (VT773) */ | 81 | {USB_DEVICE(0x1199, 0x900a)}, /* Sierra Wireless Gobi 2000 Modem device (VT773) */ |
82 | {USB_DEVICE(0x1199, 0x9011)}, /* Sierra Wireless Gobi 2000 Modem device (MC8305) */ | ||
81 | {USB_DEVICE(0x16d8, 0x8001)}, /* CMDTech Gobi 2000 QDL device (VU922) */ | 83 | {USB_DEVICE(0x16d8, 0x8001)}, /* CMDTech Gobi 2000 QDL device (VU922) */ |
82 | {USB_DEVICE(0x16d8, 0x8002)}, /* CMDTech Gobi 2000 Modem device (VU922) */ | 84 | {USB_DEVICE(0x16d8, 0x8002)}, /* CMDTech Gobi 2000 Modem device (VU922) */ |
83 | {USB_DEVICE(0x05c6, 0x9204)}, /* Gobi 2000 QDL device */ | 85 | {USB_DEVICE(0x05c6, 0x9204)}, /* Gobi 2000 QDL device */ |
diff --git a/drivers/usb/storage/unusual_devs.h b/drivers/usb/storage/unusual_devs.h index ccff3483eebc..3041a974faf3 100644 --- a/drivers/usb/storage/unusual_devs.h +++ b/drivers/usb/storage/unusual_devs.h | |||
@@ -1988,6 +1988,16 @@ UNUSUAL_DEV( 0x4146, 0xba01, 0x0100, 0x0100, | |||
1988 | "Micro Mini 1GB", | 1988 | "Micro Mini 1GB", |
1989 | USB_SC_DEVICE, USB_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ), | 1989 | USB_SC_DEVICE, USB_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ), |
1990 | 1990 | ||
1991 | /* | ||
1992 | * Nick Bowler <nbowler@elliptictech.com> | ||
1993 | * SCSI stack spams (otherwise harmless) error messages. | ||
1994 | */ | ||
1995 | UNUSUAL_DEV( 0xc251, 0x4003, 0x0100, 0x0100, | ||
1996 | "Keil Software, Inc.", | ||
1997 | "V2M MotherBoard", | ||
1998 | USB_SC_DEVICE, USB_PR_DEVICE, NULL, | ||
1999 | US_FL_NOT_LOCKABLE), | ||
2000 | |||
1991 | /* Reported by Andrew Simmons <andrew.simmons@gmail.com> */ | 2001 | /* Reported by Andrew Simmons <andrew.simmons@gmail.com> */ |
1992 | UNUSUAL_DEV( 0xed06, 0x4500, 0x0001, 0x0001, | 2002 | UNUSUAL_DEV( 0xed06, 0x4500, 0x0001, 0x0001, |
1993 | "DataStor", | 2003 | "DataStor", |
diff --git a/fs/autofs4/autofs_i.h b/fs/autofs4/autofs_i.h index 475f9c597cb7..326dc08d3e3f 100644 --- a/fs/autofs4/autofs_i.h +++ b/fs/autofs4/autofs_i.h | |||
@@ -39,27 +39,17 @@ | |||
39 | 39 | ||
40 | /* #define DEBUG */ | 40 | /* #define DEBUG */ |
41 | 41 | ||
42 | #ifdef DEBUG | 42 | #define DPRINTK(fmt, ...) \ |
43 | #define DPRINTK(fmt, args...) \ | 43 | pr_debug("pid %d: %s: " fmt "\n", \ |
44 | do { \ | 44 | current->pid, __func__, ##__VA_ARGS__) |
45 | printk(KERN_DEBUG "pid %d: %s: " fmt "\n", \ | 45 | |
46 | current->pid, __func__, ##args); \ | 46 | #define AUTOFS_WARN(fmt, ...) \ |
47 | } while (0) | ||
48 | #else | ||
49 | #define DPRINTK(fmt, args...) do {} while (0) | ||
50 | #endif | ||
51 | |||
52 | #define AUTOFS_WARN(fmt, args...) \ | ||
53 | do { \ | ||
54 | printk(KERN_WARNING "pid %d: %s: " fmt "\n", \ | 47 | printk(KERN_WARNING "pid %d: %s: " fmt "\n", \ |
55 | current->pid, __func__, ##args); \ | 48 | current->pid, __func__, ##__VA_ARGS__) |
56 | } while (0) | ||
57 | 49 | ||
58 | #define AUTOFS_ERROR(fmt, args...) \ | 50 | #define AUTOFS_ERROR(fmt, ...) \ |
59 | do { \ | ||
60 | printk(KERN_ERR "pid %d: %s: " fmt "\n", \ | 51 | printk(KERN_ERR "pid %d: %s: " fmt "\n", \ |
61 | current->pid, __func__, ##args); \ | 52 | current->pid, __func__, ##__VA_ARGS__) |
62 | } while (0) | ||
63 | 53 | ||
64 | /* Unified info structure. This is pointed to by both the dentry and | 54 | /* Unified info structure. This is pointed to by both the dentry and |
65 | inode structures. Each file in the filesystem has an instance of this | 55 | inode structures. Each file in the filesystem has an instance of this |
diff --git a/fs/autofs4/waitq.c b/fs/autofs4/waitq.c index 25435987d6ae..e1fbdeef85db 100644 --- a/fs/autofs4/waitq.c +++ b/fs/autofs4/waitq.c | |||
@@ -104,7 +104,7 @@ static void autofs4_notify_daemon(struct autofs_sb_info *sbi, | |||
104 | size_t pktsz; | 104 | size_t pktsz; |
105 | 105 | ||
106 | DPRINTK("wait id = 0x%08lx, name = %.*s, type=%d", | 106 | DPRINTK("wait id = 0x%08lx, name = %.*s, type=%d", |
107 | wq->wait_queue_token, wq->name.len, wq->name.name, type); | 107 | (unsigned long) wq->wait_queue_token, wq->name.len, wq->name.name, type); |
108 | 108 | ||
109 | memset(&pkt,0,sizeof pkt); /* For security reasons */ | 109 | memset(&pkt,0,sizeof pkt); /* For security reasons */ |
110 | 110 | ||
diff --git a/fs/ecryptfs/Kconfig b/fs/ecryptfs/Kconfig index 1cd6d9d3e29a..cc16562654de 100644 --- a/fs/ecryptfs/Kconfig +++ b/fs/ecryptfs/Kconfig | |||
@@ -1,6 +1,6 @@ | |||
1 | config ECRYPT_FS | 1 | config ECRYPT_FS |
2 | tristate "eCrypt filesystem layer support (EXPERIMENTAL)" | 2 | tristate "eCrypt filesystem layer support (EXPERIMENTAL)" |
3 | depends on EXPERIMENTAL && KEYS && CRYPTO | 3 | depends on EXPERIMENTAL && KEYS && CRYPTO && (ENCRYPTED_KEYS || ENCRYPTED_KEYS=n) |
4 | select CRYPTO_ECB | 4 | select CRYPTO_ECB |
5 | select CRYPTO_CBC | 5 | select CRYPTO_CBC |
6 | select CRYPTO_MD5 | 6 | select CRYPTO_MD5 |
diff --git a/fs/ecryptfs/keystore.c b/fs/ecryptfs/keystore.c index 08a2b52bf565..ac1ad48c2376 100644 --- a/fs/ecryptfs/keystore.c +++ b/fs/ecryptfs/keystore.c | |||
@@ -1973,7 +1973,7 @@ pki_encrypt_session_key(struct key *auth_tok_key, | |||
1973 | { | 1973 | { |
1974 | struct ecryptfs_msg_ctx *msg_ctx = NULL; | 1974 | struct ecryptfs_msg_ctx *msg_ctx = NULL; |
1975 | char *payload = NULL; | 1975 | char *payload = NULL; |
1976 | size_t payload_len; | 1976 | size_t payload_len = 0; |
1977 | struct ecryptfs_message *msg; | 1977 | struct ecryptfs_message *msg; |
1978 | int rc; | 1978 | int rc; |
1979 | 1979 | ||
diff --git a/fs/ecryptfs/main.c b/fs/ecryptfs/main.c index 9f1bb747d77d..b4a6befb1216 100644 --- a/fs/ecryptfs/main.c +++ b/fs/ecryptfs/main.c | |||
@@ -175,6 +175,7 @@ enum { ecryptfs_opt_sig, ecryptfs_opt_ecryptfs_sig, | |||
175 | ecryptfs_opt_encrypted_view, ecryptfs_opt_fnek_sig, | 175 | ecryptfs_opt_encrypted_view, ecryptfs_opt_fnek_sig, |
176 | ecryptfs_opt_fn_cipher, ecryptfs_opt_fn_cipher_key_bytes, | 176 | ecryptfs_opt_fn_cipher, ecryptfs_opt_fn_cipher_key_bytes, |
177 | ecryptfs_opt_unlink_sigs, ecryptfs_opt_mount_auth_tok_only, | 177 | ecryptfs_opt_unlink_sigs, ecryptfs_opt_mount_auth_tok_only, |
178 | ecryptfs_opt_check_dev_ruid, | ||
178 | ecryptfs_opt_err }; | 179 | ecryptfs_opt_err }; |
179 | 180 | ||
180 | static const match_table_t tokens = { | 181 | static const match_table_t tokens = { |
@@ -191,6 +192,7 @@ static const match_table_t tokens = { | |||
191 | {ecryptfs_opt_fn_cipher_key_bytes, "ecryptfs_fn_key_bytes=%u"}, | 192 | {ecryptfs_opt_fn_cipher_key_bytes, "ecryptfs_fn_key_bytes=%u"}, |
192 | {ecryptfs_opt_unlink_sigs, "ecryptfs_unlink_sigs"}, | 193 | {ecryptfs_opt_unlink_sigs, "ecryptfs_unlink_sigs"}, |
193 | {ecryptfs_opt_mount_auth_tok_only, "ecryptfs_mount_auth_tok_only"}, | 194 | {ecryptfs_opt_mount_auth_tok_only, "ecryptfs_mount_auth_tok_only"}, |
195 | {ecryptfs_opt_check_dev_ruid, "ecryptfs_check_dev_ruid"}, | ||
194 | {ecryptfs_opt_err, NULL} | 196 | {ecryptfs_opt_err, NULL} |
195 | }; | 197 | }; |
196 | 198 | ||
@@ -236,6 +238,7 @@ static void ecryptfs_init_mount_crypt_stat( | |||
236 | * ecryptfs_parse_options | 238 | * ecryptfs_parse_options |
237 | * @sb: The ecryptfs super block | 239 | * @sb: The ecryptfs super block |
238 | * @options: The options passed to the kernel | 240 | * @options: The options passed to the kernel |
241 | * @check_ruid: set to 1 if device uid should be checked against the ruid | ||
239 | * | 242 | * |
240 | * Parse mount options: | 243 | * Parse mount options: |
241 | * debug=N - ecryptfs_verbosity level for debug output | 244 | * debug=N - ecryptfs_verbosity level for debug output |
@@ -251,7 +254,8 @@ static void ecryptfs_init_mount_crypt_stat( | |||
251 | * | 254 | * |
252 | * Returns zero on success; non-zero on error | 255 | * Returns zero on success; non-zero on error |
253 | */ | 256 | */ |
254 | static int ecryptfs_parse_options(struct ecryptfs_sb_info *sbi, char *options) | 257 | static int ecryptfs_parse_options(struct ecryptfs_sb_info *sbi, char *options, |
258 | uid_t *check_ruid) | ||
255 | { | 259 | { |
256 | char *p; | 260 | char *p; |
257 | int rc = 0; | 261 | int rc = 0; |
@@ -276,6 +280,8 @@ static int ecryptfs_parse_options(struct ecryptfs_sb_info *sbi, char *options) | |||
276 | char *cipher_key_bytes_src; | 280 | char *cipher_key_bytes_src; |
277 | char *fn_cipher_key_bytes_src; | 281 | char *fn_cipher_key_bytes_src; |
278 | 282 | ||
283 | *check_ruid = 0; | ||
284 | |||
279 | if (!options) { | 285 | if (!options) { |
280 | rc = -EINVAL; | 286 | rc = -EINVAL; |
281 | goto out; | 287 | goto out; |
@@ -380,6 +386,9 @@ static int ecryptfs_parse_options(struct ecryptfs_sb_info *sbi, char *options) | |||
380 | mount_crypt_stat->flags |= | 386 | mount_crypt_stat->flags |= |
381 | ECRYPTFS_GLOBAL_MOUNT_AUTH_TOK_ONLY; | 387 | ECRYPTFS_GLOBAL_MOUNT_AUTH_TOK_ONLY; |
382 | break; | 388 | break; |
389 | case ecryptfs_opt_check_dev_ruid: | ||
390 | *check_ruid = 1; | ||
391 | break; | ||
383 | case ecryptfs_opt_err: | 392 | case ecryptfs_opt_err: |
384 | default: | 393 | default: |
385 | printk(KERN_WARNING | 394 | printk(KERN_WARNING |
@@ -475,6 +484,7 @@ static struct dentry *ecryptfs_mount(struct file_system_type *fs_type, int flags | |||
475 | const char *err = "Getting sb failed"; | 484 | const char *err = "Getting sb failed"; |
476 | struct inode *inode; | 485 | struct inode *inode; |
477 | struct path path; | 486 | struct path path; |
487 | uid_t check_ruid; | ||
478 | int rc; | 488 | int rc; |
479 | 489 | ||
480 | sbi = kmem_cache_zalloc(ecryptfs_sb_info_cache, GFP_KERNEL); | 490 | sbi = kmem_cache_zalloc(ecryptfs_sb_info_cache, GFP_KERNEL); |
@@ -483,7 +493,7 @@ static struct dentry *ecryptfs_mount(struct file_system_type *fs_type, int flags | |||
483 | goto out; | 493 | goto out; |
484 | } | 494 | } |
485 | 495 | ||
486 | rc = ecryptfs_parse_options(sbi, raw_data); | 496 | rc = ecryptfs_parse_options(sbi, raw_data, &check_ruid); |
487 | if (rc) { | 497 | if (rc) { |
488 | err = "Error parsing options"; | 498 | err = "Error parsing options"; |
489 | goto out; | 499 | goto out; |
@@ -521,6 +531,15 @@ static struct dentry *ecryptfs_mount(struct file_system_type *fs_type, int flags | |||
521 | "known incompatibilities\n"); | 531 | "known incompatibilities\n"); |
522 | goto out_free; | 532 | goto out_free; |
523 | } | 533 | } |
534 | |||
535 | if (check_ruid && path.dentry->d_inode->i_uid != current_uid()) { | ||
536 | rc = -EPERM; | ||
537 | printk(KERN_ERR "Mount of device (uid: %d) not owned by " | ||
538 | "requested user (uid: %d)\n", | ||
539 | path.dentry->d_inode->i_uid, current_uid()); | ||
540 | goto out_free; | ||
541 | } | ||
542 | |||
524 | ecryptfs_set_superblock_lower(s, path.dentry->d_sb); | 543 | ecryptfs_set_superblock_lower(s, path.dentry->d_sb); |
525 | s->s_maxbytes = path.dentry->d_sb->s_maxbytes; | 544 | s->s_maxbytes = path.dentry->d_sb->s_maxbytes; |
526 | s->s_blocksize = path.dentry->d_sb->s_blocksize; | 545 | s->s_blocksize = path.dentry->d_sb->s_blocksize; |
diff --git a/fs/ecryptfs/read_write.c b/fs/ecryptfs/read_write.c index 85d430963116..3745f7c2b9c2 100644 --- a/fs/ecryptfs/read_write.c +++ b/fs/ecryptfs/read_write.c | |||
@@ -39,15 +39,16 @@ | |||
39 | int ecryptfs_write_lower(struct inode *ecryptfs_inode, char *data, | 39 | int ecryptfs_write_lower(struct inode *ecryptfs_inode, char *data, |
40 | loff_t offset, size_t size) | 40 | loff_t offset, size_t size) |
41 | { | 41 | { |
42 | struct ecryptfs_inode_info *inode_info; | 42 | struct file *lower_file; |
43 | mm_segment_t fs_save; | 43 | mm_segment_t fs_save; |
44 | ssize_t rc; | 44 | ssize_t rc; |
45 | 45 | ||
46 | inode_info = ecryptfs_inode_to_private(ecryptfs_inode); | 46 | lower_file = ecryptfs_inode_to_private(ecryptfs_inode)->lower_file; |
47 | BUG_ON(!inode_info->lower_file); | 47 | if (!lower_file) |
48 | return -EIO; | ||
48 | fs_save = get_fs(); | 49 | fs_save = get_fs(); |
49 | set_fs(get_ds()); | 50 | set_fs(get_ds()); |
50 | rc = vfs_write(inode_info->lower_file, data, size, &offset); | 51 | rc = vfs_write(lower_file, data, size, &offset); |
51 | set_fs(fs_save); | 52 | set_fs(fs_save); |
52 | mark_inode_dirty_sync(ecryptfs_inode); | 53 | mark_inode_dirty_sync(ecryptfs_inode); |
53 | return rc; | 54 | return rc; |
@@ -225,15 +226,16 @@ out: | |||
225 | int ecryptfs_read_lower(char *data, loff_t offset, size_t size, | 226 | int ecryptfs_read_lower(char *data, loff_t offset, size_t size, |
226 | struct inode *ecryptfs_inode) | 227 | struct inode *ecryptfs_inode) |
227 | { | 228 | { |
228 | struct ecryptfs_inode_info *inode_info = | 229 | struct file *lower_file; |
229 | ecryptfs_inode_to_private(ecryptfs_inode); | ||
230 | mm_segment_t fs_save; | 230 | mm_segment_t fs_save; |
231 | ssize_t rc; | 231 | ssize_t rc; |
232 | 232 | ||
233 | BUG_ON(!inode_info->lower_file); | 233 | lower_file = ecryptfs_inode_to_private(ecryptfs_inode)->lower_file; |
234 | if (!lower_file) | ||
235 | return -EIO; | ||
234 | fs_save = get_fs(); | 236 | fs_save = get_fs(); |
235 | set_fs(get_ds()); | 237 | set_fs(get_ds()); |
236 | rc = vfs_read(inode_info->lower_file, data, size, &offset); | 238 | rc = vfs_read(lower_file, data, size, &offset); |
237 | set_fs(fs_save); | 239 | set_fs(fs_save); |
238 | return rc; | 240 | return rc; |
239 | } | 241 | } |
@@ -1459,6 +1459,23 @@ static int do_execve_common(const char *filename, | |||
1459 | struct files_struct *displaced; | 1459 | struct files_struct *displaced; |
1460 | bool clear_in_exec; | 1460 | bool clear_in_exec; |
1461 | int retval; | 1461 | int retval; |
1462 | const struct cred *cred = current_cred(); | ||
1463 | |||
1464 | /* | ||
1465 | * We move the actual failure in case of RLIMIT_NPROC excess from | ||
1466 | * set*uid() to execve() because too many poorly written programs | ||
1467 | * don't check setuid() return code. Here we additionally recheck | ||
1468 | * whether NPROC limit is still exceeded. | ||
1469 | */ | ||
1470 | if ((current->flags & PF_NPROC_EXCEEDED) && | ||
1471 | atomic_read(&cred->user->processes) > rlimit(RLIMIT_NPROC)) { | ||
1472 | retval = -EAGAIN; | ||
1473 | goto out_ret; | ||
1474 | } | ||
1475 | |||
1476 | /* We're below the limit (still or again), so we don't want to make | ||
1477 | * further execve() calls fail. */ | ||
1478 | current->flags &= ~PF_NPROC_EXCEEDED; | ||
1462 | 1479 | ||
1463 | retval = unshare_files(&displaced); | 1480 | retval = unshare_files(&displaced); |
1464 | if (retval) | 1481 | if (retval) |
diff --git a/fs/ext3/namei.c b/fs/ext3/namei.c index 6e18a0b7750d..5571708b6a58 100644 --- a/fs/ext3/namei.c +++ b/fs/ext3/namei.c | |||
@@ -2209,9 +2209,11 @@ static int ext3_symlink (struct inode * dir, | |||
2209 | /* | 2209 | /* |
2210 | * For non-fast symlinks, we just allocate inode and put it on | 2210 | * For non-fast symlinks, we just allocate inode and put it on |
2211 | * orphan list in the first transaction => we need bitmap, | 2211 | * orphan list in the first transaction => we need bitmap, |
2212 | * group descriptor, sb, inode block, quota blocks. | 2212 | * group descriptor, sb, inode block, quota blocks, and |
2213 | * possibly selinux xattr blocks. | ||
2213 | */ | 2214 | */ |
2214 | credits = 4 + EXT3_MAXQUOTAS_INIT_BLOCKS(dir->i_sb); | 2215 | credits = 4 + EXT3_MAXQUOTAS_INIT_BLOCKS(dir->i_sb) + |
2216 | EXT3_XATTR_TRANS_BLOCKS; | ||
2215 | } else { | 2217 | } else { |
2216 | /* | 2218 | /* |
2217 | * Fast symlink. We have to add entry to directory | 2219 | * Fast symlink. We have to add entry to directory |
diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c index 565a154e22d4..f8068c7bae9f 100644 --- a/fs/ext4/namei.c +++ b/fs/ext4/namei.c | |||
@@ -2253,9 +2253,11 @@ static int ext4_symlink(struct inode *dir, | |||
2253 | /* | 2253 | /* |
2254 | * For non-fast symlinks, we just allocate inode and put it on | 2254 | * For non-fast symlinks, we just allocate inode and put it on |
2255 | * orphan list in the first transaction => we need bitmap, | 2255 | * orphan list in the first transaction => we need bitmap, |
2256 | * group descriptor, sb, inode block, quota blocks. | 2256 | * group descriptor, sb, inode block, quota blocks, and |
2257 | * possibly selinux xattr blocks. | ||
2257 | */ | 2258 | */ |
2258 | credits = 4 + EXT4_MAXQUOTAS_INIT_BLOCKS(dir->i_sb); | 2259 | credits = 4 + EXT4_MAXQUOTAS_INIT_BLOCKS(dir->i_sb) + |
2260 | EXT4_XATTR_TRANS_BLOCKS; | ||
2259 | } else { | 2261 | } else { |
2260 | /* | 2262 | /* |
2261 | * Fast symlink. We have to add entry to directory | 2263 | * Fast symlink. We have to add entry to directory |
diff --git a/fs/nfs/Kconfig b/fs/nfs/Kconfig index be020771c6b4..dbcd82126aed 100644 --- a/fs/nfs/Kconfig +++ b/fs/nfs/Kconfig | |||
@@ -79,12 +79,9 @@ config NFS_V4_1 | |||
79 | depends on NFS_FS && NFS_V4 && EXPERIMENTAL | 79 | depends on NFS_FS && NFS_V4 && EXPERIMENTAL |
80 | select SUNRPC_BACKCHANNEL | 80 | select SUNRPC_BACKCHANNEL |
81 | select PNFS_FILE_LAYOUT | 81 | select PNFS_FILE_LAYOUT |
82 | select PNFS_BLOCK | ||
83 | select MD | ||
84 | select BLK_DEV_DM | ||
85 | help | 82 | help |
86 | This option enables support for minor version 1 of the NFSv4 protocol | 83 | This option enables support for minor version 1 of the NFSv4 protocol |
87 | (RFC 5661 and RFC 5663) in the kernel's NFS client. | 84 | (RFC 5661) in the kernel's NFS client. |
88 | 85 | ||
89 | If unsure, say N. | 86 | If unsure, say N. |
90 | 87 | ||
@@ -93,16 +90,13 @@ config PNFS_FILE_LAYOUT | |||
93 | 90 | ||
94 | config PNFS_BLOCK | 91 | config PNFS_BLOCK |
95 | tristate | 92 | tristate |
93 | depends on NFS_FS && NFS_V4_1 && BLK_DEV_DM | ||
94 | default m | ||
96 | 95 | ||
97 | config PNFS_OBJLAYOUT | 96 | config PNFS_OBJLAYOUT |
98 | tristate "Provide support for the pNFS Objects Layout Driver for NFSv4.1 pNFS (EXPERIMENTAL)" | 97 | tristate |
99 | depends on NFS_FS && NFS_V4_1 && SCSI_OSD_ULD | 98 | depends on NFS_FS && NFS_V4_1 && SCSI_OSD_ULD |
100 | help | 99 | default m |
101 | Say M here if you want your pNFS client to support the Objects Layout Driver. | ||
102 | Requires the SCSI osd initiator library (SCSI_OSD_INITIATOR) and | ||
103 | upper level driver (SCSI_OSD_ULD). | ||
104 | |||
105 | If unsure, say N. | ||
106 | 100 | ||
107 | config ROOT_NFS | 101 | config ROOT_NFS |
108 | bool "Root file system on NFS" | 102 | bool "Root file system on NFS" |
diff --git a/fs/xfs/linux-2.6/xfs_buf.c b/fs/xfs/linux-2.6/xfs_buf.c index d1fe74506c4c..c57836dc778f 100644 --- a/fs/xfs/linux-2.6/xfs_buf.c +++ b/fs/xfs/linux-2.6/xfs_buf.c | |||
@@ -596,7 +596,7 @@ _xfs_buf_read( | |||
596 | bp->b_flags |= flags & (XBF_READ | XBF_ASYNC | XBF_READ_AHEAD); | 596 | bp->b_flags |= flags & (XBF_READ | XBF_ASYNC | XBF_READ_AHEAD); |
597 | 597 | ||
598 | status = xfs_buf_iorequest(bp); | 598 | status = xfs_buf_iorequest(bp); |
599 | if (status || XFS_BUF_ISERROR(bp) || (flags & XBF_ASYNC)) | 599 | if (status || bp->b_error || (flags & XBF_ASYNC)) |
600 | return status; | 600 | return status; |
601 | return xfs_buf_iowait(bp); | 601 | return xfs_buf_iowait(bp); |
602 | } | 602 | } |
@@ -679,7 +679,6 @@ xfs_buf_read_uncached( | |||
679 | /* set up the buffer for a read IO */ | 679 | /* set up the buffer for a read IO */ |
680 | XFS_BUF_SET_ADDR(bp, daddr); | 680 | XFS_BUF_SET_ADDR(bp, daddr); |
681 | XFS_BUF_READ(bp); | 681 | XFS_BUF_READ(bp); |
682 | XFS_BUF_BUSY(bp); | ||
683 | 682 | ||
684 | xfsbdstrat(mp, bp); | 683 | xfsbdstrat(mp, bp); |
685 | error = xfs_buf_iowait(bp); | 684 | error = xfs_buf_iowait(bp); |
@@ -1069,7 +1068,7 @@ xfs_bioerror( | |||
1069 | /* | 1068 | /* |
1070 | * No need to wait until the buffer is unpinned, we aren't flushing it. | 1069 | * No need to wait until the buffer is unpinned, we aren't flushing it. |
1071 | */ | 1070 | */ |
1072 | XFS_BUF_ERROR(bp, EIO); | 1071 | xfs_buf_ioerror(bp, EIO); |
1073 | 1072 | ||
1074 | /* | 1073 | /* |
1075 | * We're calling xfs_buf_ioend, so delete XBF_DONE flag. | 1074 | * We're calling xfs_buf_ioend, so delete XBF_DONE flag. |
@@ -1094,7 +1093,7 @@ STATIC int | |||
1094 | xfs_bioerror_relse( | 1093 | xfs_bioerror_relse( |
1095 | struct xfs_buf *bp) | 1094 | struct xfs_buf *bp) |
1096 | { | 1095 | { |
1097 | int64_t fl = XFS_BUF_BFLAGS(bp); | 1096 | int64_t fl = bp->b_flags; |
1098 | /* | 1097 | /* |
1099 | * No need to wait until the buffer is unpinned. | 1098 | * No need to wait until the buffer is unpinned. |
1100 | * We aren't flushing it. | 1099 | * We aren't flushing it. |
@@ -1115,7 +1114,7 @@ xfs_bioerror_relse( | |||
1115 | * There's no reason to mark error for | 1114 | * There's no reason to mark error for |
1116 | * ASYNC buffers. | 1115 | * ASYNC buffers. |
1117 | */ | 1116 | */ |
1118 | XFS_BUF_ERROR(bp, EIO); | 1117 | xfs_buf_ioerror(bp, EIO); |
1119 | XFS_BUF_FINISH_IOWAIT(bp); | 1118 | XFS_BUF_FINISH_IOWAIT(bp); |
1120 | } else { | 1119 | } else { |
1121 | xfs_buf_relse(bp); | 1120 | xfs_buf_relse(bp); |
@@ -1324,7 +1323,7 @@ xfs_buf_offset( | |||
1324 | struct page *page; | 1323 | struct page *page; |
1325 | 1324 | ||
1326 | if (bp->b_flags & XBF_MAPPED) | 1325 | if (bp->b_flags & XBF_MAPPED) |
1327 | return XFS_BUF_PTR(bp) + offset; | 1326 | return bp->b_addr + offset; |
1328 | 1327 | ||
1329 | offset += bp->b_offset; | 1328 | offset += bp->b_offset; |
1330 | page = bp->b_pages[offset >> PAGE_SHIFT]; | 1329 | page = bp->b_pages[offset >> PAGE_SHIFT]; |
@@ -1484,7 +1483,7 @@ xfs_setsize_buftarg_flags( | |||
1484 | if (set_blocksize(btp->bt_bdev, sectorsize)) { | 1483 | if (set_blocksize(btp->bt_bdev, sectorsize)) { |
1485 | xfs_warn(btp->bt_mount, | 1484 | xfs_warn(btp->bt_mount, |
1486 | "Cannot set_blocksize to %u on device %s\n", | 1485 | "Cannot set_blocksize to %u on device %s\n", |
1487 | sectorsize, XFS_BUFTARG_NAME(btp)); | 1486 | sectorsize, xfs_buf_target_name(btp)); |
1488 | return EINVAL; | 1487 | return EINVAL; |
1489 | } | 1488 | } |
1490 | 1489 | ||
@@ -1681,7 +1680,7 @@ xfs_buf_delwri_split( | |||
1681 | list_for_each_entry_safe(bp, n, dwq, b_list) { | 1680 | list_for_each_entry_safe(bp, n, dwq, b_list) { |
1682 | ASSERT(bp->b_flags & XBF_DELWRI); | 1681 | ASSERT(bp->b_flags & XBF_DELWRI); |
1683 | 1682 | ||
1684 | if (!XFS_BUF_ISPINNED(bp) && xfs_buf_trylock(bp)) { | 1683 | if (!xfs_buf_ispinned(bp) && xfs_buf_trylock(bp)) { |
1685 | if (!force && | 1684 | if (!force && |
1686 | time_before(jiffies, bp->b_queuetime + age)) { | 1685 | time_before(jiffies, bp->b_queuetime + age)) { |
1687 | xfs_buf_unlock(bp); | 1686 | xfs_buf_unlock(bp); |
diff --git a/fs/xfs/linux-2.6/xfs_buf.h b/fs/xfs/linux-2.6/xfs_buf.h index 6a83b46b4bcf..620972b8094d 100644 --- a/fs/xfs/linux-2.6/xfs_buf.h +++ b/fs/xfs/linux-2.6/xfs_buf.h | |||
@@ -228,11 +228,15 @@ extern void xfs_buf_delwri_promote(xfs_buf_t *); | |||
228 | extern int xfs_buf_init(void); | 228 | extern int xfs_buf_init(void); |
229 | extern void xfs_buf_terminate(void); | 229 | extern void xfs_buf_terminate(void); |
230 | 230 | ||
231 | #define xfs_buf_target_name(target) \ | 231 | static inline const char * |
232 | ({ char __b[BDEVNAME_SIZE]; bdevname((target)->bt_bdev, __b); __b; }) | 232 | xfs_buf_target_name(struct xfs_buftarg *target) |
233 | { | ||
234 | static char __b[BDEVNAME_SIZE]; | ||
235 | |||
236 | return bdevname(target->bt_bdev, __b); | ||
237 | } | ||
233 | 238 | ||
234 | 239 | ||
235 | #define XFS_BUF_BFLAGS(bp) ((bp)->b_flags) | ||
236 | #define XFS_BUF_ZEROFLAGS(bp) \ | 240 | #define XFS_BUF_ZEROFLAGS(bp) \ |
237 | ((bp)->b_flags &= ~(XBF_READ|XBF_WRITE|XBF_ASYNC|XBF_DELWRI| \ | 241 | ((bp)->b_flags &= ~(XBF_READ|XBF_WRITE|XBF_ASYNC|XBF_DELWRI| \ |
238 | XBF_SYNCIO|XBF_FUA|XBF_FLUSH)) | 242 | XBF_SYNCIO|XBF_FUA|XBF_FLUSH)) |
@@ -251,23 +255,14 @@ void xfs_buf_stale(struct xfs_buf *bp); | |||
251 | #define XFS_BUF_UNDELAYWRITE(bp) xfs_buf_delwri_dequeue(bp) | 255 | #define XFS_BUF_UNDELAYWRITE(bp) xfs_buf_delwri_dequeue(bp) |
252 | #define XFS_BUF_ISDELAYWRITE(bp) ((bp)->b_flags & XBF_DELWRI) | 256 | #define XFS_BUF_ISDELAYWRITE(bp) ((bp)->b_flags & XBF_DELWRI) |
253 | 257 | ||
254 | #define XFS_BUF_ERROR(bp,no) xfs_buf_ioerror(bp,no) | ||
255 | #define XFS_BUF_GETERROR(bp) xfs_buf_geterror(bp) | ||
256 | #define XFS_BUF_ISERROR(bp) (xfs_buf_geterror(bp) ? 1 : 0) | ||
257 | |||
258 | #define XFS_BUF_DONE(bp) ((bp)->b_flags |= XBF_DONE) | 258 | #define XFS_BUF_DONE(bp) ((bp)->b_flags |= XBF_DONE) |
259 | #define XFS_BUF_UNDONE(bp) ((bp)->b_flags &= ~XBF_DONE) | 259 | #define XFS_BUF_UNDONE(bp) ((bp)->b_flags &= ~XBF_DONE) |
260 | #define XFS_BUF_ISDONE(bp) ((bp)->b_flags & XBF_DONE) | 260 | #define XFS_BUF_ISDONE(bp) ((bp)->b_flags & XBF_DONE) |
261 | 261 | ||
262 | #define XFS_BUF_BUSY(bp) do { } while (0) | ||
263 | #define XFS_BUF_UNBUSY(bp) do { } while (0) | ||
264 | #define XFS_BUF_ISBUSY(bp) (1) | ||
265 | |||
266 | #define XFS_BUF_ASYNC(bp) ((bp)->b_flags |= XBF_ASYNC) | 262 | #define XFS_BUF_ASYNC(bp) ((bp)->b_flags |= XBF_ASYNC) |
267 | #define XFS_BUF_UNASYNC(bp) ((bp)->b_flags &= ~XBF_ASYNC) | 263 | #define XFS_BUF_UNASYNC(bp) ((bp)->b_flags &= ~XBF_ASYNC) |
268 | #define XFS_BUF_ISASYNC(bp) ((bp)->b_flags & XBF_ASYNC) | 264 | #define XFS_BUF_ISASYNC(bp) ((bp)->b_flags & XBF_ASYNC) |
269 | 265 | ||
270 | #define XFS_BUF_HOLD(bp) xfs_buf_hold(bp) | ||
271 | #define XFS_BUF_READ(bp) ((bp)->b_flags |= XBF_READ) | 266 | #define XFS_BUF_READ(bp) ((bp)->b_flags |= XBF_READ) |
272 | #define XFS_BUF_UNREAD(bp) ((bp)->b_flags &= ~XBF_READ) | 267 | #define XFS_BUF_UNREAD(bp) ((bp)->b_flags &= ~XBF_READ) |
273 | #define XFS_BUF_ISREAD(bp) ((bp)->b_flags & XBF_READ) | 268 | #define XFS_BUF_ISREAD(bp) ((bp)->b_flags & XBF_READ) |
@@ -276,10 +271,6 @@ void xfs_buf_stale(struct xfs_buf *bp); | |||
276 | #define XFS_BUF_UNWRITE(bp) ((bp)->b_flags &= ~XBF_WRITE) | 271 | #define XFS_BUF_UNWRITE(bp) ((bp)->b_flags &= ~XBF_WRITE) |
277 | #define XFS_BUF_ISWRITE(bp) ((bp)->b_flags & XBF_WRITE) | 272 | #define XFS_BUF_ISWRITE(bp) ((bp)->b_flags & XBF_WRITE) |
278 | 273 | ||
279 | #define XFS_BUF_SET_START(bp) do { } while (0) | ||
280 | |||
281 | #define XFS_BUF_PTR(bp) (xfs_caddr_t)((bp)->b_addr) | ||
282 | #define XFS_BUF_SET_PTR(bp, val, cnt) xfs_buf_associate_memory(bp, val, cnt) | ||
283 | #define XFS_BUF_ADDR(bp) ((bp)->b_bn) | 274 | #define XFS_BUF_ADDR(bp) ((bp)->b_bn) |
284 | #define XFS_BUF_SET_ADDR(bp, bno) ((bp)->b_bn = (xfs_daddr_t)(bno)) | 275 | #define XFS_BUF_SET_ADDR(bp, bno) ((bp)->b_bn = (xfs_daddr_t)(bno)) |
285 | #define XFS_BUF_OFFSET(bp) ((bp)->b_file_offset) | 276 | #define XFS_BUF_OFFSET(bp) ((bp)->b_file_offset) |
@@ -299,14 +290,13 @@ xfs_buf_set_ref( | |||
299 | #define XFS_BUF_SET_VTYPE_REF(bp, type, ref) xfs_buf_set_ref(bp, ref) | 290 | #define XFS_BUF_SET_VTYPE_REF(bp, type, ref) xfs_buf_set_ref(bp, ref) |
300 | #define XFS_BUF_SET_VTYPE(bp, type) do { } while (0) | 291 | #define XFS_BUF_SET_VTYPE(bp, type) do { } while (0) |
301 | 292 | ||
302 | #define XFS_BUF_ISPINNED(bp) atomic_read(&((bp)->b_pin_count)) | 293 | static inline int xfs_buf_ispinned(struct xfs_buf *bp) |
294 | { | ||
295 | return atomic_read(&bp->b_pin_count); | ||
296 | } | ||
303 | 297 | ||
304 | #define XFS_BUF_FINISH_IOWAIT(bp) complete(&bp->b_iowait); | 298 | #define XFS_BUF_FINISH_IOWAIT(bp) complete(&bp->b_iowait); |
305 | 299 | ||
306 | #define XFS_BUF_SET_TARGET(bp, target) ((bp)->b_target = (target)) | ||
307 | #define XFS_BUF_TARGET(bp) ((bp)->b_target) | ||
308 | #define XFS_BUFTARG_NAME(target) xfs_buf_target_name(target) | ||
309 | |||
310 | static inline void xfs_buf_relse(xfs_buf_t *bp) | 300 | static inline void xfs_buf_relse(xfs_buf_t *bp) |
311 | { | 301 | { |
312 | xfs_buf_unlock(bp); | 302 | xfs_buf_unlock(bp); |
diff --git a/fs/xfs/linux-2.6/xfs_sync.c b/fs/xfs/linux-2.6/xfs_sync.c index e4c938afb910..4604f90f86a3 100644 --- a/fs/xfs/linux-2.6/xfs_sync.c +++ b/fs/xfs/linux-2.6/xfs_sync.c | |||
@@ -332,7 +332,7 @@ xfs_sync_fsdata( | |||
332 | * between there and here. | 332 | * between there and here. |
333 | */ | 333 | */ |
334 | bp = xfs_getsb(mp, 0); | 334 | bp = xfs_getsb(mp, 0); |
335 | if (XFS_BUF_ISPINNED(bp)) | 335 | if (xfs_buf_ispinned(bp)) |
336 | xfs_log_force(mp, 0); | 336 | xfs_log_force(mp, 0); |
337 | 337 | ||
338 | return xfs_bwrite(mp, bp); | 338 | return xfs_bwrite(mp, bp); |
diff --git a/fs/xfs/quota/xfs_dquot.c b/fs/xfs/quota/xfs_dquot.c index 837f31158d43..db62959bed13 100644 --- a/fs/xfs/quota/xfs_dquot.c +++ b/fs/xfs/quota/xfs_dquot.c | |||
@@ -318,10 +318,9 @@ xfs_qm_init_dquot_blk( | |||
318 | int curid, i; | 318 | int curid, i; |
319 | 319 | ||
320 | ASSERT(tp); | 320 | ASSERT(tp); |
321 | ASSERT(XFS_BUF_ISBUSY(bp)); | ||
322 | ASSERT(xfs_buf_islocked(bp)); | 321 | ASSERT(xfs_buf_islocked(bp)); |
323 | 322 | ||
324 | d = (xfs_dqblk_t *)XFS_BUF_PTR(bp); | 323 | d = bp->b_addr; |
325 | 324 | ||
326 | /* | 325 | /* |
327 | * ID of the first dquot in the block - id's are zero based. | 326 | * ID of the first dquot in the block - id's are zero based. |
@@ -403,7 +402,7 @@ xfs_qm_dqalloc( | |||
403 | dqp->q_blkno, | 402 | dqp->q_blkno, |
404 | mp->m_quotainfo->qi_dqchunklen, | 403 | mp->m_quotainfo->qi_dqchunklen, |
405 | 0); | 404 | 0); |
406 | if (!bp || (error = XFS_BUF_GETERROR(bp))) | 405 | if (!bp || (error = xfs_buf_geterror(bp))) |
407 | goto error1; | 406 | goto error1; |
408 | /* | 407 | /* |
409 | * Make a chunk of dquots out of this buffer and log | 408 | * Make a chunk of dquots out of this buffer and log |
@@ -534,13 +533,12 @@ xfs_qm_dqtobp( | |||
534 | return XFS_ERROR(error); | 533 | return XFS_ERROR(error); |
535 | } | 534 | } |
536 | 535 | ||
537 | ASSERT(XFS_BUF_ISBUSY(bp)); | ||
538 | ASSERT(xfs_buf_islocked(bp)); | 536 | ASSERT(xfs_buf_islocked(bp)); |
539 | 537 | ||
540 | /* | 538 | /* |
541 | * calculate the location of the dquot inside the buffer. | 539 | * calculate the location of the dquot inside the buffer. |
542 | */ | 540 | */ |
543 | ddq = (struct xfs_disk_dquot *)(XFS_BUF_PTR(bp) + dqp->q_bufoffset); | 541 | ddq = bp->b_addr + dqp->q_bufoffset; |
544 | 542 | ||
545 | /* | 543 | /* |
546 | * A simple sanity check in case we got a corrupted dquot... | 544 | * A simple sanity check in case we got a corrupted dquot... |
@@ -553,7 +551,6 @@ xfs_qm_dqtobp( | |||
553 | xfs_trans_brelse(tp, bp); | 551 | xfs_trans_brelse(tp, bp); |
554 | return XFS_ERROR(EIO); | 552 | return XFS_ERROR(EIO); |
555 | } | 553 | } |
556 | XFS_BUF_BUSY(bp); /* We dirtied this */ | ||
557 | } | 554 | } |
558 | 555 | ||
559 | *O_bpp = bp; | 556 | *O_bpp = bp; |
@@ -622,7 +619,6 @@ xfs_qm_dqread( | |||
622 | * this particular dquot was repaired. We still aren't afraid to | 619 | * this particular dquot was repaired. We still aren't afraid to |
623 | * brelse it because we have the changes incore. | 620 | * brelse it because we have the changes incore. |
624 | */ | 621 | */ |
625 | ASSERT(XFS_BUF_ISBUSY(bp)); | ||
626 | ASSERT(xfs_buf_islocked(bp)); | 622 | ASSERT(xfs_buf_islocked(bp)); |
627 | xfs_trans_brelse(tp, bp); | 623 | xfs_trans_brelse(tp, bp); |
628 | 624 | ||
@@ -1204,7 +1200,7 @@ xfs_qm_dqflush( | |||
1204 | /* | 1200 | /* |
1205 | * Calculate the location of the dquot inside the buffer. | 1201 | * Calculate the location of the dquot inside the buffer. |
1206 | */ | 1202 | */ |
1207 | ddqp = (struct xfs_disk_dquot *)(XFS_BUF_PTR(bp) + dqp->q_bufoffset); | 1203 | ddqp = bp->b_addr + dqp->q_bufoffset; |
1208 | 1204 | ||
1209 | /* | 1205 | /* |
1210 | * A simple sanity check in case we got a corrupted dquot.. | 1206 | * A simple sanity check in case we got a corrupted dquot.. |
@@ -1240,7 +1236,7 @@ xfs_qm_dqflush( | |||
1240 | * If the buffer is pinned then push on the log so we won't | 1236 | * If the buffer is pinned then push on the log so we won't |
1241 | * get stuck waiting in the write for too long. | 1237 | * get stuck waiting in the write for too long. |
1242 | */ | 1238 | */ |
1243 | if (XFS_BUF_ISPINNED(bp)) { | 1239 | if (xfs_buf_ispinned(bp)) { |
1244 | trace_xfs_dqflush_force(dqp); | 1240 | trace_xfs_dqflush_force(dqp); |
1245 | xfs_log_force(mp, 0); | 1241 | xfs_log_force(mp, 0); |
1246 | } | 1242 | } |
@@ -1447,7 +1443,7 @@ xfs_qm_dqflock_pushbuf_wait( | |||
1447 | goto out_lock; | 1443 | goto out_lock; |
1448 | 1444 | ||
1449 | if (XFS_BUF_ISDELAYWRITE(bp)) { | 1445 | if (XFS_BUF_ISDELAYWRITE(bp)) { |
1450 | if (XFS_BUF_ISPINNED(bp)) | 1446 | if (xfs_buf_ispinned(bp)) |
1451 | xfs_log_force(mp, 0); | 1447 | xfs_log_force(mp, 0); |
1452 | xfs_buf_delwri_promote(bp); | 1448 | xfs_buf_delwri_promote(bp); |
1453 | wake_up_process(bp->b_target->bt_task); | 1449 | wake_up_process(bp->b_target->bt_task); |
diff --git a/fs/xfs/quota/xfs_qm.c b/fs/xfs/quota/xfs_qm.c index 46e54ad9a2dc..9a0aa76facdf 100644 --- a/fs/xfs/quota/xfs_qm.c +++ b/fs/xfs/quota/xfs_qm.c | |||
@@ -1240,7 +1240,7 @@ xfs_qm_reset_dqcounts( | |||
1240 | do_div(j, sizeof(xfs_dqblk_t)); | 1240 | do_div(j, sizeof(xfs_dqblk_t)); |
1241 | ASSERT(mp->m_quotainfo->qi_dqperchunk == j); | 1241 | ASSERT(mp->m_quotainfo->qi_dqperchunk == j); |
1242 | #endif | 1242 | #endif |
1243 | ddq = (xfs_disk_dquot_t *)XFS_BUF_PTR(bp); | 1243 | ddq = bp->b_addr; |
1244 | for (j = 0; j < mp->m_quotainfo->qi_dqperchunk; j++) { | 1244 | for (j = 0; j < mp->m_quotainfo->qi_dqperchunk; j++) { |
1245 | /* | 1245 | /* |
1246 | * Do a sanity check, and if needed, repair the dqblk. Don't | 1246 | * Do a sanity check, and if needed, repair the dqblk. Don't |
diff --git a/fs/xfs/xfs_ag.h b/fs/xfs/xfs_ag.h index 6530769a999b..4805f009f923 100644 --- a/fs/xfs/xfs_ag.h +++ b/fs/xfs/xfs_ag.h | |||
@@ -103,7 +103,7 @@ typedef struct xfs_agf { | |||
103 | /* disk block (xfs_daddr_t) in the AG */ | 103 | /* disk block (xfs_daddr_t) in the AG */ |
104 | #define XFS_AGF_DADDR(mp) ((xfs_daddr_t)(1 << (mp)->m_sectbb_log)) | 104 | #define XFS_AGF_DADDR(mp) ((xfs_daddr_t)(1 << (mp)->m_sectbb_log)) |
105 | #define XFS_AGF_BLOCK(mp) XFS_HDR_BLOCK(mp, XFS_AGF_DADDR(mp)) | 105 | #define XFS_AGF_BLOCK(mp) XFS_HDR_BLOCK(mp, XFS_AGF_DADDR(mp)) |
106 | #define XFS_BUF_TO_AGF(bp) ((xfs_agf_t *)XFS_BUF_PTR(bp)) | 106 | #define XFS_BUF_TO_AGF(bp) ((xfs_agf_t *)((bp)->b_addr)) |
107 | 107 | ||
108 | extern int xfs_read_agf(struct xfs_mount *mp, struct xfs_trans *tp, | 108 | extern int xfs_read_agf(struct xfs_mount *mp, struct xfs_trans *tp, |
109 | xfs_agnumber_t agno, int flags, struct xfs_buf **bpp); | 109 | xfs_agnumber_t agno, int flags, struct xfs_buf **bpp); |
@@ -156,7 +156,7 @@ typedef struct xfs_agi { | |||
156 | /* disk block (xfs_daddr_t) in the AG */ | 156 | /* disk block (xfs_daddr_t) in the AG */ |
157 | #define XFS_AGI_DADDR(mp) ((xfs_daddr_t)(2 << (mp)->m_sectbb_log)) | 157 | #define XFS_AGI_DADDR(mp) ((xfs_daddr_t)(2 << (mp)->m_sectbb_log)) |
158 | #define XFS_AGI_BLOCK(mp) XFS_HDR_BLOCK(mp, XFS_AGI_DADDR(mp)) | 158 | #define XFS_AGI_BLOCK(mp) XFS_HDR_BLOCK(mp, XFS_AGI_DADDR(mp)) |
159 | #define XFS_BUF_TO_AGI(bp) ((xfs_agi_t *)XFS_BUF_PTR(bp)) | 159 | #define XFS_BUF_TO_AGI(bp) ((xfs_agi_t *)((bp)->b_addr)) |
160 | 160 | ||
161 | extern int xfs_read_agi(struct xfs_mount *mp, struct xfs_trans *tp, | 161 | extern int xfs_read_agi(struct xfs_mount *mp, struct xfs_trans *tp, |
162 | xfs_agnumber_t agno, struct xfs_buf **bpp); | 162 | xfs_agnumber_t agno, struct xfs_buf **bpp); |
@@ -168,7 +168,7 @@ extern int xfs_read_agi(struct xfs_mount *mp, struct xfs_trans *tp, | |||
168 | #define XFS_AGFL_DADDR(mp) ((xfs_daddr_t)(3 << (mp)->m_sectbb_log)) | 168 | #define XFS_AGFL_DADDR(mp) ((xfs_daddr_t)(3 << (mp)->m_sectbb_log)) |
169 | #define XFS_AGFL_BLOCK(mp) XFS_HDR_BLOCK(mp, XFS_AGFL_DADDR(mp)) | 169 | #define XFS_AGFL_BLOCK(mp) XFS_HDR_BLOCK(mp, XFS_AGFL_DADDR(mp)) |
170 | #define XFS_AGFL_SIZE(mp) ((mp)->m_sb.sb_sectsize / sizeof(xfs_agblock_t)) | 170 | #define XFS_AGFL_SIZE(mp) ((mp)->m_sb.sb_sectsize / sizeof(xfs_agblock_t)) |
171 | #define XFS_BUF_TO_AGFL(bp) ((xfs_agfl_t *)XFS_BUF_PTR(bp)) | 171 | #define XFS_BUF_TO_AGFL(bp) ((xfs_agfl_t *)((bp)->b_addr)) |
172 | 172 | ||
173 | typedef struct xfs_agfl { | 173 | typedef struct xfs_agfl { |
174 | __be32 agfl_bno[1]; /* actually XFS_AGFL_SIZE(mp) */ | 174 | __be32 agfl_bno[1]; /* actually XFS_AGFL_SIZE(mp) */ |
diff --git a/fs/xfs/xfs_alloc.c b/fs/xfs/xfs_alloc.c index 1e00b3ef6274..bdd9cb54d63b 100644 --- a/fs/xfs/xfs_alloc.c +++ b/fs/xfs/xfs_alloc.c | |||
@@ -451,8 +451,7 @@ xfs_alloc_read_agfl( | |||
451 | XFS_FSS_TO_BB(mp, 1), 0, &bp); | 451 | XFS_FSS_TO_BB(mp, 1), 0, &bp); |
452 | if (error) | 452 | if (error) |
453 | return error; | 453 | return error; |
454 | ASSERT(bp); | 454 | ASSERT(!xfs_buf_geterror(bp)); |
455 | ASSERT(!XFS_BUF_GETERROR(bp)); | ||
456 | XFS_BUF_SET_VTYPE_REF(bp, B_FS_AGFL, XFS_AGFL_REF); | 455 | XFS_BUF_SET_VTYPE_REF(bp, B_FS_AGFL, XFS_AGFL_REF); |
457 | *bpp = bp; | 456 | *bpp = bp; |
458 | return 0; | 457 | return 0; |
@@ -2116,7 +2115,7 @@ xfs_read_agf( | |||
2116 | if (!*bpp) | 2115 | if (!*bpp) |
2117 | return 0; | 2116 | return 0; |
2118 | 2117 | ||
2119 | ASSERT(!XFS_BUF_GETERROR(*bpp)); | 2118 | ASSERT(!(*bpp)->b_error); |
2120 | agf = XFS_BUF_TO_AGF(*bpp); | 2119 | agf = XFS_BUF_TO_AGF(*bpp); |
2121 | 2120 | ||
2122 | /* | 2121 | /* |
@@ -2168,7 +2167,7 @@ xfs_alloc_read_agf( | |||
2168 | return error; | 2167 | return error; |
2169 | if (!*bpp) | 2168 | if (!*bpp) |
2170 | return 0; | 2169 | return 0; |
2171 | ASSERT(!XFS_BUF_GETERROR(*bpp)); | 2170 | ASSERT(!(*bpp)->b_error); |
2172 | 2171 | ||
2173 | agf = XFS_BUF_TO_AGF(*bpp); | 2172 | agf = XFS_BUF_TO_AGF(*bpp); |
2174 | pag = xfs_perag_get(mp, agno); | 2173 | pag = xfs_perag_get(mp, agno); |
diff --git a/fs/xfs/xfs_attr.c b/fs/xfs/xfs_attr.c index cbae424fe1ba..160bcdc34a6e 100644 --- a/fs/xfs/xfs_attr.c +++ b/fs/xfs/xfs_attr.c | |||
@@ -2121,8 +2121,7 @@ xfs_attr_rmtval_set(xfs_da_args_t *args) | |||
2121 | 2121 | ||
2122 | bp = xfs_buf_get(mp->m_ddev_targp, dblkno, blkcnt, | 2122 | bp = xfs_buf_get(mp->m_ddev_targp, dblkno, blkcnt, |
2123 | XBF_LOCK | XBF_DONT_BLOCK); | 2123 | XBF_LOCK | XBF_DONT_BLOCK); |
2124 | ASSERT(bp); | 2124 | ASSERT(!xfs_buf_geterror(bp)); |
2125 | ASSERT(!XFS_BUF_GETERROR(bp)); | ||
2126 | 2125 | ||
2127 | tmp = (valuelen < XFS_BUF_SIZE(bp)) ? valuelen : | 2126 | tmp = (valuelen < XFS_BUF_SIZE(bp)) ? valuelen : |
2128 | XFS_BUF_SIZE(bp); | 2127 | XFS_BUF_SIZE(bp); |
diff --git a/fs/xfs/xfs_bmap.c b/fs/xfs/xfs_bmap.c index ab3e5c6c4642..452a291383ab 100644 --- a/fs/xfs/xfs_bmap.c +++ b/fs/xfs/xfs_bmap.c | |||
@@ -3383,8 +3383,7 @@ xfs_bmap_local_to_extents( | |||
3383 | ASSERT(args.len == 1); | 3383 | ASSERT(args.len == 1); |
3384 | *firstblock = args.fsbno; | 3384 | *firstblock = args.fsbno; |
3385 | bp = xfs_btree_get_bufl(args.mp, tp, args.fsbno, 0); | 3385 | bp = xfs_btree_get_bufl(args.mp, tp, args.fsbno, 0); |
3386 | memcpy((char *)XFS_BUF_PTR(bp), ifp->if_u1.if_data, | 3386 | memcpy(bp->b_addr, ifp->if_u1.if_data, ifp->if_bytes); |
3387 | ifp->if_bytes); | ||
3388 | xfs_trans_log_buf(tp, bp, 0, ifp->if_bytes - 1); | 3387 | xfs_trans_log_buf(tp, bp, 0, ifp->if_bytes - 1); |
3389 | xfs_bmap_forkoff_reset(args.mp, ip, whichfork); | 3388 | xfs_bmap_forkoff_reset(args.mp, ip, whichfork); |
3390 | xfs_idata_realloc(ip, -ifp->if_bytes, whichfork); | 3389 | xfs_idata_realloc(ip, -ifp->if_bytes, whichfork); |
diff --git a/fs/xfs/xfs_btree.c b/fs/xfs/xfs_btree.c index cabf4b5604aa..2b9fd385e27d 100644 --- a/fs/xfs/xfs_btree.c +++ b/fs/xfs/xfs_btree.c | |||
@@ -275,8 +275,7 @@ xfs_btree_dup_cursor( | |||
275 | return error; | 275 | return error; |
276 | } | 276 | } |
277 | new->bc_bufs[i] = bp; | 277 | new->bc_bufs[i] = bp; |
278 | ASSERT(bp); | 278 | ASSERT(!xfs_buf_geterror(bp)); |
279 | ASSERT(!XFS_BUF_GETERROR(bp)); | ||
280 | } else | 279 | } else |
281 | new->bc_bufs[i] = NULL; | 280 | new->bc_bufs[i] = NULL; |
282 | } | 281 | } |
@@ -467,8 +466,7 @@ xfs_btree_get_bufl( | |||
467 | ASSERT(fsbno != NULLFSBLOCK); | 466 | ASSERT(fsbno != NULLFSBLOCK); |
468 | d = XFS_FSB_TO_DADDR(mp, fsbno); | 467 | d = XFS_FSB_TO_DADDR(mp, fsbno); |
469 | bp = xfs_trans_get_buf(tp, mp->m_ddev_targp, d, mp->m_bsize, lock); | 468 | bp = xfs_trans_get_buf(tp, mp->m_ddev_targp, d, mp->m_bsize, lock); |
470 | ASSERT(bp); | 469 | ASSERT(!xfs_buf_geterror(bp)); |
471 | ASSERT(!XFS_BUF_GETERROR(bp)); | ||
472 | return bp; | 470 | return bp; |
473 | } | 471 | } |
474 | 472 | ||
@@ -491,8 +489,7 @@ xfs_btree_get_bufs( | |||
491 | ASSERT(agbno != NULLAGBLOCK); | 489 | ASSERT(agbno != NULLAGBLOCK); |
492 | d = XFS_AGB_TO_DADDR(mp, agno, agbno); | 490 | d = XFS_AGB_TO_DADDR(mp, agno, agbno); |
493 | bp = xfs_trans_get_buf(tp, mp->m_ddev_targp, d, mp->m_bsize, lock); | 491 | bp = xfs_trans_get_buf(tp, mp->m_ddev_targp, d, mp->m_bsize, lock); |
494 | ASSERT(bp); | 492 | ASSERT(!xfs_buf_geterror(bp)); |
495 | ASSERT(!XFS_BUF_GETERROR(bp)); | ||
496 | return bp; | 493 | return bp; |
497 | } | 494 | } |
498 | 495 | ||
@@ -632,7 +629,7 @@ xfs_btree_read_bufl( | |||
632 | mp->m_bsize, lock, &bp))) { | 629 | mp->m_bsize, lock, &bp))) { |
633 | return error; | 630 | return error; |
634 | } | 631 | } |
635 | ASSERT(!bp || !XFS_BUF_GETERROR(bp)); | 632 | ASSERT(!xfs_buf_geterror(bp)); |
636 | if (bp) | 633 | if (bp) |
637 | XFS_BUF_SET_VTYPE_REF(bp, B_FS_MAP, refval); | 634 | XFS_BUF_SET_VTYPE_REF(bp, B_FS_MAP, refval); |
638 | *bpp = bp; | 635 | *bpp = bp; |
@@ -973,8 +970,7 @@ xfs_btree_get_buf_block( | |||
973 | *bpp = xfs_trans_get_buf(cur->bc_tp, mp->m_ddev_targp, d, | 970 | *bpp = xfs_trans_get_buf(cur->bc_tp, mp->m_ddev_targp, d, |
974 | mp->m_bsize, flags); | 971 | mp->m_bsize, flags); |
975 | 972 | ||
976 | ASSERT(*bpp); | 973 | ASSERT(!xfs_buf_geterror(*bpp)); |
977 | ASSERT(!XFS_BUF_GETERROR(*bpp)); | ||
978 | 974 | ||
979 | *block = XFS_BUF_TO_BLOCK(*bpp); | 975 | *block = XFS_BUF_TO_BLOCK(*bpp); |
980 | return 0; | 976 | return 0; |
@@ -1006,8 +1002,7 @@ xfs_btree_read_buf_block( | |||
1006 | if (error) | 1002 | if (error) |
1007 | return error; | 1003 | return error; |
1008 | 1004 | ||
1009 | ASSERT(*bpp != NULL); | 1005 | ASSERT(!xfs_buf_geterror(*bpp)); |
1010 | ASSERT(!XFS_BUF_GETERROR(*bpp)); | ||
1011 | 1006 | ||
1012 | xfs_btree_set_refs(cur, *bpp); | 1007 | xfs_btree_set_refs(cur, *bpp); |
1013 | *block = XFS_BUF_TO_BLOCK(*bpp); | 1008 | *block = XFS_BUF_TO_BLOCK(*bpp); |
diff --git a/fs/xfs/xfs_btree.h b/fs/xfs/xfs_btree.h index 8d05a6a46ce3..5b240de104c0 100644 --- a/fs/xfs/xfs_btree.h +++ b/fs/xfs/xfs_btree.h | |||
@@ -262,7 +262,7 @@ typedef struct xfs_btree_cur | |||
262 | /* | 262 | /* |
263 | * Convert from buffer to btree block header. | 263 | * Convert from buffer to btree block header. |
264 | */ | 264 | */ |
265 | #define XFS_BUF_TO_BLOCK(bp) ((struct xfs_btree_block *)XFS_BUF_PTR(bp)) | 265 | #define XFS_BUF_TO_BLOCK(bp) ((struct xfs_btree_block *)((bp)->b_addr)) |
266 | 266 | ||
267 | 267 | ||
268 | /* | 268 | /* |
diff --git a/fs/xfs/xfs_buf_item.c b/fs/xfs/xfs_buf_item.c index 88492916c3dc..cac2ecfa6746 100644 --- a/fs/xfs/xfs_buf_item.c +++ b/fs/xfs/xfs_buf_item.c | |||
@@ -124,9 +124,9 @@ xfs_buf_item_log_check( | |||
124 | 124 | ||
125 | bp = bip->bli_buf; | 125 | bp = bip->bli_buf; |
126 | ASSERT(XFS_BUF_COUNT(bp) > 0); | 126 | ASSERT(XFS_BUF_COUNT(bp) > 0); |
127 | ASSERT(XFS_BUF_PTR(bp) != NULL); | 127 | ASSERT(bp->b_addr != NULL); |
128 | orig = bip->bli_orig; | 128 | orig = bip->bli_orig; |
129 | buffer = XFS_BUF_PTR(bp); | 129 | buffer = bp->b_addr; |
130 | for (x = 0; x < XFS_BUF_COUNT(bp); x++) { | 130 | for (x = 0; x < XFS_BUF_COUNT(bp); x++) { |
131 | if (orig[x] != buffer[x] && !btst(bip->bli_logged, x)) { | 131 | if (orig[x] != buffer[x] && !btst(bip->bli_logged, x)) { |
132 | xfs_emerg(bp->b_mount, | 132 | xfs_emerg(bp->b_mount, |
@@ -371,7 +371,6 @@ xfs_buf_item_pin( | |||
371 | { | 371 | { |
372 | struct xfs_buf_log_item *bip = BUF_ITEM(lip); | 372 | struct xfs_buf_log_item *bip = BUF_ITEM(lip); |
373 | 373 | ||
374 | ASSERT(XFS_BUF_ISBUSY(bip->bli_buf)); | ||
375 | ASSERT(atomic_read(&bip->bli_refcount) > 0); | 374 | ASSERT(atomic_read(&bip->bli_refcount) > 0); |
376 | ASSERT((bip->bli_flags & XFS_BLI_LOGGED) || | 375 | ASSERT((bip->bli_flags & XFS_BLI_LOGGED) || |
377 | (bip->bli_flags & XFS_BLI_STALE)); | 376 | (bip->bli_flags & XFS_BLI_STALE)); |
@@ -479,13 +478,13 @@ xfs_buf_item_trylock( | |||
479 | struct xfs_buf_log_item *bip = BUF_ITEM(lip); | 478 | struct xfs_buf_log_item *bip = BUF_ITEM(lip); |
480 | struct xfs_buf *bp = bip->bli_buf; | 479 | struct xfs_buf *bp = bip->bli_buf; |
481 | 480 | ||
482 | if (XFS_BUF_ISPINNED(bp)) | 481 | if (xfs_buf_ispinned(bp)) |
483 | return XFS_ITEM_PINNED; | 482 | return XFS_ITEM_PINNED; |
484 | if (!xfs_buf_trylock(bp)) | 483 | if (!xfs_buf_trylock(bp)) |
485 | return XFS_ITEM_LOCKED; | 484 | return XFS_ITEM_LOCKED; |
486 | 485 | ||
487 | /* take a reference to the buffer. */ | 486 | /* take a reference to the buffer. */ |
488 | XFS_BUF_HOLD(bp); | 487 | xfs_buf_hold(bp); |
489 | 488 | ||
490 | ASSERT(!(bip->bli_flags & XFS_BLI_STALE)); | 489 | ASSERT(!(bip->bli_flags & XFS_BLI_STALE)); |
491 | trace_xfs_buf_item_trylock(bip); | 490 | trace_xfs_buf_item_trylock(bip); |
@@ -726,7 +725,7 @@ xfs_buf_item_init( | |||
726 | * to have logged. | 725 | * to have logged. |
727 | */ | 726 | */ |
728 | bip->bli_orig = (char *)kmem_alloc(XFS_BUF_COUNT(bp), KM_SLEEP); | 727 | bip->bli_orig = (char *)kmem_alloc(XFS_BUF_COUNT(bp), KM_SLEEP); |
729 | memcpy(bip->bli_orig, XFS_BUF_PTR(bp), XFS_BUF_COUNT(bp)); | 728 | memcpy(bip->bli_orig, bp->b_addr, XFS_BUF_COUNT(bp)); |
730 | bip->bli_logged = (char *)kmem_zalloc(XFS_BUF_COUNT(bp) / NBBY, KM_SLEEP); | 729 | bip->bli_logged = (char *)kmem_zalloc(XFS_BUF_COUNT(bp) / NBBY, KM_SLEEP); |
731 | #endif | 730 | #endif |
732 | 731 | ||
@@ -895,7 +894,6 @@ xfs_buf_attach_iodone( | |||
895 | { | 894 | { |
896 | xfs_log_item_t *head_lip; | 895 | xfs_log_item_t *head_lip; |
897 | 896 | ||
898 | ASSERT(XFS_BUF_ISBUSY(bp)); | ||
899 | ASSERT(xfs_buf_islocked(bp)); | 897 | ASSERT(xfs_buf_islocked(bp)); |
900 | 898 | ||
901 | lip->li_cb = cb; | 899 | lip->li_cb = cb; |
@@ -960,7 +958,7 @@ xfs_buf_iodone_callbacks( | |||
960 | static ulong lasttime; | 958 | static ulong lasttime; |
961 | static xfs_buftarg_t *lasttarg; | 959 | static xfs_buftarg_t *lasttarg; |
962 | 960 | ||
963 | if (likely(!XFS_BUF_GETERROR(bp))) | 961 | if (likely(!xfs_buf_geterror(bp))) |
964 | goto do_callbacks; | 962 | goto do_callbacks; |
965 | 963 | ||
966 | /* | 964 | /* |
@@ -973,14 +971,14 @@ xfs_buf_iodone_callbacks( | |||
973 | goto do_callbacks; | 971 | goto do_callbacks; |
974 | } | 972 | } |
975 | 973 | ||
976 | if (XFS_BUF_TARGET(bp) != lasttarg || | 974 | if (bp->b_target != lasttarg || |
977 | time_after(jiffies, (lasttime + 5*HZ))) { | 975 | time_after(jiffies, (lasttime + 5*HZ))) { |
978 | lasttime = jiffies; | 976 | lasttime = jiffies; |
979 | xfs_alert(mp, "Device %s: metadata write error block 0x%llx", | 977 | xfs_alert(mp, "Device %s: metadata write error block 0x%llx", |
980 | XFS_BUFTARG_NAME(XFS_BUF_TARGET(bp)), | 978 | xfs_buf_target_name(bp->b_target), |
981 | (__uint64_t)XFS_BUF_ADDR(bp)); | 979 | (__uint64_t)XFS_BUF_ADDR(bp)); |
982 | } | 980 | } |
983 | lasttarg = XFS_BUF_TARGET(bp); | 981 | lasttarg = bp->b_target; |
984 | 982 | ||
985 | /* | 983 | /* |
986 | * If the write was asynchronous then no one will be looking for the | 984 | * If the write was asynchronous then no one will be looking for the |
@@ -991,12 +989,11 @@ xfs_buf_iodone_callbacks( | |||
991 | * around. | 989 | * around. |
992 | */ | 990 | */ |
993 | if (XFS_BUF_ISASYNC(bp)) { | 991 | if (XFS_BUF_ISASYNC(bp)) { |
994 | XFS_BUF_ERROR(bp, 0); /* errno of 0 unsets the flag */ | 992 | xfs_buf_ioerror(bp, 0); /* errno of 0 unsets the flag */ |
995 | 993 | ||
996 | if (!XFS_BUF_ISSTALE(bp)) { | 994 | if (!XFS_BUF_ISSTALE(bp)) { |
997 | XFS_BUF_DELAYWRITE(bp); | 995 | XFS_BUF_DELAYWRITE(bp); |
998 | XFS_BUF_DONE(bp); | 996 | XFS_BUF_DONE(bp); |
999 | XFS_BUF_SET_START(bp); | ||
1000 | } | 997 | } |
1001 | ASSERT(bp->b_iodone != NULL); | 998 | ASSERT(bp->b_iodone != NULL); |
1002 | trace_xfs_buf_item_iodone_async(bp, _RET_IP_); | 999 | trace_xfs_buf_item_iodone_async(bp, _RET_IP_); |
@@ -1013,7 +1010,6 @@ xfs_buf_iodone_callbacks( | |||
1013 | XFS_BUF_UNDELAYWRITE(bp); | 1010 | XFS_BUF_UNDELAYWRITE(bp); |
1014 | 1011 | ||
1015 | trace_xfs_buf_error_relse(bp, _RET_IP_); | 1012 | trace_xfs_buf_error_relse(bp, _RET_IP_); |
1016 | xfs_force_shutdown(mp, SHUTDOWN_META_IO_ERROR); | ||
1017 | 1013 | ||
1018 | do_callbacks: | 1014 | do_callbacks: |
1019 | xfs_buf_do_callbacks(bp); | 1015 | xfs_buf_do_callbacks(bp); |
diff --git a/fs/xfs/xfs_da_btree.c b/fs/xfs/xfs_da_btree.c index 5bfcb8779f9f..ee9d5427fcd4 100644 --- a/fs/xfs/xfs_da_btree.c +++ b/fs/xfs/xfs_da_btree.c | |||
@@ -2050,7 +2050,7 @@ xfs_da_do_buf( | |||
2050 | case 0: | 2050 | case 0: |
2051 | bp = xfs_trans_get_buf(trans, mp->m_ddev_targp, | 2051 | bp = xfs_trans_get_buf(trans, mp->m_ddev_targp, |
2052 | mappedbno, nmapped, 0); | 2052 | mappedbno, nmapped, 0); |
2053 | error = bp ? XFS_BUF_GETERROR(bp) : XFS_ERROR(EIO); | 2053 | error = bp ? bp->b_error : XFS_ERROR(EIO); |
2054 | break; | 2054 | break; |
2055 | case 1: | 2055 | case 1: |
2056 | case 2: | 2056 | case 2: |
@@ -2268,7 +2268,7 @@ xfs_da_buf_make(int nbuf, xfs_buf_t **bps) | |||
2268 | dabuf->nbuf = 1; | 2268 | dabuf->nbuf = 1; |
2269 | bp = bps[0]; | 2269 | bp = bps[0]; |
2270 | dabuf->bbcount = (short)BTOBB(XFS_BUF_COUNT(bp)); | 2270 | dabuf->bbcount = (short)BTOBB(XFS_BUF_COUNT(bp)); |
2271 | dabuf->data = XFS_BUF_PTR(bp); | 2271 | dabuf->data = bp->b_addr; |
2272 | dabuf->bps[0] = bp; | 2272 | dabuf->bps[0] = bp; |
2273 | } else { | 2273 | } else { |
2274 | dabuf->nbuf = nbuf; | 2274 | dabuf->nbuf = nbuf; |
@@ -2279,7 +2279,7 @@ xfs_da_buf_make(int nbuf, xfs_buf_t **bps) | |||
2279 | dabuf->data = kmem_alloc(BBTOB(dabuf->bbcount), KM_SLEEP); | 2279 | dabuf->data = kmem_alloc(BBTOB(dabuf->bbcount), KM_SLEEP); |
2280 | for (i = off = 0; i < nbuf; i++, off += XFS_BUF_COUNT(bp)) { | 2280 | for (i = off = 0; i < nbuf; i++, off += XFS_BUF_COUNT(bp)) { |
2281 | bp = bps[i]; | 2281 | bp = bps[i]; |
2282 | memcpy((char *)dabuf->data + off, XFS_BUF_PTR(bp), | 2282 | memcpy((char *)dabuf->data + off, bp->b_addr, |
2283 | XFS_BUF_COUNT(bp)); | 2283 | XFS_BUF_COUNT(bp)); |
2284 | } | 2284 | } |
2285 | } | 2285 | } |
@@ -2302,8 +2302,8 @@ xfs_da_buf_clean(xfs_dabuf_t *dabuf) | |||
2302 | for (i = off = 0; i < dabuf->nbuf; | 2302 | for (i = off = 0; i < dabuf->nbuf; |
2303 | i++, off += XFS_BUF_COUNT(bp)) { | 2303 | i++, off += XFS_BUF_COUNT(bp)) { |
2304 | bp = dabuf->bps[i]; | 2304 | bp = dabuf->bps[i]; |
2305 | memcpy(XFS_BUF_PTR(bp), (char *)dabuf->data + off, | 2305 | memcpy(bp->b_addr, dabuf->data + off, |
2306 | XFS_BUF_COUNT(bp)); | 2306 | XFS_BUF_COUNT(bp)); |
2307 | } | 2307 | } |
2308 | } | 2308 | } |
2309 | } | 2309 | } |
@@ -2340,7 +2340,7 @@ xfs_da_log_buf(xfs_trans_t *tp, xfs_dabuf_t *dabuf, uint first, uint last) | |||
2340 | 2340 | ||
2341 | ASSERT(dabuf->nbuf && dabuf->data && dabuf->bbcount && dabuf->bps[0]); | 2341 | ASSERT(dabuf->nbuf && dabuf->data && dabuf->bbcount && dabuf->bps[0]); |
2342 | if (dabuf->nbuf == 1) { | 2342 | if (dabuf->nbuf == 1) { |
2343 | ASSERT(dabuf->data == (void *)XFS_BUF_PTR(dabuf->bps[0])); | 2343 | ASSERT(dabuf->data == dabuf->bps[0]->b_addr); |
2344 | xfs_trans_log_buf(tp, dabuf->bps[0], first, last); | 2344 | xfs_trans_log_buf(tp, dabuf->bps[0], first, last); |
2345 | return; | 2345 | return; |
2346 | } | 2346 | } |
diff --git a/fs/xfs/xfs_dinode.h b/fs/xfs/xfs_dinode.h index dffba9ba0db6..a3721633abc8 100644 --- a/fs/xfs/xfs_dinode.h +++ b/fs/xfs/xfs_dinode.h | |||
@@ -148,7 +148,7 @@ typedef enum xfs_dinode_fmt { | |||
148 | be32_to_cpu((dip)->di_nextents) : \ | 148 | be32_to_cpu((dip)->di_nextents) : \ |
149 | be16_to_cpu((dip)->di_anextents)) | 149 | be16_to_cpu((dip)->di_anextents)) |
150 | 150 | ||
151 | #define XFS_BUF_TO_DINODE(bp) ((xfs_dinode_t *)XFS_BUF_PTR(bp)) | 151 | #define XFS_BUF_TO_DINODE(bp) ((xfs_dinode_t *)((bp)->b_addr)) |
152 | 152 | ||
153 | /* | 153 | /* |
154 | * For block and character special files the 32bit dev_t is stored at the | 154 | * For block and character special files the 32bit dev_t is stored at the |
diff --git a/fs/xfs/xfs_ialloc.c b/fs/xfs/xfs_ialloc.c index dd5628bd8d0b..9f24ec28283b 100644 --- a/fs/xfs/xfs_ialloc.c +++ b/fs/xfs/xfs_ialloc.c | |||
@@ -202,8 +202,7 @@ xfs_ialloc_inode_init( | |||
202 | fbuf = xfs_trans_get_buf(tp, mp->m_ddev_targp, d, | 202 | fbuf = xfs_trans_get_buf(tp, mp->m_ddev_targp, d, |
203 | mp->m_bsize * blks_per_cluster, | 203 | mp->m_bsize * blks_per_cluster, |
204 | XBF_LOCK); | 204 | XBF_LOCK); |
205 | ASSERT(fbuf); | 205 | ASSERT(!xfs_buf_geterror(fbuf)); |
206 | ASSERT(!XFS_BUF_GETERROR(fbuf)); | ||
207 | 206 | ||
208 | /* | 207 | /* |
209 | * Initialize all inodes in this buffer and then log them. | 208 | * Initialize all inodes in this buffer and then log them. |
@@ -1486,7 +1485,7 @@ xfs_read_agi( | |||
1486 | if (error) | 1485 | if (error) |
1487 | return error; | 1486 | return error; |
1488 | 1487 | ||
1489 | ASSERT(*bpp && !XFS_BUF_GETERROR(*bpp)); | 1488 | ASSERT(!xfs_buf_geterror(*bpp)); |
1490 | agi = XFS_BUF_TO_AGI(*bpp); | 1489 | agi = XFS_BUF_TO_AGI(*bpp); |
1491 | 1490 | ||
1492 | /* | 1491 | /* |
diff --git a/fs/xfs/xfs_inode.c b/fs/xfs/xfs_inode.c index 2fcca4b03ed3..0239a7c7c886 100644 --- a/fs/xfs/xfs_inode.c +++ b/fs/xfs/xfs_inode.c | |||
@@ -2473,7 +2473,7 @@ cluster_corrupt_out: | |||
2473 | if (bp->b_iodone) { | 2473 | if (bp->b_iodone) { |
2474 | XFS_BUF_UNDONE(bp); | 2474 | XFS_BUF_UNDONE(bp); |
2475 | XFS_BUF_STALE(bp); | 2475 | XFS_BUF_STALE(bp); |
2476 | XFS_BUF_ERROR(bp,EIO); | 2476 | xfs_buf_ioerror(bp, EIO); |
2477 | xfs_buf_ioend(bp, 0); | 2477 | xfs_buf_ioend(bp, 0); |
2478 | } else { | 2478 | } else { |
2479 | XFS_BUF_STALE(bp); | 2479 | XFS_BUF_STALE(bp); |
@@ -2585,7 +2585,7 @@ xfs_iflush( | |||
2585 | * If the buffer is pinned then push on the log now so we won't | 2585 | * If the buffer is pinned then push on the log now so we won't |
2586 | * get stuck waiting in the write for too long. | 2586 | * get stuck waiting in the write for too long. |
2587 | */ | 2587 | */ |
2588 | if (XFS_BUF_ISPINNED(bp)) | 2588 | if (xfs_buf_ispinned(bp)) |
2589 | xfs_log_force(mp, 0); | 2589 | xfs_log_force(mp, 0); |
2590 | 2590 | ||
2591 | /* | 2591 | /* |
diff --git a/fs/xfs/xfs_log.c b/fs/xfs/xfs_log.c index 06ff8437ed8e..3a8d4f66d702 100644 --- a/fs/xfs/xfs_log.c +++ b/fs/xfs/xfs_log.c | |||
@@ -878,7 +878,7 @@ xlog_iodone(xfs_buf_t *bp) | |||
878 | /* | 878 | /* |
879 | * Race to shutdown the filesystem if we see an error. | 879 | * Race to shutdown the filesystem if we see an error. |
880 | */ | 880 | */ |
881 | if (XFS_TEST_ERROR((XFS_BUF_GETERROR(bp)), l->l_mp, | 881 | if (XFS_TEST_ERROR((xfs_buf_geterror(bp)), l->l_mp, |
882 | XFS_ERRTAG_IODONE_IOERR, XFS_RANDOM_IODONE_IOERR)) { | 882 | XFS_ERRTAG_IODONE_IOERR, XFS_RANDOM_IODONE_IOERR)) { |
883 | xfs_ioerror_alert("xlog_iodone", l->l_mp, bp, XFS_BUF_ADDR(bp)); | 883 | xfs_ioerror_alert("xlog_iodone", l->l_mp, bp, XFS_BUF_ADDR(bp)); |
884 | XFS_BUF_STALE(bp); | 884 | XFS_BUF_STALE(bp); |
@@ -1051,7 +1051,6 @@ xlog_alloc_log(xfs_mount_t *mp, | |||
1051 | if (!bp) | 1051 | if (!bp) |
1052 | goto out_free_log; | 1052 | goto out_free_log; |
1053 | bp->b_iodone = xlog_iodone; | 1053 | bp->b_iodone = xlog_iodone; |
1054 | ASSERT(XFS_BUF_ISBUSY(bp)); | ||
1055 | ASSERT(xfs_buf_islocked(bp)); | 1054 | ASSERT(xfs_buf_islocked(bp)); |
1056 | log->l_xbuf = bp; | 1055 | log->l_xbuf = bp; |
1057 | 1056 | ||
@@ -1108,7 +1107,6 @@ xlog_alloc_log(xfs_mount_t *mp, | |||
1108 | iclog->ic_callback_tail = &(iclog->ic_callback); | 1107 | iclog->ic_callback_tail = &(iclog->ic_callback); |
1109 | iclog->ic_datap = (char *)iclog->ic_data + log->l_iclog_hsize; | 1108 | iclog->ic_datap = (char *)iclog->ic_data + log->l_iclog_hsize; |
1110 | 1109 | ||
1111 | ASSERT(XFS_BUF_ISBUSY(iclog->ic_bp)); | ||
1112 | ASSERT(xfs_buf_islocked(iclog->ic_bp)); | 1110 | ASSERT(xfs_buf_islocked(iclog->ic_bp)); |
1113 | init_waitqueue_head(&iclog->ic_force_wait); | 1111 | init_waitqueue_head(&iclog->ic_force_wait); |
1114 | init_waitqueue_head(&iclog->ic_write_wait); | 1112 | init_waitqueue_head(&iclog->ic_write_wait); |
@@ -1248,7 +1246,7 @@ xlog_bdstrat( | |||
1248 | struct xlog_in_core *iclog = bp->b_fspriv; | 1246 | struct xlog_in_core *iclog = bp->b_fspriv; |
1249 | 1247 | ||
1250 | if (iclog->ic_state & XLOG_STATE_IOERROR) { | 1248 | if (iclog->ic_state & XLOG_STATE_IOERROR) { |
1251 | XFS_BUF_ERROR(bp, EIO); | 1249 | xfs_buf_ioerror(bp, EIO); |
1252 | XFS_BUF_STALE(bp); | 1250 | XFS_BUF_STALE(bp); |
1253 | xfs_buf_ioend(bp, 0); | 1251 | xfs_buf_ioend(bp, 0); |
1254 | /* | 1252 | /* |
@@ -1355,7 +1353,6 @@ xlog_sync(xlog_t *log, | |||
1355 | XFS_BUF_SET_COUNT(bp, count); | 1353 | XFS_BUF_SET_COUNT(bp, count); |
1356 | bp->b_fspriv = iclog; | 1354 | bp->b_fspriv = iclog; |
1357 | XFS_BUF_ZEROFLAGS(bp); | 1355 | XFS_BUF_ZEROFLAGS(bp); |
1358 | XFS_BUF_BUSY(bp); | ||
1359 | XFS_BUF_ASYNC(bp); | 1356 | XFS_BUF_ASYNC(bp); |
1360 | bp->b_flags |= XBF_SYNCIO; | 1357 | bp->b_flags |= XBF_SYNCIO; |
1361 | 1358 | ||
@@ -1398,16 +1395,15 @@ xlog_sync(xlog_t *log, | |||
1398 | if (split) { | 1395 | if (split) { |
1399 | bp = iclog->ic_log->l_xbuf; | 1396 | bp = iclog->ic_log->l_xbuf; |
1400 | XFS_BUF_SET_ADDR(bp, 0); /* logical 0 */ | 1397 | XFS_BUF_SET_ADDR(bp, 0); /* logical 0 */ |
1401 | XFS_BUF_SET_PTR(bp, (xfs_caddr_t)((__psint_t)&(iclog->ic_header)+ | 1398 | xfs_buf_associate_memory(bp, |
1402 | (__psint_t)count), split); | 1399 | (char *)&iclog->ic_header + count, split); |
1403 | bp->b_fspriv = iclog; | 1400 | bp->b_fspriv = iclog; |
1404 | XFS_BUF_ZEROFLAGS(bp); | 1401 | XFS_BUF_ZEROFLAGS(bp); |
1405 | XFS_BUF_BUSY(bp); | ||
1406 | XFS_BUF_ASYNC(bp); | 1402 | XFS_BUF_ASYNC(bp); |
1407 | bp->b_flags |= XBF_SYNCIO; | 1403 | bp->b_flags |= XBF_SYNCIO; |
1408 | if (log->l_mp->m_flags & XFS_MOUNT_BARRIER) | 1404 | if (log->l_mp->m_flags & XFS_MOUNT_BARRIER) |
1409 | bp->b_flags |= XBF_FUA; | 1405 | bp->b_flags |= XBF_FUA; |
1410 | dptr = XFS_BUF_PTR(bp); | 1406 | dptr = bp->b_addr; |
1411 | /* | 1407 | /* |
1412 | * Bump the cycle numbers at the start of each block | 1408 | * Bump the cycle numbers at the start of each block |
1413 | * since this part of the buffer is at the start of | 1409 | * since this part of the buffer is at the start of |
diff --git a/fs/xfs/xfs_log_recover.c b/fs/xfs/xfs_log_recover.c index 052a2c0ec5fb..a199dbcee7d8 100644 --- a/fs/xfs/xfs_log_recover.c +++ b/fs/xfs/xfs_log_recover.c | |||
@@ -147,7 +147,7 @@ xlog_align( | |||
147 | xfs_daddr_t offset = blk_no & ((xfs_daddr_t)log->l_sectBBsize - 1); | 147 | xfs_daddr_t offset = blk_no & ((xfs_daddr_t)log->l_sectBBsize - 1); |
148 | 148 | ||
149 | ASSERT(BBTOB(offset + nbblks) <= XFS_BUF_SIZE(bp)); | 149 | ASSERT(BBTOB(offset + nbblks) <= XFS_BUF_SIZE(bp)); |
150 | return XFS_BUF_PTR(bp) + BBTOB(offset); | 150 | return bp->b_addr + BBTOB(offset); |
151 | } | 151 | } |
152 | 152 | ||
153 | 153 | ||
@@ -178,9 +178,7 @@ xlog_bread_noalign( | |||
178 | 178 | ||
179 | XFS_BUF_SET_ADDR(bp, log->l_logBBstart + blk_no); | 179 | XFS_BUF_SET_ADDR(bp, log->l_logBBstart + blk_no); |
180 | XFS_BUF_READ(bp); | 180 | XFS_BUF_READ(bp); |
181 | XFS_BUF_BUSY(bp); | ||
182 | XFS_BUF_SET_COUNT(bp, BBTOB(nbblks)); | 181 | XFS_BUF_SET_COUNT(bp, BBTOB(nbblks)); |
183 | XFS_BUF_SET_TARGET(bp, log->l_mp->m_logdev_targp); | ||
184 | 182 | ||
185 | xfsbdstrat(log->l_mp, bp); | 183 | xfsbdstrat(log->l_mp, bp); |
186 | error = xfs_buf_iowait(bp); | 184 | error = xfs_buf_iowait(bp); |
@@ -220,18 +218,18 @@ xlog_bread_offset( | |||
220 | xfs_buf_t *bp, | 218 | xfs_buf_t *bp, |
221 | xfs_caddr_t offset) | 219 | xfs_caddr_t offset) |
222 | { | 220 | { |
223 | xfs_caddr_t orig_offset = XFS_BUF_PTR(bp); | 221 | xfs_caddr_t orig_offset = bp->b_addr; |
224 | int orig_len = bp->b_buffer_length; | 222 | int orig_len = bp->b_buffer_length; |
225 | int error, error2; | 223 | int error, error2; |
226 | 224 | ||
227 | error = XFS_BUF_SET_PTR(bp, offset, BBTOB(nbblks)); | 225 | error = xfs_buf_associate_memory(bp, offset, BBTOB(nbblks)); |
228 | if (error) | 226 | if (error) |
229 | return error; | 227 | return error; |
230 | 228 | ||
231 | error = xlog_bread_noalign(log, blk_no, nbblks, bp); | 229 | error = xlog_bread_noalign(log, blk_no, nbblks, bp); |
232 | 230 | ||
233 | /* must reset buffer pointer even on error */ | 231 | /* must reset buffer pointer even on error */ |
234 | error2 = XFS_BUF_SET_PTR(bp, orig_offset, orig_len); | 232 | error2 = xfs_buf_associate_memory(bp, orig_offset, orig_len); |
235 | if (error) | 233 | if (error) |
236 | return error; | 234 | return error; |
237 | return error2; | 235 | return error2; |
@@ -266,11 +264,9 @@ xlog_bwrite( | |||
266 | 264 | ||
267 | XFS_BUF_SET_ADDR(bp, log->l_logBBstart + blk_no); | 265 | XFS_BUF_SET_ADDR(bp, log->l_logBBstart + blk_no); |
268 | XFS_BUF_ZEROFLAGS(bp); | 266 | XFS_BUF_ZEROFLAGS(bp); |
269 | XFS_BUF_BUSY(bp); | 267 | xfs_buf_hold(bp); |
270 | XFS_BUF_HOLD(bp); | ||
271 | xfs_buf_lock(bp); | 268 | xfs_buf_lock(bp); |
272 | XFS_BUF_SET_COUNT(bp, BBTOB(nbblks)); | 269 | XFS_BUF_SET_COUNT(bp, BBTOB(nbblks)); |
273 | XFS_BUF_SET_TARGET(bp, log->l_mp->m_logdev_targp); | ||
274 | 270 | ||
275 | if ((error = xfs_bwrite(log->l_mp, bp))) | 271 | if ((error = xfs_bwrite(log->l_mp, bp))) |
276 | xfs_ioerror_alert("xlog_bwrite", log->l_mp, | 272 | xfs_ioerror_alert("xlog_bwrite", log->l_mp, |
@@ -360,7 +356,7 @@ STATIC void | |||
360 | xlog_recover_iodone( | 356 | xlog_recover_iodone( |
361 | struct xfs_buf *bp) | 357 | struct xfs_buf *bp) |
362 | { | 358 | { |
363 | if (XFS_BUF_GETERROR(bp)) { | 359 | if (bp->b_error) { |
364 | /* | 360 | /* |
365 | * We're not going to bother about retrying | 361 | * We're not going to bother about retrying |
366 | * this during recovery. One strike! | 362 | * this during recovery. One strike! |
@@ -1262,7 +1258,7 @@ xlog_write_log_records( | |||
1262 | */ | 1258 | */ |
1263 | ealign = round_down(end_block, sectbb); | 1259 | ealign = round_down(end_block, sectbb); |
1264 | if (j == 0 && (start_block + endcount > ealign)) { | 1260 | if (j == 0 && (start_block + endcount > ealign)) { |
1265 | offset = XFS_BUF_PTR(bp) + BBTOB(ealign - start_block); | 1261 | offset = bp->b_addr + BBTOB(ealign - start_block); |
1266 | error = xlog_bread_offset(log, ealign, sectbb, | 1262 | error = xlog_bread_offset(log, ealign, sectbb, |
1267 | bp, offset); | 1263 | bp, offset); |
1268 | if (error) | 1264 | if (error) |
@@ -2135,15 +2131,16 @@ xlog_recover_buffer_pass2( | |||
2135 | 2131 | ||
2136 | bp = xfs_buf_read(mp->m_ddev_targp, buf_f->blf_blkno, buf_f->blf_len, | 2132 | bp = xfs_buf_read(mp->m_ddev_targp, buf_f->blf_blkno, buf_f->blf_len, |
2137 | buf_flags); | 2133 | buf_flags); |
2138 | if (XFS_BUF_ISERROR(bp)) { | 2134 | if (!bp) |
2135 | return XFS_ERROR(ENOMEM); | ||
2136 | error = bp->b_error; | ||
2137 | if (error) { | ||
2139 | xfs_ioerror_alert("xlog_recover_do..(read#1)", mp, | 2138 | xfs_ioerror_alert("xlog_recover_do..(read#1)", mp, |
2140 | bp, buf_f->blf_blkno); | 2139 | bp, buf_f->blf_blkno); |
2141 | error = XFS_BUF_GETERROR(bp); | ||
2142 | xfs_buf_relse(bp); | 2140 | xfs_buf_relse(bp); |
2143 | return error; | 2141 | return error; |
2144 | } | 2142 | } |
2145 | 2143 | ||
2146 | error = 0; | ||
2147 | if (buf_f->blf_flags & XFS_BLF_INODE_BUF) { | 2144 | if (buf_f->blf_flags & XFS_BLF_INODE_BUF) { |
2148 | error = xlog_recover_do_inode_buffer(mp, item, bp, buf_f); | 2145 | error = xlog_recover_do_inode_buffer(mp, item, bp, buf_f); |
2149 | } else if (buf_f->blf_flags & | 2146 | } else if (buf_f->blf_flags & |
@@ -2227,14 +2224,17 @@ xlog_recover_inode_pass2( | |||
2227 | 2224 | ||
2228 | bp = xfs_buf_read(mp->m_ddev_targp, in_f->ilf_blkno, in_f->ilf_len, | 2225 | bp = xfs_buf_read(mp->m_ddev_targp, in_f->ilf_blkno, in_f->ilf_len, |
2229 | XBF_LOCK); | 2226 | XBF_LOCK); |
2230 | if (XFS_BUF_ISERROR(bp)) { | 2227 | if (!bp) { |
2228 | error = ENOMEM; | ||
2229 | goto error; | ||
2230 | } | ||
2231 | error = bp->b_error; | ||
2232 | if (error) { | ||
2231 | xfs_ioerror_alert("xlog_recover_do..(read#2)", mp, | 2233 | xfs_ioerror_alert("xlog_recover_do..(read#2)", mp, |
2232 | bp, in_f->ilf_blkno); | 2234 | bp, in_f->ilf_blkno); |
2233 | error = XFS_BUF_GETERROR(bp); | ||
2234 | xfs_buf_relse(bp); | 2235 | xfs_buf_relse(bp); |
2235 | goto error; | 2236 | goto error; |
2236 | } | 2237 | } |
2237 | error = 0; | ||
2238 | ASSERT(in_f->ilf_fields & XFS_ILOG_CORE); | 2238 | ASSERT(in_f->ilf_fields & XFS_ILOG_CORE); |
2239 | dip = (xfs_dinode_t *)xfs_buf_offset(bp, in_f->ilf_boffset); | 2239 | dip = (xfs_dinode_t *)xfs_buf_offset(bp, in_f->ilf_boffset); |
2240 | 2240 | ||
@@ -3437,7 +3437,7 @@ xlog_do_recovery_pass( | |||
3437 | /* | 3437 | /* |
3438 | * Check for header wrapping around physical end-of-log | 3438 | * Check for header wrapping around physical end-of-log |
3439 | */ | 3439 | */ |
3440 | offset = XFS_BUF_PTR(hbp); | 3440 | offset = hbp->b_addr; |
3441 | split_hblks = 0; | 3441 | split_hblks = 0; |
3442 | wrapped_hblks = 0; | 3442 | wrapped_hblks = 0; |
3443 | if (blk_no + hblks <= log->l_logBBsize) { | 3443 | if (blk_no + hblks <= log->l_logBBsize) { |
@@ -3497,7 +3497,7 @@ xlog_do_recovery_pass( | |||
3497 | } else { | 3497 | } else { |
3498 | /* This log record is split across the | 3498 | /* This log record is split across the |
3499 | * physical end of log */ | 3499 | * physical end of log */ |
3500 | offset = XFS_BUF_PTR(dbp); | 3500 | offset = dbp->b_addr; |
3501 | split_bblks = 0; | 3501 | split_bblks = 0; |
3502 | if (blk_no != log->l_logBBsize) { | 3502 | if (blk_no != log->l_logBBsize) { |
3503 | /* some data is before the physical | 3503 | /* some data is before the physical |
diff --git a/fs/xfs/xfs_mount.c b/fs/xfs/xfs_mount.c index 092e16ae4d9d..0081657ad985 100644 --- a/fs/xfs/xfs_mount.c +++ b/fs/xfs/xfs_mount.c | |||
@@ -1615,7 +1615,7 @@ xfs_unmountfs_writesb(xfs_mount_t *mp) | |||
1615 | XFS_BUF_UNDELAYWRITE(sbp); | 1615 | XFS_BUF_UNDELAYWRITE(sbp); |
1616 | XFS_BUF_WRITE(sbp); | 1616 | XFS_BUF_WRITE(sbp); |
1617 | XFS_BUF_UNASYNC(sbp); | 1617 | XFS_BUF_UNASYNC(sbp); |
1618 | ASSERT(XFS_BUF_TARGET(sbp) == mp->m_ddev_targp); | 1618 | ASSERT(sbp->b_target == mp->m_ddev_targp); |
1619 | xfsbdstrat(mp, sbp); | 1619 | xfsbdstrat(mp, sbp); |
1620 | error = xfs_buf_iowait(sbp); | 1620 | error = xfs_buf_iowait(sbp); |
1621 | if (error) | 1621 | if (error) |
@@ -1938,7 +1938,7 @@ xfs_getsb( | |||
1938 | xfs_buf_lock(bp); | 1938 | xfs_buf_lock(bp); |
1939 | } | 1939 | } |
1940 | 1940 | ||
1941 | XFS_BUF_HOLD(bp); | 1941 | xfs_buf_hold(bp); |
1942 | ASSERT(XFS_BUF_ISDONE(bp)); | 1942 | ASSERT(XFS_BUF_ISDONE(bp)); |
1943 | return bp; | 1943 | return bp; |
1944 | } | 1944 | } |
diff --git a/fs/xfs/xfs_rtalloc.c b/fs/xfs/xfs_rtalloc.c index 8f76fdff4f46..35561a511b57 100644 --- a/fs/xfs/xfs_rtalloc.c +++ b/fs/xfs/xfs_rtalloc.c | |||
@@ -168,7 +168,7 @@ error_cancel: | |||
168 | xfs_trans_cancel(tp, cancelflags); | 168 | xfs_trans_cancel(tp, cancelflags); |
169 | goto error; | 169 | goto error; |
170 | } | 170 | } |
171 | memset(XFS_BUF_PTR(bp), 0, mp->m_sb.sb_blocksize); | 171 | memset(bp->b_addr, 0, mp->m_sb.sb_blocksize); |
172 | xfs_trans_log_buf(tp, bp, 0, mp->m_sb.sb_blocksize - 1); | 172 | xfs_trans_log_buf(tp, bp, 0, mp->m_sb.sb_blocksize - 1); |
173 | /* | 173 | /* |
174 | * Commit the transaction. | 174 | * Commit the transaction. |
@@ -883,7 +883,7 @@ xfs_rtbuf_get( | |||
883 | if (error) { | 883 | if (error) { |
884 | return error; | 884 | return error; |
885 | } | 885 | } |
886 | ASSERT(bp && !XFS_BUF_GETERROR(bp)); | 886 | ASSERT(!xfs_buf_geterror(bp)); |
887 | *bpp = bp; | 887 | *bpp = bp; |
888 | return 0; | 888 | return 0; |
889 | } | 889 | } |
@@ -943,7 +943,7 @@ xfs_rtcheck_range( | |||
943 | if (error) { | 943 | if (error) { |
944 | return error; | 944 | return error; |
945 | } | 945 | } |
946 | bufp = (xfs_rtword_t *)XFS_BUF_PTR(bp); | 946 | bufp = bp->b_addr; |
947 | /* | 947 | /* |
948 | * Compute the starting word's address, and starting bit. | 948 | * Compute the starting word's address, and starting bit. |
949 | */ | 949 | */ |
@@ -994,7 +994,7 @@ xfs_rtcheck_range( | |||
994 | if (error) { | 994 | if (error) { |
995 | return error; | 995 | return error; |
996 | } | 996 | } |
997 | b = bufp = (xfs_rtword_t *)XFS_BUF_PTR(bp); | 997 | b = bufp = bp->b_addr; |
998 | word = 0; | 998 | word = 0; |
999 | } else { | 999 | } else { |
1000 | /* | 1000 | /* |
@@ -1040,7 +1040,7 @@ xfs_rtcheck_range( | |||
1040 | if (error) { | 1040 | if (error) { |
1041 | return error; | 1041 | return error; |
1042 | } | 1042 | } |
1043 | b = bufp = (xfs_rtword_t *)XFS_BUF_PTR(bp); | 1043 | b = bufp = bp->b_addr; |
1044 | word = 0; | 1044 | word = 0; |
1045 | } else { | 1045 | } else { |
1046 | /* | 1046 | /* |
@@ -1158,7 +1158,7 @@ xfs_rtfind_back( | |||
1158 | if (error) { | 1158 | if (error) { |
1159 | return error; | 1159 | return error; |
1160 | } | 1160 | } |
1161 | bufp = (xfs_rtword_t *)XFS_BUF_PTR(bp); | 1161 | bufp = bp->b_addr; |
1162 | /* | 1162 | /* |
1163 | * Get the first word's index & point to it. | 1163 | * Get the first word's index & point to it. |
1164 | */ | 1164 | */ |
@@ -1210,7 +1210,7 @@ xfs_rtfind_back( | |||
1210 | if (error) { | 1210 | if (error) { |
1211 | return error; | 1211 | return error; |
1212 | } | 1212 | } |
1213 | bufp = (xfs_rtword_t *)XFS_BUF_PTR(bp); | 1213 | bufp = bp->b_addr; |
1214 | word = XFS_BLOCKWMASK(mp); | 1214 | word = XFS_BLOCKWMASK(mp); |
1215 | b = &bufp[word]; | 1215 | b = &bufp[word]; |
1216 | } else { | 1216 | } else { |
@@ -1256,7 +1256,7 @@ xfs_rtfind_back( | |||
1256 | if (error) { | 1256 | if (error) { |
1257 | return error; | 1257 | return error; |
1258 | } | 1258 | } |
1259 | bufp = (xfs_rtword_t *)XFS_BUF_PTR(bp); | 1259 | bufp = bp->b_addr; |
1260 | word = XFS_BLOCKWMASK(mp); | 1260 | word = XFS_BLOCKWMASK(mp); |
1261 | b = &bufp[word]; | 1261 | b = &bufp[word]; |
1262 | } else { | 1262 | } else { |
@@ -1333,7 +1333,7 @@ xfs_rtfind_forw( | |||
1333 | if (error) { | 1333 | if (error) { |
1334 | return error; | 1334 | return error; |
1335 | } | 1335 | } |
1336 | bufp = (xfs_rtword_t *)XFS_BUF_PTR(bp); | 1336 | bufp = bp->b_addr; |
1337 | /* | 1337 | /* |
1338 | * Get the first word's index & point to it. | 1338 | * Get the first word's index & point to it. |
1339 | */ | 1339 | */ |
@@ -1384,7 +1384,7 @@ xfs_rtfind_forw( | |||
1384 | if (error) { | 1384 | if (error) { |
1385 | return error; | 1385 | return error; |
1386 | } | 1386 | } |
1387 | b = bufp = (xfs_rtword_t *)XFS_BUF_PTR(bp); | 1387 | b = bufp = bp->b_addr; |
1388 | word = 0; | 1388 | word = 0; |
1389 | } else { | 1389 | } else { |
1390 | /* | 1390 | /* |
@@ -1429,7 +1429,7 @@ xfs_rtfind_forw( | |||
1429 | if (error) { | 1429 | if (error) { |
1430 | return error; | 1430 | return error; |
1431 | } | 1431 | } |
1432 | b = bufp = (xfs_rtword_t *)XFS_BUF_PTR(bp); | 1432 | b = bufp = bp->b_addr; |
1433 | word = 0; | 1433 | word = 0; |
1434 | } else { | 1434 | } else { |
1435 | /* | 1435 | /* |
@@ -1649,7 +1649,7 @@ xfs_rtmodify_range( | |||
1649 | if (error) { | 1649 | if (error) { |
1650 | return error; | 1650 | return error; |
1651 | } | 1651 | } |
1652 | bufp = (xfs_rtword_t *)XFS_BUF_PTR(bp); | 1652 | bufp = bp->b_addr; |
1653 | /* | 1653 | /* |
1654 | * Compute the starting word's address, and starting bit. | 1654 | * Compute the starting word's address, and starting bit. |
1655 | */ | 1655 | */ |
@@ -1694,7 +1694,7 @@ xfs_rtmodify_range( | |||
1694 | if (error) { | 1694 | if (error) { |
1695 | return error; | 1695 | return error; |
1696 | } | 1696 | } |
1697 | first = b = bufp = (xfs_rtword_t *)XFS_BUF_PTR(bp); | 1697 | first = b = bufp = bp->b_addr; |
1698 | word = 0; | 1698 | word = 0; |
1699 | } else { | 1699 | } else { |
1700 | /* | 1700 | /* |
@@ -1734,7 +1734,7 @@ xfs_rtmodify_range( | |||
1734 | if (error) { | 1734 | if (error) { |
1735 | return error; | 1735 | return error; |
1736 | } | 1736 | } |
1737 | first = b = bufp = (xfs_rtword_t *)XFS_BUF_PTR(bp); | 1737 | first = b = bufp = bp->b_addr; |
1738 | word = 0; | 1738 | word = 0; |
1739 | } else { | 1739 | } else { |
1740 | /* | 1740 | /* |
@@ -1832,8 +1832,8 @@ xfs_rtmodify_summary( | |||
1832 | */ | 1832 | */ |
1833 | sp = XFS_SUMPTR(mp, bp, so); | 1833 | sp = XFS_SUMPTR(mp, bp, so); |
1834 | *sp += delta; | 1834 | *sp += delta; |
1835 | xfs_trans_log_buf(tp, bp, (uint)((char *)sp - (char *)XFS_BUF_PTR(bp)), | 1835 | xfs_trans_log_buf(tp, bp, (uint)((char *)sp - (char *)bp->b_addr), |
1836 | (uint)((char *)sp - (char *)XFS_BUF_PTR(bp) + sizeof(*sp) - 1)); | 1836 | (uint)((char *)sp - (char *)bp->b_addr + sizeof(*sp) - 1)); |
1837 | return 0; | 1837 | return 0; |
1838 | } | 1838 | } |
1839 | 1839 | ||
diff --git a/fs/xfs/xfs_rtalloc.h b/fs/xfs/xfs_rtalloc.h index 09e1f4f35e97..f7f3a359c1c5 100644 --- a/fs/xfs/xfs_rtalloc.h +++ b/fs/xfs/xfs_rtalloc.h | |||
@@ -47,7 +47,7 @@ struct xfs_trans; | |||
47 | #define XFS_SUMOFFSTOBLOCK(mp,s) \ | 47 | #define XFS_SUMOFFSTOBLOCK(mp,s) \ |
48 | (((s) * (uint)sizeof(xfs_suminfo_t)) >> (mp)->m_sb.sb_blocklog) | 48 | (((s) * (uint)sizeof(xfs_suminfo_t)) >> (mp)->m_sb.sb_blocklog) |
49 | #define XFS_SUMPTR(mp,bp,so) \ | 49 | #define XFS_SUMPTR(mp,bp,so) \ |
50 | ((xfs_suminfo_t *)((char *)XFS_BUF_PTR(bp) + \ | 50 | ((xfs_suminfo_t *)((bp)->b_addr + \ |
51 | (((so) * (uint)sizeof(xfs_suminfo_t)) & XFS_BLOCKMASK(mp)))) | 51 | (((so) * (uint)sizeof(xfs_suminfo_t)) & XFS_BLOCKMASK(mp)))) |
52 | 52 | ||
53 | #define XFS_BITTOBLOCK(mp,bi) ((bi) >> (mp)->m_blkbit_log) | 53 | #define XFS_BITTOBLOCK(mp,bi) ((bi) >> (mp)->m_blkbit_log) |
diff --git a/fs/xfs/xfs_rw.c b/fs/xfs/xfs_rw.c index d6d6fdfe9422..c96a8a05ac03 100644 --- a/fs/xfs/xfs_rw.c +++ b/fs/xfs/xfs_rw.c | |||
@@ -104,9 +104,9 @@ xfs_ioerror_alert( | |||
104 | xfs_alert(mp, | 104 | xfs_alert(mp, |
105 | "I/O error occurred: meta-data dev %s block 0x%llx" | 105 | "I/O error occurred: meta-data dev %s block 0x%llx" |
106 | " (\"%s\") error %d buf count %zd", | 106 | " (\"%s\") error %d buf count %zd", |
107 | XFS_BUFTARG_NAME(XFS_BUF_TARGET(bp)), | 107 | xfs_buf_target_name(bp->b_target), |
108 | (__uint64_t)blkno, func, | 108 | (__uint64_t)blkno, func, |
109 | XFS_BUF_GETERROR(bp), XFS_BUF_COUNT(bp)); | 109 | bp->b_error, XFS_BUF_COUNT(bp)); |
110 | } | 110 | } |
111 | 111 | ||
112 | /* | 112 | /* |
@@ -137,8 +137,8 @@ xfs_read_buf( | |||
137 | bp = xfs_buf_read(target, blkno, len, flags); | 137 | bp = xfs_buf_read(target, blkno, len, flags); |
138 | if (!bp) | 138 | if (!bp) |
139 | return XFS_ERROR(EIO); | 139 | return XFS_ERROR(EIO); |
140 | error = XFS_BUF_GETERROR(bp); | 140 | error = bp->b_error; |
141 | if (bp && !error && !XFS_FORCED_SHUTDOWN(mp)) { | 141 | if (!error && !XFS_FORCED_SHUTDOWN(mp)) { |
142 | *bpp = bp; | 142 | *bpp = bp; |
143 | } else { | 143 | } else { |
144 | *bpp = NULL; | 144 | *bpp = NULL; |
diff --git a/fs/xfs/xfs_sb.h b/fs/xfs/xfs_sb.h index 1eb2ba586814..cb6ae715814a 100644 --- a/fs/xfs/xfs_sb.h +++ b/fs/xfs/xfs_sb.h | |||
@@ -509,7 +509,7 @@ static inline int xfs_sb_version_hasprojid32bit(xfs_sb_t *sbp) | |||
509 | 509 | ||
510 | #define XFS_SB_DADDR ((xfs_daddr_t)0) /* daddr in filesystem/ag */ | 510 | #define XFS_SB_DADDR ((xfs_daddr_t)0) /* daddr in filesystem/ag */ |
511 | #define XFS_SB_BLOCK(mp) XFS_HDR_BLOCK(mp, XFS_SB_DADDR) | 511 | #define XFS_SB_BLOCK(mp) XFS_HDR_BLOCK(mp, XFS_SB_DADDR) |
512 | #define XFS_BUF_TO_SBP(bp) ((xfs_dsb_t *)XFS_BUF_PTR(bp)) | 512 | #define XFS_BUF_TO_SBP(bp) ((xfs_dsb_t *)((bp)->b_addr)) |
513 | 513 | ||
514 | #define XFS_HDR_BLOCK(mp,d) ((xfs_agblock_t)XFS_BB_TO_FSBT(mp,d)) | 514 | #define XFS_HDR_BLOCK(mp,d) ((xfs_agblock_t)XFS_BB_TO_FSBT(mp,d)) |
515 | #define XFS_DADDR_TO_FSB(mp,d) XFS_AGB_TO_FSB(mp, \ | 515 | #define XFS_DADDR_TO_FSB(mp,d) XFS_AGB_TO_FSB(mp, \ |
diff --git a/fs/xfs/xfs_trans_ail.c b/fs/xfs/xfs_trans_ail.c index 43233e92f0f6..c15aa29fa169 100644 --- a/fs/xfs/xfs_trans_ail.c +++ b/fs/xfs/xfs_trans_ail.c | |||
@@ -299,7 +299,7 @@ xfs_trans_ail_cursor_last( | |||
299 | * Splice the log item list into the AIL at the given LSN. We splice to the | 299 | * Splice the log item list into the AIL at the given LSN. We splice to the |
300 | * tail of the given LSN to maintain insert order for push traversals. The | 300 | * tail of the given LSN to maintain insert order for push traversals. The |
301 | * cursor is optional, allowing repeated updates to the same LSN to avoid | 301 | * cursor is optional, allowing repeated updates to the same LSN to avoid |
302 | * repeated traversals. | 302 | * repeated traversals. This should not be called with an empty list. |
303 | */ | 303 | */ |
304 | static void | 304 | static void |
305 | xfs_ail_splice( | 305 | xfs_ail_splice( |
@@ -308,50 +308,39 @@ xfs_ail_splice( | |||
308 | struct list_head *list, | 308 | struct list_head *list, |
309 | xfs_lsn_t lsn) | 309 | xfs_lsn_t lsn) |
310 | { | 310 | { |
311 | struct xfs_log_item *lip = cur ? cur->item : NULL; | 311 | struct xfs_log_item *lip; |
312 | struct xfs_log_item *next_lip; | 312 | |
313 | ASSERT(!list_empty(list)); | ||
313 | 314 | ||
314 | /* | 315 | /* |
315 | * Get a new cursor if we don't have a placeholder or the existing one | 316 | * Use the cursor to determine the insertion point if one is |
316 | * has been invalidated. | 317 | * provided. If not, or if the one we got is not valid, |
318 | * find the place in the AIL where the items belong. | ||
317 | */ | 319 | */ |
318 | if (!lip || (__psint_t)lip & 1) { | 320 | lip = cur ? cur->item : NULL; |
321 | if (!lip || (__psint_t) lip & 1) | ||
319 | lip = __xfs_trans_ail_cursor_last(ailp, lsn); | 322 | lip = __xfs_trans_ail_cursor_last(ailp, lsn); |
320 | 323 | ||
321 | if (!lip) { | 324 | /* |
322 | /* The list is empty, so just splice and return. */ | 325 | * If a cursor is provided, we know we're processing the AIL |
323 | if (cur) | 326 | * in lsn order, and future items to be spliced in will |
324 | cur->item = NULL; | 327 | * follow the last one being inserted now. Update the |
325 | list_splice(list, &ailp->xa_ail); | 328 | * cursor to point to that last item, now while we have a |
326 | return; | 329 | * reliable pointer to it. |
327 | } | 330 | */ |
328 | } | 331 | if (cur) |
332 | cur->item = list_entry(list->prev, struct xfs_log_item, li_ail); | ||
329 | 333 | ||
330 | /* | 334 | /* |
331 | * Our cursor points to the item we want to insert _after_, so we have | 335 | * Finally perform the splice. Unless the AIL was empty, |
332 | * to update the cursor to point to the end of the list we are splicing | 336 | * lip points to the item in the AIL _after_ which the new |
333 | * in so that it points to the correct location for the next splice. | 337 | * items should go. If lip is null the AIL was empty, so |
334 | * i.e. before the splice | 338 | * the new items go at the head of the AIL. |
335 | * | ||
336 | * lsn -> lsn -> lsn + x -> lsn + x ... | ||
337 | * ^ | ||
338 | * | cursor points here | ||
339 | * | ||
340 | * After the splice we have: | ||
341 | * | ||
342 | * lsn -> lsn -> lsn -> lsn -> .... -> lsn -> lsn + x -> lsn + x ... | ||
343 | * ^ ^ | ||
344 | * | cursor points here | needs to move here | ||
345 | * | ||
346 | * So we set the cursor to the last item in the list to be spliced | ||
347 | * before we execute the splice, resulting in the cursor pointing to | ||
348 | * the correct item after the splice occurs. | ||
349 | */ | 339 | */ |
350 | if (cur) { | 340 | if (lip) |
351 | next_lip = list_entry(list->prev, struct xfs_log_item, li_ail); | 341 | list_splice(list, &lip->li_ail); |
352 | cur->item = next_lip; | 342 | else |
353 | } | 343 | list_splice(list, &ailp->xa_ail); |
354 | list_splice(list, &lip->li_ail); | ||
355 | } | 344 | } |
356 | 345 | ||
357 | /* | 346 | /* |
@@ -682,6 +671,7 @@ xfs_trans_ail_update_bulk( | |||
682 | int i; | 671 | int i; |
683 | LIST_HEAD(tmp); | 672 | LIST_HEAD(tmp); |
684 | 673 | ||
674 | ASSERT(nr_items > 0); /* Not required, but true. */ | ||
685 | mlip = xfs_ail_min(ailp); | 675 | mlip = xfs_ail_min(ailp); |
686 | 676 | ||
687 | for (i = 0; i < nr_items; i++) { | 677 | for (i = 0; i < nr_items; i++) { |
@@ -701,7 +691,8 @@ xfs_trans_ail_update_bulk( | |||
701 | list_add(&lip->li_ail, &tmp); | 691 | list_add(&lip->li_ail, &tmp); |
702 | } | 692 | } |
703 | 693 | ||
704 | xfs_ail_splice(ailp, cur, &tmp, lsn); | 694 | if (!list_empty(&tmp)) |
695 | xfs_ail_splice(ailp, cur, &tmp, lsn); | ||
705 | 696 | ||
706 | if (!mlip_changed) { | 697 | if (!mlip_changed) { |
707 | spin_unlock(&ailp->xa_lock); | 698 | spin_unlock(&ailp->xa_lock); |
diff --git a/fs/xfs/xfs_trans_buf.c b/fs/xfs/xfs_trans_buf.c index 15584fc3ed7d..137e2b9e2948 100644 --- a/fs/xfs/xfs_trans_buf.c +++ b/fs/xfs/xfs_trans_buf.c | |||
@@ -54,7 +54,7 @@ xfs_trans_buf_item_match( | |||
54 | list_for_each_entry(lidp, &tp->t_items, lid_trans) { | 54 | list_for_each_entry(lidp, &tp->t_items, lid_trans) { |
55 | blip = (struct xfs_buf_log_item *)lidp->lid_item; | 55 | blip = (struct xfs_buf_log_item *)lidp->lid_item; |
56 | if (blip->bli_item.li_type == XFS_LI_BUF && | 56 | if (blip->bli_item.li_type == XFS_LI_BUF && |
57 | XFS_BUF_TARGET(blip->bli_buf) == target && | 57 | blip->bli_buf->b_target == target && |
58 | XFS_BUF_ADDR(blip->bli_buf) == blkno && | 58 | XFS_BUF_ADDR(blip->bli_buf) == blkno && |
59 | XFS_BUF_COUNT(blip->bli_buf) == len) | 59 | XFS_BUF_COUNT(blip->bli_buf) == len) |
60 | return blip->bli_buf; | 60 | return blip->bli_buf; |
@@ -80,7 +80,6 @@ _xfs_trans_bjoin( | |||
80 | { | 80 | { |
81 | struct xfs_buf_log_item *bip; | 81 | struct xfs_buf_log_item *bip; |
82 | 82 | ||
83 | ASSERT(XFS_BUF_ISBUSY(bp)); | ||
84 | ASSERT(bp->b_transp == NULL); | 83 | ASSERT(bp->b_transp == NULL); |
85 | 84 | ||
86 | /* | 85 | /* |
@@ -194,7 +193,7 @@ xfs_trans_get_buf(xfs_trans_t *tp, | |||
194 | return NULL; | 193 | return NULL; |
195 | } | 194 | } |
196 | 195 | ||
197 | ASSERT(!XFS_BUF_GETERROR(bp)); | 196 | ASSERT(!bp->b_error); |
198 | 197 | ||
199 | _xfs_trans_bjoin(tp, bp, 1); | 198 | _xfs_trans_bjoin(tp, bp, 1); |
200 | trace_xfs_trans_get_buf(bp->b_fspriv); | 199 | trace_xfs_trans_get_buf(bp->b_fspriv); |
@@ -293,10 +292,10 @@ xfs_trans_read_buf( | |||
293 | return (flags & XBF_TRYLOCK) ? | 292 | return (flags & XBF_TRYLOCK) ? |
294 | EAGAIN : XFS_ERROR(ENOMEM); | 293 | EAGAIN : XFS_ERROR(ENOMEM); |
295 | 294 | ||
296 | if (XFS_BUF_GETERROR(bp) != 0) { | 295 | if (bp->b_error) { |
296 | error = bp->b_error; | ||
297 | xfs_ioerror_alert("xfs_trans_read_buf", mp, | 297 | xfs_ioerror_alert("xfs_trans_read_buf", mp, |
298 | bp, blkno); | 298 | bp, blkno); |
299 | error = XFS_BUF_GETERROR(bp); | ||
300 | xfs_buf_relse(bp); | 299 | xfs_buf_relse(bp); |
301 | return error; | 300 | return error; |
302 | } | 301 | } |
@@ -330,7 +329,7 @@ xfs_trans_read_buf( | |||
330 | ASSERT(xfs_buf_islocked(bp)); | 329 | ASSERT(xfs_buf_islocked(bp)); |
331 | ASSERT(bp->b_transp == tp); | 330 | ASSERT(bp->b_transp == tp); |
332 | ASSERT(bp->b_fspriv != NULL); | 331 | ASSERT(bp->b_fspriv != NULL); |
333 | ASSERT((XFS_BUF_ISERROR(bp)) == 0); | 332 | ASSERT(!bp->b_error); |
334 | if (!(XFS_BUF_ISDONE(bp))) { | 333 | if (!(XFS_BUF_ISDONE(bp))) { |
335 | trace_xfs_trans_read_buf_io(bp, _RET_IP_); | 334 | trace_xfs_trans_read_buf_io(bp, _RET_IP_); |
336 | ASSERT(!XFS_BUF_ISASYNC(bp)); | 335 | ASSERT(!XFS_BUF_ISASYNC(bp)); |
@@ -386,10 +385,9 @@ xfs_trans_read_buf( | |||
386 | return (flags & XBF_TRYLOCK) ? | 385 | return (flags & XBF_TRYLOCK) ? |
387 | 0 : XFS_ERROR(ENOMEM); | 386 | 0 : XFS_ERROR(ENOMEM); |
388 | } | 387 | } |
389 | if (XFS_BUF_GETERROR(bp) != 0) { | 388 | if (bp->b_error) { |
390 | XFS_BUF_SUPER_STALE(bp); | 389 | error = bp->b_error; |
391 | error = XFS_BUF_GETERROR(bp); | 390 | XFS_BUF_SUPER_STALE(bp); |
392 | |||
393 | xfs_ioerror_alert("xfs_trans_read_buf", mp, | 391 | xfs_ioerror_alert("xfs_trans_read_buf", mp, |
394 | bp, blkno); | 392 | bp, blkno); |
395 | if (tp->t_flags & XFS_TRANS_DIRTY) | 393 | if (tp->t_flags & XFS_TRANS_DIRTY) |
@@ -430,7 +428,7 @@ shutdown_abort: | |||
430 | if (XFS_BUF_ISSTALE(bp) && XFS_BUF_ISDELAYWRITE(bp)) | 428 | if (XFS_BUF_ISSTALE(bp) && XFS_BUF_ISDELAYWRITE(bp)) |
431 | xfs_notice(mp, "about to pop assert, bp == 0x%p", bp); | 429 | xfs_notice(mp, "about to pop assert, bp == 0x%p", bp); |
432 | #endif | 430 | #endif |
433 | ASSERT((XFS_BUF_BFLAGS(bp) & (XBF_STALE|XBF_DELWRI)) != | 431 | ASSERT((bp->b_flags & (XBF_STALE|XBF_DELWRI)) != |
434 | (XBF_STALE|XBF_DELWRI)); | 432 | (XBF_STALE|XBF_DELWRI)); |
435 | 433 | ||
436 | trace_xfs_trans_read_buf_shut(bp, _RET_IP_); | 434 | trace_xfs_trans_read_buf_shut(bp, _RET_IP_); |
@@ -581,7 +579,6 @@ xfs_trans_bhold(xfs_trans_t *tp, | |||
581 | { | 579 | { |
582 | xfs_buf_log_item_t *bip = bp->b_fspriv; | 580 | xfs_buf_log_item_t *bip = bp->b_fspriv; |
583 | 581 | ||
584 | ASSERT(XFS_BUF_ISBUSY(bp)); | ||
585 | ASSERT(bp->b_transp == tp); | 582 | ASSERT(bp->b_transp == tp); |
586 | ASSERT(bip != NULL); | 583 | ASSERT(bip != NULL); |
587 | ASSERT(!(bip->bli_flags & XFS_BLI_STALE)); | 584 | ASSERT(!(bip->bli_flags & XFS_BLI_STALE)); |
@@ -602,7 +599,6 @@ xfs_trans_bhold_release(xfs_trans_t *tp, | |||
602 | { | 599 | { |
603 | xfs_buf_log_item_t *bip = bp->b_fspriv; | 600 | xfs_buf_log_item_t *bip = bp->b_fspriv; |
604 | 601 | ||
605 | ASSERT(XFS_BUF_ISBUSY(bp)); | ||
606 | ASSERT(bp->b_transp == tp); | 602 | ASSERT(bp->b_transp == tp); |
607 | ASSERT(bip != NULL); | 603 | ASSERT(bip != NULL); |
608 | ASSERT(!(bip->bli_flags & XFS_BLI_STALE)); | 604 | ASSERT(!(bip->bli_flags & XFS_BLI_STALE)); |
@@ -631,7 +627,6 @@ xfs_trans_log_buf(xfs_trans_t *tp, | |||
631 | { | 627 | { |
632 | xfs_buf_log_item_t *bip = bp->b_fspriv; | 628 | xfs_buf_log_item_t *bip = bp->b_fspriv; |
633 | 629 | ||
634 | ASSERT(XFS_BUF_ISBUSY(bp)); | ||
635 | ASSERT(bp->b_transp == tp); | 630 | ASSERT(bp->b_transp == tp); |
636 | ASSERT(bip != NULL); | 631 | ASSERT(bip != NULL); |
637 | ASSERT((first <= last) && (last < XFS_BUF_COUNT(bp))); | 632 | ASSERT((first <= last) && (last < XFS_BUF_COUNT(bp))); |
@@ -702,7 +697,6 @@ xfs_trans_binval( | |||
702 | { | 697 | { |
703 | xfs_buf_log_item_t *bip = bp->b_fspriv; | 698 | xfs_buf_log_item_t *bip = bp->b_fspriv; |
704 | 699 | ||
705 | ASSERT(XFS_BUF_ISBUSY(bp)); | ||
706 | ASSERT(bp->b_transp == tp); | 700 | ASSERT(bp->b_transp == tp); |
707 | ASSERT(bip != NULL); | 701 | ASSERT(bip != NULL); |
708 | ASSERT(atomic_read(&bip->bli_refcount) > 0); | 702 | ASSERT(atomic_read(&bip->bli_refcount) > 0); |
@@ -774,7 +768,6 @@ xfs_trans_inode_buf( | |||
774 | { | 768 | { |
775 | xfs_buf_log_item_t *bip = bp->b_fspriv; | 769 | xfs_buf_log_item_t *bip = bp->b_fspriv; |
776 | 770 | ||
777 | ASSERT(XFS_BUF_ISBUSY(bp)); | ||
778 | ASSERT(bp->b_transp == tp); | 771 | ASSERT(bp->b_transp == tp); |
779 | ASSERT(bip != NULL); | 772 | ASSERT(bip != NULL); |
780 | ASSERT(atomic_read(&bip->bli_refcount) > 0); | 773 | ASSERT(atomic_read(&bip->bli_refcount) > 0); |
@@ -798,7 +791,6 @@ xfs_trans_stale_inode_buf( | |||
798 | { | 791 | { |
799 | xfs_buf_log_item_t *bip = bp->b_fspriv; | 792 | xfs_buf_log_item_t *bip = bp->b_fspriv; |
800 | 793 | ||
801 | ASSERT(XFS_BUF_ISBUSY(bp)); | ||
802 | ASSERT(bp->b_transp == tp); | 794 | ASSERT(bp->b_transp == tp); |
803 | ASSERT(bip != NULL); | 795 | ASSERT(bip != NULL); |
804 | ASSERT(atomic_read(&bip->bli_refcount) > 0); | 796 | ASSERT(atomic_read(&bip->bli_refcount) > 0); |
@@ -823,7 +815,6 @@ xfs_trans_inode_alloc_buf( | |||
823 | { | 815 | { |
824 | xfs_buf_log_item_t *bip = bp->b_fspriv; | 816 | xfs_buf_log_item_t *bip = bp->b_fspriv; |
825 | 817 | ||
826 | ASSERT(XFS_BUF_ISBUSY(bp)); | ||
827 | ASSERT(bp->b_transp == tp); | 818 | ASSERT(bp->b_transp == tp); |
828 | ASSERT(bip != NULL); | 819 | ASSERT(bip != NULL); |
829 | ASSERT(atomic_read(&bip->bli_refcount) > 0); | 820 | ASSERT(atomic_read(&bip->bli_refcount) > 0); |
@@ -851,7 +842,6 @@ xfs_trans_dquot_buf( | |||
851 | { | 842 | { |
852 | xfs_buf_log_item_t *bip = bp->b_fspriv; | 843 | xfs_buf_log_item_t *bip = bp->b_fspriv; |
853 | 844 | ||
854 | ASSERT(XFS_BUF_ISBUSY(bp)); | ||
855 | ASSERT(bp->b_transp == tp); | 845 | ASSERT(bp->b_transp == tp); |
856 | ASSERT(bip != NULL); | 846 | ASSERT(bip != NULL); |
857 | ASSERT(type == XFS_BLF_UDQUOT_BUF || | 847 | ASSERT(type == XFS_BLF_UDQUOT_BUF || |
diff --git a/fs/xfs/xfs_vnodeops.c b/fs/xfs/xfs_vnodeops.c index 9322e13f0c63..51fc429527bc 100644 --- a/fs/xfs/xfs_vnodeops.c +++ b/fs/xfs/xfs_vnodeops.c | |||
@@ -83,7 +83,9 @@ xfs_readlink_bmap( | |||
83 | 83 | ||
84 | bp = xfs_buf_read(mp->m_ddev_targp, d, BTOBB(byte_cnt), | 84 | bp = xfs_buf_read(mp->m_ddev_targp, d, BTOBB(byte_cnt), |
85 | XBF_LOCK | XBF_MAPPED | XBF_DONT_BLOCK); | 85 | XBF_LOCK | XBF_MAPPED | XBF_DONT_BLOCK); |
86 | error = XFS_BUF_GETERROR(bp); | 86 | if (!bp) |
87 | return XFS_ERROR(ENOMEM); | ||
88 | error = bp->b_error; | ||
87 | if (error) { | 89 | if (error) { |
88 | xfs_ioerror_alert("xfs_readlink", | 90 | xfs_ioerror_alert("xfs_readlink", |
89 | ip->i_mount, bp, XFS_BUF_ADDR(bp)); | 91 | ip->i_mount, bp, XFS_BUF_ADDR(bp)); |
@@ -94,7 +96,7 @@ xfs_readlink_bmap( | |||
94 | byte_cnt = pathlen; | 96 | byte_cnt = pathlen; |
95 | pathlen -= byte_cnt; | 97 | pathlen -= byte_cnt; |
96 | 98 | ||
97 | memcpy(link, XFS_BUF_PTR(bp), byte_cnt); | 99 | memcpy(link, bp->b_addr, byte_cnt); |
98 | xfs_buf_relse(bp); | 100 | xfs_buf_relse(bp); |
99 | } | 101 | } |
100 | 102 | ||
@@ -1648,13 +1650,13 @@ xfs_symlink( | |||
1648 | byte_cnt = XFS_FSB_TO_B(mp, mval[n].br_blockcount); | 1650 | byte_cnt = XFS_FSB_TO_B(mp, mval[n].br_blockcount); |
1649 | bp = xfs_trans_get_buf(tp, mp->m_ddev_targp, d, | 1651 | bp = xfs_trans_get_buf(tp, mp->m_ddev_targp, d, |
1650 | BTOBB(byte_cnt), 0); | 1652 | BTOBB(byte_cnt), 0); |
1651 | ASSERT(bp && !XFS_BUF_GETERROR(bp)); | 1653 | ASSERT(!xfs_buf_geterror(bp)); |
1652 | if (pathlen < byte_cnt) { | 1654 | if (pathlen < byte_cnt) { |
1653 | byte_cnt = pathlen; | 1655 | byte_cnt = pathlen; |
1654 | } | 1656 | } |
1655 | pathlen -= byte_cnt; | 1657 | pathlen -= byte_cnt; |
1656 | 1658 | ||
1657 | memcpy(XFS_BUF_PTR(bp), cur_chunk, byte_cnt); | 1659 | memcpy(bp->b_addr, cur_chunk, byte_cnt); |
1658 | cur_chunk += byte_cnt; | 1660 | cur_chunk += byte_cnt; |
1659 | 1661 | ||
1660 | xfs_trans_log_buf(tp, bp, 0, byte_cnt - 1); | 1662 | xfs_trans_log_buf(tp, bp, 0, byte_cnt - 1); |
@@ -1999,7 +2001,7 @@ xfs_zero_remaining_bytes( | |||
1999 | mp, bp, XFS_BUF_ADDR(bp)); | 2001 | mp, bp, XFS_BUF_ADDR(bp)); |
2000 | break; | 2002 | break; |
2001 | } | 2003 | } |
2002 | memset(XFS_BUF_PTR(bp) + | 2004 | memset(bp->b_addr + |
2003 | (offset - XFS_FSB_TO_B(mp, imap.br_startoff)), | 2005 | (offset - XFS_FSB_TO_B(mp, imap.br_startoff)), |
2004 | 0, lastoffset - offset + 1); | 2006 | 0, lastoffset - offset + 1); |
2005 | XFS_BUF_UNDONE(bp); | 2007 | XFS_BUF_UNDONE(bp); |
diff --git a/include/linux/cred.h b/include/linux/cred.h index 98f46efbe2d2..40308969ed00 100644 --- a/include/linux/cred.h +++ b/include/linux/cred.h | |||
@@ -269,7 +269,7 @@ static inline void put_cred(const struct cred *_cred) | |||
269 | * since nobody else can modify it. | 269 | * since nobody else can modify it. |
270 | */ | 270 | */ |
271 | #define current_cred() \ | 271 | #define current_cred() \ |
272 | (*(__force struct cred **)¤t->cred) | 272 | rcu_dereference_protected(current->cred, 1) |
273 | 273 | ||
274 | /** | 274 | /** |
275 | * __task_cred - Access a task's objective credentials | 275 | * __task_cred - Access a task's objective credentials |
@@ -307,7 +307,7 @@ static inline void put_cred(const struct cred *_cred) | |||
307 | #define get_current_user() \ | 307 | #define get_current_user() \ |
308 | ({ \ | 308 | ({ \ |
309 | struct user_struct *__u; \ | 309 | struct user_struct *__u; \ |
310 | struct cred *__cred; \ | 310 | const struct cred *__cred; \ |
311 | __cred = current_cred(); \ | 311 | __cred = current_cred(); \ |
312 | __u = get_uid(__cred->user); \ | 312 | __u = get_uid(__cred->user); \ |
313 | __u; \ | 313 | __u; \ |
@@ -322,7 +322,7 @@ static inline void put_cred(const struct cred *_cred) | |||
322 | #define get_current_groups() \ | 322 | #define get_current_groups() \ |
323 | ({ \ | 323 | ({ \ |
324 | struct group_info *__groups; \ | 324 | struct group_info *__groups; \ |
325 | struct cred *__cred; \ | 325 | const struct cred *__cred; \ |
326 | __cred = current_cred(); \ | 326 | __cred = current_cred(); \ |
327 | __groups = get_group_info(__cred->group_info); \ | 327 | __groups = get_group_info(__cred->group_info); \ |
328 | __groups; \ | 328 | __groups; \ |
diff --git a/include/linux/mm.h b/include/linux/mm.h index f2690cf49827..fd599f4bb846 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h | |||
@@ -962,6 +962,8 @@ int invalidate_inode_page(struct page *page); | |||
962 | #ifdef CONFIG_MMU | 962 | #ifdef CONFIG_MMU |
963 | extern int handle_mm_fault(struct mm_struct *mm, struct vm_area_struct *vma, | 963 | extern int handle_mm_fault(struct mm_struct *mm, struct vm_area_struct *vma, |
964 | unsigned long address, unsigned int flags); | 964 | unsigned long address, unsigned int flags); |
965 | extern int fixup_user_fault(struct task_struct *tsk, struct mm_struct *mm, | ||
966 | unsigned long address, unsigned int fault_flags); | ||
965 | #else | 967 | #else |
966 | static inline int handle_mm_fault(struct mm_struct *mm, | 968 | static inline int handle_mm_fault(struct mm_struct *mm, |
967 | struct vm_area_struct *vma, unsigned long address, | 969 | struct vm_area_struct *vma, unsigned long address, |
@@ -971,6 +973,14 @@ static inline int handle_mm_fault(struct mm_struct *mm, | |||
971 | BUG(); | 973 | BUG(); |
972 | return VM_FAULT_SIGBUS; | 974 | return VM_FAULT_SIGBUS; |
973 | } | 975 | } |
976 | static inline int fixup_user_fault(struct task_struct *tsk, | ||
977 | struct mm_struct *mm, unsigned long address, | ||
978 | unsigned int fault_flags) | ||
979 | { | ||
980 | /* should never happen if there's no MMU */ | ||
981 | BUG(); | ||
982 | return -EFAULT; | ||
983 | } | ||
974 | #endif | 984 | #endif |
975 | 985 | ||
976 | extern int make_pages_present(unsigned long addr, unsigned long end); | 986 | extern int make_pages_present(unsigned long addr, unsigned long end); |
@@ -988,8 +998,6 @@ int get_user_pages(struct task_struct *tsk, struct mm_struct *mm, | |||
988 | int get_user_pages_fast(unsigned long start, int nr_pages, int write, | 998 | int get_user_pages_fast(unsigned long start, int nr_pages, int write, |
989 | struct page **pages); | 999 | struct page **pages); |
990 | struct page *get_dump_page(unsigned long addr); | 1000 | struct page *get_dump_page(unsigned long addr); |
991 | extern int fixup_user_fault(struct task_struct *tsk, struct mm_struct *mm, | ||
992 | unsigned long address, unsigned int fault_flags); | ||
993 | 1001 | ||
994 | extern int try_to_release_page(struct page * page, gfp_t gfp_mask); | 1002 | extern int try_to_release_page(struct page * page, gfp_t gfp_mask); |
995 | extern void do_invalidatepage(struct page *page, unsigned long offset); | 1003 | extern void do_invalidatepage(struct page *page, unsigned long offset); |
diff --git a/include/linux/of.h b/include/linux/of.h index 0085bb01c041..9180dc5cb00b 100644 --- a/include/linux/of.h +++ b/include/linux/of.h | |||
@@ -256,6 +256,13 @@ static inline int of_property_read_string(struct device_node *np, | |||
256 | return -ENOSYS; | 256 | return -ENOSYS; |
257 | } | 257 | } |
258 | 258 | ||
259 | static inline const void *of_get_property(const struct device_node *node, | ||
260 | const char *name, | ||
261 | int *lenp) | ||
262 | { | ||
263 | return NULL; | ||
264 | } | ||
265 | |||
259 | #endif /* CONFIG_OF */ | 266 | #endif /* CONFIG_OF */ |
260 | 267 | ||
261 | static inline int of_property_read_u32(const struct device_node *np, | 268 | static inline int of_property_read_u32(const struct device_node *np, |
diff --git a/include/linux/sched.h b/include/linux/sched.h index 20b03bf94748..4ac2c0578e0f 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h | |||
@@ -1767,6 +1767,7 @@ extern void thread_group_times(struct task_struct *p, cputime_t *ut, cputime_t * | |||
1767 | #define PF_DUMPCORE 0x00000200 /* dumped core */ | 1767 | #define PF_DUMPCORE 0x00000200 /* dumped core */ |
1768 | #define PF_SIGNALED 0x00000400 /* killed by a signal */ | 1768 | #define PF_SIGNALED 0x00000400 /* killed by a signal */ |
1769 | #define PF_MEMALLOC 0x00000800 /* Allocating memory */ | 1769 | #define PF_MEMALLOC 0x00000800 /* Allocating memory */ |
1770 | #define PF_NPROC_EXCEEDED 0x00001000 /* set_user noticed that RLIMIT_NPROC was exceeded */ | ||
1770 | #define PF_USED_MATH 0x00002000 /* if unset the fpu must be initialized before use */ | 1771 | #define PF_USED_MATH 0x00002000 /* if unset the fpu must be initialized before use */ |
1771 | #define PF_FREEZING 0x00004000 /* freeze in progress. do not account to load */ | 1772 | #define PF_FREEZING 0x00004000 /* freeze in progress. do not account to load */ |
1772 | #define PF_NOFREEZE 0x00008000 /* this thread should not be frozen */ | 1773 | #define PF_NOFREEZE 0x00008000 /* this thread should not be frozen */ |
diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h index f902c331217b..ea0b37463860 100644 --- a/include/linux/skbuff.h +++ b/include/linux/skbuff.h | |||
@@ -322,6 +322,8 @@ typedef unsigned char *sk_buff_data_t; | |||
322 | * @queue_mapping: Queue mapping for multiqueue devices | 322 | * @queue_mapping: Queue mapping for multiqueue devices |
323 | * @ndisc_nodetype: router type (from link layer) | 323 | * @ndisc_nodetype: router type (from link layer) |
324 | * @ooo_okay: allow the mapping of a socket to a queue to be changed | 324 | * @ooo_okay: allow the mapping of a socket to a queue to be changed |
325 | * @l4_rxhash: indicate rxhash is a canonical 4-tuple hash over transport | ||
326 | * ports. | ||
325 | * @dma_cookie: a cookie to one of several possible DMA operations | 327 | * @dma_cookie: a cookie to one of several possible DMA operations |
326 | * done by skb DMA functions | 328 | * done by skb DMA functions |
327 | * @secmark: security marking | 329 | * @secmark: security marking |
diff --git a/include/sound/wm8915.h b/include/sound/wm8996.h index 5817d762f6f3..ea4d88f43975 100644 --- a/include/sound/wm8915.h +++ b/include/sound/wm8996.h | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * linux/sound/wm8915.h -- Platform data for WM8915 | 2 | * linux/sound/wm8996.h -- Platform data for WM8996 |
3 | * | 3 | * |
4 | * Copyright 2011 Wolfson Microelectronics. PLC. | 4 | * Copyright 2011 Wolfson Microelectronics. PLC. |
5 | * | 5 | * |
@@ -8,14 +8,14 @@ | |||
8 | * published by the Free Software Foundation. | 8 | * published by the Free Software Foundation. |
9 | */ | 9 | */ |
10 | 10 | ||
11 | #ifndef __LINUX_SND_WM8903_H | 11 | #ifndef __LINUX_SND_WM8996_H |
12 | #define __LINUX_SND_WM8903_H | 12 | #define __LINUX_SND_WM8996_H |
13 | 13 | ||
14 | enum wm8915_inmode { | 14 | enum wm8996_inmode { |
15 | WM8915_DIFFERRENTIAL_1 = 0, /* IN1xP - IN1xN */ | 15 | WM8996_DIFFERRENTIAL_1 = 0, /* IN1xP - IN1xN */ |
16 | WM8915_INVERTING = 1, /* IN1xN */ | 16 | WM8996_INVERTING = 1, /* IN1xN */ |
17 | WM8915_NON_INVERTING = 2, /* IN1xP */ | 17 | WM8996_NON_INVERTING = 2, /* IN1xP */ |
18 | WM8915_DIFFERENTIAL_2 = 3, /* IN2xP - IN2xP */ | 18 | WM8996_DIFFERENTIAL_2 = 3, /* IN2xP - IN2xP */ |
19 | }; | 19 | }; |
20 | 20 | ||
21 | /** | 21 | /** |
@@ -25,23 +25,23 @@ enum wm8915_inmode { | |||
25 | * Configurations are expected to be generated using the ReTune Mobile | 25 | * Configurations are expected to be generated using the ReTune Mobile |
26 | * control panel in WISCE - see http://www.wolfsonmicro.com/wisce/ | 26 | * control panel in WISCE - see http://www.wolfsonmicro.com/wisce/ |
27 | */ | 27 | */ |
28 | struct wm8915_retune_mobile_config { | 28 | struct wm8996_retune_mobile_config { |
29 | const char *name; | 29 | const char *name; |
30 | int rate; | 30 | int rate; |
31 | u16 regs[20]; | 31 | u16 regs[20]; |
32 | }; | 32 | }; |
33 | 33 | ||
34 | #define WM8915_SET_DEFAULT 0x10000 | 34 | #define WM8996_SET_DEFAULT 0x10000 |
35 | 35 | ||
36 | struct wm8915_pdata { | 36 | struct wm8996_pdata { |
37 | int irq_flags; /** Set IRQ trigger flags; default active low */ | 37 | int irq_flags; /** Set IRQ trigger flags; default active low */ |
38 | 38 | ||
39 | int ldo_ena; /** GPIO for LDO1; -1 for none */ | 39 | int ldo_ena; /** GPIO for LDO1; -1 for none */ |
40 | 40 | ||
41 | int micdet_def; /** Default MICDET_SRC/HP1FB_SRC/MICD_BIAS */ | 41 | int micdet_def; /** Default MICDET_SRC/HP1FB_SRC/MICD_BIAS */ |
42 | 42 | ||
43 | enum wm8915_inmode inl_mode; | 43 | enum wm8996_inmode inl_mode; |
44 | enum wm8915_inmode inr_mode; | 44 | enum wm8996_inmode inr_mode; |
45 | 45 | ||
46 | u32 spkmute_seq; /** Value for register 0x802 */ | 46 | u32 spkmute_seq; /** Value for register 0x802 */ |
47 | 47 | ||
@@ -49,7 +49,7 @@ struct wm8915_pdata { | |||
49 | u32 gpio_default[5]; | 49 | u32 gpio_default[5]; |
50 | 50 | ||
51 | int num_retune_mobile_cfgs; | 51 | int num_retune_mobile_cfgs; |
52 | struct wm8915_retune_mobile_config *retune_mobile_cfgs; | 52 | struct wm8996_retune_mobile_config *retune_mobile_cfgs; |
53 | }; | 53 | }; |
54 | 54 | ||
55 | #endif | 55 | #endif |
diff --git a/kernel/Makefile b/kernel/Makefile index d06467fc8f7c..eca595e2fd52 100644 --- a/kernel/Makefile +++ b/kernel/Makefile | |||
@@ -10,7 +10,7 @@ obj-y = sched.o fork.o exec_domain.o panic.o printk.o \ | |||
10 | kthread.o wait.o kfifo.o sys_ni.o posix-cpu-timers.o mutex.o \ | 10 | kthread.o wait.o kfifo.o sys_ni.o posix-cpu-timers.o mutex.o \ |
11 | hrtimer.o rwsem.o nsproxy.o srcu.o semaphore.o \ | 11 | hrtimer.o rwsem.o nsproxy.o srcu.o semaphore.o \ |
12 | notifier.o ksysfs.o pm_qos_params.o sched_clock.o cred.o \ | 12 | notifier.o ksysfs.o pm_qos_params.o sched_clock.o cred.o \ |
13 | async.o range.o jump_label.o | 13 | async.o range.o |
14 | obj-y += groups.o | 14 | obj-y += groups.o |
15 | 15 | ||
16 | ifdef CONFIG_FUNCTION_TRACER | 16 | ifdef CONFIG_FUNCTION_TRACER |
@@ -107,6 +107,7 @@ obj-$(CONFIG_PERF_EVENTS) += events/ | |||
107 | obj-$(CONFIG_USER_RETURN_NOTIFIER) += user-return-notifier.o | 107 | obj-$(CONFIG_USER_RETURN_NOTIFIER) += user-return-notifier.o |
108 | obj-$(CONFIG_PADATA) += padata.o | 108 | obj-$(CONFIG_PADATA) += padata.o |
109 | obj-$(CONFIG_CRASH_DUMP) += crash_dump.o | 109 | obj-$(CONFIG_CRASH_DUMP) += crash_dump.o |
110 | obj-$(CONFIG_JUMP_LABEL) += jump_label.o | ||
110 | 111 | ||
111 | ifneq ($(CONFIG_SCHED_OMIT_FRAME_POINTER),y) | 112 | ifneq ($(CONFIG_SCHED_OMIT_FRAME_POINTER),y) |
112 | # According to Alan Modra <alan@linuxcare.com.au>, the -fno-omit-frame-pointer is | 113 | # According to Alan Modra <alan@linuxcare.com.au>, the -fno-omit-frame-pointer is |
diff --git a/kernel/cred.c b/kernel/cred.c index 174fa84eca30..8ef31f53c44c 100644 --- a/kernel/cred.c +++ b/kernel/cred.c | |||
@@ -508,10 +508,8 @@ int commit_creds(struct cred *new) | |||
508 | key_fsgid_changed(task); | 508 | key_fsgid_changed(task); |
509 | 509 | ||
510 | /* do it | 510 | /* do it |
511 | * - What if a process setreuid()'s and this brings the | 511 | * RLIMIT_NPROC limits on user->processes have already been checked |
512 | * new uid over his NPROC rlimit? We can check this now | 512 | * in set_user(). |
513 | * cheaply with the new uid cache, so if it matters | ||
514 | * we should be checking for it. -DaveM | ||
515 | */ | 513 | */ |
516 | alter_cred_subscribers(new, 2); | 514 | alter_cred_subscribers(new, 2); |
517 | if (new->user != old->user) | 515 | if (new->user != old->user) |
diff --git a/kernel/fork.c b/kernel/fork.c index e7ceaca89609..8e6b6f4fb272 100644 --- a/kernel/fork.c +++ b/kernel/fork.c | |||
@@ -1111,6 +1111,7 @@ static struct task_struct *copy_process(unsigned long clone_flags, | |||
1111 | p->real_cred->user != INIT_USER) | 1111 | p->real_cred->user != INIT_USER) |
1112 | goto bad_fork_free; | 1112 | goto bad_fork_free; |
1113 | } | 1113 | } |
1114 | current->flags &= ~PF_NPROC_EXCEEDED; | ||
1114 | 1115 | ||
1115 | retval = copy_creds(p, clone_flags); | 1116 | retval = copy_creds(p, clone_flags); |
1116 | if (retval < 0) | 1117 | if (retval < 0) |
diff --git a/kernel/printk.c b/kernel/printk.c index 37dff3429adb..836a2ae0ac31 100644 --- a/kernel/printk.c +++ b/kernel/printk.c | |||
@@ -318,8 +318,10 @@ static int check_syslog_permissions(int type, bool from_file) | |||
318 | return 0; | 318 | return 0; |
319 | /* For historical reasons, accept CAP_SYS_ADMIN too, with a warning */ | 319 | /* For historical reasons, accept CAP_SYS_ADMIN too, with a warning */ |
320 | if (capable(CAP_SYS_ADMIN)) { | 320 | if (capable(CAP_SYS_ADMIN)) { |
321 | WARN_ONCE(1, "Attempt to access syslog with CAP_SYS_ADMIN " | 321 | printk_once(KERN_WARNING "%s (%d): " |
322 | "but no CAP_SYSLOG (deprecated).\n"); | 322 | "Attempt to access syslog with CAP_SYS_ADMIN " |
323 | "but no CAP_SYSLOG (deprecated).\n", | ||
324 | current->comm, task_pid_nr(current)); | ||
323 | return 0; | 325 | return 0; |
324 | } | 326 | } |
325 | return -EPERM; | 327 | return -EPERM; |
diff --git a/kernel/sys.c b/kernel/sys.c index a101ba36c444..dd948a1fca4c 100644 --- a/kernel/sys.c +++ b/kernel/sys.c | |||
@@ -621,11 +621,18 @@ static int set_user(struct cred *new) | |||
621 | if (!new_user) | 621 | if (!new_user) |
622 | return -EAGAIN; | 622 | return -EAGAIN; |
623 | 623 | ||
624 | /* | ||
625 | * We don't fail in case of NPROC limit excess here because too many | ||
626 | * poorly written programs don't check set*uid() return code, assuming | ||
627 | * it never fails if called by root. We may still enforce NPROC limit | ||
628 | * for programs doing set*uid()+execve() by harmlessly deferring the | ||
629 | * failure to the execve() stage. | ||
630 | */ | ||
624 | if (atomic_read(&new_user->processes) >= rlimit(RLIMIT_NPROC) && | 631 | if (atomic_read(&new_user->processes) >= rlimit(RLIMIT_NPROC) && |
625 | new_user != INIT_USER) { | 632 | new_user != INIT_USER) |
626 | free_uid(new_user); | 633 | current->flags |= PF_NPROC_EXCEEDED; |
627 | return -EAGAIN; | 634 | else |
628 | } | 635 | current->flags &= ~PF_NPROC_EXCEEDED; |
629 | 636 | ||
630 | free_uid(new->user); | 637 | free_uid(new->user); |
631 | new->user = new_user; | 638 | new->user = new_user; |
diff --git a/kernel/trace/Kconfig b/kernel/trace/Kconfig index 2ad39e556cb4..cd3134510f3d 100644 --- a/kernel/trace/Kconfig +++ b/kernel/trace/Kconfig | |||
@@ -82,7 +82,7 @@ config EVENT_POWER_TRACING_DEPRECATED | |||
82 | power:power_frequency | 82 | power:power_frequency |
83 | This is for userspace compatibility | 83 | This is for userspace compatibility |
84 | and will vanish after 5 kernel iterations, | 84 | and will vanish after 5 kernel iterations, |
85 | namely 2.6.41. | 85 | namely 3.1. |
86 | 86 | ||
87 | config CONTEXT_SWITCH_TRACER | 87 | config CONTEXT_SWITCH_TRACER |
88 | bool | 88 | bool |
diff --git a/mm/memcontrol.c b/mm/memcontrol.c index f4ec4e7ca4cd..930de9437271 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c | |||
@@ -2091,6 +2091,7 @@ struct memcg_stock_pcp { | |||
2091 | #define FLUSHING_CACHED_CHARGE (0) | 2091 | #define FLUSHING_CACHED_CHARGE (0) |
2092 | }; | 2092 | }; |
2093 | static DEFINE_PER_CPU(struct memcg_stock_pcp, memcg_stock); | 2093 | static DEFINE_PER_CPU(struct memcg_stock_pcp, memcg_stock); |
2094 | static DEFINE_MUTEX(percpu_charge_mutex); | ||
2094 | 2095 | ||
2095 | /* | 2096 | /* |
2096 | * Try to consume stocked charge on this cpu. If success, one page is consumed | 2097 | * Try to consume stocked charge on this cpu. If success, one page is consumed |
@@ -2197,8 +2198,7 @@ static void drain_all_stock(struct mem_cgroup *root_mem, bool sync) | |||
2197 | 2198 | ||
2198 | for_each_online_cpu(cpu) { | 2199 | for_each_online_cpu(cpu) { |
2199 | struct memcg_stock_pcp *stock = &per_cpu(memcg_stock, cpu); | 2200 | struct memcg_stock_pcp *stock = &per_cpu(memcg_stock, cpu); |
2200 | if (mem_cgroup_same_or_subtree(root_mem, stock->cached) && | 2201 | if (test_bit(FLUSHING_CACHED_CHARGE, &stock->flags)) |
2201 | test_bit(FLUSHING_CACHED_CHARGE, &stock->flags)) | ||
2202 | flush_work(&stock->work); | 2202 | flush_work(&stock->work); |
2203 | } | 2203 | } |
2204 | out: | 2204 | out: |
@@ -2213,14 +2213,22 @@ out: | |||
2213 | */ | 2213 | */ |
2214 | static void drain_all_stock_async(struct mem_cgroup *root_mem) | 2214 | static void drain_all_stock_async(struct mem_cgroup *root_mem) |
2215 | { | 2215 | { |
2216 | /* | ||
2217 | * If someone calls draining, avoid adding more kworker runs. | ||
2218 | */ | ||
2219 | if (!mutex_trylock(&percpu_charge_mutex)) | ||
2220 | return; | ||
2216 | drain_all_stock(root_mem, false); | 2221 | drain_all_stock(root_mem, false); |
2222 | mutex_unlock(&percpu_charge_mutex); | ||
2217 | } | 2223 | } |
2218 | 2224 | ||
2219 | /* This is a synchronous drain interface. */ | 2225 | /* This is a synchronous drain interface. */ |
2220 | static void drain_all_stock_sync(struct mem_cgroup *root_mem) | 2226 | static void drain_all_stock_sync(struct mem_cgroup *root_mem) |
2221 | { | 2227 | { |
2222 | /* called when force_empty is called */ | 2228 | /* called when force_empty is called */ |
2229 | mutex_lock(&percpu_charge_mutex); | ||
2223 | drain_all_stock(root_mem, true); | 2230 | drain_all_stock(root_mem, true); |
2231 | mutex_unlock(&percpu_charge_mutex); | ||
2224 | } | 2232 | } |
2225 | 2233 | ||
2226 | /* | 2234 | /* |
@@ -701,7 +701,7 @@ static u8 *check_bytes(u8 *start, u8 value, unsigned int bytes) | |||
701 | return check_bytes8(start, value, bytes); | 701 | return check_bytes8(start, value, bytes); |
702 | 702 | ||
703 | value64 = value | value << 8 | value << 16 | value << 24; | 703 | value64 = value | value << 8 | value << 16 | value << 24; |
704 | value64 = value64 | value64 << 32; | 704 | value64 = (value64 & 0xffffffff) | value64 << 32; |
705 | prefix = 8 - ((unsigned long)start) % 8; | 705 | prefix = 8 - ((unsigned long)start) % 8; |
706 | 706 | ||
707 | if (prefix) { | 707 | if (prefix) { |
@@ -1854,7 +1854,7 @@ redo: | |||
1854 | 1854 | ||
1855 | new.frozen = 0; | 1855 | new.frozen = 0; |
1856 | 1856 | ||
1857 | if (!new.inuse && n->nr_partial < s->min_partial) | 1857 | if (!new.inuse && n->nr_partial > s->min_partial) |
1858 | m = M_FREE; | 1858 | m = M_FREE; |
1859 | else if (new.freelist) { | 1859 | else if (new.freelist) { |
1860 | m = M_PARTIAL; | 1860 | m = M_PARTIAL; |
@@ -2387,11 +2387,13 @@ static void __slab_free(struct kmem_cache *s, struct page *page, | |||
2387 | slab_empty: | 2387 | slab_empty: |
2388 | if (prior) { | 2388 | if (prior) { |
2389 | /* | 2389 | /* |
2390 | * Slab still on the partial list. | 2390 | * Slab on the partial list. |
2391 | */ | 2391 | */ |
2392 | remove_partial(n, page); | 2392 | remove_partial(n, page); |
2393 | stat(s, FREE_REMOVE_PARTIAL); | 2393 | stat(s, FREE_REMOVE_PARTIAL); |
2394 | } | 2394 | } else |
2395 | /* Slab must be on the full list */ | ||
2396 | remove_full(s, page); | ||
2395 | 2397 | ||
2396 | spin_unlock_irqrestore(&n->list_lock, flags); | 2398 | spin_unlock_irqrestore(&n->list_lock, flags); |
2397 | stat(s, FREE_SLAB); | 2399 | stat(s, FREE_SLAB); |
diff --git a/net/8021q/vlan_core.c b/net/8021q/vlan_core.c index 5f27f8e30254..f1f2f7bb6661 100644 --- a/net/8021q/vlan_core.c +++ b/net/8021q/vlan_core.c | |||
@@ -167,6 +167,8 @@ struct sk_buff *vlan_untag(struct sk_buff *skb) | |||
167 | if (unlikely(!skb)) | 167 | if (unlikely(!skb)) |
168 | goto err_free; | 168 | goto err_free; |
169 | 169 | ||
170 | skb_reset_network_header(skb); | ||
171 | skb_reset_transport_header(skb); | ||
170 | return skb; | 172 | return skb; |
171 | 173 | ||
172 | err_free: | 174 | err_free: |
diff --git a/net/bridge/br_if.c b/net/bridge/br_if.c index 3176e2e13d9b..2cdf0070419f 100644 --- a/net/bridge/br_if.c +++ b/net/bridge/br_if.c | |||
@@ -417,6 +417,7 @@ put_back: | |||
417 | int br_del_if(struct net_bridge *br, struct net_device *dev) | 417 | int br_del_if(struct net_bridge *br, struct net_device *dev) |
418 | { | 418 | { |
419 | struct net_bridge_port *p; | 419 | struct net_bridge_port *p; |
420 | bool changed_addr; | ||
420 | 421 | ||
421 | p = br_port_get_rtnl(dev); | 422 | p = br_port_get_rtnl(dev); |
422 | if (!p || p->br != br) | 423 | if (!p || p->br != br) |
@@ -425,9 +426,12 @@ int br_del_if(struct net_bridge *br, struct net_device *dev) | |||
425 | del_nbp(p); | 426 | del_nbp(p); |
426 | 427 | ||
427 | spin_lock_bh(&br->lock); | 428 | spin_lock_bh(&br->lock); |
428 | br_stp_recalculate_bridge_id(br); | 429 | changed_addr = br_stp_recalculate_bridge_id(br); |
429 | spin_unlock_bh(&br->lock); | 430 | spin_unlock_bh(&br->lock); |
430 | 431 | ||
432 | if (changed_addr) | ||
433 | call_netdevice_notifiers(NETDEV_CHANGEADDR, br->dev); | ||
434 | |||
431 | netdev_update_features(br->dev); | 435 | netdev_update_features(br->dev); |
432 | 436 | ||
433 | return 0; | 437 | return 0; |
diff --git a/net/bridge/br_notify.c b/net/bridge/br_notify.c index 6545ee9591d1..a76b62135558 100644 --- a/net/bridge/br_notify.c +++ b/net/bridge/br_notify.c | |||
@@ -34,6 +34,7 @@ static int br_device_event(struct notifier_block *unused, unsigned long event, v | |||
34 | struct net_device *dev = ptr; | 34 | struct net_device *dev = ptr; |
35 | struct net_bridge_port *p; | 35 | struct net_bridge_port *p; |
36 | struct net_bridge *br; | 36 | struct net_bridge *br; |
37 | bool changed_addr; | ||
37 | int err; | 38 | int err; |
38 | 39 | ||
39 | /* register of bridge completed, add sysfs entries */ | 40 | /* register of bridge completed, add sysfs entries */ |
@@ -57,8 +58,12 @@ static int br_device_event(struct notifier_block *unused, unsigned long event, v | |||
57 | case NETDEV_CHANGEADDR: | 58 | case NETDEV_CHANGEADDR: |
58 | spin_lock_bh(&br->lock); | 59 | spin_lock_bh(&br->lock); |
59 | br_fdb_changeaddr(p, dev->dev_addr); | 60 | br_fdb_changeaddr(p, dev->dev_addr); |
60 | br_stp_recalculate_bridge_id(br); | 61 | changed_addr = br_stp_recalculate_bridge_id(br); |
61 | spin_unlock_bh(&br->lock); | 62 | spin_unlock_bh(&br->lock); |
63 | |||
64 | if (changed_addr) | ||
65 | call_netdevice_notifiers(NETDEV_CHANGEADDR, br->dev); | ||
66 | |||
62 | break; | 67 | break; |
63 | 68 | ||
64 | case NETDEV_CHANGE: | 69 | case NETDEV_CHANGE: |
diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c index 2b5ca1a0054d..5864cc491369 100644 --- a/net/bridge/netfilter/ebtables.c +++ b/net/bridge/netfilter/ebtables.c | |||
@@ -1198,7 +1198,8 @@ ebt_register_table(struct net *net, const struct ebt_table *input_table) | |||
1198 | 1198 | ||
1199 | if (table->check && table->check(newinfo, table->valid_hooks)) { | 1199 | if (table->check && table->check(newinfo, table->valid_hooks)) { |
1200 | BUGPRINT("The table doesn't like its own initial data, lol\n"); | 1200 | BUGPRINT("The table doesn't like its own initial data, lol\n"); |
1201 | return ERR_PTR(-EINVAL); | 1201 | ret = -EINVAL; |
1202 | goto free_chainstack; | ||
1202 | } | 1203 | } |
1203 | 1204 | ||
1204 | table->private = newinfo; | 1205 | table->private = newinfo; |
diff --git a/net/core/scm.c b/net/core/scm.c index 4c1ef026d695..811b53fb330e 100644 --- a/net/core/scm.c +++ b/net/core/scm.c | |||
@@ -192,7 +192,7 @@ int __scm_send(struct socket *sock, struct msghdr *msg, struct scm_cookie *p) | |||
192 | goto error; | 192 | goto error; |
193 | 193 | ||
194 | cred->uid = cred->euid = p->creds.uid; | 194 | cred->uid = cred->euid = p->creds.uid; |
195 | cred->gid = cred->egid = p->creds.uid; | 195 | cred->gid = cred->egid = p->creds.gid; |
196 | put_cred(p->cred); | 196 | put_cred(p->cred); |
197 | p->cred = cred; | 197 | p->cred = cred; |
198 | } | 198 | } |
diff --git a/net/core/skbuff.c b/net/core/skbuff.c index edb66f3e24f1..e27334ec367a 100644 --- a/net/core/skbuff.c +++ b/net/core/skbuff.c | |||
@@ -529,6 +529,7 @@ static void __copy_skb_header(struct sk_buff *new, const struct sk_buff *old) | |||
529 | new->mac_header = old->mac_header; | 529 | new->mac_header = old->mac_header; |
530 | skb_dst_copy(new, old); | 530 | skb_dst_copy(new, old); |
531 | new->rxhash = old->rxhash; | 531 | new->rxhash = old->rxhash; |
532 | new->ooo_okay = old->ooo_okay; | ||
532 | new->l4_rxhash = old->l4_rxhash; | 533 | new->l4_rxhash = old->l4_rxhash; |
533 | #ifdef CONFIG_XFRM | 534 | #ifdef CONFIG_XFRM |
534 | new->sp = secpath_get(old->sp); | 535 | new->sp = secpath_get(old->sp); |
diff --git a/net/ipv4/route.c b/net/ipv4/route.c index d6e32138f712..2c21d3be891b 100644 --- a/net/ipv4/route.c +++ b/net/ipv4/route.c | |||
@@ -722,7 +722,7 @@ static inline bool compare_hash_inputs(const struct rtable *rt1, | |||
722 | { | 722 | { |
723 | return ((((__force u32)rt1->rt_key_dst ^ (__force u32)rt2->rt_key_dst) | | 723 | return ((((__force u32)rt1->rt_key_dst ^ (__force u32)rt2->rt_key_dst) | |
724 | ((__force u32)rt1->rt_key_src ^ (__force u32)rt2->rt_key_src) | | 724 | ((__force u32)rt1->rt_key_src ^ (__force u32)rt2->rt_key_src) | |
725 | (rt1->rt_iif ^ rt2->rt_iif)) == 0); | 725 | (rt1->rt_route_iif ^ rt2->rt_route_iif)) == 0); |
726 | } | 726 | } |
727 | 727 | ||
728 | static inline int compare_keys(struct rtable *rt1, struct rtable *rt2) | 728 | static inline int compare_keys(struct rtable *rt1, struct rtable *rt2) |
@@ -732,8 +732,7 @@ static inline int compare_keys(struct rtable *rt1, struct rtable *rt2) | |||
732 | (rt1->rt_mark ^ rt2->rt_mark) | | 732 | (rt1->rt_mark ^ rt2->rt_mark) | |
733 | (rt1->rt_key_tos ^ rt2->rt_key_tos) | | 733 | (rt1->rt_key_tos ^ rt2->rt_key_tos) | |
734 | (rt1->rt_route_iif ^ rt2->rt_route_iif) | | 734 | (rt1->rt_route_iif ^ rt2->rt_route_iif) | |
735 | (rt1->rt_oif ^ rt2->rt_oif) | | 735 | (rt1->rt_oif ^ rt2->rt_oif)) == 0; |
736 | (rt1->rt_iif ^ rt2->rt_iif)) == 0; | ||
737 | } | 736 | } |
738 | 737 | ||
739 | static inline int compare_netns(struct rtable *rt1, struct rtable *rt2) | 738 | static inline int compare_netns(struct rtable *rt1, struct rtable *rt2) |
@@ -2321,9 +2320,8 @@ int ip_route_input_common(struct sk_buff *skb, __be32 daddr, __be32 saddr, | |||
2321 | rth = rcu_dereference(rth->dst.rt_next)) { | 2320 | rth = rcu_dereference(rth->dst.rt_next)) { |
2322 | if ((((__force u32)rth->rt_key_dst ^ (__force u32)daddr) | | 2321 | if ((((__force u32)rth->rt_key_dst ^ (__force u32)daddr) | |
2323 | ((__force u32)rth->rt_key_src ^ (__force u32)saddr) | | 2322 | ((__force u32)rth->rt_key_src ^ (__force u32)saddr) | |
2324 | (rth->rt_iif ^ iif) | | 2323 | (rth->rt_route_iif ^ iif) | |
2325 | (rth->rt_key_tos ^ tos)) == 0 && | 2324 | (rth->rt_key_tos ^ tos)) == 0 && |
2326 | rt_is_input_route(rth) && | ||
2327 | rth->rt_mark == skb->mark && | 2325 | rth->rt_mark == skb->mark && |
2328 | net_eq(dev_net(rth->dst.dev), net) && | 2326 | net_eq(dev_net(rth->dst.dev), net) && |
2329 | !rt_is_expired(rth)) { | 2327 | !rt_is_expired(rth)) { |
diff --git a/net/ipv4/syncookies.c b/net/ipv4/syncookies.c index 92bb9434b338..3bc5c8f7c71b 100644 --- a/net/ipv4/syncookies.c +++ b/net/ipv4/syncookies.c | |||
@@ -276,7 +276,7 @@ struct sock *cookie_v4_check(struct sock *sk, struct sk_buff *skb, | |||
276 | int mss; | 276 | int mss; |
277 | struct rtable *rt; | 277 | struct rtable *rt; |
278 | __u8 rcv_wscale; | 278 | __u8 rcv_wscale; |
279 | bool ecn_ok; | 279 | bool ecn_ok = false; |
280 | 280 | ||
281 | if (!sysctl_tcp_syncookies || !th->ack || th->rst) | 281 | if (!sysctl_tcp_syncookies || !th->ack || th->rst) |
282 | goto out; | 282 | goto out; |
diff --git a/net/ipv6/ipv6_sockglue.c b/net/ipv6/ipv6_sockglue.c index 9cb191ecaba8..147ede38ab48 100644 --- a/net/ipv6/ipv6_sockglue.c +++ b/net/ipv6/ipv6_sockglue.c | |||
@@ -913,7 +913,7 @@ static int ipv6_getsockopt_sticky(struct sock *sk, struct ipv6_txoptions *opt, | |||
913 | } | 913 | } |
914 | 914 | ||
915 | static int do_ipv6_getsockopt(struct sock *sk, int level, int optname, | 915 | static int do_ipv6_getsockopt(struct sock *sk, int level, int optname, |
916 | char __user *optval, int __user *optlen) | 916 | char __user *optval, int __user *optlen, unsigned flags) |
917 | { | 917 | { |
918 | struct ipv6_pinfo *np = inet6_sk(sk); | 918 | struct ipv6_pinfo *np = inet6_sk(sk); |
919 | int len; | 919 | int len; |
@@ -962,7 +962,7 @@ static int do_ipv6_getsockopt(struct sock *sk, int level, int optname, | |||
962 | 962 | ||
963 | msg.msg_control = optval; | 963 | msg.msg_control = optval; |
964 | msg.msg_controllen = len; | 964 | msg.msg_controllen = len; |
965 | msg.msg_flags = 0; | 965 | msg.msg_flags = flags; |
966 | 966 | ||
967 | lock_sock(sk); | 967 | lock_sock(sk); |
968 | skb = np->pktoptions; | 968 | skb = np->pktoptions; |
@@ -1222,7 +1222,7 @@ int ipv6_getsockopt(struct sock *sk, int level, int optname, | |||
1222 | if(level != SOL_IPV6) | 1222 | if(level != SOL_IPV6) |
1223 | return -ENOPROTOOPT; | 1223 | return -ENOPROTOOPT; |
1224 | 1224 | ||
1225 | err = do_ipv6_getsockopt(sk, level, optname, optval, optlen); | 1225 | err = do_ipv6_getsockopt(sk, level, optname, optval, optlen, 0); |
1226 | #ifdef CONFIG_NETFILTER | 1226 | #ifdef CONFIG_NETFILTER |
1227 | /* we need to exclude all possible ENOPROTOOPTs except default case */ | 1227 | /* we need to exclude all possible ENOPROTOOPTs except default case */ |
1228 | if (err == -ENOPROTOOPT && optname != IPV6_2292PKTOPTIONS) { | 1228 | if (err == -ENOPROTOOPT && optname != IPV6_2292PKTOPTIONS) { |
@@ -1264,7 +1264,8 @@ int compat_ipv6_getsockopt(struct sock *sk, int level, int optname, | |||
1264 | return compat_mc_getsockopt(sk, level, optname, optval, optlen, | 1264 | return compat_mc_getsockopt(sk, level, optname, optval, optlen, |
1265 | ipv6_getsockopt); | 1265 | ipv6_getsockopt); |
1266 | 1266 | ||
1267 | err = do_ipv6_getsockopt(sk, level, optname, optval, optlen); | 1267 | err = do_ipv6_getsockopt(sk, level, optname, optval, optlen, |
1268 | MSG_CMSG_COMPAT); | ||
1268 | #ifdef CONFIG_NETFILTER | 1269 | #ifdef CONFIG_NETFILTER |
1269 | /* we need to exclude all possible ENOPROTOOPTs except default case */ | 1270 | /* we need to exclude all possible ENOPROTOOPTs except default case */ |
1270 | if (err == -ENOPROTOOPT && optname != IPV6_2292PKTOPTIONS) { | 1271 | if (err == -ENOPROTOOPT && optname != IPV6_2292PKTOPTIONS) { |
diff --git a/net/ipv6/sit.c b/net/ipv6/sit.c index e48a41c133f1..a7a18602a046 100644 --- a/net/ipv6/sit.c +++ b/net/ipv6/sit.c | |||
@@ -672,6 +672,9 @@ static netdev_tx_t ipip6_tunnel_xmit(struct sk_buff *skb, | |||
672 | if (skb->protocol != htons(ETH_P_IPV6)) | 672 | if (skb->protocol != htons(ETH_P_IPV6)) |
673 | goto tx_error; | 673 | goto tx_error; |
674 | 674 | ||
675 | if (tos == 1) | ||
676 | tos = ipv6_get_dsfield(iph6); | ||
677 | |||
675 | /* ISATAP (RFC4214) - must come before 6to4 */ | 678 | /* ISATAP (RFC4214) - must come before 6to4 */ |
676 | if (dev->priv_flags & IFF_ISATAP) { | 679 | if (dev->priv_flags & IFF_ISATAP) { |
677 | struct neighbour *neigh = NULL; | 680 | struct neighbour *neigh = NULL; |
diff --git a/net/ipv6/syncookies.c b/net/ipv6/syncookies.c index 89d5bf806222..ac838965ff34 100644 --- a/net/ipv6/syncookies.c +++ b/net/ipv6/syncookies.c | |||
@@ -165,7 +165,7 @@ struct sock *cookie_v6_check(struct sock *sk, struct sk_buff *skb) | |||
165 | int mss; | 165 | int mss; |
166 | struct dst_entry *dst; | 166 | struct dst_entry *dst; |
167 | __u8 rcv_wscale; | 167 | __u8 rcv_wscale; |
168 | bool ecn_ok; | 168 | bool ecn_ok = false; |
169 | 169 | ||
170 | if (!sysctl_tcp_syncookies || !th->ack || th->rst) | 170 | if (!sysctl_tcp_syncookies || !th->ack || th->rst) |
171 | goto out; | 171 | goto out; |
diff --git a/net/netlabel/netlabel_kapi.c b/net/netlabel/netlabel_kapi.c index 58107d060846..9c24de10a657 100644 --- a/net/netlabel/netlabel_kapi.c +++ b/net/netlabel/netlabel_kapi.c | |||
@@ -341,11 +341,11 @@ int netlbl_cfg_cipsov4_map_add(u32 doi, | |||
341 | 341 | ||
342 | entry = kzalloc(sizeof(*entry), GFP_ATOMIC); | 342 | entry = kzalloc(sizeof(*entry), GFP_ATOMIC); |
343 | if (entry == NULL) | 343 | if (entry == NULL) |
344 | return -ENOMEM; | 344 | goto out_entry; |
345 | if (domain != NULL) { | 345 | if (domain != NULL) { |
346 | entry->domain = kstrdup(domain, GFP_ATOMIC); | 346 | entry->domain = kstrdup(domain, GFP_ATOMIC); |
347 | if (entry->domain == NULL) | 347 | if (entry->domain == NULL) |
348 | goto cfg_cipsov4_map_add_failure; | 348 | goto out_domain; |
349 | } | 349 | } |
350 | 350 | ||
351 | if (addr == NULL && mask == NULL) { | 351 | if (addr == NULL && mask == NULL) { |
@@ -354,13 +354,13 @@ int netlbl_cfg_cipsov4_map_add(u32 doi, | |||
354 | } else if (addr != NULL && mask != NULL) { | 354 | } else if (addr != NULL && mask != NULL) { |
355 | addrmap = kzalloc(sizeof(*addrmap), GFP_ATOMIC); | 355 | addrmap = kzalloc(sizeof(*addrmap), GFP_ATOMIC); |
356 | if (addrmap == NULL) | 356 | if (addrmap == NULL) |
357 | goto cfg_cipsov4_map_add_failure; | 357 | goto out_addrmap; |
358 | INIT_LIST_HEAD(&addrmap->list4); | 358 | INIT_LIST_HEAD(&addrmap->list4); |
359 | INIT_LIST_HEAD(&addrmap->list6); | 359 | INIT_LIST_HEAD(&addrmap->list6); |
360 | 360 | ||
361 | addrinfo = kzalloc(sizeof(*addrinfo), GFP_ATOMIC); | 361 | addrinfo = kzalloc(sizeof(*addrinfo), GFP_ATOMIC); |
362 | if (addrinfo == NULL) | 362 | if (addrinfo == NULL) |
363 | goto cfg_cipsov4_map_add_failure; | 363 | goto out_addrinfo; |
364 | addrinfo->type_def.cipsov4 = doi_def; | 364 | addrinfo->type_def.cipsov4 = doi_def; |
365 | addrinfo->type = NETLBL_NLTYPE_CIPSOV4; | 365 | addrinfo->type = NETLBL_NLTYPE_CIPSOV4; |
366 | addrinfo->list.addr = addr->s_addr & mask->s_addr; | 366 | addrinfo->list.addr = addr->s_addr & mask->s_addr; |
@@ -374,7 +374,7 @@ int netlbl_cfg_cipsov4_map_add(u32 doi, | |||
374 | entry->type = NETLBL_NLTYPE_ADDRSELECT; | 374 | entry->type = NETLBL_NLTYPE_ADDRSELECT; |
375 | } else { | 375 | } else { |
376 | ret_val = -EINVAL; | 376 | ret_val = -EINVAL; |
377 | goto cfg_cipsov4_map_add_failure; | 377 | goto out_addrmap; |
378 | } | 378 | } |
379 | 379 | ||
380 | ret_val = netlbl_domhsh_add(entry, audit_info); | 380 | ret_val = netlbl_domhsh_add(entry, audit_info); |
@@ -384,11 +384,15 @@ int netlbl_cfg_cipsov4_map_add(u32 doi, | |||
384 | return 0; | 384 | return 0; |
385 | 385 | ||
386 | cfg_cipsov4_map_add_failure: | 386 | cfg_cipsov4_map_add_failure: |
387 | cipso_v4_doi_putdef(doi_def); | 387 | kfree(addrinfo); |
388 | out_addrinfo: | ||
389 | kfree(addrmap); | ||
390 | out_addrmap: | ||
388 | kfree(entry->domain); | 391 | kfree(entry->domain); |
392 | out_domain: | ||
389 | kfree(entry); | 393 | kfree(entry); |
390 | kfree(addrmap); | 394 | out_entry: |
391 | kfree(addrinfo); | 395 | cipso_v4_doi_putdef(doi_def); |
392 | return ret_val; | 396 | return ret_val; |
393 | } | 397 | } |
394 | 398 | ||
diff --git a/net/sched/act_mirred.c b/net/sched/act_mirred.c index 102fc212cd64..e051398fdf6b 100644 --- a/net/sched/act_mirred.c +++ b/net/sched/act_mirred.c | |||
@@ -196,8 +196,7 @@ static int tcf_mirred(struct sk_buff *skb, const struct tc_action *a, | |||
196 | 196 | ||
197 | skb2->skb_iif = skb->dev->ifindex; | 197 | skb2->skb_iif = skb->dev->ifindex; |
198 | skb2->dev = dev; | 198 | skb2->dev = dev; |
199 | dev_queue_xmit(skb2); | 199 | err = dev_queue_xmit(skb2); |
200 | err = 0; | ||
201 | 200 | ||
202 | out: | 201 | out: |
203 | if (err) { | 202 | if (err) { |
diff --git a/net/sched/sch_prio.c b/net/sched/sch_prio.c index 2a318f2dc3e5..b5d56a22b1d2 100644 --- a/net/sched/sch_prio.c +++ b/net/sched/sch_prio.c | |||
@@ -112,7 +112,7 @@ static struct sk_buff *prio_dequeue(struct Qdisc *sch) | |||
112 | 112 | ||
113 | for (prio = 0; prio < q->bands; prio++) { | 113 | for (prio = 0; prio < q->bands; prio++) { |
114 | struct Qdisc *qdisc = q->queues[prio]; | 114 | struct Qdisc *qdisc = q->queues[prio]; |
115 | struct sk_buff *skb = qdisc->dequeue(qdisc); | 115 | struct sk_buff *skb = qdisc_dequeue_peeked(qdisc); |
116 | if (skb) { | 116 | if (skb) { |
117 | qdisc_bstats_update(sch, skb); | 117 | qdisc_bstats_update(sch, skb); |
118 | sch->q.qlen--; | 118 | sch->q.qlen--; |
diff --git a/security/tomoyo/common.c b/security/tomoyo/common.c index c8439cf2a448..2e43aec1c36b 100644 --- a/security/tomoyo/common.c +++ b/security/tomoyo/common.c | |||
@@ -710,8 +710,10 @@ static void tomoyo_read_profile(struct tomoyo_io_buffer *head) | |||
710 | head->r.index++) | 710 | head->r.index++) |
711 | if (ns->profile_ptr[head->r.index]) | 711 | if (ns->profile_ptr[head->r.index]) |
712 | break; | 712 | break; |
713 | if (head->r.index == TOMOYO_MAX_PROFILES) | 713 | if (head->r.index == TOMOYO_MAX_PROFILES) { |
714 | head->r.eof = true; | ||
714 | return; | 715 | return; |
716 | } | ||
715 | head->r.step++; | 717 | head->r.step++; |
716 | break; | 718 | break; |
717 | case 2: | 719 | case 2: |
@@ -723,6 +725,7 @@ static void tomoyo_read_profile(struct tomoyo_io_buffer *head) | |||
723 | tomoyo_io_printf(head, "%u-COMMENT=", index); | 725 | tomoyo_io_printf(head, "%u-COMMENT=", index); |
724 | tomoyo_set_string(head, comment ? comment->name : ""); | 726 | tomoyo_set_string(head, comment ? comment->name : ""); |
725 | tomoyo_set_lf(head); | 727 | tomoyo_set_lf(head); |
728 | tomoyo_print_namespace(head); | ||
726 | tomoyo_io_printf(head, "%u-PREFERENCE={ ", index); | 729 | tomoyo_io_printf(head, "%u-PREFERENCE={ ", index); |
727 | for (i = 0; i < TOMOYO_MAX_PREF; i++) | 730 | for (i = 0; i < TOMOYO_MAX_PREF; i++) |
728 | tomoyo_io_printf(head, "%s=%u ", | 731 | tomoyo_io_printf(head, "%s=%u ", |
diff --git a/sound/core/timer.c b/sound/core/timer.c index 7c1cbf0a0dc4..67ebf1c21c04 100644 --- a/sound/core/timer.c +++ b/sound/core/timer.c | |||
@@ -328,6 +328,8 @@ int snd_timer_close(struct snd_timer_instance *timeri) | |||
328 | mutex_unlock(®ister_mutex); | 328 | mutex_unlock(®ister_mutex); |
329 | } else { | 329 | } else { |
330 | timer = timeri->timer; | 330 | timer = timeri->timer; |
331 | if (snd_BUG_ON(!timer)) | ||
332 | goto out; | ||
331 | /* wait, until the active callback is finished */ | 333 | /* wait, until the active callback is finished */ |
332 | spin_lock_irq(&timer->lock); | 334 | spin_lock_irq(&timer->lock); |
333 | while (timeri->flags & SNDRV_TIMER_IFLG_CALLBACK) { | 335 | while (timeri->flags & SNDRV_TIMER_IFLG_CALLBACK) { |
@@ -353,6 +355,7 @@ int snd_timer_close(struct snd_timer_instance *timeri) | |||
353 | } | 355 | } |
354 | mutex_unlock(®ister_mutex); | 356 | mutex_unlock(®ister_mutex); |
355 | } | 357 | } |
358 | out: | ||
356 | if (timeri->private_free) | 359 | if (timeri->private_free) |
357 | timeri->private_free(timeri); | 360 | timeri->private_free(timeri); |
358 | kfree(timeri->owner); | 361 | kfree(timeri->owner); |
@@ -531,6 +534,8 @@ int snd_timer_stop(struct snd_timer_instance *timeri) | |||
531 | if (err < 0) | 534 | if (err < 0) |
532 | return err; | 535 | return err; |
533 | timer = timeri->timer; | 536 | timer = timeri->timer; |
537 | if (!timer) | ||
538 | return -EINVAL; | ||
534 | spin_lock_irqsave(&timer->lock, flags); | 539 | spin_lock_irqsave(&timer->lock, flags); |
535 | timeri->cticks = timeri->ticks; | 540 | timeri->cticks = timeri->ticks; |
536 | timeri->pticks = 0; | 541 | timeri->pticks = 0; |
diff --git a/sound/oss/pas2_pcm.c b/sound/oss/pas2_pcm.c index 8f7d175767a2..6f13ab4afc6b 100644 --- a/sound/oss/pas2_pcm.c +++ b/sound/oss/pas2_pcm.c | |||
@@ -63,13 +63,13 @@ static int pcm_set_speed(int arg) | |||
63 | 63 | ||
64 | if (pcm_channels & 2) | 64 | if (pcm_channels & 2) |
65 | { | 65 | { |
66 | foo = ((CLOCK_TICK_RATE / 2) + (arg / 2)) / arg; | 66 | foo = ((PIT_TICK_RATE / 2) + (arg / 2)) / arg; |
67 | arg = ((CLOCK_TICK_RATE / 2) + (foo / 2)) / foo; | 67 | arg = ((PIT_TICK_RATE / 2) + (foo / 2)) / foo; |
68 | } | 68 | } |
69 | else | 69 | else |
70 | { | 70 | { |
71 | foo = (CLOCK_TICK_RATE + (arg / 2)) / arg; | 71 | foo = (PIT_TICK_RATE + (arg / 2)) / arg; |
72 | arg = (CLOCK_TICK_RATE + (foo / 2)) / foo; | 72 | arg = (PIT_TICK_RATE + (foo / 2)) / foo; |
73 | } | 73 | } |
74 | 74 | ||
75 | pcm_speed = arg; | 75 | pcm_speed = arg; |
diff --git a/sound/oss/pss.c b/sound/oss/pss.c index 9b800ce5100e..2fc0624024b5 100644 --- a/sound/oss/pss.c +++ b/sound/oss/pss.c | |||
@@ -673,7 +673,8 @@ static void configure_nonsound_components(void) | |||
673 | 673 | ||
674 | if (pss_cdrom_port == -1) { /* If cdrom port enablation wasn't requested */ | 674 | if (pss_cdrom_port == -1) { /* If cdrom port enablation wasn't requested */ |
675 | printk(KERN_INFO "PSS: CDROM port not enabled.\n"); | 675 | printk(KERN_INFO "PSS: CDROM port not enabled.\n"); |
676 | } else if (check_region(pss_cdrom_port, 2)) { | 676 | } else if (!request_region(pss_cdrom_port, 2, "PSS CDROM")) { |
677 | pss_cdrom_port = -1; | ||
677 | printk(KERN_ERR "PSS: CDROM I/O port conflict.\n"); | 678 | printk(KERN_ERR "PSS: CDROM I/O port conflict.\n"); |
678 | } else { | 679 | } else { |
679 | set_io_base(devc, CONF_CDROM, pss_cdrom_port); | 680 | set_io_base(devc, CONF_CDROM, pss_cdrom_port); |
@@ -1232,7 +1233,8 @@ static void __exit cleanup_pss(void) | |||
1232 | if(pssmpu) | 1233 | if(pssmpu) |
1233 | unload_pss_mpu(&cfg_mpu); | 1234 | unload_pss_mpu(&cfg_mpu); |
1234 | unload_pss(&cfg); | 1235 | unload_pss(&cfg); |
1235 | } | 1236 | } else if (pss_cdrom_port != -1) |
1237 | release_region(pss_cdrom_port, 2); | ||
1236 | 1238 | ||
1237 | if(!pss_keep_settings) /* Keep hardware settings if asked */ | 1239 | if(!pss_keep_settings) /* Keep hardware settings if asked */ |
1238 | { | 1240 | { |
diff --git a/sound/pci/Kconfig b/sound/pci/Kconfig index 50abf5bf8e09..88168044375f 100644 --- a/sound/pci/Kconfig +++ b/sound/pci/Kconfig | |||
@@ -1,5 +1,10 @@ | |||
1 | # ALSA PCI drivers | 1 | # ALSA PCI drivers |
2 | 2 | ||
3 | config SND_TEA575X | ||
4 | tristate | ||
5 | depends on SND_FM801_TEA575X_BOOL || SND_ES1968_RADIO || RADIO_SF16FMR2 | ||
6 | default SND_FM801 || SND_ES1968 || RADIO_SF16FMR2 | ||
7 | |||
3 | menuconfig SND_PCI | 8 | menuconfig SND_PCI |
4 | bool "PCI sound devices" | 9 | bool "PCI sound devices" |
5 | depends on PCI | 10 | depends on PCI |
@@ -563,11 +568,6 @@ config SND_FM801_TEA575X_BOOL | |||
563 | FM801 chip with a TEA5757 tuner (MediaForte SF256-PCS, SF256-PCP and | 568 | FM801 chip with a TEA5757 tuner (MediaForte SF256-PCS, SF256-PCP and |
564 | SF64-PCR) into the snd-fm801 driver. | 569 | SF64-PCR) into the snd-fm801 driver. |
565 | 570 | ||
566 | config SND_TEA575X | ||
567 | tristate | ||
568 | depends on SND_FM801_TEA575X_BOOL || SND_ES1968_RADIO || RADIO_SF16FMR2 | ||
569 | default SND_FM801 || SND_ES1968 || RADIO_SF16FMR2 | ||
570 | |||
571 | source "sound/pci/hda/Kconfig" | 571 | source "sound/pci/hda/Kconfig" |
572 | 572 | ||
573 | config SND_HDSP | 573 | config SND_HDSP |
diff --git a/sound/pci/asihpi/hpicmn.c b/sound/pci/asihpi/hpicmn.c index 65b7ca13115b..bd47521b24ec 100644 --- a/sound/pci/asihpi/hpicmn.c +++ b/sound/pci/asihpi/hpicmn.c | |||
@@ -631,13 +631,12 @@ struct hpi_control_cache *hpi_alloc_control_cache(const u32 control_count, | |||
631 | if (!p_cache) | 631 | if (!p_cache) |
632 | return NULL; | 632 | return NULL; |
633 | 633 | ||
634 | p_cache->p_info = | 634 | p_cache->p_info = kzalloc(sizeof(*p_cache->p_info) * control_count, |
635 | kmalloc(sizeof(*p_cache->p_info) * control_count, GFP_KERNEL); | 635 | GFP_KERNEL); |
636 | if (!p_cache->p_info) { | 636 | if (!p_cache->p_info) { |
637 | kfree(p_cache); | 637 | kfree(p_cache); |
638 | return NULL; | 638 | return NULL; |
639 | } | 639 | } |
640 | memset(p_cache->p_info, 0, sizeof(*p_cache->p_info) * control_count); | ||
641 | p_cache->cache_size_in_bytes = size_in_bytes; | 640 | p_cache->cache_size_in_bytes = size_in_bytes; |
642 | p_cache->control_count = control_count; | 641 | p_cache->control_count = control_count; |
643 | p_cache->p_cache = p_dsp_control_buffer; | 642 | p_cache->p_cache = p_dsp_control_buffer; |
diff --git a/sound/pci/hda/alc269_quirks.c b/sound/pci/hda/alc269_quirks.c index 14fdcf29b154..5ac0e2162a46 100644 --- a/sound/pci/hda/alc269_quirks.c +++ b/sound/pci/hda/alc269_quirks.c | |||
@@ -531,17 +531,10 @@ static const struct snd_pci_quirk alc269_cfg_tbl[] = { | |||
531 | SND_PCI_QUIRK(0x1043, 0x1653, "ASUS U50", ALC269_AMIC), | 531 | SND_PCI_QUIRK(0x1043, 0x1653, "ASUS U50", ALC269_AMIC), |
532 | SND_PCI_QUIRK(0x1043, 0x1693, "ASUS F50N", ALC269_AMIC), | 532 | SND_PCI_QUIRK(0x1043, 0x1693, "ASUS F50N", ALC269_AMIC), |
533 | SND_PCI_QUIRK(0x1043, 0x16a3, "ASUS F5Q", ALC269_AMIC), | 533 | SND_PCI_QUIRK(0x1043, 0x16a3, "ASUS F5Q", ALC269_AMIC), |
534 | SND_PCI_QUIRK(0x1043, 0x16e3, "ASUS UX50", ALC269_DMIC), | ||
535 | SND_PCI_QUIRK(0x1043, 0x1723, "ASUS P80", ALC269_AMIC), | 534 | SND_PCI_QUIRK(0x1043, 0x1723, "ASUS P80", ALC269_AMIC), |
536 | SND_PCI_QUIRK(0x1043, 0x1743, "ASUS U80", ALC269_AMIC), | 535 | SND_PCI_QUIRK(0x1043, 0x1743, "ASUS U80", ALC269_AMIC), |
537 | SND_PCI_QUIRK(0x1043, 0x1773, "ASUS U20A", ALC269_AMIC), | 536 | SND_PCI_QUIRK(0x1043, 0x1773, "ASUS U20A", ALC269_AMIC), |
538 | SND_PCI_QUIRK(0x1043, 0x1883, "ASUS F81Se", ALC269_AMIC), | 537 | SND_PCI_QUIRK(0x1043, 0x1883, "ASUS F81Se", ALC269_AMIC), |
539 | SND_PCI_QUIRK(0x1043, 0x831a, "ASUS Eeepc P901", | ||
540 | ALC269_DMIC), | ||
541 | SND_PCI_QUIRK(0x1043, 0x834a, "ASUS Eeepc S101", | ||
542 | ALC269_DMIC), | ||
543 | SND_PCI_QUIRK(0x1043, 0x8398, "ASUS P1005HA", ALC269_DMIC), | ||
544 | SND_PCI_QUIRK(0x1043, 0x83ce, "ASUS P1005HA", ALC269_DMIC), | ||
545 | SND_PCI_QUIRK(0x104d, 0x9071, "Sony VAIO", ALC269_AUTO), | 538 | SND_PCI_QUIRK(0x104d, 0x9071, "Sony VAIO", ALC269_AUTO), |
546 | SND_PCI_QUIRK(0x10cf, 0x1475, "Lifebook ICH9M-based", ALC269_LIFEBOOK), | 539 | SND_PCI_QUIRK(0x10cf, 0x1475, "Lifebook ICH9M-based", ALC269_LIFEBOOK), |
547 | SND_PCI_QUIRK(0x152d, 0x1778, "Quanta ON1", ALC269_DMIC), | 540 | SND_PCI_QUIRK(0x152d, 0x1778, "Quanta ON1", ALC269_DMIC), |
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index e125c60fe352..9a1aa09f47fe 100644 --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c | |||
@@ -4484,6 +4484,22 @@ static void alc269_fixup_pcm_44k(struct hda_codec *codec, | |||
4484 | spec->stream_analog_capture = &alc269_44k_pcm_analog_capture; | 4484 | spec->stream_analog_capture = &alc269_44k_pcm_analog_capture; |
4485 | } | 4485 | } |
4486 | 4486 | ||
4487 | static void alc269_fixup_stereo_dmic(struct hda_codec *codec, | ||
4488 | const struct alc_fixup *fix, int action) | ||
4489 | { | ||
4490 | int coef; | ||
4491 | |||
4492 | if (action != ALC_FIXUP_ACT_INIT) | ||
4493 | return; | ||
4494 | /* The digital-mic unit sends PDM (differential signal) instead of | ||
4495 | * the standard PCM, thus you can't record a valid mono stream as is. | ||
4496 | * Below is a workaround specific to ALC269 to control the dmic | ||
4497 | * signal source as mono. | ||
4498 | */ | ||
4499 | coef = alc_read_coef_idx(codec, 0x07); | ||
4500 | alc_write_coef_idx(codec, 0x07, coef | 0x80); | ||
4501 | } | ||
4502 | |||
4487 | enum { | 4503 | enum { |
4488 | ALC269_FIXUP_SONY_VAIO, | 4504 | ALC269_FIXUP_SONY_VAIO, |
4489 | ALC275_FIXUP_SONY_VAIO_GPIO2, | 4505 | ALC275_FIXUP_SONY_VAIO_GPIO2, |
@@ -4494,6 +4510,7 @@ enum { | |||
4494 | ALC275_FIXUP_SONY_HWEQ, | 4510 | ALC275_FIXUP_SONY_HWEQ, |
4495 | ALC271_FIXUP_DMIC, | 4511 | ALC271_FIXUP_DMIC, |
4496 | ALC269_FIXUP_PCM_44K, | 4512 | ALC269_FIXUP_PCM_44K, |
4513 | ALC269_FIXUP_STEREO_DMIC, | ||
4497 | }; | 4514 | }; |
4498 | 4515 | ||
4499 | static const struct alc_fixup alc269_fixups[] = { | 4516 | static const struct alc_fixup alc269_fixups[] = { |
@@ -4556,10 +4573,19 @@ static const struct alc_fixup alc269_fixups[] = { | |||
4556 | .type = ALC_FIXUP_FUNC, | 4573 | .type = ALC_FIXUP_FUNC, |
4557 | .v.func = alc269_fixup_pcm_44k, | 4574 | .v.func = alc269_fixup_pcm_44k, |
4558 | }, | 4575 | }, |
4576 | [ALC269_FIXUP_STEREO_DMIC] = { | ||
4577 | .type = ALC_FIXUP_FUNC, | ||
4578 | .v.func = alc269_fixup_stereo_dmic, | ||
4579 | }, | ||
4559 | }; | 4580 | }; |
4560 | 4581 | ||
4561 | static const struct snd_pci_quirk alc269_fixup_tbl[] = { | 4582 | static const struct snd_pci_quirk alc269_fixup_tbl[] = { |
4562 | SND_PCI_QUIRK(0x1043, 0x1a13, "Asus G73Jw", ALC269_FIXUP_ASUS_G73JW), | 4583 | SND_PCI_QUIRK(0x1043, 0x1a13, "Asus G73Jw", ALC269_FIXUP_ASUS_G73JW), |
4584 | SND_PCI_QUIRK(0x1043, 0x16e3, "ASUS UX50", ALC269_FIXUP_STEREO_DMIC), | ||
4585 | SND_PCI_QUIRK(0x1043, 0x831a, "ASUS P901", ALC269_FIXUP_STEREO_DMIC), | ||
4586 | SND_PCI_QUIRK(0x1043, 0x834a, "ASUS S101", ALC269_FIXUP_STEREO_DMIC), | ||
4587 | SND_PCI_QUIRK(0x1043, 0x8398, "ASUS P1005", ALC269_FIXUP_STEREO_DMIC), | ||
4588 | SND_PCI_QUIRK(0x1043, 0x83ce, "ASUS P1005", ALC269_FIXUP_STEREO_DMIC), | ||
4563 | SND_PCI_QUIRK(0x104d, 0x9073, "Sony VAIO", ALC275_FIXUP_SONY_VAIO_GPIO2), | 4589 | SND_PCI_QUIRK(0x104d, 0x9073, "Sony VAIO", ALC275_FIXUP_SONY_VAIO_GPIO2), |
4564 | SND_PCI_QUIRK(0x104d, 0x907b, "Sony VAIO", ALC275_FIXUP_SONY_HWEQ), | 4590 | SND_PCI_QUIRK(0x104d, 0x907b, "Sony VAIO", ALC275_FIXUP_SONY_HWEQ), |
4565 | SND_PCI_QUIRK(0x104d, 0x9084, "Sony VAIO", ALC275_FIXUP_SONY_HWEQ), | 4591 | SND_PCI_QUIRK(0x104d, 0x9084, "Sony VAIO", ALC275_FIXUP_SONY_HWEQ), |
diff --git a/sound/pci/hda/patch_via.c b/sound/pci/hda/patch_via.c index 84d8798bf33a..4ebfbd874c9a 100644 --- a/sound/pci/hda/patch_via.c +++ b/sound/pci/hda/patch_via.c | |||
@@ -2084,7 +2084,7 @@ static int via_auto_create_speaker_ctls(struct hda_codec *codec) | |||
2084 | struct via_spec *spec = codec->spec; | 2084 | struct via_spec *spec = codec->spec; |
2085 | struct nid_path *path; | 2085 | struct nid_path *path; |
2086 | bool check_dac; | 2086 | bool check_dac; |
2087 | hda_nid_t pin, dac; | 2087 | hda_nid_t pin, dac = 0; |
2088 | int err; | 2088 | int err; |
2089 | 2089 | ||
2090 | pin = spec->autocfg.speaker_pins[0]; | 2090 | pin = spec->autocfg.speaker_pins[0]; |
diff --git a/sound/pci/rme9652/hdspm.c b/sound/pci/rme9652/hdspm.c index 6edc67ced905..493e3946756f 100644 --- a/sound/pci/rme9652/hdspm.c +++ b/sound/pci/rme9652/hdspm.c | |||
@@ -1339,6 +1339,10 @@ static u64 hdspm_calc_dds_value(struct hdspm *hdspm, u64 period) | |||
1339 | break; | 1339 | break; |
1340 | case MADIface: | 1340 | case MADIface: |
1341 | freq_const = 131072000000000ULL; | 1341 | freq_const = 131072000000000ULL; |
1342 | break; | ||
1343 | default: | ||
1344 | snd_BUG(); | ||
1345 | return 0; | ||
1342 | } | 1346 | } |
1343 | 1347 | ||
1344 | return div_u64(freq_const, period); | 1348 | return div_u64(freq_const, period); |
@@ -1356,16 +1360,19 @@ static void hdspm_set_dds_value(struct hdspm *hdspm, int rate) | |||
1356 | 1360 | ||
1357 | switch (hdspm->io_type) { | 1361 | switch (hdspm->io_type) { |
1358 | case MADIface: | 1362 | case MADIface: |
1359 | n = 131072000000000ULL; /* 125 MHz */ | 1363 | n = 131072000000000ULL; /* 125 MHz */ |
1360 | break; | 1364 | break; |
1361 | case MADI: | 1365 | case MADI: |
1362 | case AES32: | 1366 | case AES32: |
1363 | n = 110069313433624ULL; /* 105 MHz */ | 1367 | n = 110069313433624ULL; /* 105 MHz */ |
1364 | break; | 1368 | break; |
1365 | case RayDAT: | 1369 | case RayDAT: |
1366 | case AIO: | 1370 | case AIO: |
1367 | n = 104857600000000ULL; /* 100 MHz */ | 1371 | n = 104857600000000ULL; /* 100 MHz */ |
1368 | break; | 1372 | break; |
1373 | default: | ||
1374 | snd_BUG(); | ||
1375 | return; | ||
1369 | } | 1376 | } |
1370 | 1377 | ||
1371 | n = div_u64(n, rate); | 1378 | n = div_u64(n, rate); |
diff --git a/sound/soc/codecs/Kconfig b/sound/soc/codecs/Kconfig index 379b2e3afd98..665d9240c4ae 100644 --- a/sound/soc/codecs/Kconfig +++ b/sound/soc/codecs/Kconfig | |||
@@ -78,7 +78,6 @@ config SND_SOC_ALL_CODECS | |||
78 | select SND_SOC_WM8900 if I2C | 78 | select SND_SOC_WM8900 if I2C |
79 | select SND_SOC_WM8903 if I2C | 79 | select SND_SOC_WM8903 if I2C |
80 | select SND_SOC_WM8904 if I2C | 80 | select SND_SOC_WM8904 if I2C |
81 | select SND_SOC_WM8915 if I2C | ||
82 | select SND_SOC_WM8940 if I2C | 81 | select SND_SOC_WM8940 if I2C |
83 | select SND_SOC_WM8955 if I2C | 82 | select SND_SOC_WM8955 if I2C |
84 | select SND_SOC_WM8960 if I2C | 83 | select SND_SOC_WM8960 if I2C |
@@ -95,6 +94,7 @@ config SND_SOC_ALL_CODECS | |||
95 | select SND_SOC_WM8993 if I2C | 94 | select SND_SOC_WM8993 if I2C |
96 | select SND_SOC_WM8994 if MFD_WM8994 | 95 | select SND_SOC_WM8994 if MFD_WM8994 |
97 | select SND_SOC_WM8995 if SND_SOC_I2C_AND_SPI | 96 | select SND_SOC_WM8995 if SND_SOC_I2C_AND_SPI |
97 | select SND_SOC_WM8996 if I2C | ||
98 | select SND_SOC_WM9081 if I2C | 98 | select SND_SOC_WM9081 if I2C |
99 | select SND_SOC_WM9090 if I2C | 99 | select SND_SOC_WM9090 if I2C |
100 | select SND_SOC_WM9705 if SND_SOC_AC97_BUS | 100 | select SND_SOC_WM9705 if SND_SOC_AC97_BUS |
@@ -329,9 +329,6 @@ config SND_SOC_WM8903 | |||
329 | config SND_SOC_WM8904 | 329 | config SND_SOC_WM8904 |
330 | tristate | 330 | tristate |
331 | 331 | ||
332 | config SND_SOC_WM8915 | ||
333 | tristate | ||
334 | |||
335 | config SND_SOC_WM8940 | 332 | config SND_SOC_WM8940 |
336 | tristate | 333 | tristate |
337 | 334 | ||
@@ -380,6 +377,9 @@ config SND_SOC_WM8994 | |||
380 | config SND_SOC_WM8995 | 377 | config SND_SOC_WM8995 |
381 | tristate | 378 | tristate |
382 | 379 | ||
380 | config SND_SOC_WM8996 | ||
381 | tristate | ||
382 | |||
383 | config SND_SOC_WM9081 | 383 | config SND_SOC_WM9081 |
384 | tristate | 384 | tristate |
385 | 385 | ||
diff --git a/sound/soc/codecs/Makefile b/sound/soc/codecs/Makefile index da9990fb8569..5119a7e2c1a8 100644 --- a/sound/soc/codecs/Makefile +++ b/sound/soc/codecs/Makefile | |||
@@ -63,7 +63,7 @@ snd-soc-wm8804-objs := wm8804.o | |||
63 | snd-soc-wm8900-objs := wm8900.o | 63 | snd-soc-wm8900-objs := wm8900.o |
64 | snd-soc-wm8903-objs := wm8903.o | 64 | snd-soc-wm8903-objs := wm8903.o |
65 | snd-soc-wm8904-objs := wm8904.o | 65 | snd-soc-wm8904-objs := wm8904.o |
66 | snd-soc-wm8915-objs := wm8915.o | 66 | snd-soc-wm8996-objs := wm8996.o |
67 | snd-soc-wm8940-objs := wm8940.o | 67 | snd-soc-wm8940-objs := wm8940.o |
68 | snd-soc-wm8955-objs := wm8955.o | 68 | snd-soc-wm8955-objs := wm8955.o |
69 | snd-soc-wm8960-objs := wm8960.o | 69 | snd-soc-wm8960-objs := wm8960.o |
@@ -160,7 +160,7 @@ obj-$(CONFIG_SND_SOC_WM8804) += snd-soc-wm8804.o | |||
160 | obj-$(CONFIG_SND_SOC_WM8900) += snd-soc-wm8900.o | 160 | obj-$(CONFIG_SND_SOC_WM8900) += snd-soc-wm8900.o |
161 | obj-$(CONFIG_SND_SOC_WM8903) += snd-soc-wm8903.o | 161 | obj-$(CONFIG_SND_SOC_WM8903) += snd-soc-wm8903.o |
162 | obj-$(CONFIG_SND_SOC_WM8904) += snd-soc-wm8904.o | 162 | obj-$(CONFIG_SND_SOC_WM8904) += snd-soc-wm8904.o |
163 | obj-$(CONFIG_SND_SOC_WM8915) += snd-soc-wm8915.o | 163 | obj-$(CONFIG_SND_SOC_WM8996) += snd-soc-wm8996.o |
164 | obj-$(CONFIG_SND_SOC_WM8940) += snd-soc-wm8940.o | 164 | obj-$(CONFIG_SND_SOC_WM8940) += snd-soc-wm8940.o |
165 | obj-$(CONFIG_SND_SOC_WM8955) += snd-soc-wm8955.o | 165 | obj-$(CONFIG_SND_SOC_WM8955) += snd-soc-wm8955.o |
166 | obj-$(CONFIG_SND_SOC_WM8960) += snd-soc-wm8960.o | 166 | obj-$(CONFIG_SND_SOC_WM8960) += snd-soc-wm8960.o |
diff --git a/sound/soc/codecs/sgtl5000.c b/sound/soc/codecs/sgtl5000.c index 76258f2a2ffb..7e4066e131e6 100644 --- a/sound/soc/codecs/sgtl5000.c +++ b/sound/soc/codecs/sgtl5000.c | |||
@@ -33,73 +33,31 @@ | |||
33 | #define SGTL5000_DAP_REG_OFFSET 0x0100 | 33 | #define SGTL5000_DAP_REG_OFFSET 0x0100 |
34 | #define SGTL5000_MAX_REG_OFFSET 0x013A | 34 | #define SGTL5000_MAX_REG_OFFSET 0x013A |
35 | 35 | ||
36 | /* default value of sgtl5000 registers except DAP */ | 36 | /* default value of sgtl5000 registers */ |
37 | static const u16 sgtl5000_regs[SGTL5000_MAX_REG_OFFSET >> 1] = { | 37 | static const u16 sgtl5000_regs[SGTL5000_MAX_REG_OFFSET] = { |
38 | 0xa011, /* 0x0000, CHIP_ID. 11 stand for revison 17 */ | 38 | [SGTL5000_CHIP_CLK_CTRL] = 0x0008, |
39 | 0x0000, /* 0x0002, CHIP_DIG_POWER. */ | 39 | [SGTL5000_CHIP_I2S_CTRL] = 0x0010, |
40 | 0x0008, /* 0x0004, CHIP_CKL_CTRL */ | 40 | [SGTL5000_CHIP_SSS_CTRL] = 0x0008, |
41 | 0x0010, /* 0x0006, CHIP_I2S_CTRL */ | 41 | [SGTL5000_CHIP_DAC_VOL] = 0x3c3c, |
42 | 0x0000, /* 0x0008, reserved */ | 42 | [SGTL5000_CHIP_PAD_STRENGTH] = 0x015f, |
43 | 0x0008, /* 0x000A, CHIP_SSS_CTRL */ | 43 | [SGTL5000_CHIP_ANA_HP_CTRL] = 0x1818, |
44 | 0x0000, /* 0x000C, reserved */ | 44 | [SGTL5000_CHIP_ANA_CTRL] = 0x0111, |
45 | 0x020c, /* 0x000E, CHIP_ADCDAC_CTRL */ | 45 | [SGTL5000_CHIP_LINE_OUT_VOL] = 0x0404, |
46 | 0x3c3c, /* 0x0010, CHIP_DAC_VOL */ | 46 | [SGTL5000_CHIP_ANA_POWER] = 0x7060, |
47 | 0x0000, /* 0x0012, reserved */ | 47 | [SGTL5000_CHIP_PLL_CTRL] = 0x5000, |
48 | 0x015f, /* 0x0014, CHIP_PAD_STRENGTH */ | 48 | [SGTL5000_DAP_BASS_ENHANCE] = 0x0040, |
49 | 0x0000, /* 0x0016, reserved */ | 49 | [SGTL5000_DAP_BASS_ENHANCE_CTRL] = 0x051f, |
50 | 0x0000, /* 0x0018, reserved */ | 50 | [SGTL5000_DAP_SURROUND] = 0x0040, |
51 | 0x0000, /* 0x001A, reserved */ | 51 | [SGTL5000_DAP_EQ_BASS_BAND0] = 0x002f, |
52 | 0x0000, /* 0x001E, reserved */ | 52 | [SGTL5000_DAP_EQ_BASS_BAND1] = 0x002f, |
53 | 0x0000, /* 0x0020, CHIP_ANA_ADC_CTRL */ | 53 | [SGTL5000_DAP_EQ_BASS_BAND2] = 0x002f, |
54 | 0x1818, /* 0x0022, CHIP_ANA_HP_CTRL */ | 54 | [SGTL5000_DAP_EQ_BASS_BAND3] = 0x002f, |
55 | 0x0111, /* 0x0024, CHIP_ANN_CTRL */ | 55 | [SGTL5000_DAP_EQ_BASS_BAND4] = 0x002f, |
56 | 0x0000, /* 0x0026, CHIP_LINREG_CTRL */ | 56 | [SGTL5000_DAP_MAIN_CHAN] = 0x8000, |
57 | 0x0000, /* 0x0028, CHIP_REF_CTRL */ | 57 | [SGTL5000_DAP_AVC_CTRL] = 0x0510, |
58 | 0x0000, /* 0x002A, CHIP_MIC_CTRL */ | 58 | [SGTL5000_DAP_AVC_THRESHOLD] = 0x1473, |
59 | 0x0000, /* 0x002C, CHIP_LINE_OUT_CTRL */ | 59 | [SGTL5000_DAP_AVC_ATTACK] = 0x0028, |
60 | 0x0404, /* 0x002E, CHIP_LINE_OUT_VOL */ | 60 | [SGTL5000_DAP_AVC_DECAY] = 0x0050, |
61 | 0x7060, /* 0x0030, CHIP_ANA_POWER */ | ||
62 | 0x5000, /* 0x0032, CHIP_PLL_CTRL */ | ||
63 | 0x0000, /* 0x0034, CHIP_CLK_TOP_CTRL */ | ||
64 | 0x0000, /* 0x0036, CHIP_ANA_STATUS */ | ||
65 | 0x0000, /* 0x0038, reserved */ | ||
66 | 0x0000, /* 0x003A, CHIP_ANA_TEST2 */ | ||
67 | 0x0000, /* 0x003C, CHIP_SHORT_CTRL */ | ||
68 | 0x0000, /* reserved */ | ||
69 | }; | ||
70 | |||
71 | /* default value of dap registers */ | ||
72 | static const u16 sgtl5000_dap_regs[] = { | ||
73 | 0x0000, /* 0x0100, DAP_CONTROL */ | ||
74 | 0x0000, /* 0x0102, DAP_PEQ */ | ||
75 | 0x0040, /* 0x0104, DAP_BASS_ENHANCE */ | ||
76 | 0x051f, /* 0x0106, DAP_BASS_ENHANCE_CTRL */ | ||
77 | 0x0000, /* 0x0108, DAP_AUDIO_EQ */ | ||
78 | 0x0040, /* 0x010A, DAP_SGTL_SURROUND */ | ||
79 | 0x0000, /* 0x010C, DAP_FILTER_COEF_ACCESS */ | ||
80 | 0x0000, /* 0x010E, DAP_COEF_WR_B0_MSB */ | ||
81 | 0x0000, /* 0x0110, DAP_COEF_WR_B0_LSB */ | ||
82 | 0x0000, /* 0x0112, reserved */ | ||
83 | 0x0000, /* 0x0114, reserved */ | ||
84 | 0x002f, /* 0x0116, DAP_AUDIO_EQ_BASS_BAND0 */ | ||
85 | 0x002f, /* 0x0118, DAP_AUDIO_EQ_BAND0 */ | ||
86 | 0x002f, /* 0x011A, DAP_AUDIO_EQ_BAND2 */ | ||
87 | 0x002f, /* 0x011C, DAP_AUDIO_EQ_BAND3 */ | ||
88 | 0x002f, /* 0x011E, DAP_AUDIO_EQ_TREBLE_BAND4 */ | ||
89 | 0x8000, /* 0x0120, DAP_MAIN_CHAN */ | ||
90 | 0x0000, /* 0x0122, DAP_MIX_CHAN */ | ||
91 | 0x0510, /* 0x0124, DAP_AVC_CTRL */ | ||
92 | 0x1473, /* 0x0126, DAP_AVC_THRESHOLD */ | ||
93 | 0x0028, /* 0x0128, DAP_AVC_ATTACK */ | ||
94 | 0x0050, /* 0x012A, DAP_AVC_DECAY */ | ||
95 | 0x0000, /* 0x012C, DAP_COEF_WR_B1_MSB */ | ||
96 | 0x0000, /* 0x012E, DAP_COEF_WR_B1_LSB */ | ||
97 | 0x0000, /* 0x0130, DAP_COEF_WR_B2_MSB */ | ||
98 | 0x0000, /* 0x0132, DAP_COEF_WR_B2_LSB */ | ||
99 | 0x0000, /* 0x0134, DAP_COEF_WR_A1_MSB */ | ||
100 | 0x0000, /* 0x0136, DAP_COEF_WR_A1_LSB */ | ||
101 | 0x0000, /* 0x0138, DAP_COEF_WR_A2_MSB */ | ||
102 | 0x0000, /* 0x013A, DAP_COEF_WR_A2_LSB */ | ||
103 | }; | 61 | }; |
104 | 62 | ||
105 | /* regulator supplies for sgtl5000, VDDD is an optional external supply */ | 63 | /* regulator supplies for sgtl5000, VDDD is an optional external supply */ |
@@ -1023,12 +981,10 @@ static int sgtl5000_suspend(struct snd_soc_codec *codec, pm_message_t state) | |||
1023 | static int sgtl5000_restore_regs(struct snd_soc_codec *codec) | 981 | static int sgtl5000_restore_regs(struct snd_soc_codec *codec) |
1024 | { | 982 | { |
1025 | u16 *cache = codec->reg_cache; | 983 | u16 *cache = codec->reg_cache; |
1026 | int i; | 984 | u16 reg; |
1027 | int regular_regs = SGTL5000_CHIP_SHORT_CTRL >> 1; | ||
1028 | 985 | ||
1029 | /* restore regular registers */ | 986 | /* restore regular registers */ |
1030 | for (i = 0; i < regular_regs; i++) { | 987 | for (reg = 0; reg <= SGTL5000_CHIP_SHORT_CTRL; reg += 2) { |
1031 | int reg = i << 1; | ||
1032 | 988 | ||
1033 | /* this regs depends on the others */ | 989 | /* this regs depends on the others */ |
1034 | if (reg == SGTL5000_CHIP_ANA_POWER || | 990 | if (reg == SGTL5000_CHIP_ANA_POWER || |
@@ -1038,35 +994,31 @@ static int sgtl5000_restore_regs(struct snd_soc_codec *codec) | |||
1038 | reg == SGTL5000_CHIP_CLK_CTRL) | 994 | reg == SGTL5000_CHIP_CLK_CTRL) |
1039 | continue; | 995 | continue; |
1040 | 996 | ||
1041 | snd_soc_write(codec, reg, cache[i]); | 997 | snd_soc_write(codec, reg, cache[reg]); |
1042 | } | 998 | } |
1043 | 999 | ||
1044 | /* restore dap registers */ | 1000 | /* restore dap registers */ |
1045 | for (i = SGTL5000_DAP_REG_OFFSET >> 1; | 1001 | for (reg = SGTL5000_DAP_REG_OFFSET; reg < SGTL5000_MAX_REG_OFFSET; reg += 2) |
1046 | i < SGTL5000_MAX_REG_OFFSET >> 1; i++) { | 1002 | snd_soc_write(codec, reg, cache[reg]); |
1047 | int reg = i << 1; | ||
1048 | |||
1049 | snd_soc_write(codec, reg, cache[i]); | ||
1050 | } | ||
1051 | 1003 | ||
1052 | /* | 1004 | /* |
1053 | * restore power and other regs according | 1005 | * restore power and other regs according |
1054 | * to set_power() and set_clock() | 1006 | * to set_power() and set_clock() |
1055 | */ | 1007 | */ |
1056 | snd_soc_write(codec, SGTL5000_CHIP_LINREG_CTRL, | 1008 | snd_soc_write(codec, SGTL5000_CHIP_LINREG_CTRL, |
1057 | cache[SGTL5000_CHIP_LINREG_CTRL >> 1]); | 1009 | cache[SGTL5000_CHIP_LINREG_CTRL]); |
1058 | 1010 | ||
1059 | snd_soc_write(codec, SGTL5000_CHIP_ANA_POWER, | 1011 | snd_soc_write(codec, SGTL5000_CHIP_ANA_POWER, |
1060 | cache[SGTL5000_CHIP_ANA_POWER >> 1]); | 1012 | cache[SGTL5000_CHIP_ANA_POWER]); |
1061 | 1013 | ||
1062 | snd_soc_write(codec, SGTL5000_CHIP_CLK_CTRL, | 1014 | snd_soc_write(codec, SGTL5000_CHIP_CLK_CTRL, |
1063 | cache[SGTL5000_CHIP_CLK_CTRL >> 1]); | 1015 | cache[SGTL5000_CHIP_CLK_CTRL]); |
1064 | 1016 | ||
1065 | snd_soc_write(codec, SGTL5000_CHIP_REF_CTRL, | 1017 | snd_soc_write(codec, SGTL5000_CHIP_REF_CTRL, |
1066 | cache[SGTL5000_CHIP_REF_CTRL >> 1]); | 1018 | cache[SGTL5000_CHIP_REF_CTRL]); |
1067 | 1019 | ||
1068 | snd_soc_write(codec, SGTL5000_CHIP_LINE_OUT_CTRL, | 1020 | snd_soc_write(codec, SGTL5000_CHIP_LINE_OUT_CTRL, |
1069 | cache[SGTL5000_CHIP_LINE_OUT_CTRL >> 1]); | 1021 | cache[SGTL5000_CHIP_LINE_OUT_CTRL]); |
1070 | return 0; | 1022 | return 0; |
1071 | } | 1023 | } |
1072 | 1024 | ||
@@ -1454,16 +1406,6 @@ static __devinit int sgtl5000_i2c_probe(struct i2c_client *client, | |||
1454 | if (!sgtl5000) | 1406 | if (!sgtl5000) |
1455 | return -ENOMEM; | 1407 | return -ENOMEM; |
1456 | 1408 | ||
1457 | /* | ||
1458 | * copy DAP default values to default value array. | ||
1459 | * sgtl5000 register space has a big hole, merge it | ||
1460 | * at init phase makes life easy. | ||
1461 | * FIXME: should we drop 'const' of sgtl5000_regs? | ||
1462 | */ | ||
1463 | memcpy((void *)(&sgtl5000_regs[0] + (SGTL5000_DAP_REG_OFFSET >> 1)), | ||
1464 | sgtl5000_dap_regs, | ||
1465 | SGTL5000_MAX_REG_OFFSET - SGTL5000_DAP_REG_OFFSET); | ||
1466 | |||
1467 | i2c_set_clientdata(client, sgtl5000); | 1409 | i2c_set_clientdata(client, sgtl5000); |
1468 | 1410 | ||
1469 | ret = snd_soc_register_codec(&client->dev, | 1411 | ret = snd_soc_register_codec(&client->dev, |
diff --git a/sound/soc/codecs/wm8915.c b/sound/soc/codecs/wm8915.c deleted file mode 100644 index 423baa9be241..000000000000 --- a/sound/soc/codecs/wm8915.c +++ /dev/null | |||
@@ -1,2995 +0,0 @@ | |||
1 | /* | ||
2 | * wm8915.c - WM8915 audio codec interface | ||
3 | * | ||
4 | * Copyright 2011 Wolfson Microelectronics PLC. | ||
5 | * Author: Mark Brown <broonie@opensource.wolfsonmicro.com> | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify it | ||
8 | * under the terms of the GNU General Public License as published by the | ||
9 | * Free Software Foundation; either version 2 of the License, or (at your | ||
10 | * option) any later version. | ||
11 | */ | ||
12 | |||
13 | #include <linux/module.h> | ||
14 | #include <linux/moduleparam.h> | ||
15 | #include <linux/init.h> | ||
16 | #include <linux/completion.h> | ||
17 | #include <linux/delay.h> | ||
18 | #include <linux/pm.h> | ||
19 | #include <linux/gcd.h> | ||
20 | #include <linux/gpio.h> | ||
21 | #include <linux/i2c.h> | ||
22 | #include <linux/regulator/consumer.h> | ||
23 | #include <linux/slab.h> | ||
24 | #include <linux/workqueue.h> | ||
25 | #include <sound/core.h> | ||
26 | #include <sound/jack.h> | ||
27 | #include <sound/pcm.h> | ||
28 | #include <sound/pcm_params.h> | ||
29 | #include <sound/soc.h> | ||
30 | #include <sound/initval.h> | ||
31 | #include <sound/tlv.h> | ||
32 | #include <trace/events/asoc.h> | ||
33 | |||
34 | #include <sound/wm8915.h> | ||
35 | #include "wm8915.h" | ||
36 | |||
37 | #define WM8915_AIFS 2 | ||
38 | |||
39 | #define HPOUT1L 1 | ||
40 | #define HPOUT1R 2 | ||
41 | #define HPOUT2L 4 | ||
42 | #define HPOUT2R 8 | ||
43 | |||
44 | #define WM8915_NUM_SUPPLIES 4 | ||
45 | static const char *wm8915_supply_names[WM8915_NUM_SUPPLIES] = { | ||
46 | "DBVDD", | ||
47 | "AVDD1", | ||
48 | "AVDD2", | ||
49 | "CPVDD", | ||
50 | }; | ||
51 | |||
52 | struct wm8915_priv { | ||
53 | struct snd_soc_codec *codec; | ||
54 | |||
55 | int ldo1ena; | ||
56 | |||
57 | int sysclk; | ||
58 | int sysclk_src; | ||
59 | |||
60 | int fll_src; | ||
61 | int fll_fref; | ||
62 | int fll_fout; | ||
63 | |||
64 | struct completion fll_lock; | ||
65 | |||
66 | u16 dcs_pending; | ||
67 | struct completion dcs_done; | ||
68 | |||
69 | u16 hpout_ena; | ||
70 | u16 hpout_pending; | ||
71 | |||
72 | struct regulator_bulk_data supplies[WM8915_NUM_SUPPLIES]; | ||
73 | struct notifier_block disable_nb[WM8915_NUM_SUPPLIES]; | ||
74 | |||
75 | struct wm8915_pdata pdata; | ||
76 | |||
77 | int rx_rate[WM8915_AIFS]; | ||
78 | int bclk_rate[WM8915_AIFS]; | ||
79 | |||
80 | /* Platform dependant ReTune mobile configuration */ | ||
81 | int num_retune_mobile_texts; | ||
82 | const char **retune_mobile_texts; | ||
83 | int retune_mobile_cfg[2]; | ||
84 | struct soc_enum retune_mobile_enum; | ||
85 | |||
86 | struct snd_soc_jack *jack; | ||
87 | bool detecting; | ||
88 | bool jack_mic; | ||
89 | wm8915_polarity_fn polarity_cb; | ||
90 | |||
91 | #ifdef CONFIG_GPIOLIB | ||
92 | struct gpio_chip gpio_chip; | ||
93 | #endif | ||
94 | }; | ||
95 | |||
96 | /* We can't use the same notifier block for more than one supply and | ||
97 | * there's no way I can see to get from a callback to the caller | ||
98 | * except container_of(). | ||
99 | */ | ||
100 | #define WM8915_REGULATOR_EVENT(n) \ | ||
101 | static int wm8915_regulator_event_##n(struct notifier_block *nb, \ | ||
102 | unsigned long event, void *data) \ | ||
103 | { \ | ||
104 | struct wm8915_priv *wm8915 = container_of(nb, struct wm8915_priv, \ | ||
105 | disable_nb[n]); \ | ||
106 | if (event & REGULATOR_EVENT_DISABLE) { \ | ||
107 | wm8915->codec->cache_sync = 1; \ | ||
108 | } \ | ||
109 | return 0; \ | ||
110 | } | ||
111 | |||
112 | WM8915_REGULATOR_EVENT(0) | ||
113 | WM8915_REGULATOR_EVENT(1) | ||
114 | WM8915_REGULATOR_EVENT(2) | ||
115 | WM8915_REGULATOR_EVENT(3) | ||
116 | |||
117 | static const u16 wm8915_reg[WM8915_MAX_REGISTER] = { | ||
118 | [WM8915_SOFTWARE_RESET] = 0x8915, | ||
119 | [WM8915_POWER_MANAGEMENT_7] = 0x10, | ||
120 | [WM8915_DAC1_HPOUT1_VOLUME] = 0x88, | ||
121 | [WM8915_DAC2_HPOUT2_VOLUME] = 0x88, | ||
122 | [WM8915_DAC1_LEFT_VOLUME] = 0x2c0, | ||
123 | [WM8915_DAC1_RIGHT_VOLUME] = 0x2c0, | ||
124 | [WM8915_DAC2_LEFT_VOLUME] = 0x2c0, | ||
125 | [WM8915_DAC2_RIGHT_VOLUME] = 0x2c0, | ||
126 | [WM8915_OUTPUT1_LEFT_VOLUME] = 0x80, | ||
127 | [WM8915_OUTPUT1_RIGHT_VOLUME] = 0x80, | ||
128 | [WM8915_OUTPUT2_LEFT_VOLUME] = 0x80, | ||
129 | [WM8915_OUTPUT2_RIGHT_VOLUME] = 0x80, | ||
130 | [WM8915_MICBIAS_1] = 0x39, | ||
131 | [WM8915_MICBIAS_2] = 0x39, | ||
132 | [WM8915_LDO_1] = 0x3, | ||
133 | [WM8915_LDO_2] = 0x13, | ||
134 | [WM8915_ACCESSORY_DETECT_MODE_1] = 0x4, | ||
135 | [WM8915_HEADPHONE_DETECT_1] = 0x20, | ||
136 | [WM8915_MIC_DETECT_1] = 0x7600, | ||
137 | [WM8915_MIC_DETECT_2] = 0xbf, | ||
138 | [WM8915_CHARGE_PUMP_1] = 0x1f25, | ||
139 | [WM8915_CHARGE_PUMP_2] = 0xab19, | ||
140 | [WM8915_DC_SERVO_5] = 0x2a2a, | ||
141 | [WM8915_CONTROL_INTERFACE_1] = 0x8004, | ||
142 | [WM8915_CLOCKING_1] = 0x10, | ||
143 | [WM8915_AIF_RATE] = 0x83, | ||
144 | [WM8915_FLL_CONTROL_4] = 0x5dc0, | ||
145 | [WM8915_FLL_CONTROL_5] = 0xc84, | ||
146 | [WM8915_FLL_EFS_2] = 0x2, | ||
147 | [WM8915_AIF1_TX_LRCLK_1] = 0x80, | ||
148 | [WM8915_AIF1_TX_LRCLK_2] = 0x8, | ||
149 | [WM8915_AIF1_RX_LRCLK_1] = 0x80, | ||
150 | [WM8915_AIF1TX_DATA_CONFIGURATION_1] = 0x1818, | ||
151 | [WM8915_AIF1RX_DATA_CONFIGURATION] = 0x1818, | ||
152 | [WM8915_AIF1TX_TEST] = 0x7, | ||
153 | [WM8915_AIF2_TX_LRCLK_1] = 0x80, | ||
154 | [WM8915_AIF2_TX_LRCLK_2] = 0x8, | ||
155 | [WM8915_AIF2_RX_LRCLK_1] = 0x80, | ||
156 | [WM8915_AIF2TX_DATA_CONFIGURATION_1] = 0x1818, | ||
157 | [WM8915_AIF2RX_DATA_CONFIGURATION] = 0x1818, | ||
158 | [WM8915_AIF2TX_TEST] = 0x1, | ||
159 | [WM8915_DSP1_TX_LEFT_VOLUME] = 0xc0, | ||
160 | [WM8915_DSP1_TX_RIGHT_VOLUME] = 0xc0, | ||
161 | [WM8915_DSP1_RX_LEFT_VOLUME] = 0xc0, | ||
162 | [WM8915_DSP1_RX_RIGHT_VOLUME] = 0xc0, | ||
163 | [WM8915_DSP1_TX_FILTERS] = 0x2000, | ||
164 | [WM8915_DSP1_RX_FILTERS_1] = 0x200, | ||
165 | [WM8915_DSP1_RX_FILTERS_2] = 0x10, | ||
166 | [WM8915_DSP1_DRC_1] = 0x98, | ||
167 | [WM8915_DSP1_DRC_2] = 0x845, | ||
168 | [WM8915_DSP1_RX_EQ_GAINS_1] = 0x6318, | ||
169 | [WM8915_DSP1_RX_EQ_GAINS_2] = 0x6300, | ||
170 | [WM8915_DSP1_RX_EQ_BAND_1_A] = 0xfca, | ||
171 | [WM8915_DSP1_RX_EQ_BAND_1_B] = 0x400, | ||
172 | [WM8915_DSP1_RX_EQ_BAND_1_PG] = 0xd8, | ||
173 | [WM8915_DSP1_RX_EQ_BAND_2_A] = 0x1eb5, | ||
174 | [WM8915_DSP1_RX_EQ_BAND_2_B] = 0xf145, | ||
175 | [WM8915_DSP1_RX_EQ_BAND_2_C] = 0xb75, | ||
176 | [WM8915_DSP1_RX_EQ_BAND_2_PG] = 0x1c5, | ||
177 | [WM8915_DSP1_RX_EQ_BAND_3_A] = 0x1c58, | ||
178 | [WM8915_DSP1_RX_EQ_BAND_3_B] = 0xf373, | ||
179 | [WM8915_DSP1_RX_EQ_BAND_3_C] = 0xa54, | ||
180 | [WM8915_DSP1_RX_EQ_BAND_3_PG] = 0x558, | ||
181 | [WM8915_DSP1_RX_EQ_BAND_4_A] = 0x168e, | ||
182 | [WM8915_DSP1_RX_EQ_BAND_4_B] = 0xf829, | ||
183 | [WM8915_DSP1_RX_EQ_BAND_4_C] = 0x7ad, | ||
184 | [WM8915_DSP1_RX_EQ_BAND_4_PG] = 0x1103, | ||
185 | [WM8915_DSP1_RX_EQ_BAND_5_A] = 0x564, | ||
186 | [WM8915_DSP1_RX_EQ_BAND_5_B] = 0x559, | ||
187 | [WM8915_DSP1_RX_EQ_BAND_5_PG] = 0x4000, | ||
188 | [WM8915_DSP2_TX_LEFT_VOLUME] = 0xc0, | ||
189 | [WM8915_DSP2_TX_RIGHT_VOLUME] = 0xc0, | ||
190 | [WM8915_DSP2_RX_LEFT_VOLUME] = 0xc0, | ||
191 | [WM8915_DSP2_RX_RIGHT_VOLUME] = 0xc0, | ||
192 | [WM8915_DSP2_TX_FILTERS] = 0x2000, | ||
193 | [WM8915_DSP2_RX_FILTERS_1] = 0x200, | ||
194 | [WM8915_DSP2_RX_FILTERS_2] = 0x10, | ||
195 | [WM8915_DSP2_DRC_1] = 0x98, | ||
196 | [WM8915_DSP2_DRC_2] = 0x845, | ||
197 | [WM8915_DSP2_RX_EQ_GAINS_1] = 0x6318, | ||
198 | [WM8915_DSP2_RX_EQ_GAINS_2] = 0x6300, | ||
199 | [WM8915_DSP2_RX_EQ_BAND_1_A] = 0xfca, | ||
200 | [WM8915_DSP2_RX_EQ_BAND_1_B] = 0x400, | ||
201 | [WM8915_DSP2_RX_EQ_BAND_1_PG] = 0xd8, | ||
202 | [WM8915_DSP2_RX_EQ_BAND_2_A] = 0x1eb5, | ||
203 | [WM8915_DSP2_RX_EQ_BAND_2_B] = 0xf145, | ||
204 | [WM8915_DSP2_RX_EQ_BAND_2_C] = 0xb75, | ||
205 | [WM8915_DSP2_RX_EQ_BAND_2_PG] = 0x1c5, | ||
206 | [WM8915_DSP2_RX_EQ_BAND_3_A] = 0x1c58, | ||
207 | [WM8915_DSP2_RX_EQ_BAND_3_B] = 0xf373, | ||
208 | [WM8915_DSP2_RX_EQ_BAND_3_C] = 0xa54, | ||
209 | [WM8915_DSP2_RX_EQ_BAND_3_PG] = 0x558, | ||
210 | [WM8915_DSP2_RX_EQ_BAND_4_A] = 0x168e, | ||
211 | [WM8915_DSP2_RX_EQ_BAND_4_B] = 0xf829, | ||
212 | [WM8915_DSP2_RX_EQ_BAND_4_C] = 0x7ad, | ||
213 | [WM8915_DSP2_RX_EQ_BAND_4_PG] = 0x1103, | ||
214 | [WM8915_DSP2_RX_EQ_BAND_5_A] = 0x564, | ||
215 | [WM8915_DSP2_RX_EQ_BAND_5_B] = 0x559, | ||
216 | [WM8915_DSP2_RX_EQ_BAND_5_PG] = 0x4000, | ||
217 | [WM8915_OVERSAMPLING] = 0xd, | ||
218 | [WM8915_SIDETONE] = 0x1040, | ||
219 | [WM8915_GPIO_1] = 0xa101, | ||
220 | [WM8915_GPIO_2] = 0xa101, | ||
221 | [WM8915_GPIO_3] = 0xa101, | ||
222 | [WM8915_GPIO_4] = 0xa101, | ||
223 | [WM8915_GPIO_5] = 0xa101, | ||
224 | [WM8915_PULL_CONTROL_2] = 0x140, | ||
225 | [WM8915_INTERRUPT_STATUS_1_MASK] = 0x1f, | ||
226 | [WM8915_INTERRUPT_STATUS_2_MASK] = 0x1ecf, | ||
227 | [WM8915_RIGHT_PDM_SPEAKER] = 0x1, | ||
228 | [WM8915_PDM_SPEAKER_MUTE_SEQUENCE] = 0x69, | ||
229 | [WM8915_PDM_SPEAKER_VOLUME] = 0x66, | ||
230 | [WM8915_WRITE_SEQUENCER_0] = 0x1, | ||
231 | [WM8915_WRITE_SEQUENCER_1] = 0x1, | ||
232 | [WM8915_WRITE_SEQUENCER_3] = 0x6, | ||
233 | [WM8915_WRITE_SEQUENCER_4] = 0x40, | ||
234 | [WM8915_WRITE_SEQUENCER_5] = 0x1, | ||
235 | [WM8915_WRITE_SEQUENCER_6] = 0xf, | ||
236 | [WM8915_WRITE_SEQUENCER_7] = 0x6, | ||
237 | [WM8915_WRITE_SEQUENCER_8] = 0x1, | ||
238 | [WM8915_WRITE_SEQUENCER_9] = 0x3, | ||
239 | [WM8915_WRITE_SEQUENCER_10] = 0x104, | ||
240 | [WM8915_WRITE_SEQUENCER_12] = 0x60, | ||
241 | [WM8915_WRITE_SEQUENCER_13] = 0x11, | ||
242 | [WM8915_WRITE_SEQUENCER_14] = 0x401, | ||
243 | [WM8915_WRITE_SEQUENCER_16] = 0x50, | ||
244 | [WM8915_WRITE_SEQUENCER_17] = 0x3, | ||
245 | [WM8915_WRITE_SEQUENCER_18] = 0x100, | ||
246 | [WM8915_WRITE_SEQUENCER_20] = 0x51, | ||
247 | [WM8915_WRITE_SEQUENCER_21] = 0x3, | ||
248 | [WM8915_WRITE_SEQUENCER_22] = 0x104, | ||
249 | [WM8915_WRITE_SEQUENCER_23] = 0xa, | ||
250 | [WM8915_WRITE_SEQUENCER_24] = 0x60, | ||
251 | [WM8915_WRITE_SEQUENCER_25] = 0x3b, | ||
252 | [WM8915_WRITE_SEQUENCER_26] = 0x502, | ||
253 | [WM8915_WRITE_SEQUENCER_27] = 0x100, | ||
254 | [WM8915_WRITE_SEQUENCER_28] = 0x2fff, | ||
255 | [WM8915_WRITE_SEQUENCER_32] = 0x2fff, | ||
256 | [WM8915_WRITE_SEQUENCER_36] = 0x2fff, | ||
257 | [WM8915_WRITE_SEQUENCER_40] = 0x2fff, | ||
258 | [WM8915_WRITE_SEQUENCER_44] = 0x2fff, | ||
259 | [WM8915_WRITE_SEQUENCER_48] = 0x2fff, | ||
260 | [WM8915_WRITE_SEQUENCER_52] = 0x2fff, | ||
261 | [WM8915_WRITE_SEQUENCER_56] = 0x2fff, | ||
262 | [WM8915_WRITE_SEQUENCER_60] = 0x2fff, | ||
263 | [WM8915_WRITE_SEQUENCER_64] = 0x1, | ||
264 | [WM8915_WRITE_SEQUENCER_65] = 0x1, | ||
265 | [WM8915_WRITE_SEQUENCER_67] = 0x6, | ||
266 | [WM8915_WRITE_SEQUENCER_68] = 0x40, | ||
267 | [WM8915_WRITE_SEQUENCER_69] = 0x1, | ||
268 | [WM8915_WRITE_SEQUENCER_70] = 0xf, | ||
269 | [WM8915_WRITE_SEQUENCER_71] = 0x6, | ||
270 | [WM8915_WRITE_SEQUENCER_72] = 0x1, | ||
271 | [WM8915_WRITE_SEQUENCER_73] = 0x3, | ||
272 | [WM8915_WRITE_SEQUENCER_74] = 0x104, | ||
273 | [WM8915_WRITE_SEQUENCER_76] = 0x60, | ||
274 | [WM8915_WRITE_SEQUENCER_77] = 0x11, | ||
275 | [WM8915_WRITE_SEQUENCER_78] = 0x401, | ||
276 | [WM8915_WRITE_SEQUENCER_80] = 0x50, | ||
277 | [WM8915_WRITE_SEQUENCER_81] = 0x3, | ||
278 | [WM8915_WRITE_SEQUENCER_82] = 0x100, | ||
279 | [WM8915_WRITE_SEQUENCER_84] = 0x60, | ||
280 | [WM8915_WRITE_SEQUENCER_85] = 0x3b, | ||
281 | [WM8915_WRITE_SEQUENCER_86] = 0x502, | ||
282 | [WM8915_WRITE_SEQUENCER_87] = 0x100, | ||
283 | [WM8915_WRITE_SEQUENCER_88] = 0x2fff, | ||
284 | [WM8915_WRITE_SEQUENCER_92] = 0x2fff, | ||
285 | [WM8915_WRITE_SEQUENCER_96] = 0x2fff, | ||
286 | [WM8915_WRITE_SEQUENCER_100] = 0x2fff, | ||
287 | [WM8915_WRITE_SEQUENCER_104] = 0x2fff, | ||
288 | [WM8915_WRITE_SEQUENCER_108] = 0x2fff, | ||
289 | [WM8915_WRITE_SEQUENCER_112] = 0x2fff, | ||
290 | [WM8915_WRITE_SEQUENCER_116] = 0x2fff, | ||
291 | [WM8915_WRITE_SEQUENCER_120] = 0x2fff, | ||
292 | [WM8915_WRITE_SEQUENCER_124] = 0x2fff, | ||
293 | [WM8915_WRITE_SEQUENCER_128] = 0x1, | ||
294 | [WM8915_WRITE_SEQUENCER_129] = 0x1, | ||
295 | [WM8915_WRITE_SEQUENCER_131] = 0x6, | ||
296 | [WM8915_WRITE_SEQUENCER_132] = 0x40, | ||
297 | [WM8915_WRITE_SEQUENCER_133] = 0x1, | ||
298 | [WM8915_WRITE_SEQUENCER_134] = 0xf, | ||
299 | [WM8915_WRITE_SEQUENCER_135] = 0x6, | ||
300 | [WM8915_WRITE_SEQUENCER_136] = 0x1, | ||
301 | [WM8915_WRITE_SEQUENCER_137] = 0x3, | ||
302 | [WM8915_WRITE_SEQUENCER_138] = 0x106, | ||
303 | [WM8915_WRITE_SEQUENCER_140] = 0x61, | ||
304 | [WM8915_WRITE_SEQUENCER_141] = 0x11, | ||
305 | [WM8915_WRITE_SEQUENCER_142] = 0x401, | ||
306 | [WM8915_WRITE_SEQUENCER_144] = 0x50, | ||
307 | [WM8915_WRITE_SEQUENCER_145] = 0x3, | ||
308 | [WM8915_WRITE_SEQUENCER_146] = 0x102, | ||
309 | [WM8915_WRITE_SEQUENCER_148] = 0x51, | ||
310 | [WM8915_WRITE_SEQUENCER_149] = 0x3, | ||
311 | [WM8915_WRITE_SEQUENCER_150] = 0x106, | ||
312 | [WM8915_WRITE_SEQUENCER_151] = 0xa, | ||
313 | [WM8915_WRITE_SEQUENCER_152] = 0x61, | ||
314 | [WM8915_WRITE_SEQUENCER_153] = 0x3b, | ||
315 | [WM8915_WRITE_SEQUENCER_154] = 0x502, | ||
316 | [WM8915_WRITE_SEQUENCER_155] = 0x100, | ||
317 | [WM8915_WRITE_SEQUENCER_156] = 0x2fff, | ||
318 | [WM8915_WRITE_SEQUENCER_160] = 0x2fff, | ||
319 | [WM8915_WRITE_SEQUENCER_164] = 0x2fff, | ||
320 | [WM8915_WRITE_SEQUENCER_168] = 0x2fff, | ||
321 | [WM8915_WRITE_SEQUENCER_172] = 0x2fff, | ||
322 | [WM8915_WRITE_SEQUENCER_176] = 0x2fff, | ||
323 | [WM8915_WRITE_SEQUENCER_180] = 0x2fff, | ||
324 | [WM8915_WRITE_SEQUENCER_184] = 0x2fff, | ||
325 | [WM8915_WRITE_SEQUENCER_188] = 0x2fff, | ||
326 | [WM8915_WRITE_SEQUENCER_192] = 0x1, | ||
327 | [WM8915_WRITE_SEQUENCER_193] = 0x1, | ||
328 | [WM8915_WRITE_SEQUENCER_195] = 0x6, | ||
329 | [WM8915_WRITE_SEQUENCER_196] = 0x40, | ||
330 | [WM8915_WRITE_SEQUENCER_197] = 0x1, | ||
331 | [WM8915_WRITE_SEQUENCER_198] = 0xf, | ||
332 | [WM8915_WRITE_SEQUENCER_199] = 0x6, | ||
333 | [WM8915_WRITE_SEQUENCER_200] = 0x1, | ||
334 | [WM8915_WRITE_SEQUENCER_201] = 0x3, | ||
335 | [WM8915_WRITE_SEQUENCER_202] = 0x106, | ||
336 | [WM8915_WRITE_SEQUENCER_204] = 0x61, | ||
337 | [WM8915_WRITE_SEQUENCER_205] = 0x11, | ||
338 | [WM8915_WRITE_SEQUENCER_206] = 0x401, | ||
339 | [WM8915_WRITE_SEQUENCER_208] = 0x50, | ||
340 | [WM8915_WRITE_SEQUENCER_209] = 0x3, | ||
341 | [WM8915_WRITE_SEQUENCER_210] = 0x102, | ||
342 | [WM8915_WRITE_SEQUENCER_212] = 0x61, | ||
343 | [WM8915_WRITE_SEQUENCER_213] = 0x3b, | ||
344 | [WM8915_WRITE_SEQUENCER_214] = 0x502, | ||
345 | [WM8915_WRITE_SEQUENCER_215] = 0x100, | ||
346 | [WM8915_WRITE_SEQUENCER_216] = 0x2fff, | ||
347 | [WM8915_WRITE_SEQUENCER_220] = 0x2fff, | ||
348 | [WM8915_WRITE_SEQUENCER_224] = 0x2fff, | ||
349 | [WM8915_WRITE_SEQUENCER_228] = 0x2fff, | ||
350 | [WM8915_WRITE_SEQUENCER_232] = 0x2fff, | ||
351 | [WM8915_WRITE_SEQUENCER_236] = 0x2fff, | ||
352 | [WM8915_WRITE_SEQUENCER_240] = 0x2fff, | ||
353 | [WM8915_WRITE_SEQUENCER_244] = 0x2fff, | ||
354 | [WM8915_WRITE_SEQUENCER_248] = 0x2fff, | ||
355 | [WM8915_WRITE_SEQUENCER_252] = 0x2fff, | ||
356 | [WM8915_WRITE_SEQUENCER_256] = 0x60, | ||
357 | [WM8915_WRITE_SEQUENCER_258] = 0x601, | ||
358 | [WM8915_WRITE_SEQUENCER_260] = 0x50, | ||
359 | [WM8915_WRITE_SEQUENCER_262] = 0x100, | ||
360 | [WM8915_WRITE_SEQUENCER_264] = 0x1, | ||
361 | [WM8915_WRITE_SEQUENCER_266] = 0x104, | ||
362 | [WM8915_WRITE_SEQUENCER_267] = 0x100, | ||
363 | [WM8915_WRITE_SEQUENCER_268] = 0x2fff, | ||
364 | [WM8915_WRITE_SEQUENCER_272] = 0x2fff, | ||
365 | [WM8915_WRITE_SEQUENCER_276] = 0x2fff, | ||
366 | [WM8915_WRITE_SEQUENCER_280] = 0x2fff, | ||
367 | [WM8915_WRITE_SEQUENCER_284] = 0x2fff, | ||
368 | [WM8915_WRITE_SEQUENCER_288] = 0x2fff, | ||
369 | [WM8915_WRITE_SEQUENCER_292] = 0x2fff, | ||
370 | [WM8915_WRITE_SEQUENCER_296] = 0x2fff, | ||
371 | [WM8915_WRITE_SEQUENCER_300] = 0x2fff, | ||
372 | [WM8915_WRITE_SEQUENCER_304] = 0x2fff, | ||
373 | [WM8915_WRITE_SEQUENCER_308] = 0x2fff, | ||
374 | [WM8915_WRITE_SEQUENCER_312] = 0x2fff, | ||
375 | [WM8915_WRITE_SEQUENCER_316] = 0x2fff, | ||
376 | [WM8915_WRITE_SEQUENCER_320] = 0x61, | ||
377 | [WM8915_WRITE_SEQUENCER_322] = 0x601, | ||
378 | [WM8915_WRITE_SEQUENCER_324] = 0x50, | ||
379 | [WM8915_WRITE_SEQUENCER_326] = 0x102, | ||
380 | [WM8915_WRITE_SEQUENCER_328] = 0x1, | ||
381 | [WM8915_WRITE_SEQUENCER_330] = 0x106, | ||
382 | [WM8915_WRITE_SEQUENCER_331] = 0x100, | ||
383 | [WM8915_WRITE_SEQUENCER_332] = 0x2fff, | ||
384 | [WM8915_WRITE_SEQUENCER_336] = 0x2fff, | ||
385 | [WM8915_WRITE_SEQUENCER_340] = 0x2fff, | ||
386 | [WM8915_WRITE_SEQUENCER_344] = 0x2fff, | ||
387 | [WM8915_WRITE_SEQUENCER_348] = 0x2fff, | ||
388 | [WM8915_WRITE_SEQUENCER_352] = 0x2fff, | ||
389 | [WM8915_WRITE_SEQUENCER_356] = 0x2fff, | ||
390 | [WM8915_WRITE_SEQUENCER_360] = 0x2fff, | ||
391 | [WM8915_WRITE_SEQUENCER_364] = 0x2fff, | ||
392 | [WM8915_WRITE_SEQUENCER_368] = 0x2fff, | ||
393 | [WM8915_WRITE_SEQUENCER_372] = 0x2fff, | ||
394 | [WM8915_WRITE_SEQUENCER_376] = 0x2fff, | ||
395 | [WM8915_WRITE_SEQUENCER_380] = 0x2fff, | ||
396 | [WM8915_WRITE_SEQUENCER_384] = 0x60, | ||
397 | [WM8915_WRITE_SEQUENCER_386] = 0x601, | ||
398 | [WM8915_WRITE_SEQUENCER_388] = 0x61, | ||
399 | [WM8915_WRITE_SEQUENCER_390] = 0x601, | ||
400 | [WM8915_WRITE_SEQUENCER_392] = 0x50, | ||
401 | [WM8915_WRITE_SEQUENCER_394] = 0x300, | ||
402 | [WM8915_WRITE_SEQUENCER_396] = 0x1, | ||
403 | [WM8915_WRITE_SEQUENCER_398] = 0x304, | ||
404 | [WM8915_WRITE_SEQUENCER_400] = 0x40, | ||
405 | [WM8915_WRITE_SEQUENCER_402] = 0xf, | ||
406 | [WM8915_WRITE_SEQUENCER_404] = 0x1, | ||
407 | [WM8915_WRITE_SEQUENCER_407] = 0x100, | ||
408 | }; | ||
409 | |||
410 | static const DECLARE_TLV_DB_SCALE(inpga_tlv, 0, 100, 0); | ||
411 | static const DECLARE_TLV_DB_SCALE(sidetone_tlv, -3600, 150, 0); | ||
412 | static const DECLARE_TLV_DB_SCALE(digital_tlv, -7200, 75, 1); | ||
413 | static const DECLARE_TLV_DB_SCALE(out_digital_tlv, -1200, 150, 0); | ||
414 | static const DECLARE_TLV_DB_SCALE(out_tlv, -900, 75, 0); | ||
415 | static const DECLARE_TLV_DB_SCALE(spk_tlv, -900, 150, 0); | ||
416 | static const DECLARE_TLV_DB_SCALE(eq_tlv, -1200, 100, 0); | ||
417 | |||
418 | static const char *sidetone_hpf_text[] = { | ||
419 | "2.9kHz", "1.5kHz", "735Hz", "403Hz", "196Hz", "98Hz", "49Hz" | ||
420 | }; | ||
421 | |||
422 | static const struct soc_enum sidetone_hpf = | ||
423 | SOC_ENUM_SINGLE(WM8915_SIDETONE, 7, 6, sidetone_hpf_text); | ||
424 | |||
425 | static const char *hpf_mode_text[] = { | ||
426 | "HiFi", "Custom", "Voice" | ||
427 | }; | ||
428 | |||
429 | static const struct soc_enum dsp1tx_hpf_mode = | ||
430 | SOC_ENUM_SINGLE(WM8915_DSP1_TX_FILTERS, 3, 3, hpf_mode_text); | ||
431 | |||
432 | static const struct soc_enum dsp2tx_hpf_mode = | ||
433 | SOC_ENUM_SINGLE(WM8915_DSP2_TX_FILTERS, 3, 3, hpf_mode_text); | ||
434 | |||
435 | static const char *hpf_cutoff_text[] = { | ||
436 | "50Hz", "75Hz", "100Hz", "150Hz", "200Hz", "300Hz", "400Hz" | ||
437 | }; | ||
438 | |||
439 | static const struct soc_enum dsp1tx_hpf_cutoff = | ||
440 | SOC_ENUM_SINGLE(WM8915_DSP1_TX_FILTERS, 0, 7, hpf_cutoff_text); | ||
441 | |||
442 | static const struct soc_enum dsp2tx_hpf_cutoff = | ||
443 | SOC_ENUM_SINGLE(WM8915_DSP2_TX_FILTERS, 0, 7, hpf_cutoff_text); | ||
444 | |||
445 | static void wm8915_set_retune_mobile(struct snd_soc_codec *codec, int block) | ||
446 | { | ||
447 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
448 | struct wm8915_pdata *pdata = &wm8915->pdata; | ||
449 | int base, best, best_val, save, i, cfg, iface; | ||
450 | |||
451 | if (!wm8915->num_retune_mobile_texts) | ||
452 | return; | ||
453 | |||
454 | switch (block) { | ||
455 | case 0: | ||
456 | base = WM8915_DSP1_RX_EQ_GAINS_1; | ||
457 | if (snd_soc_read(codec, WM8915_POWER_MANAGEMENT_8) & | ||
458 | WM8915_DSP1RX_SRC) | ||
459 | iface = 1; | ||
460 | else | ||
461 | iface = 0; | ||
462 | break; | ||
463 | case 1: | ||
464 | base = WM8915_DSP1_RX_EQ_GAINS_2; | ||
465 | if (snd_soc_read(codec, WM8915_POWER_MANAGEMENT_8) & | ||
466 | WM8915_DSP2RX_SRC) | ||
467 | iface = 1; | ||
468 | else | ||
469 | iface = 0; | ||
470 | break; | ||
471 | default: | ||
472 | return; | ||
473 | } | ||
474 | |||
475 | /* Find the version of the currently selected configuration | ||
476 | * with the nearest sample rate. */ | ||
477 | cfg = wm8915->retune_mobile_cfg[block]; | ||
478 | best = 0; | ||
479 | best_val = INT_MAX; | ||
480 | for (i = 0; i < pdata->num_retune_mobile_cfgs; i++) { | ||
481 | if (strcmp(pdata->retune_mobile_cfgs[i].name, | ||
482 | wm8915->retune_mobile_texts[cfg]) == 0 && | ||
483 | abs(pdata->retune_mobile_cfgs[i].rate | ||
484 | - wm8915->rx_rate[iface]) < best_val) { | ||
485 | best = i; | ||
486 | best_val = abs(pdata->retune_mobile_cfgs[i].rate | ||
487 | - wm8915->rx_rate[iface]); | ||
488 | } | ||
489 | } | ||
490 | |||
491 | dev_dbg(codec->dev, "ReTune Mobile %d %s/%dHz for %dHz sample rate\n", | ||
492 | block, | ||
493 | pdata->retune_mobile_cfgs[best].name, | ||
494 | pdata->retune_mobile_cfgs[best].rate, | ||
495 | wm8915->rx_rate[iface]); | ||
496 | |||
497 | /* The EQ will be disabled while reconfiguring it, remember the | ||
498 | * current configuration. | ||
499 | */ | ||
500 | save = snd_soc_read(codec, base); | ||
501 | save &= WM8915_DSP1RX_EQ_ENA; | ||
502 | |||
503 | for (i = 0; i < ARRAY_SIZE(pdata->retune_mobile_cfgs[best].regs); i++) | ||
504 | snd_soc_update_bits(codec, base + i, 0xffff, | ||
505 | pdata->retune_mobile_cfgs[best].regs[i]); | ||
506 | |||
507 | snd_soc_update_bits(codec, base, WM8915_DSP1RX_EQ_ENA, save); | ||
508 | } | ||
509 | |||
510 | /* Icky as hell but saves code duplication */ | ||
511 | static int wm8915_get_retune_mobile_block(const char *name) | ||
512 | { | ||
513 | if (strcmp(name, "DSP1 EQ Mode") == 0) | ||
514 | return 0; | ||
515 | if (strcmp(name, "DSP2 EQ Mode") == 0) | ||
516 | return 1; | ||
517 | return -EINVAL; | ||
518 | } | ||
519 | |||
520 | static int wm8915_put_retune_mobile_enum(struct snd_kcontrol *kcontrol, | ||
521 | struct snd_ctl_elem_value *ucontrol) | ||
522 | { | ||
523 | struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol); | ||
524 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
525 | struct wm8915_pdata *pdata = &wm8915->pdata; | ||
526 | int block = wm8915_get_retune_mobile_block(kcontrol->id.name); | ||
527 | int value = ucontrol->value.integer.value[0]; | ||
528 | |||
529 | if (block < 0) | ||
530 | return block; | ||
531 | |||
532 | if (value >= pdata->num_retune_mobile_cfgs) | ||
533 | return -EINVAL; | ||
534 | |||
535 | wm8915->retune_mobile_cfg[block] = value; | ||
536 | |||
537 | wm8915_set_retune_mobile(codec, block); | ||
538 | |||
539 | return 0; | ||
540 | } | ||
541 | |||
542 | static int wm8915_get_retune_mobile_enum(struct snd_kcontrol *kcontrol, | ||
543 | struct snd_ctl_elem_value *ucontrol) | ||
544 | { | ||
545 | struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol); | ||
546 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
547 | int block = wm8915_get_retune_mobile_block(kcontrol->id.name); | ||
548 | |||
549 | ucontrol->value.enumerated.item[0] = wm8915->retune_mobile_cfg[block]; | ||
550 | |||
551 | return 0; | ||
552 | } | ||
553 | |||
554 | static const struct snd_kcontrol_new wm8915_snd_controls[] = { | ||
555 | SOC_DOUBLE_R_TLV("Capture Volume", WM8915_LEFT_LINE_INPUT_VOLUME, | ||
556 | WM8915_RIGHT_LINE_INPUT_VOLUME, 0, 31, 0, inpga_tlv), | ||
557 | SOC_DOUBLE_R("Capture ZC Switch", WM8915_LEFT_LINE_INPUT_VOLUME, | ||
558 | WM8915_RIGHT_LINE_INPUT_VOLUME, 5, 1, 0), | ||
559 | |||
560 | SOC_DOUBLE_TLV("DAC1 Sidetone Volume", WM8915_DAC1_MIXER_VOLUMES, | ||
561 | 0, 5, 24, 0, sidetone_tlv), | ||
562 | SOC_DOUBLE_TLV("DAC2 Sidetone Volume", WM8915_DAC2_MIXER_VOLUMES, | ||
563 | 0, 5, 24, 0, sidetone_tlv), | ||
564 | SOC_SINGLE("Sidetone LPF Switch", WM8915_SIDETONE, 12, 1, 0), | ||
565 | SOC_ENUM("Sidetone HPF Cut-off", sidetone_hpf), | ||
566 | SOC_SINGLE("Sidetone HPF Switch", WM8915_SIDETONE, 6, 1, 0), | ||
567 | |||
568 | SOC_DOUBLE_R_TLV("DSP1 Capture Volume", WM8915_DSP1_TX_LEFT_VOLUME, | ||
569 | WM8915_DSP1_TX_RIGHT_VOLUME, 1, 96, 0, digital_tlv), | ||
570 | SOC_DOUBLE_R_TLV("DSP2 Capture Volume", WM8915_DSP2_TX_LEFT_VOLUME, | ||
571 | WM8915_DSP2_TX_RIGHT_VOLUME, 1, 96, 0, digital_tlv), | ||
572 | |||
573 | SOC_SINGLE("DSP1 Capture Notch Filter Switch", WM8915_DSP1_TX_FILTERS, | ||
574 | 13, 1, 0), | ||
575 | SOC_DOUBLE("DSP1 Capture HPF Switch", WM8915_DSP1_TX_FILTERS, 12, 11, 1, 0), | ||
576 | SOC_ENUM("DSP1 Capture HPF Mode", dsp1tx_hpf_mode), | ||
577 | SOC_ENUM("DSP1 Capture HPF Cutoff", dsp1tx_hpf_cutoff), | ||
578 | |||
579 | SOC_SINGLE("DSP2 Capture Notch Filter Switch", WM8915_DSP2_TX_FILTERS, | ||
580 | 13, 1, 0), | ||
581 | SOC_DOUBLE("DSP2 Capture HPF Switch", WM8915_DSP2_TX_FILTERS, 12, 11, 1, 0), | ||
582 | SOC_ENUM("DSP2 Capture HPF Mode", dsp2tx_hpf_mode), | ||
583 | SOC_ENUM("DSP2 Capture HPF Cutoff", dsp2tx_hpf_cutoff), | ||
584 | |||
585 | SOC_DOUBLE_R_TLV("DSP1 Playback Volume", WM8915_DSP1_RX_LEFT_VOLUME, | ||
586 | WM8915_DSP1_RX_RIGHT_VOLUME, 1, 112, 0, digital_tlv), | ||
587 | SOC_SINGLE("DSP1 Playback Switch", WM8915_DSP1_RX_FILTERS_1, 9, 1, 1), | ||
588 | |||
589 | SOC_DOUBLE_R_TLV("DSP2 Playback Volume", WM8915_DSP2_RX_LEFT_VOLUME, | ||
590 | WM8915_DSP2_RX_RIGHT_VOLUME, 1, 112, 0, digital_tlv), | ||
591 | SOC_SINGLE("DSP2 Playback Switch", WM8915_DSP2_RX_FILTERS_1, 9, 1, 1), | ||
592 | |||
593 | SOC_DOUBLE_R_TLV("DAC1 Volume", WM8915_DAC1_LEFT_VOLUME, | ||
594 | WM8915_DAC1_RIGHT_VOLUME, 1, 112, 0, digital_tlv), | ||
595 | SOC_DOUBLE_R("DAC1 Switch", WM8915_DAC1_LEFT_VOLUME, | ||
596 | WM8915_DAC1_RIGHT_VOLUME, 9, 1, 1), | ||
597 | |||
598 | SOC_DOUBLE_R_TLV("DAC2 Volume", WM8915_DAC2_LEFT_VOLUME, | ||
599 | WM8915_DAC2_RIGHT_VOLUME, 1, 112, 0, digital_tlv), | ||
600 | SOC_DOUBLE_R("DAC2 Switch", WM8915_DAC2_LEFT_VOLUME, | ||
601 | WM8915_DAC2_RIGHT_VOLUME, 9, 1, 1), | ||
602 | |||
603 | SOC_SINGLE("Speaker High Performance Switch", WM8915_OVERSAMPLING, 3, 1, 0), | ||
604 | SOC_SINGLE("DMIC High Performance Switch", WM8915_OVERSAMPLING, 2, 1, 0), | ||
605 | SOC_SINGLE("ADC High Performance Switch", WM8915_OVERSAMPLING, 1, 1, 0), | ||
606 | SOC_SINGLE("DAC High Performance Switch", WM8915_OVERSAMPLING, 0, 1, 0), | ||
607 | |||
608 | SOC_SINGLE("DAC Soft Mute Switch", WM8915_DAC_SOFTMUTE, 1, 1, 0), | ||
609 | SOC_SINGLE("DAC Slow Soft Mute Switch", WM8915_DAC_SOFTMUTE, 0, 1, 0), | ||
610 | |||
611 | SOC_DOUBLE_TLV("Digital Output 1 Volume", WM8915_DAC1_HPOUT1_VOLUME, 0, 4, | ||
612 | 8, 0, out_digital_tlv), | ||
613 | SOC_DOUBLE_TLV("Digital Output 2 Volume", WM8915_DAC2_HPOUT2_VOLUME, 0, 4, | ||
614 | 8, 0, out_digital_tlv), | ||
615 | |||
616 | SOC_DOUBLE_R_TLV("Output 1 Volume", WM8915_OUTPUT1_LEFT_VOLUME, | ||
617 | WM8915_OUTPUT1_RIGHT_VOLUME, 0, 12, 0, out_tlv), | ||
618 | SOC_DOUBLE_R("Output 1 ZC Switch", WM8915_OUTPUT1_LEFT_VOLUME, | ||
619 | WM8915_OUTPUT1_RIGHT_VOLUME, 7, 1, 0), | ||
620 | |||
621 | SOC_DOUBLE_R_TLV("Output 2 Volume", WM8915_OUTPUT2_LEFT_VOLUME, | ||
622 | WM8915_OUTPUT2_RIGHT_VOLUME, 0, 12, 0, out_tlv), | ||
623 | SOC_DOUBLE_R("Output 2 ZC Switch", WM8915_OUTPUT2_LEFT_VOLUME, | ||
624 | WM8915_OUTPUT2_RIGHT_VOLUME, 7, 1, 0), | ||
625 | |||
626 | SOC_DOUBLE_TLV("Speaker Volume", WM8915_PDM_SPEAKER_VOLUME, 0, 4, 8, 0, | ||
627 | spk_tlv), | ||
628 | SOC_DOUBLE_R("Speaker Switch", WM8915_LEFT_PDM_SPEAKER, | ||
629 | WM8915_RIGHT_PDM_SPEAKER, 3, 1, 1), | ||
630 | SOC_DOUBLE_R("Speaker ZC Switch", WM8915_LEFT_PDM_SPEAKER, | ||
631 | WM8915_RIGHT_PDM_SPEAKER, 2, 1, 0), | ||
632 | |||
633 | SOC_SINGLE("DSP1 EQ Switch", WM8915_DSP1_RX_EQ_GAINS_1, 0, 1, 0), | ||
634 | SOC_SINGLE("DSP2 EQ Switch", WM8915_DSP2_RX_EQ_GAINS_1, 0, 1, 0), | ||
635 | }; | ||
636 | |||
637 | static const struct snd_kcontrol_new wm8915_eq_controls[] = { | ||
638 | SOC_SINGLE_TLV("DSP1 EQ B1 Volume", WM8915_DSP1_RX_EQ_GAINS_1, 11, 31, 0, | ||
639 | eq_tlv), | ||
640 | SOC_SINGLE_TLV("DSP1 EQ B2 Volume", WM8915_DSP1_RX_EQ_GAINS_1, 6, 31, 0, | ||
641 | eq_tlv), | ||
642 | SOC_SINGLE_TLV("DSP1 EQ B3 Volume", WM8915_DSP1_RX_EQ_GAINS_1, 1, 31, 0, | ||
643 | eq_tlv), | ||
644 | SOC_SINGLE_TLV("DSP1 EQ B4 Volume", WM8915_DSP1_RX_EQ_GAINS_2, 11, 31, 0, | ||
645 | eq_tlv), | ||
646 | SOC_SINGLE_TLV("DSP1 EQ B5 Volume", WM8915_DSP1_RX_EQ_GAINS_2, 6, 31, 0, | ||
647 | eq_tlv), | ||
648 | |||
649 | SOC_SINGLE_TLV("DSP2 EQ B1 Volume", WM8915_DSP2_RX_EQ_GAINS_1, 11, 31, 0, | ||
650 | eq_tlv), | ||
651 | SOC_SINGLE_TLV("DSP2 EQ B2 Volume", WM8915_DSP2_RX_EQ_GAINS_1, 6, 31, 0, | ||
652 | eq_tlv), | ||
653 | SOC_SINGLE_TLV("DSP2 EQ B3 Volume", WM8915_DSP2_RX_EQ_GAINS_1, 1, 31, 0, | ||
654 | eq_tlv), | ||
655 | SOC_SINGLE_TLV("DSP2 EQ B4 Volume", WM8915_DSP2_RX_EQ_GAINS_2, 11, 31, 0, | ||
656 | eq_tlv), | ||
657 | SOC_SINGLE_TLV("DSP2 EQ B5 Volume", WM8915_DSP2_RX_EQ_GAINS_2, 6, 31, 0, | ||
658 | eq_tlv), | ||
659 | }; | ||
660 | |||
661 | static int cp_event(struct snd_soc_dapm_widget *w, | ||
662 | struct snd_kcontrol *kcontrol, int event) | ||
663 | { | ||
664 | switch (event) { | ||
665 | case SND_SOC_DAPM_POST_PMU: | ||
666 | msleep(5); | ||
667 | break; | ||
668 | default: | ||
669 | BUG(); | ||
670 | return -EINVAL; | ||
671 | } | ||
672 | |||
673 | return 0; | ||
674 | } | ||
675 | |||
676 | static int rmv_short_event(struct snd_soc_dapm_widget *w, | ||
677 | struct snd_kcontrol *kcontrol, int event) | ||
678 | { | ||
679 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(w->codec); | ||
680 | |||
681 | /* Record which outputs we enabled */ | ||
682 | switch (event) { | ||
683 | case SND_SOC_DAPM_PRE_PMD: | ||
684 | wm8915->hpout_pending &= ~w->shift; | ||
685 | break; | ||
686 | case SND_SOC_DAPM_PRE_PMU: | ||
687 | wm8915->hpout_pending |= w->shift; | ||
688 | break; | ||
689 | default: | ||
690 | BUG(); | ||
691 | return -EINVAL; | ||
692 | } | ||
693 | |||
694 | return 0; | ||
695 | } | ||
696 | |||
697 | static void wait_for_dc_servo(struct snd_soc_codec *codec, u16 mask) | ||
698 | { | ||
699 | struct i2c_client *i2c = to_i2c_client(codec->dev); | ||
700 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
701 | int i, ret; | ||
702 | unsigned long timeout = 200; | ||
703 | |||
704 | snd_soc_write(codec, WM8915_DC_SERVO_2, mask); | ||
705 | |||
706 | /* Use the interrupt if possible */ | ||
707 | do { | ||
708 | if (i2c->irq) { | ||
709 | timeout = wait_for_completion_timeout(&wm8915->dcs_done, | ||
710 | msecs_to_jiffies(200)); | ||
711 | if (timeout == 0) | ||
712 | dev_err(codec->dev, "DC servo timed out\n"); | ||
713 | |||
714 | } else { | ||
715 | msleep(1); | ||
716 | if (--i) { | ||
717 | timeout = 0; | ||
718 | break; | ||
719 | } | ||
720 | } | ||
721 | |||
722 | ret = snd_soc_read(codec, WM8915_DC_SERVO_2); | ||
723 | dev_dbg(codec->dev, "DC servo state: %x\n", ret); | ||
724 | } while (ret & mask); | ||
725 | |||
726 | if (timeout == 0) | ||
727 | dev_err(codec->dev, "DC servo timed out for %x\n", mask); | ||
728 | else | ||
729 | dev_dbg(codec->dev, "DC servo complete for %x\n", mask); | ||
730 | } | ||
731 | |||
732 | static void wm8915_seq_notifier(struct snd_soc_dapm_context *dapm, | ||
733 | enum snd_soc_dapm_type event, int subseq) | ||
734 | { | ||
735 | struct snd_soc_codec *codec = container_of(dapm, | ||
736 | struct snd_soc_codec, dapm); | ||
737 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
738 | u16 val, mask; | ||
739 | |||
740 | /* Complete any pending DC servo starts */ | ||
741 | if (wm8915->dcs_pending) { | ||
742 | dev_dbg(codec->dev, "Starting DC servo for %x\n", | ||
743 | wm8915->dcs_pending); | ||
744 | |||
745 | /* Trigger a startup sequence */ | ||
746 | wait_for_dc_servo(codec, wm8915->dcs_pending | ||
747 | << WM8915_DCS_TRIG_STARTUP_0_SHIFT); | ||
748 | |||
749 | wm8915->dcs_pending = 0; | ||
750 | } | ||
751 | |||
752 | if (wm8915->hpout_pending != wm8915->hpout_ena) { | ||
753 | dev_dbg(codec->dev, "Applying RMV_SHORTs %x->%x\n", | ||
754 | wm8915->hpout_ena, wm8915->hpout_pending); | ||
755 | |||
756 | val = 0; | ||
757 | mask = 0; | ||
758 | if (wm8915->hpout_pending & HPOUT1L) { | ||
759 | val |= WM8915_HPOUT1L_RMV_SHORT; | ||
760 | mask |= WM8915_HPOUT1L_RMV_SHORT; | ||
761 | } else { | ||
762 | mask |= WM8915_HPOUT1L_RMV_SHORT | | ||
763 | WM8915_HPOUT1L_OUTP | | ||
764 | WM8915_HPOUT1L_DLY; | ||
765 | } | ||
766 | |||
767 | if (wm8915->hpout_pending & HPOUT1R) { | ||
768 | val |= WM8915_HPOUT1R_RMV_SHORT; | ||
769 | mask |= WM8915_HPOUT1R_RMV_SHORT; | ||
770 | } else { | ||
771 | mask |= WM8915_HPOUT1R_RMV_SHORT | | ||
772 | WM8915_HPOUT1R_OUTP | | ||
773 | WM8915_HPOUT1R_DLY; | ||
774 | } | ||
775 | |||
776 | snd_soc_update_bits(codec, WM8915_ANALOGUE_HP_1, mask, val); | ||
777 | |||
778 | val = 0; | ||
779 | mask = 0; | ||
780 | if (wm8915->hpout_pending & HPOUT2L) { | ||
781 | val |= WM8915_HPOUT2L_RMV_SHORT; | ||
782 | mask |= WM8915_HPOUT2L_RMV_SHORT; | ||
783 | } else { | ||
784 | mask |= WM8915_HPOUT2L_RMV_SHORT | | ||
785 | WM8915_HPOUT2L_OUTP | | ||
786 | WM8915_HPOUT2L_DLY; | ||
787 | } | ||
788 | |||
789 | if (wm8915->hpout_pending & HPOUT2R) { | ||
790 | val |= WM8915_HPOUT2R_RMV_SHORT; | ||
791 | mask |= WM8915_HPOUT2R_RMV_SHORT; | ||
792 | } else { | ||
793 | mask |= WM8915_HPOUT2R_RMV_SHORT | | ||
794 | WM8915_HPOUT2R_OUTP | | ||
795 | WM8915_HPOUT2R_DLY; | ||
796 | } | ||
797 | |||
798 | snd_soc_update_bits(codec, WM8915_ANALOGUE_HP_2, mask, val); | ||
799 | |||
800 | wm8915->hpout_ena = wm8915->hpout_pending; | ||
801 | } | ||
802 | } | ||
803 | |||
804 | static int dcs_start(struct snd_soc_dapm_widget *w, | ||
805 | struct snd_kcontrol *kcontrol, int event) | ||
806 | { | ||
807 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(w->codec); | ||
808 | |||
809 | switch (event) { | ||
810 | case SND_SOC_DAPM_POST_PMU: | ||
811 | wm8915->dcs_pending |= 1 << w->shift; | ||
812 | break; | ||
813 | default: | ||
814 | BUG(); | ||
815 | return -EINVAL; | ||
816 | } | ||
817 | |||
818 | return 0; | ||
819 | } | ||
820 | |||
821 | static const char *sidetone_text[] = { | ||
822 | "IN1", "IN2", | ||
823 | }; | ||
824 | |||
825 | static const struct soc_enum left_sidetone_enum = | ||
826 | SOC_ENUM_SINGLE(WM8915_SIDETONE, 0, 2, sidetone_text); | ||
827 | |||
828 | static const struct snd_kcontrol_new left_sidetone = | ||
829 | SOC_DAPM_ENUM("Left Sidetone", left_sidetone_enum); | ||
830 | |||
831 | static const struct soc_enum right_sidetone_enum = | ||
832 | SOC_ENUM_SINGLE(WM8915_SIDETONE, 1, 2, sidetone_text); | ||
833 | |||
834 | static const struct snd_kcontrol_new right_sidetone = | ||
835 | SOC_DAPM_ENUM("Right Sidetone", right_sidetone_enum); | ||
836 | |||
837 | static const char *spk_text[] = { | ||
838 | "DAC1L", "DAC1R", "DAC2L", "DAC2R" | ||
839 | }; | ||
840 | |||
841 | static const struct soc_enum spkl_enum = | ||
842 | SOC_ENUM_SINGLE(WM8915_LEFT_PDM_SPEAKER, 0, 4, spk_text); | ||
843 | |||
844 | static const struct snd_kcontrol_new spkl_mux = | ||
845 | SOC_DAPM_ENUM("SPKL", spkl_enum); | ||
846 | |||
847 | static const struct soc_enum spkr_enum = | ||
848 | SOC_ENUM_SINGLE(WM8915_RIGHT_PDM_SPEAKER, 0, 4, spk_text); | ||
849 | |||
850 | static const struct snd_kcontrol_new spkr_mux = | ||
851 | SOC_DAPM_ENUM("SPKR", spkr_enum); | ||
852 | |||
853 | static const char *dsp1rx_text[] = { | ||
854 | "AIF1", "AIF2" | ||
855 | }; | ||
856 | |||
857 | static const struct soc_enum dsp1rx_enum = | ||
858 | SOC_ENUM_SINGLE(WM8915_POWER_MANAGEMENT_8, 0, 2, dsp1rx_text); | ||
859 | |||
860 | static const struct snd_kcontrol_new dsp1rx = | ||
861 | SOC_DAPM_ENUM("DSP1RX", dsp1rx_enum); | ||
862 | |||
863 | static const char *dsp2rx_text[] = { | ||
864 | "AIF2", "AIF1" | ||
865 | }; | ||
866 | |||
867 | static const struct soc_enum dsp2rx_enum = | ||
868 | SOC_ENUM_SINGLE(WM8915_POWER_MANAGEMENT_8, 4, 2, dsp2rx_text); | ||
869 | |||
870 | static const struct snd_kcontrol_new dsp2rx = | ||
871 | SOC_DAPM_ENUM("DSP2RX", dsp2rx_enum); | ||
872 | |||
873 | static const char *aif2tx_text[] = { | ||
874 | "DSP2", "DSP1", "AIF1" | ||
875 | }; | ||
876 | |||
877 | static const struct soc_enum aif2tx_enum = | ||
878 | SOC_ENUM_SINGLE(WM8915_POWER_MANAGEMENT_8, 6, 3, aif2tx_text); | ||
879 | |||
880 | static const struct snd_kcontrol_new aif2tx = | ||
881 | SOC_DAPM_ENUM("AIF2TX", aif2tx_enum); | ||
882 | |||
883 | static const char *inmux_text[] = { | ||
884 | "ADC", "DMIC1", "DMIC2" | ||
885 | }; | ||
886 | |||
887 | static const struct soc_enum in1_enum = | ||
888 | SOC_ENUM_SINGLE(WM8915_POWER_MANAGEMENT_7, 0, 3, inmux_text); | ||
889 | |||
890 | static const struct snd_kcontrol_new in1_mux = | ||
891 | SOC_DAPM_ENUM("IN1 Mux", in1_enum); | ||
892 | |||
893 | static const struct soc_enum in2_enum = | ||
894 | SOC_ENUM_SINGLE(WM8915_POWER_MANAGEMENT_7, 4, 3, inmux_text); | ||
895 | |||
896 | static const struct snd_kcontrol_new in2_mux = | ||
897 | SOC_DAPM_ENUM("IN2 Mux", in2_enum); | ||
898 | |||
899 | static const struct snd_kcontrol_new dac2r_mix[] = { | ||
900 | SOC_DAPM_SINGLE("Right Sidetone Switch", WM8915_DAC2_RIGHT_MIXER_ROUTING, | ||
901 | 5, 1, 0), | ||
902 | SOC_DAPM_SINGLE("Left Sidetone Switch", WM8915_DAC2_RIGHT_MIXER_ROUTING, | ||
903 | 4, 1, 0), | ||
904 | SOC_DAPM_SINGLE("DSP2 Switch", WM8915_DAC2_RIGHT_MIXER_ROUTING, 1, 1, 0), | ||
905 | SOC_DAPM_SINGLE("DSP1 Switch", WM8915_DAC2_RIGHT_MIXER_ROUTING, 0, 1, 0), | ||
906 | }; | ||
907 | |||
908 | static const struct snd_kcontrol_new dac2l_mix[] = { | ||
909 | SOC_DAPM_SINGLE("Right Sidetone Switch", WM8915_DAC2_LEFT_MIXER_ROUTING, | ||
910 | 5, 1, 0), | ||
911 | SOC_DAPM_SINGLE("Left Sidetone Switch", WM8915_DAC2_LEFT_MIXER_ROUTING, | ||
912 | 4, 1, 0), | ||
913 | SOC_DAPM_SINGLE("DSP2 Switch", WM8915_DAC2_LEFT_MIXER_ROUTING, 1, 1, 0), | ||
914 | SOC_DAPM_SINGLE("DSP1 Switch", WM8915_DAC2_LEFT_MIXER_ROUTING, 0, 1, 0), | ||
915 | }; | ||
916 | |||
917 | static const struct snd_kcontrol_new dac1r_mix[] = { | ||
918 | SOC_DAPM_SINGLE("Right Sidetone Switch", WM8915_DAC1_RIGHT_MIXER_ROUTING, | ||
919 | 5, 1, 0), | ||
920 | SOC_DAPM_SINGLE("Left Sidetone Switch", WM8915_DAC1_RIGHT_MIXER_ROUTING, | ||
921 | 4, 1, 0), | ||
922 | SOC_DAPM_SINGLE("DSP2 Switch", WM8915_DAC1_RIGHT_MIXER_ROUTING, 1, 1, 0), | ||
923 | SOC_DAPM_SINGLE("DSP1 Switch", WM8915_DAC1_RIGHT_MIXER_ROUTING, 0, 1, 0), | ||
924 | }; | ||
925 | |||
926 | static const struct snd_kcontrol_new dac1l_mix[] = { | ||
927 | SOC_DAPM_SINGLE("Right Sidetone Switch", WM8915_DAC1_LEFT_MIXER_ROUTING, | ||
928 | 5, 1, 0), | ||
929 | SOC_DAPM_SINGLE("Left Sidetone Switch", WM8915_DAC1_LEFT_MIXER_ROUTING, | ||
930 | 4, 1, 0), | ||
931 | SOC_DAPM_SINGLE("DSP2 Switch", WM8915_DAC1_LEFT_MIXER_ROUTING, 1, 1, 0), | ||
932 | SOC_DAPM_SINGLE("DSP1 Switch", WM8915_DAC1_LEFT_MIXER_ROUTING, 0, 1, 0), | ||
933 | }; | ||
934 | |||
935 | static const struct snd_kcontrol_new dsp1txl[] = { | ||
936 | SOC_DAPM_SINGLE("IN1 Switch", WM8915_DSP1_TX_LEFT_MIXER_ROUTING, | ||
937 | 1, 1, 0), | ||
938 | SOC_DAPM_SINGLE("DAC Switch", WM8915_DSP1_TX_LEFT_MIXER_ROUTING, | ||
939 | 0, 1, 0), | ||
940 | }; | ||
941 | |||
942 | static const struct snd_kcontrol_new dsp1txr[] = { | ||
943 | SOC_DAPM_SINGLE("IN1 Switch", WM8915_DSP1_TX_RIGHT_MIXER_ROUTING, | ||
944 | 1, 1, 0), | ||
945 | SOC_DAPM_SINGLE("DAC Switch", WM8915_DSP1_TX_RIGHT_MIXER_ROUTING, | ||
946 | 0, 1, 0), | ||
947 | }; | ||
948 | |||
949 | static const struct snd_kcontrol_new dsp2txl[] = { | ||
950 | SOC_DAPM_SINGLE("IN1 Switch", WM8915_DSP2_TX_LEFT_MIXER_ROUTING, | ||
951 | 1, 1, 0), | ||
952 | SOC_DAPM_SINGLE("DAC Switch", WM8915_DSP2_TX_LEFT_MIXER_ROUTING, | ||
953 | 0, 1, 0), | ||
954 | }; | ||
955 | |||
956 | static const struct snd_kcontrol_new dsp2txr[] = { | ||
957 | SOC_DAPM_SINGLE("IN1 Switch", WM8915_DSP2_TX_RIGHT_MIXER_ROUTING, | ||
958 | 1, 1, 0), | ||
959 | SOC_DAPM_SINGLE("DAC Switch", WM8915_DSP2_TX_RIGHT_MIXER_ROUTING, | ||
960 | 0, 1, 0), | ||
961 | }; | ||
962 | |||
963 | |||
964 | static const struct snd_soc_dapm_widget wm8915_dapm_widgets[] = { | ||
965 | SND_SOC_DAPM_INPUT("IN1LN"), | ||
966 | SND_SOC_DAPM_INPUT("IN1LP"), | ||
967 | SND_SOC_DAPM_INPUT("IN1RN"), | ||
968 | SND_SOC_DAPM_INPUT("IN1RP"), | ||
969 | |||
970 | SND_SOC_DAPM_INPUT("IN2LN"), | ||
971 | SND_SOC_DAPM_INPUT("IN2LP"), | ||
972 | SND_SOC_DAPM_INPUT("IN2RN"), | ||
973 | SND_SOC_DAPM_INPUT("IN2RP"), | ||
974 | |||
975 | SND_SOC_DAPM_INPUT("DMIC1DAT"), | ||
976 | SND_SOC_DAPM_INPUT("DMIC2DAT"), | ||
977 | |||
978 | SND_SOC_DAPM_SUPPLY_S("SYSCLK", 1, WM8915_AIF_CLOCKING_1, 0, 0, NULL, 0), | ||
979 | SND_SOC_DAPM_SUPPLY_S("SYSDSPCLK", 2, WM8915_CLOCKING_1, 1, 0, NULL, 0), | ||
980 | SND_SOC_DAPM_SUPPLY_S("AIFCLK", 2, WM8915_CLOCKING_1, 2, 0, NULL, 0), | ||
981 | SND_SOC_DAPM_SUPPLY_S("Charge Pump", 2, WM8915_CHARGE_PUMP_1, 15, 0, cp_event, | ||
982 | SND_SOC_DAPM_POST_PMU), | ||
983 | |||
984 | SND_SOC_DAPM_SUPPLY("LDO2", WM8915_POWER_MANAGEMENT_2, 1, 0, NULL, 0), | ||
985 | SND_SOC_DAPM_MICBIAS("MICB2", WM8915_POWER_MANAGEMENT_1, 9, 0), | ||
986 | SND_SOC_DAPM_MICBIAS("MICB1", WM8915_POWER_MANAGEMENT_1, 8, 0), | ||
987 | |||
988 | SND_SOC_DAPM_PGA("IN1L PGA", WM8915_POWER_MANAGEMENT_2, 5, 0, NULL, 0), | ||
989 | SND_SOC_DAPM_PGA("IN1R PGA", WM8915_POWER_MANAGEMENT_2, 4, 0, NULL, 0), | ||
990 | |||
991 | SND_SOC_DAPM_MUX("IN1L Mux", SND_SOC_NOPM, 0, 0, &in1_mux), | ||
992 | SND_SOC_DAPM_MUX("IN1R Mux", SND_SOC_NOPM, 0, 0, &in1_mux), | ||
993 | SND_SOC_DAPM_MUX("IN2L Mux", SND_SOC_NOPM, 0, 0, &in2_mux), | ||
994 | SND_SOC_DAPM_MUX("IN2R Mux", SND_SOC_NOPM, 0, 0, &in2_mux), | ||
995 | |||
996 | SND_SOC_DAPM_PGA("IN1L", WM8915_POWER_MANAGEMENT_7, 2, 0, NULL, 0), | ||
997 | SND_SOC_DAPM_PGA("IN1R", WM8915_POWER_MANAGEMENT_7, 3, 0, NULL, 0), | ||
998 | SND_SOC_DAPM_PGA("IN2L", WM8915_POWER_MANAGEMENT_7, 6, 0, NULL, 0), | ||
999 | SND_SOC_DAPM_PGA("IN2R", WM8915_POWER_MANAGEMENT_7, 7, 0, NULL, 0), | ||
1000 | |||
1001 | SND_SOC_DAPM_SUPPLY("DMIC2", WM8915_POWER_MANAGEMENT_7, 9, 0, NULL, 0), | ||
1002 | SND_SOC_DAPM_SUPPLY("DMIC1", WM8915_POWER_MANAGEMENT_7, 8, 0, NULL, 0), | ||
1003 | |||
1004 | SND_SOC_DAPM_ADC("DMIC2L", NULL, WM8915_POWER_MANAGEMENT_3, 5, 0), | ||
1005 | SND_SOC_DAPM_ADC("DMIC2R", NULL, WM8915_POWER_MANAGEMENT_3, 4, 0), | ||
1006 | SND_SOC_DAPM_ADC("DMIC1L", NULL, WM8915_POWER_MANAGEMENT_3, 3, 0), | ||
1007 | SND_SOC_DAPM_ADC("DMIC1R", NULL, WM8915_POWER_MANAGEMENT_3, 2, 0), | ||
1008 | |||
1009 | SND_SOC_DAPM_ADC("ADCL", NULL, WM8915_POWER_MANAGEMENT_3, 1, 0), | ||
1010 | SND_SOC_DAPM_ADC("ADCR", NULL, WM8915_POWER_MANAGEMENT_3, 0, 0), | ||
1011 | |||
1012 | SND_SOC_DAPM_MUX("Left Sidetone", SND_SOC_NOPM, 0, 0, &left_sidetone), | ||
1013 | SND_SOC_DAPM_MUX("Right Sidetone", SND_SOC_NOPM, 0, 0, &right_sidetone), | ||
1014 | |||
1015 | SND_SOC_DAPM_AIF_IN("DSP2RXL", NULL, 0, WM8915_POWER_MANAGEMENT_3, 11, 0), | ||
1016 | SND_SOC_DAPM_AIF_IN("DSP2RXR", NULL, 1, WM8915_POWER_MANAGEMENT_3, 10, 0), | ||
1017 | SND_SOC_DAPM_AIF_IN("DSP1RXL", NULL, 0, WM8915_POWER_MANAGEMENT_3, 9, 0), | ||
1018 | SND_SOC_DAPM_AIF_IN("DSP1RXR", NULL, 1, WM8915_POWER_MANAGEMENT_3, 8, 0), | ||
1019 | |||
1020 | SND_SOC_DAPM_MIXER("DSP2TXL", WM8915_POWER_MANAGEMENT_5, 11, 0, | ||
1021 | dsp2txl, ARRAY_SIZE(dsp2txl)), | ||
1022 | SND_SOC_DAPM_MIXER("DSP2TXR", WM8915_POWER_MANAGEMENT_5, 10, 0, | ||
1023 | dsp2txr, ARRAY_SIZE(dsp2txr)), | ||
1024 | SND_SOC_DAPM_MIXER("DSP1TXL", WM8915_POWER_MANAGEMENT_5, 9, 0, | ||
1025 | dsp1txl, ARRAY_SIZE(dsp1txl)), | ||
1026 | SND_SOC_DAPM_MIXER("DSP1TXR", WM8915_POWER_MANAGEMENT_5, 8, 0, | ||
1027 | dsp1txr, ARRAY_SIZE(dsp1txr)), | ||
1028 | |||
1029 | SND_SOC_DAPM_MIXER("DAC2L Mixer", SND_SOC_NOPM, 0, 0, | ||
1030 | dac2l_mix, ARRAY_SIZE(dac2l_mix)), | ||
1031 | SND_SOC_DAPM_MIXER("DAC2R Mixer", SND_SOC_NOPM, 0, 0, | ||
1032 | dac2r_mix, ARRAY_SIZE(dac2r_mix)), | ||
1033 | SND_SOC_DAPM_MIXER("DAC1L Mixer", SND_SOC_NOPM, 0, 0, | ||
1034 | dac1l_mix, ARRAY_SIZE(dac1l_mix)), | ||
1035 | SND_SOC_DAPM_MIXER("DAC1R Mixer", SND_SOC_NOPM, 0, 0, | ||
1036 | dac1r_mix, ARRAY_SIZE(dac1r_mix)), | ||
1037 | |||
1038 | SND_SOC_DAPM_DAC("DAC2L", NULL, WM8915_POWER_MANAGEMENT_5, 3, 0), | ||
1039 | SND_SOC_DAPM_DAC("DAC2R", NULL, WM8915_POWER_MANAGEMENT_5, 2, 0), | ||
1040 | SND_SOC_DAPM_DAC("DAC1L", NULL, WM8915_POWER_MANAGEMENT_5, 1, 0), | ||
1041 | SND_SOC_DAPM_DAC("DAC1R", NULL, WM8915_POWER_MANAGEMENT_5, 0, 0), | ||
1042 | |||
1043 | SND_SOC_DAPM_AIF_IN("AIF2RX1", "AIF2 Playback", 1, | ||
1044 | WM8915_POWER_MANAGEMENT_4, 9, 0), | ||
1045 | SND_SOC_DAPM_AIF_IN("AIF2RX0", "AIF2 Playback", 2, | ||
1046 | WM8915_POWER_MANAGEMENT_4, 8, 0), | ||
1047 | |||
1048 | SND_SOC_DAPM_AIF_IN("AIF2TX1", "AIF2 Capture", 1, | ||
1049 | WM8915_POWER_MANAGEMENT_6, 9, 0), | ||
1050 | SND_SOC_DAPM_AIF_IN("AIF2TX0", "AIF2 Capture", 2, | ||
1051 | WM8915_POWER_MANAGEMENT_6, 8, 0), | ||
1052 | |||
1053 | SND_SOC_DAPM_AIF_IN("AIF1RX5", "AIF1 Playback", 5, | ||
1054 | WM8915_POWER_MANAGEMENT_4, 5, 0), | ||
1055 | SND_SOC_DAPM_AIF_IN("AIF1RX4", "AIF1 Playback", 4, | ||
1056 | WM8915_POWER_MANAGEMENT_4, 4, 0), | ||
1057 | SND_SOC_DAPM_AIF_IN("AIF1RX3", "AIF1 Playback", 3, | ||
1058 | WM8915_POWER_MANAGEMENT_4, 3, 0), | ||
1059 | SND_SOC_DAPM_AIF_IN("AIF1RX2", "AIF1 Playback", 2, | ||
1060 | WM8915_POWER_MANAGEMENT_4, 2, 0), | ||
1061 | SND_SOC_DAPM_AIF_IN("AIF1RX1", "AIF1 Playback", 1, | ||
1062 | WM8915_POWER_MANAGEMENT_4, 1, 0), | ||
1063 | SND_SOC_DAPM_AIF_IN("AIF1RX0", "AIF1 Playback", 0, | ||
1064 | WM8915_POWER_MANAGEMENT_4, 0, 0), | ||
1065 | |||
1066 | SND_SOC_DAPM_AIF_OUT("AIF1TX5", "AIF1 Capture", 5, | ||
1067 | WM8915_POWER_MANAGEMENT_6, 5, 0), | ||
1068 | SND_SOC_DAPM_AIF_OUT("AIF1TX4", "AIF1 Capture", 4, | ||
1069 | WM8915_POWER_MANAGEMENT_6, 4, 0), | ||
1070 | SND_SOC_DAPM_AIF_OUT("AIF1TX3", "AIF1 Capture", 3, | ||
1071 | WM8915_POWER_MANAGEMENT_6, 3, 0), | ||
1072 | SND_SOC_DAPM_AIF_OUT("AIF1TX2", "AIF1 Capture", 2, | ||
1073 | WM8915_POWER_MANAGEMENT_6, 2, 0), | ||
1074 | SND_SOC_DAPM_AIF_OUT("AIF1TX1", "AIF1 Capture", 1, | ||
1075 | WM8915_POWER_MANAGEMENT_6, 1, 0), | ||
1076 | SND_SOC_DAPM_AIF_OUT("AIF1TX0", "AIF1 Capture", 0, | ||
1077 | WM8915_POWER_MANAGEMENT_6, 0, 0), | ||
1078 | |||
1079 | /* We route as stereo pairs so define some dummy widgets to squash | ||
1080 | * things down for now. RXA = 0,1, RXB = 2,3 and so on */ | ||
1081 | SND_SOC_DAPM_PGA("AIF1RXA", SND_SOC_NOPM, 0, 0, NULL, 0), | ||
1082 | SND_SOC_DAPM_PGA("AIF1RXB", SND_SOC_NOPM, 0, 0, NULL, 0), | ||
1083 | SND_SOC_DAPM_PGA("AIF1RXC", SND_SOC_NOPM, 0, 0, NULL, 0), | ||
1084 | SND_SOC_DAPM_PGA("AIF2RX", SND_SOC_NOPM, 0, 0, NULL, 0), | ||
1085 | SND_SOC_DAPM_PGA("DSP2TX", SND_SOC_NOPM, 0, 0, NULL, 0), | ||
1086 | |||
1087 | SND_SOC_DAPM_MUX("DSP1RX", SND_SOC_NOPM, 0, 0, &dsp1rx), | ||
1088 | SND_SOC_DAPM_MUX("DSP2RX", SND_SOC_NOPM, 0, 0, &dsp2rx), | ||
1089 | SND_SOC_DAPM_MUX("AIF2TX", SND_SOC_NOPM, 0, 0, &aif2tx), | ||
1090 | |||
1091 | SND_SOC_DAPM_MUX("SPKL", SND_SOC_NOPM, 0, 0, &spkl_mux), | ||
1092 | SND_SOC_DAPM_MUX("SPKR", SND_SOC_NOPM, 0, 0, &spkr_mux), | ||
1093 | SND_SOC_DAPM_PGA("SPKL PGA", WM8915_LEFT_PDM_SPEAKER, 4, 0, NULL, 0), | ||
1094 | SND_SOC_DAPM_PGA("SPKR PGA", WM8915_RIGHT_PDM_SPEAKER, 4, 0, NULL, 0), | ||
1095 | |||
1096 | SND_SOC_DAPM_PGA_S("HPOUT2L PGA", 0, WM8915_POWER_MANAGEMENT_1, 7, 0, NULL, 0), | ||
1097 | SND_SOC_DAPM_PGA_S("HPOUT2L_DLY", 1, WM8915_ANALOGUE_HP_2, 5, 0, NULL, 0), | ||
1098 | SND_SOC_DAPM_PGA_S("HPOUT2L_DCS", 2, WM8915_DC_SERVO_1, 2, 0, dcs_start, | ||
1099 | SND_SOC_DAPM_POST_PMU), | ||
1100 | SND_SOC_DAPM_PGA_S("HPOUT2L_OUTP", 3, WM8915_ANALOGUE_HP_2, 6, 0, NULL, 0), | ||
1101 | SND_SOC_DAPM_PGA_S("HPOUT2L_RMV_SHORT", 3, SND_SOC_NOPM, HPOUT2L, 0, | ||
1102 | rmv_short_event, | ||
1103 | SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_PRE_PMD), | ||
1104 | |||
1105 | SND_SOC_DAPM_PGA_S("HPOUT2R PGA", 0, WM8915_POWER_MANAGEMENT_1, 6, 0,NULL, 0), | ||
1106 | SND_SOC_DAPM_PGA_S("HPOUT2R_DLY", 1, WM8915_ANALOGUE_HP_2, 1, 0, NULL, 0), | ||
1107 | SND_SOC_DAPM_PGA_S("HPOUT2R_DCS", 2, WM8915_DC_SERVO_1, 3, 0, dcs_start, | ||
1108 | SND_SOC_DAPM_POST_PMU), | ||
1109 | SND_SOC_DAPM_PGA_S("HPOUT2R_OUTP", 3, WM8915_ANALOGUE_HP_2, 2, 0, NULL, 0), | ||
1110 | SND_SOC_DAPM_PGA_S("HPOUT2R_RMV_SHORT", 3, SND_SOC_NOPM, HPOUT2R, 0, | ||
1111 | rmv_short_event, | ||
1112 | SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_PRE_PMD), | ||
1113 | |||
1114 | SND_SOC_DAPM_PGA_S("HPOUT1L PGA", 0, WM8915_POWER_MANAGEMENT_1, 5, 0, NULL, 0), | ||
1115 | SND_SOC_DAPM_PGA_S("HPOUT1L_DLY", 1, WM8915_ANALOGUE_HP_1, 5, 0, NULL, 0), | ||
1116 | SND_SOC_DAPM_PGA_S("HPOUT1L_DCS", 2, WM8915_DC_SERVO_1, 0, 0, dcs_start, | ||
1117 | SND_SOC_DAPM_POST_PMU), | ||
1118 | SND_SOC_DAPM_PGA_S("HPOUT1L_OUTP", 3, WM8915_ANALOGUE_HP_1, 6, 0, NULL, 0), | ||
1119 | SND_SOC_DAPM_PGA_S("HPOUT1L_RMV_SHORT", 3, SND_SOC_NOPM, HPOUT1L, 0, | ||
1120 | rmv_short_event, | ||
1121 | SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_PRE_PMD), | ||
1122 | |||
1123 | SND_SOC_DAPM_PGA_S("HPOUT1R PGA", 0, WM8915_POWER_MANAGEMENT_1, 4, 0, NULL, 0), | ||
1124 | SND_SOC_DAPM_PGA_S("HPOUT1R_DLY", 1, WM8915_ANALOGUE_HP_1, 1, 0, NULL, 0), | ||
1125 | SND_SOC_DAPM_PGA_S("HPOUT1R_DCS", 2, WM8915_DC_SERVO_1, 1, 0, dcs_start, | ||
1126 | SND_SOC_DAPM_POST_PMU), | ||
1127 | SND_SOC_DAPM_PGA_S("HPOUT1R_OUTP", 3, WM8915_ANALOGUE_HP_1, 2, 0, NULL, 0), | ||
1128 | SND_SOC_DAPM_PGA_S("HPOUT1R_RMV_SHORT", 3, SND_SOC_NOPM, HPOUT1R, 0, | ||
1129 | rmv_short_event, | ||
1130 | SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_PRE_PMD), | ||
1131 | |||
1132 | SND_SOC_DAPM_OUTPUT("HPOUT1L"), | ||
1133 | SND_SOC_DAPM_OUTPUT("HPOUT1R"), | ||
1134 | SND_SOC_DAPM_OUTPUT("HPOUT2L"), | ||
1135 | SND_SOC_DAPM_OUTPUT("HPOUT2R"), | ||
1136 | SND_SOC_DAPM_OUTPUT("SPKDAT"), | ||
1137 | }; | ||
1138 | |||
1139 | static const struct snd_soc_dapm_route wm8915_dapm_routes[] = { | ||
1140 | { "AIFCLK", NULL, "SYSCLK" }, | ||
1141 | { "SYSDSPCLK", NULL, "SYSCLK" }, | ||
1142 | { "Charge Pump", NULL, "SYSCLK" }, | ||
1143 | |||
1144 | { "MICB1", NULL, "LDO2" }, | ||
1145 | { "MICB2", NULL, "LDO2" }, | ||
1146 | |||
1147 | { "IN1L PGA", NULL, "IN2LN" }, | ||
1148 | { "IN1L PGA", NULL, "IN2LP" }, | ||
1149 | { "IN1L PGA", NULL, "IN1LN" }, | ||
1150 | { "IN1L PGA", NULL, "IN1LP" }, | ||
1151 | |||
1152 | { "IN1R PGA", NULL, "IN2RN" }, | ||
1153 | { "IN1R PGA", NULL, "IN2RP" }, | ||
1154 | { "IN1R PGA", NULL, "IN1RN" }, | ||
1155 | { "IN1R PGA", NULL, "IN1RP" }, | ||
1156 | |||
1157 | { "ADCL", NULL, "IN1L PGA" }, | ||
1158 | |||
1159 | { "ADCR", NULL, "IN1R PGA" }, | ||
1160 | |||
1161 | { "DMIC1L", NULL, "DMIC1DAT" }, | ||
1162 | { "DMIC1R", NULL, "DMIC1DAT" }, | ||
1163 | { "DMIC2L", NULL, "DMIC2DAT" }, | ||
1164 | { "DMIC2R", NULL, "DMIC2DAT" }, | ||
1165 | |||
1166 | { "DMIC2L", NULL, "DMIC2" }, | ||
1167 | { "DMIC2R", NULL, "DMIC2" }, | ||
1168 | { "DMIC1L", NULL, "DMIC1" }, | ||
1169 | { "DMIC1R", NULL, "DMIC1" }, | ||
1170 | |||
1171 | { "IN1L Mux", "ADC", "ADCL" }, | ||
1172 | { "IN1L Mux", "DMIC1", "DMIC1L" }, | ||
1173 | { "IN1L Mux", "DMIC2", "DMIC2L" }, | ||
1174 | |||
1175 | { "IN1R Mux", "ADC", "ADCR" }, | ||
1176 | { "IN1R Mux", "DMIC1", "DMIC1R" }, | ||
1177 | { "IN1R Mux", "DMIC2", "DMIC2R" }, | ||
1178 | |||
1179 | { "IN2L Mux", "ADC", "ADCL" }, | ||
1180 | { "IN2L Mux", "DMIC1", "DMIC1L" }, | ||
1181 | { "IN2L Mux", "DMIC2", "DMIC2L" }, | ||
1182 | |||
1183 | { "IN2R Mux", "ADC", "ADCR" }, | ||
1184 | { "IN2R Mux", "DMIC1", "DMIC1R" }, | ||
1185 | { "IN2R Mux", "DMIC2", "DMIC2R" }, | ||
1186 | |||
1187 | { "Left Sidetone", "IN1", "IN1L Mux" }, | ||
1188 | { "Left Sidetone", "IN2", "IN2L Mux" }, | ||
1189 | |||
1190 | { "Right Sidetone", "IN1", "IN1R Mux" }, | ||
1191 | { "Right Sidetone", "IN2", "IN2R Mux" }, | ||
1192 | |||
1193 | { "DSP1TXL", "IN1 Switch", "IN1L Mux" }, | ||
1194 | { "DSP1TXR", "IN1 Switch", "IN1R Mux" }, | ||
1195 | |||
1196 | { "DSP2TXL", "IN1 Switch", "IN2L Mux" }, | ||
1197 | { "DSP2TXR", "IN1 Switch", "IN2R Mux" }, | ||
1198 | |||
1199 | { "AIF1TX0", NULL, "DSP1TXL" }, | ||
1200 | { "AIF1TX1", NULL, "DSP1TXR" }, | ||
1201 | { "AIF1TX2", NULL, "DSP2TXL" }, | ||
1202 | { "AIF1TX3", NULL, "DSP2TXR" }, | ||
1203 | { "AIF1TX4", NULL, "AIF2RX0" }, | ||
1204 | { "AIF1TX5", NULL, "AIF2RX1" }, | ||
1205 | |||
1206 | { "AIF1RX0", NULL, "AIFCLK" }, | ||
1207 | { "AIF1RX1", NULL, "AIFCLK" }, | ||
1208 | { "AIF1RX2", NULL, "AIFCLK" }, | ||
1209 | { "AIF1RX3", NULL, "AIFCLK" }, | ||
1210 | { "AIF1RX4", NULL, "AIFCLK" }, | ||
1211 | { "AIF1RX5", NULL, "AIFCLK" }, | ||
1212 | |||
1213 | { "AIF2RX0", NULL, "AIFCLK" }, | ||
1214 | { "AIF2RX1", NULL, "AIFCLK" }, | ||
1215 | |||
1216 | { "DSP1RXL", NULL, "SYSDSPCLK" }, | ||
1217 | { "DSP1RXR", NULL, "SYSDSPCLK" }, | ||
1218 | { "DSP2RXL", NULL, "SYSDSPCLK" }, | ||
1219 | { "DSP2RXR", NULL, "SYSDSPCLK" }, | ||
1220 | { "DSP1TXL", NULL, "SYSDSPCLK" }, | ||
1221 | { "DSP1TXR", NULL, "SYSDSPCLK" }, | ||
1222 | { "DSP2TXL", NULL, "SYSDSPCLK" }, | ||
1223 | { "DSP2TXR", NULL, "SYSDSPCLK" }, | ||
1224 | |||
1225 | { "AIF1RXA", NULL, "AIF1RX0" }, | ||
1226 | { "AIF1RXA", NULL, "AIF1RX1" }, | ||
1227 | { "AIF1RXB", NULL, "AIF1RX2" }, | ||
1228 | { "AIF1RXB", NULL, "AIF1RX3" }, | ||
1229 | { "AIF1RXC", NULL, "AIF1RX4" }, | ||
1230 | { "AIF1RXC", NULL, "AIF1RX5" }, | ||
1231 | |||
1232 | { "AIF2RX", NULL, "AIF2RX0" }, | ||
1233 | { "AIF2RX", NULL, "AIF2RX1" }, | ||
1234 | |||
1235 | { "AIF2TX", "DSP2", "DSP2TX" }, | ||
1236 | { "AIF2TX", "DSP1", "DSP1RX" }, | ||
1237 | { "AIF2TX", "AIF1", "AIF1RXC" }, | ||
1238 | |||
1239 | { "DSP1RXL", NULL, "DSP1RX" }, | ||
1240 | { "DSP1RXR", NULL, "DSP1RX" }, | ||
1241 | { "DSP2RXL", NULL, "DSP2RX" }, | ||
1242 | { "DSP2RXR", NULL, "DSP2RX" }, | ||
1243 | |||
1244 | { "DSP2TX", NULL, "DSP2TXL" }, | ||
1245 | { "DSP2TX", NULL, "DSP2TXR" }, | ||
1246 | |||
1247 | { "DSP1RX", "AIF1", "AIF1RXA" }, | ||
1248 | { "DSP1RX", "AIF2", "AIF2RX" }, | ||
1249 | |||
1250 | { "DSP2RX", "AIF1", "AIF1RXB" }, | ||
1251 | { "DSP2RX", "AIF2", "AIF2RX" }, | ||
1252 | |||
1253 | { "DAC2L Mixer", "DSP2 Switch", "DSP2RXL" }, | ||
1254 | { "DAC2L Mixer", "DSP1 Switch", "DSP1RXL" }, | ||
1255 | { "DAC2L Mixer", "Right Sidetone Switch", "Right Sidetone" }, | ||
1256 | { "DAC2L Mixer", "Left Sidetone Switch", "Left Sidetone" }, | ||
1257 | |||
1258 | { "DAC2R Mixer", "DSP2 Switch", "DSP2RXR" }, | ||
1259 | { "DAC2R Mixer", "DSP1 Switch", "DSP1RXR" }, | ||
1260 | { "DAC2R Mixer", "Right Sidetone Switch", "Right Sidetone" }, | ||
1261 | { "DAC2R Mixer", "Left Sidetone Switch", "Left Sidetone" }, | ||
1262 | |||
1263 | { "DAC1L Mixer", "DSP2 Switch", "DSP2RXL" }, | ||
1264 | { "DAC1L Mixer", "DSP1 Switch", "DSP1RXL" }, | ||
1265 | { "DAC1L Mixer", "Right Sidetone Switch", "Right Sidetone" }, | ||
1266 | { "DAC1L Mixer", "Left Sidetone Switch", "Left Sidetone" }, | ||
1267 | |||
1268 | { "DAC1R Mixer", "DSP2 Switch", "DSP2RXR" }, | ||
1269 | { "DAC1R Mixer", "DSP1 Switch", "DSP1RXR" }, | ||
1270 | { "DAC1R Mixer", "Right Sidetone Switch", "Right Sidetone" }, | ||
1271 | { "DAC1R Mixer", "Left Sidetone Switch", "Left Sidetone" }, | ||
1272 | |||
1273 | { "DAC1L", NULL, "DAC1L Mixer" }, | ||
1274 | { "DAC1R", NULL, "DAC1R Mixer" }, | ||
1275 | { "DAC2L", NULL, "DAC2L Mixer" }, | ||
1276 | { "DAC2R", NULL, "DAC2R Mixer" }, | ||
1277 | |||
1278 | { "HPOUT2L PGA", NULL, "Charge Pump" }, | ||
1279 | { "HPOUT2L PGA", NULL, "DAC2L" }, | ||
1280 | { "HPOUT2L_DLY", NULL, "HPOUT2L PGA" }, | ||
1281 | { "HPOUT2L_DCS", NULL, "HPOUT2L_DLY" }, | ||
1282 | { "HPOUT2L_OUTP", NULL, "HPOUT2L_DCS" }, | ||
1283 | { "HPOUT2L_RMV_SHORT", NULL, "HPOUT2L_OUTP" }, | ||
1284 | |||
1285 | { "HPOUT2R PGA", NULL, "Charge Pump" }, | ||
1286 | { "HPOUT2R PGA", NULL, "DAC2R" }, | ||
1287 | { "HPOUT2R_DLY", NULL, "HPOUT2R PGA" }, | ||
1288 | { "HPOUT2R_DCS", NULL, "HPOUT2R_DLY" }, | ||
1289 | { "HPOUT2R_OUTP", NULL, "HPOUT2R_DCS" }, | ||
1290 | { "HPOUT2R_RMV_SHORT", NULL, "HPOUT2R_OUTP" }, | ||
1291 | |||
1292 | { "HPOUT1L PGA", NULL, "Charge Pump" }, | ||
1293 | { "HPOUT1L PGA", NULL, "DAC1L" }, | ||
1294 | { "HPOUT1L_DLY", NULL, "HPOUT1L PGA" }, | ||
1295 | { "HPOUT1L_DCS", NULL, "HPOUT1L_DLY" }, | ||
1296 | { "HPOUT1L_OUTP", NULL, "HPOUT1L_DCS" }, | ||
1297 | { "HPOUT1L_RMV_SHORT", NULL, "HPOUT1L_OUTP" }, | ||
1298 | |||
1299 | { "HPOUT1R PGA", NULL, "Charge Pump" }, | ||
1300 | { "HPOUT1R PGA", NULL, "DAC1R" }, | ||
1301 | { "HPOUT1R_DLY", NULL, "HPOUT1R PGA" }, | ||
1302 | { "HPOUT1R_DCS", NULL, "HPOUT1R_DLY" }, | ||
1303 | { "HPOUT1R_OUTP", NULL, "HPOUT1R_DCS" }, | ||
1304 | { "HPOUT1R_RMV_SHORT", NULL, "HPOUT1R_OUTP" }, | ||
1305 | |||
1306 | { "HPOUT2L", NULL, "HPOUT2L_RMV_SHORT" }, | ||
1307 | { "HPOUT2R", NULL, "HPOUT2R_RMV_SHORT" }, | ||
1308 | { "HPOUT1L", NULL, "HPOUT1L_RMV_SHORT" }, | ||
1309 | { "HPOUT1R", NULL, "HPOUT1R_RMV_SHORT" }, | ||
1310 | |||
1311 | { "SPKL", "DAC1L", "DAC1L" }, | ||
1312 | { "SPKL", "DAC1R", "DAC1R" }, | ||
1313 | { "SPKL", "DAC2L", "DAC2L" }, | ||
1314 | { "SPKL", "DAC2R", "DAC2R" }, | ||
1315 | |||
1316 | { "SPKR", "DAC1L", "DAC1L" }, | ||
1317 | { "SPKR", "DAC1R", "DAC1R" }, | ||
1318 | { "SPKR", "DAC2L", "DAC2L" }, | ||
1319 | { "SPKR", "DAC2R", "DAC2R" }, | ||
1320 | |||
1321 | { "SPKL PGA", NULL, "SPKL" }, | ||
1322 | { "SPKR PGA", NULL, "SPKR" }, | ||
1323 | |||
1324 | { "SPKDAT", NULL, "SPKL PGA" }, | ||
1325 | { "SPKDAT", NULL, "SPKR PGA" }, | ||
1326 | }; | ||
1327 | |||
1328 | static int wm8915_readable_register(struct snd_soc_codec *codec, | ||
1329 | unsigned int reg) | ||
1330 | { | ||
1331 | /* Due to the sparseness of the register map the compiler | ||
1332 | * output from an explicit switch statement ends up being much | ||
1333 | * more efficient than a table. | ||
1334 | */ | ||
1335 | switch (reg) { | ||
1336 | case WM8915_SOFTWARE_RESET: | ||
1337 | case WM8915_POWER_MANAGEMENT_1: | ||
1338 | case WM8915_POWER_MANAGEMENT_2: | ||
1339 | case WM8915_POWER_MANAGEMENT_3: | ||
1340 | case WM8915_POWER_MANAGEMENT_4: | ||
1341 | case WM8915_POWER_MANAGEMENT_5: | ||
1342 | case WM8915_POWER_MANAGEMENT_6: | ||
1343 | case WM8915_POWER_MANAGEMENT_7: | ||
1344 | case WM8915_POWER_MANAGEMENT_8: | ||
1345 | case WM8915_LEFT_LINE_INPUT_VOLUME: | ||
1346 | case WM8915_RIGHT_LINE_INPUT_VOLUME: | ||
1347 | case WM8915_LINE_INPUT_CONTROL: | ||
1348 | case WM8915_DAC1_HPOUT1_VOLUME: | ||
1349 | case WM8915_DAC2_HPOUT2_VOLUME: | ||
1350 | case WM8915_DAC1_LEFT_VOLUME: | ||
1351 | case WM8915_DAC1_RIGHT_VOLUME: | ||
1352 | case WM8915_DAC2_LEFT_VOLUME: | ||
1353 | case WM8915_DAC2_RIGHT_VOLUME: | ||
1354 | case WM8915_OUTPUT1_LEFT_VOLUME: | ||
1355 | case WM8915_OUTPUT1_RIGHT_VOLUME: | ||
1356 | case WM8915_OUTPUT2_LEFT_VOLUME: | ||
1357 | case WM8915_OUTPUT2_RIGHT_VOLUME: | ||
1358 | case WM8915_MICBIAS_1: | ||
1359 | case WM8915_MICBIAS_2: | ||
1360 | case WM8915_LDO_1: | ||
1361 | case WM8915_LDO_2: | ||
1362 | case WM8915_ACCESSORY_DETECT_MODE_1: | ||
1363 | case WM8915_ACCESSORY_DETECT_MODE_2: | ||
1364 | case WM8915_HEADPHONE_DETECT_1: | ||
1365 | case WM8915_HEADPHONE_DETECT_2: | ||
1366 | case WM8915_MIC_DETECT_1: | ||
1367 | case WM8915_MIC_DETECT_2: | ||
1368 | case WM8915_MIC_DETECT_3: | ||
1369 | case WM8915_CHARGE_PUMP_1: | ||
1370 | case WM8915_CHARGE_PUMP_2: | ||
1371 | case WM8915_DC_SERVO_1: | ||
1372 | case WM8915_DC_SERVO_2: | ||
1373 | case WM8915_DC_SERVO_3: | ||
1374 | case WM8915_DC_SERVO_5: | ||
1375 | case WM8915_DC_SERVO_6: | ||
1376 | case WM8915_DC_SERVO_7: | ||
1377 | case WM8915_DC_SERVO_READBACK_0: | ||
1378 | case WM8915_ANALOGUE_HP_1: | ||
1379 | case WM8915_ANALOGUE_HP_2: | ||
1380 | case WM8915_CHIP_REVISION: | ||
1381 | case WM8915_CONTROL_INTERFACE_1: | ||
1382 | case WM8915_WRITE_SEQUENCER_CTRL_1: | ||
1383 | case WM8915_WRITE_SEQUENCER_CTRL_2: | ||
1384 | case WM8915_AIF_CLOCKING_1: | ||
1385 | case WM8915_AIF_CLOCKING_2: | ||
1386 | case WM8915_CLOCKING_1: | ||
1387 | case WM8915_CLOCKING_2: | ||
1388 | case WM8915_AIF_RATE: | ||
1389 | case WM8915_FLL_CONTROL_1: | ||
1390 | case WM8915_FLL_CONTROL_2: | ||
1391 | case WM8915_FLL_CONTROL_3: | ||
1392 | case WM8915_FLL_CONTROL_4: | ||
1393 | case WM8915_FLL_CONTROL_5: | ||
1394 | case WM8915_FLL_CONTROL_6: | ||
1395 | case WM8915_FLL_EFS_1: | ||
1396 | case WM8915_FLL_EFS_2: | ||
1397 | case WM8915_AIF1_CONTROL: | ||
1398 | case WM8915_AIF1_BCLK: | ||
1399 | case WM8915_AIF1_TX_LRCLK_1: | ||
1400 | case WM8915_AIF1_TX_LRCLK_2: | ||
1401 | case WM8915_AIF1_RX_LRCLK_1: | ||
1402 | case WM8915_AIF1_RX_LRCLK_2: | ||
1403 | case WM8915_AIF1TX_DATA_CONFIGURATION_1: | ||
1404 | case WM8915_AIF1TX_DATA_CONFIGURATION_2: | ||
1405 | case WM8915_AIF1RX_DATA_CONFIGURATION: | ||
1406 | case WM8915_AIF1TX_CHANNEL_0_CONFIGURATION: | ||
1407 | case WM8915_AIF1TX_CHANNEL_1_CONFIGURATION: | ||
1408 | case WM8915_AIF1TX_CHANNEL_2_CONFIGURATION: | ||
1409 | case WM8915_AIF1TX_CHANNEL_3_CONFIGURATION: | ||
1410 | case WM8915_AIF1TX_CHANNEL_4_CONFIGURATION: | ||
1411 | case WM8915_AIF1TX_CHANNEL_5_CONFIGURATION: | ||
1412 | case WM8915_AIF1RX_CHANNEL_0_CONFIGURATION: | ||
1413 | case WM8915_AIF1RX_CHANNEL_1_CONFIGURATION: | ||
1414 | case WM8915_AIF1RX_CHANNEL_2_CONFIGURATION: | ||
1415 | case WM8915_AIF1RX_CHANNEL_3_CONFIGURATION: | ||
1416 | case WM8915_AIF1RX_CHANNEL_4_CONFIGURATION: | ||
1417 | case WM8915_AIF1RX_CHANNEL_5_CONFIGURATION: | ||
1418 | case WM8915_AIF1RX_MONO_CONFIGURATION: | ||
1419 | case WM8915_AIF1TX_TEST: | ||
1420 | case WM8915_AIF2_CONTROL: | ||
1421 | case WM8915_AIF2_BCLK: | ||
1422 | case WM8915_AIF2_TX_LRCLK_1: | ||
1423 | case WM8915_AIF2_TX_LRCLK_2: | ||
1424 | case WM8915_AIF2_RX_LRCLK_1: | ||
1425 | case WM8915_AIF2_RX_LRCLK_2: | ||
1426 | case WM8915_AIF2TX_DATA_CONFIGURATION_1: | ||
1427 | case WM8915_AIF2TX_DATA_CONFIGURATION_2: | ||
1428 | case WM8915_AIF2RX_DATA_CONFIGURATION: | ||
1429 | case WM8915_AIF2TX_CHANNEL_0_CONFIGURATION: | ||
1430 | case WM8915_AIF2TX_CHANNEL_1_CONFIGURATION: | ||
1431 | case WM8915_AIF2RX_CHANNEL_0_CONFIGURATION: | ||
1432 | case WM8915_AIF2RX_CHANNEL_1_CONFIGURATION: | ||
1433 | case WM8915_AIF2RX_MONO_CONFIGURATION: | ||
1434 | case WM8915_AIF2TX_TEST: | ||
1435 | case WM8915_DSP1_TX_LEFT_VOLUME: | ||
1436 | case WM8915_DSP1_TX_RIGHT_VOLUME: | ||
1437 | case WM8915_DSP1_RX_LEFT_VOLUME: | ||
1438 | case WM8915_DSP1_RX_RIGHT_VOLUME: | ||
1439 | case WM8915_DSP1_TX_FILTERS: | ||
1440 | case WM8915_DSP1_RX_FILTERS_1: | ||
1441 | case WM8915_DSP1_RX_FILTERS_2: | ||
1442 | case WM8915_DSP1_DRC_1: | ||
1443 | case WM8915_DSP1_DRC_2: | ||
1444 | case WM8915_DSP1_DRC_3: | ||
1445 | case WM8915_DSP1_DRC_4: | ||
1446 | case WM8915_DSP1_DRC_5: | ||
1447 | case WM8915_DSP1_RX_EQ_GAINS_1: | ||
1448 | case WM8915_DSP1_RX_EQ_GAINS_2: | ||
1449 | case WM8915_DSP1_RX_EQ_BAND_1_A: | ||
1450 | case WM8915_DSP1_RX_EQ_BAND_1_B: | ||
1451 | case WM8915_DSP1_RX_EQ_BAND_1_PG: | ||
1452 | case WM8915_DSP1_RX_EQ_BAND_2_A: | ||
1453 | case WM8915_DSP1_RX_EQ_BAND_2_B: | ||
1454 | case WM8915_DSP1_RX_EQ_BAND_2_C: | ||
1455 | case WM8915_DSP1_RX_EQ_BAND_2_PG: | ||
1456 | case WM8915_DSP1_RX_EQ_BAND_3_A: | ||
1457 | case WM8915_DSP1_RX_EQ_BAND_3_B: | ||
1458 | case WM8915_DSP1_RX_EQ_BAND_3_C: | ||
1459 | case WM8915_DSP1_RX_EQ_BAND_3_PG: | ||
1460 | case WM8915_DSP1_RX_EQ_BAND_4_A: | ||
1461 | case WM8915_DSP1_RX_EQ_BAND_4_B: | ||
1462 | case WM8915_DSP1_RX_EQ_BAND_4_C: | ||
1463 | case WM8915_DSP1_RX_EQ_BAND_4_PG: | ||
1464 | case WM8915_DSP1_RX_EQ_BAND_5_A: | ||
1465 | case WM8915_DSP1_RX_EQ_BAND_5_B: | ||
1466 | case WM8915_DSP1_RX_EQ_BAND_5_PG: | ||
1467 | case WM8915_DSP2_TX_LEFT_VOLUME: | ||
1468 | case WM8915_DSP2_TX_RIGHT_VOLUME: | ||
1469 | case WM8915_DSP2_RX_LEFT_VOLUME: | ||
1470 | case WM8915_DSP2_RX_RIGHT_VOLUME: | ||
1471 | case WM8915_DSP2_TX_FILTERS: | ||
1472 | case WM8915_DSP2_RX_FILTERS_1: | ||
1473 | case WM8915_DSP2_RX_FILTERS_2: | ||
1474 | case WM8915_DSP2_DRC_1: | ||
1475 | case WM8915_DSP2_DRC_2: | ||
1476 | case WM8915_DSP2_DRC_3: | ||
1477 | case WM8915_DSP2_DRC_4: | ||
1478 | case WM8915_DSP2_DRC_5: | ||
1479 | case WM8915_DSP2_RX_EQ_GAINS_1: | ||
1480 | case WM8915_DSP2_RX_EQ_GAINS_2: | ||
1481 | case WM8915_DSP2_RX_EQ_BAND_1_A: | ||
1482 | case WM8915_DSP2_RX_EQ_BAND_1_B: | ||
1483 | case WM8915_DSP2_RX_EQ_BAND_1_PG: | ||
1484 | case WM8915_DSP2_RX_EQ_BAND_2_A: | ||
1485 | case WM8915_DSP2_RX_EQ_BAND_2_B: | ||
1486 | case WM8915_DSP2_RX_EQ_BAND_2_C: | ||
1487 | case WM8915_DSP2_RX_EQ_BAND_2_PG: | ||
1488 | case WM8915_DSP2_RX_EQ_BAND_3_A: | ||
1489 | case WM8915_DSP2_RX_EQ_BAND_3_B: | ||
1490 | case WM8915_DSP2_RX_EQ_BAND_3_C: | ||
1491 | case WM8915_DSP2_RX_EQ_BAND_3_PG: | ||
1492 | case WM8915_DSP2_RX_EQ_BAND_4_A: | ||
1493 | case WM8915_DSP2_RX_EQ_BAND_4_B: | ||
1494 | case WM8915_DSP2_RX_EQ_BAND_4_C: | ||
1495 | case WM8915_DSP2_RX_EQ_BAND_4_PG: | ||
1496 | case WM8915_DSP2_RX_EQ_BAND_5_A: | ||
1497 | case WM8915_DSP2_RX_EQ_BAND_5_B: | ||
1498 | case WM8915_DSP2_RX_EQ_BAND_5_PG: | ||
1499 | case WM8915_DAC1_MIXER_VOLUMES: | ||
1500 | case WM8915_DAC1_LEFT_MIXER_ROUTING: | ||
1501 | case WM8915_DAC1_RIGHT_MIXER_ROUTING: | ||
1502 | case WM8915_DAC2_MIXER_VOLUMES: | ||
1503 | case WM8915_DAC2_LEFT_MIXER_ROUTING: | ||
1504 | case WM8915_DAC2_RIGHT_MIXER_ROUTING: | ||
1505 | case WM8915_DSP1_TX_LEFT_MIXER_ROUTING: | ||
1506 | case WM8915_DSP1_TX_RIGHT_MIXER_ROUTING: | ||
1507 | case WM8915_DSP2_TX_LEFT_MIXER_ROUTING: | ||
1508 | case WM8915_DSP2_TX_RIGHT_MIXER_ROUTING: | ||
1509 | case WM8915_DSP_TX_MIXER_SELECT: | ||
1510 | case WM8915_DAC_SOFTMUTE: | ||
1511 | case WM8915_OVERSAMPLING: | ||
1512 | case WM8915_SIDETONE: | ||
1513 | case WM8915_GPIO_1: | ||
1514 | case WM8915_GPIO_2: | ||
1515 | case WM8915_GPIO_3: | ||
1516 | case WM8915_GPIO_4: | ||
1517 | case WM8915_GPIO_5: | ||
1518 | case WM8915_PULL_CONTROL_1: | ||
1519 | case WM8915_PULL_CONTROL_2: | ||
1520 | case WM8915_INTERRUPT_STATUS_1: | ||
1521 | case WM8915_INTERRUPT_STATUS_2: | ||
1522 | case WM8915_INTERRUPT_RAW_STATUS_2: | ||
1523 | case WM8915_INTERRUPT_STATUS_1_MASK: | ||
1524 | case WM8915_INTERRUPT_STATUS_2_MASK: | ||
1525 | case WM8915_INTERRUPT_CONTROL: | ||
1526 | case WM8915_LEFT_PDM_SPEAKER: | ||
1527 | case WM8915_RIGHT_PDM_SPEAKER: | ||
1528 | case WM8915_PDM_SPEAKER_MUTE_SEQUENCE: | ||
1529 | case WM8915_PDM_SPEAKER_VOLUME: | ||
1530 | return 1; | ||
1531 | default: | ||
1532 | return 0; | ||
1533 | } | ||
1534 | } | ||
1535 | |||
1536 | static int wm8915_volatile_register(struct snd_soc_codec *codec, | ||
1537 | unsigned int reg) | ||
1538 | { | ||
1539 | switch (reg) { | ||
1540 | case WM8915_SOFTWARE_RESET: | ||
1541 | case WM8915_CHIP_REVISION: | ||
1542 | case WM8915_LDO_1: | ||
1543 | case WM8915_LDO_2: | ||
1544 | case WM8915_INTERRUPT_STATUS_1: | ||
1545 | case WM8915_INTERRUPT_STATUS_2: | ||
1546 | case WM8915_INTERRUPT_RAW_STATUS_2: | ||
1547 | case WM8915_DC_SERVO_READBACK_0: | ||
1548 | case WM8915_DC_SERVO_2: | ||
1549 | case WM8915_DC_SERVO_6: | ||
1550 | case WM8915_DC_SERVO_7: | ||
1551 | case WM8915_FLL_CONTROL_6: | ||
1552 | case WM8915_MIC_DETECT_3: | ||
1553 | case WM8915_HEADPHONE_DETECT_1: | ||
1554 | case WM8915_HEADPHONE_DETECT_2: | ||
1555 | return 1; | ||
1556 | default: | ||
1557 | return 0; | ||
1558 | } | ||
1559 | } | ||
1560 | |||
1561 | static int wm8915_reset(struct snd_soc_codec *codec) | ||
1562 | { | ||
1563 | return snd_soc_write(codec, WM8915_SOFTWARE_RESET, 0x8915); | ||
1564 | } | ||
1565 | |||
1566 | static const int bclk_divs[] = { | ||
1567 | 1, 2, 3, 4, 6, 8, 12, 16, 24, 32, 48, 64, 96 | ||
1568 | }; | ||
1569 | |||
1570 | static void wm8915_update_bclk(struct snd_soc_codec *codec) | ||
1571 | { | ||
1572 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
1573 | int aif, best, cur_val, bclk_rate, bclk_reg, i; | ||
1574 | |||
1575 | /* Don't bother if we're in a low frequency idle mode that | ||
1576 | * can't support audio. | ||
1577 | */ | ||
1578 | if (wm8915->sysclk < 64000) | ||
1579 | return; | ||
1580 | |||
1581 | for (aif = 0; aif < WM8915_AIFS; aif++) { | ||
1582 | switch (aif) { | ||
1583 | case 0: | ||
1584 | bclk_reg = WM8915_AIF1_BCLK; | ||
1585 | break; | ||
1586 | case 1: | ||
1587 | bclk_reg = WM8915_AIF2_BCLK; | ||
1588 | break; | ||
1589 | } | ||
1590 | |||
1591 | bclk_rate = wm8915->bclk_rate[aif]; | ||
1592 | |||
1593 | /* Pick a divisor for BCLK as close as we can get to ideal */ | ||
1594 | best = 0; | ||
1595 | for (i = 0; i < ARRAY_SIZE(bclk_divs); i++) { | ||
1596 | cur_val = (wm8915->sysclk / bclk_divs[i]) - bclk_rate; | ||
1597 | if (cur_val < 0) /* BCLK table is sorted */ | ||
1598 | break; | ||
1599 | best = i; | ||
1600 | } | ||
1601 | bclk_rate = wm8915->sysclk / bclk_divs[best]; | ||
1602 | dev_dbg(codec->dev, "Using BCLK_DIV %d for actual BCLK %dHz\n", | ||
1603 | bclk_divs[best], bclk_rate); | ||
1604 | |||
1605 | snd_soc_update_bits(codec, bclk_reg, | ||
1606 | WM8915_AIF1_BCLK_DIV_MASK, best); | ||
1607 | } | ||
1608 | } | ||
1609 | |||
1610 | static int wm8915_set_bias_level(struct snd_soc_codec *codec, | ||
1611 | enum snd_soc_bias_level level) | ||
1612 | { | ||
1613 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
1614 | int ret; | ||
1615 | |||
1616 | switch (level) { | ||
1617 | case SND_SOC_BIAS_ON: | ||
1618 | break; | ||
1619 | |||
1620 | case SND_SOC_BIAS_PREPARE: | ||
1621 | if (codec->dapm.bias_level == SND_SOC_BIAS_STANDBY) { | ||
1622 | snd_soc_update_bits(codec, WM8915_POWER_MANAGEMENT_1, | ||
1623 | WM8915_BG_ENA, WM8915_BG_ENA); | ||
1624 | msleep(2); | ||
1625 | } | ||
1626 | break; | ||
1627 | |||
1628 | case SND_SOC_BIAS_STANDBY: | ||
1629 | if (codec->dapm.bias_level == SND_SOC_BIAS_OFF) { | ||
1630 | ret = regulator_bulk_enable(ARRAY_SIZE(wm8915->supplies), | ||
1631 | wm8915->supplies); | ||
1632 | if (ret != 0) { | ||
1633 | dev_err(codec->dev, | ||
1634 | "Failed to enable supplies: %d\n", | ||
1635 | ret); | ||
1636 | return ret; | ||
1637 | } | ||
1638 | |||
1639 | if (wm8915->pdata.ldo_ena >= 0) { | ||
1640 | gpio_set_value_cansleep(wm8915->pdata.ldo_ena, | ||
1641 | 1); | ||
1642 | msleep(5); | ||
1643 | } | ||
1644 | |||
1645 | codec->cache_only = false; | ||
1646 | snd_soc_cache_sync(codec); | ||
1647 | } | ||
1648 | |||
1649 | snd_soc_update_bits(codec, WM8915_POWER_MANAGEMENT_1, | ||
1650 | WM8915_BG_ENA, 0); | ||
1651 | break; | ||
1652 | |||
1653 | case SND_SOC_BIAS_OFF: | ||
1654 | codec->cache_only = true; | ||
1655 | if (wm8915->pdata.ldo_ena >= 0) | ||
1656 | gpio_set_value_cansleep(wm8915->pdata.ldo_ena, 0); | ||
1657 | regulator_bulk_disable(ARRAY_SIZE(wm8915->supplies), | ||
1658 | wm8915->supplies); | ||
1659 | break; | ||
1660 | } | ||
1661 | |||
1662 | codec->dapm.bias_level = level; | ||
1663 | |||
1664 | return 0; | ||
1665 | } | ||
1666 | |||
1667 | static int wm8915_set_fmt(struct snd_soc_dai *dai, unsigned int fmt) | ||
1668 | { | ||
1669 | struct snd_soc_codec *codec = dai->codec; | ||
1670 | int aifctrl = 0; | ||
1671 | int bclk = 0; | ||
1672 | int lrclk_tx = 0; | ||
1673 | int lrclk_rx = 0; | ||
1674 | int aifctrl_reg, bclk_reg, lrclk_tx_reg, lrclk_rx_reg; | ||
1675 | |||
1676 | switch (dai->id) { | ||
1677 | case 0: | ||
1678 | aifctrl_reg = WM8915_AIF1_CONTROL; | ||
1679 | bclk_reg = WM8915_AIF1_BCLK; | ||
1680 | lrclk_tx_reg = WM8915_AIF1_TX_LRCLK_2; | ||
1681 | lrclk_rx_reg = WM8915_AIF1_RX_LRCLK_2; | ||
1682 | break; | ||
1683 | case 1: | ||
1684 | aifctrl_reg = WM8915_AIF2_CONTROL; | ||
1685 | bclk_reg = WM8915_AIF2_BCLK; | ||
1686 | lrclk_tx_reg = WM8915_AIF2_TX_LRCLK_2; | ||
1687 | lrclk_rx_reg = WM8915_AIF2_RX_LRCLK_2; | ||
1688 | break; | ||
1689 | default: | ||
1690 | BUG(); | ||
1691 | return -EINVAL; | ||
1692 | } | ||
1693 | |||
1694 | switch (fmt & SND_SOC_DAIFMT_INV_MASK) { | ||
1695 | case SND_SOC_DAIFMT_NB_NF: | ||
1696 | break; | ||
1697 | case SND_SOC_DAIFMT_IB_NF: | ||
1698 | bclk |= WM8915_AIF1_BCLK_INV; | ||
1699 | break; | ||
1700 | case SND_SOC_DAIFMT_NB_IF: | ||
1701 | lrclk_tx |= WM8915_AIF1TX_LRCLK_INV; | ||
1702 | lrclk_rx |= WM8915_AIF1RX_LRCLK_INV; | ||
1703 | break; | ||
1704 | case SND_SOC_DAIFMT_IB_IF: | ||
1705 | bclk |= WM8915_AIF1_BCLK_INV; | ||
1706 | lrclk_tx |= WM8915_AIF1TX_LRCLK_INV; | ||
1707 | lrclk_rx |= WM8915_AIF1RX_LRCLK_INV; | ||
1708 | break; | ||
1709 | } | ||
1710 | |||
1711 | switch (fmt & SND_SOC_DAIFMT_MASTER_MASK) { | ||
1712 | case SND_SOC_DAIFMT_CBS_CFS: | ||
1713 | break; | ||
1714 | case SND_SOC_DAIFMT_CBS_CFM: | ||
1715 | lrclk_tx |= WM8915_AIF1TX_LRCLK_MSTR; | ||
1716 | lrclk_rx |= WM8915_AIF1RX_LRCLK_MSTR; | ||
1717 | break; | ||
1718 | case SND_SOC_DAIFMT_CBM_CFS: | ||
1719 | bclk |= WM8915_AIF1_BCLK_MSTR; | ||
1720 | break; | ||
1721 | case SND_SOC_DAIFMT_CBM_CFM: | ||
1722 | bclk |= WM8915_AIF1_BCLK_MSTR; | ||
1723 | lrclk_tx |= WM8915_AIF1TX_LRCLK_MSTR; | ||
1724 | lrclk_rx |= WM8915_AIF1RX_LRCLK_MSTR; | ||
1725 | break; | ||
1726 | default: | ||
1727 | return -EINVAL; | ||
1728 | } | ||
1729 | |||
1730 | switch (fmt & SND_SOC_DAIFMT_FORMAT_MASK) { | ||
1731 | case SND_SOC_DAIFMT_DSP_A: | ||
1732 | break; | ||
1733 | case SND_SOC_DAIFMT_DSP_B: | ||
1734 | aifctrl |= 1; | ||
1735 | break; | ||
1736 | case SND_SOC_DAIFMT_I2S: | ||
1737 | aifctrl |= 2; | ||
1738 | break; | ||
1739 | case SND_SOC_DAIFMT_LEFT_J: | ||
1740 | aifctrl |= 3; | ||
1741 | break; | ||
1742 | default: | ||
1743 | return -EINVAL; | ||
1744 | } | ||
1745 | |||
1746 | snd_soc_update_bits(codec, aifctrl_reg, WM8915_AIF1_FMT_MASK, aifctrl); | ||
1747 | snd_soc_update_bits(codec, bclk_reg, | ||
1748 | WM8915_AIF1_BCLK_INV | WM8915_AIF1_BCLK_MSTR, | ||
1749 | bclk); | ||
1750 | snd_soc_update_bits(codec, lrclk_tx_reg, | ||
1751 | WM8915_AIF1TX_LRCLK_INV | | ||
1752 | WM8915_AIF1TX_LRCLK_MSTR, | ||
1753 | lrclk_tx); | ||
1754 | snd_soc_update_bits(codec, lrclk_rx_reg, | ||
1755 | WM8915_AIF1RX_LRCLK_INV | | ||
1756 | WM8915_AIF1RX_LRCLK_MSTR, | ||
1757 | lrclk_rx); | ||
1758 | |||
1759 | return 0; | ||
1760 | } | ||
1761 | |||
1762 | static const int dsp_divs[] = { | ||
1763 | 48000, 32000, 16000, 8000 | ||
1764 | }; | ||
1765 | |||
1766 | static int wm8915_hw_params(struct snd_pcm_substream *substream, | ||
1767 | struct snd_pcm_hw_params *params, | ||
1768 | struct snd_soc_dai *dai) | ||
1769 | { | ||
1770 | struct snd_soc_codec *codec = dai->codec; | ||
1771 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
1772 | int bits, i, bclk_rate; | ||
1773 | int aifdata = 0; | ||
1774 | int lrclk = 0; | ||
1775 | int dsp = 0; | ||
1776 | int aifdata_reg, lrclk_reg, dsp_shift; | ||
1777 | |||
1778 | switch (dai->id) { | ||
1779 | case 0: | ||
1780 | if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK || | ||
1781 | (snd_soc_read(codec, WM8915_GPIO_1)) & WM8915_GP1_FN_MASK) { | ||
1782 | aifdata_reg = WM8915_AIF1RX_DATA_CONFIGURATION; | ||
1783 | lrclk_reg = WM8915_AIF1_RX_LRCLK_1; | ||
1784 | } else { | ||
1785 | aifdata_reg = WM8915_AIF1TX_DATA_CONFIGURATION_1; | ||
1786 | lrclk_reg = WM8915_AIF1_TX_LRCLK_1; | ||
1787 | } | ||
1788 | dsp_shift = 0; | ||
1789 | break; | ||
1790 | case 1: | ||
1791 | if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK || | ||
1792 | (snd_soc_read(codec, WM8915_GPIO_2)) & WM8915_GP2_FN_MASK) { | ||
1793 | aifdata_reg = WM8915_AIF2RX_DATA_CONFIGURATION; | ||
1794 | lrclk_reg = WM8915_AIF2_RX_LRCLK_1; | ||
1795 | } else { | ||
1796 | aifdata_reg = WM8915_AIF2TX_DATA_CONFIGURATION_1; | ||
1797 | lrclk_reg = WM8915_AIF2_TX_LRCLK_1; | ||
1798 | } | ||
1799 | dsp_shift = WM8915_DSP2_DIV_SHIFT; | ||
1800 | break; | ||
1801 | default: | ||
1802 | BUG(); | ||
1803 | return -EINVAL; | ||
1804 | } | ||
1805 | |||
1806 | bclk_rate = snd_soc_params_to_bclk(params); | ||
1807 | if (bclk_rate < 0) { | ||
1808 | dev_err(codec->dev, "Unsupported BCLK rate: %d\n", bclk_rate); | ||
1809 | return bclk_rate; | ||
1810 | } | ||
1811 | |||
1812 | wm8915->bclk_rate[dai->id] = bclk_rate; | ||
1813 | wm8915->rx_rate[dai->id] = params_rate(params); | ||
1814 | |||
1815 | /* Needs looking at for TDM */ | ||
1816 | bits = snd_pcm_format_width(params_format(params)); | ||
1817 | if (bits < 0) | ||
1818 | return bits; | ||
1819 | aifdata |= (bits << WM8915_AIF1TX_WL_SHIFT) | bits; | ||
1820 | |||
1821 | for (i = 0; i < ARRAY_SIZE(dsp_divs); i++) { | ||
1822 | if (dsp_divs[i] == params_rate(params)) | ||
1823 | break; | ||
1824 | } | ||
1825 | if (i == ARRAY_SIZE(dsp_divs)) { | ||
1826 | dev_err(codec->dev, "Unsupported sample rate %dHz\n", | ||
1827 | params_rate(params)); | ||
1828 | return -EINVAL; | ||
1829 | } | ||
1830 | dsp |= i << dsp_shift; | ||
1831 | |||
1832 | wm8915_update_bclk(codec); | ||
1833 | |||
1834 | lrclk = bclk_rate / params_rate(params); | ||
1835 | dev_dbg(dai->dev, "Using LRCLK rate %d for actual LRCLK %dHz\n", | ||
1836 | lrclk, bclk_rate / lrclk); | ||
1837 | |||
1838 | snd_soc_update_bits(codec, aifdata_reg, | ||
1839 | WM8915_AIF1TX_WL_MASK | | ||
1840 | WM8915_AIF1TX_SLOT_LEN_MASK, | ||
1841 | aifdata); | ||
1842 | snd_soc_update_bits(codec, lrclk_reg, WM8915_AIF1RX_RATE_MASK, | ||
1843 | lrclk); | ||
1844 | snd_soc_update_bits(codec, WM8915_AIF_CLOCKING_2, | ||
1845 | WM8915_DSP1_DIV_SHIFT << dsp_shift, dsp); | ||
1846 | |||
1847 | return 0; | ||
1848 | } | ||
1849 | |||
1850 | static int wm8915_set_sysclk(struct snd_soc_dai *dai, | ||
1851 | int clk_id, unsigned int freq, int dir) | ||
1852 | { | ||
1853 | struct snd_soc_codec *codec = dai->codec; | ||
1854 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
1855 | int lfclk = 0; | ||
1856 | int ratediv = 0; | ||
1857 | int src; | ||
1858 | int old; | ||
1859 | |||
1860 | if (freq == wm8915->sysclk && clk_id == wm8915->sysclk_src) | ||
1861 | return 0; | ||
1862 | |||
1863 | /* Disable SYSCLK while we reconfigure */ | ||
1864 | old = snd_soc_read(codec, WM8915_AIF_CLOCKING_1) & WM8915_SYSCLK_ENA; | ||
1865 | snd_soc_update_bits(codec, WM8915_AIF_CLOCKING_1, | ||
1866 | WM8915_SYSCLK_ENA, 0); | ||
1867 | |||
1868 | switch (clk_id) { | ||
1869 | case WM8915_SYSCLK_MCLK1: | ||
1870 | wm8915->sysclk = freq; | ||
1871 | src = 0; | ||
1872 | break; | ||
1873 | case WM8915_SYSCLK_MCLK2: | ||
1874 | wm8915->sysclk = freq; | ||
1875 | src = 1; | ||
1876 | break; | ||
1877 | case WM8915_SYSCLK_FLL: | ||
1878 | wm8915->sysclk = freq; | ||
1879 | src = 2; | ||
1880 | break; | ||
1881 | default: | ||
1882 | dev_err(codec->dev, "Unsupported clock source %d\n", clk_id); | ||
1883 | return -EINVAL; | ||
1884 | } | ||
1885 | |||
1886 | switch (wm8915->sysclk) { | ||
1887 | case 6144000: | ||
1888 | snd_soc_update_bits(codec, WM8915_AIF_RATE, | ||
1889 | WM8915_SYSCLK_RATE, 0); | ||
1890 | break; | ||
1891 | case 24576000: | ||
1892 | ratediv = WM8915_SYSCLK_DIV; | ||
1893 | case 12288000: | ||
1894 | snd_soc_update_bits(codec, WM8915_AIF_RATE, | ||
1895 | WM8915_SYSCLK_RATE, WM8915_SYSCLK_RATE); | ||
1896 | break; | ||
1897 | case 32000: | ||
1898 | case 32768: | ||
1899 | lfclk = WM8915_LFCLK_ENA; | ||
1900 | break; | ||
1901 | default: | ||
1902 | dev_warn(codec->dev, "Unsupported clock rate %dHz\n", | ||
1903 | wm8915->sysclk); | ||
1904 | return -EINVAL; | ||
1905 | } | ||
1906 | |||
1907 | wm8915_update_bclk(codec); | ||
1908 | |||
1909 | snd_soc_update_bits(codec, WM8915_AIF_CLOCKING_1, | ||
1910 | WM8915_SYSCLK_SRC_MASK | WM8915_SYSCLK_DIV_MASK, | ||
1911 | src << WM8915_SYSCLK_SRC_SHIFT | ratediv); | ||
1912 | snd_soc_update_bits(codec, WM8915_CLOCKING_1, WM8915_LFCLK_ENA, lfclk); | ||
1913 | snd_soc_update_bits(codec, WM8915_AIF_CLOCKING_1, | ||
1914 | WM8915_SYSCLK_ENA, old); | ||
1915 | |||
1916 | wm8915->sysclk_src = clk_id; | ||
1917 | |||
1918 | return 0; | ||
1919 | } | ||
1920 | |||
1921 | struct _fll_div { | ||
1922 | u16 fll_fratio; | ||
1923 | u16 fll_outdiv; | ||
1924 | u16 fll_refclk_div; | ||
1925 | u16 fll_loop_gain; | ||
1926 | u16 fll_ref_freq; | ||
1927 | u16 n; | ||
1928 | u16 theta; | ||
1929 | u16 lambda; | ||
1930 | }; | ||
1931 | |||
1932 | static struct { | ||
1933 | unsigned int min; | ||
1934 | unsigned int max; | ||
1935 | u16 fll_fratio; | ||
1936 | int ratio; | ||
1937 | } fll_fratios[] = { | ||
1938 | { 0, 64000, 4, 16 }, | ||
1939 | { 64000, 128000, 3, 8 }, | ||
1940 | { 128000, 256000, 2, 4 }, | ||
1941 | { 256000, 1000000, 1, 2 }, | ||
1942 | { 1000000, 13500000, 0, 1 }, | ||
1943 | }; | ||
1944 | |||
1945 | static int fll_factors(struct _fll_div *fll_div, unsigned int Fref, | ||
1946 | unsigned int Fout) | ||
1947 | { | ||
1948 | unsigned int target; | ||
1949 | unsigned int div; | ||
1950 | unsigned int fratio, gcd_fll; | ||
1951 | int i; | ||
1952 | |||
1953 | /* Fref must be <=13.5MHz */ | ||
1954 | div = 1; | ||
1955 | fll_div->fll_refclk_div = 0; | ||
1956 | while ((Fref / div) > 13500000) { | ||
1957 | div *= 2; | ||
1958 | fll_div->fll_refclk_div++; | ||
1959 | |||
1960 | if (div > 8) { | ||
1961 | pr_err("Can't scale %dMHz input down to <=13.5MHz\n", | ||
1962 | Fref); | ||
1963 | return -EINVAL; | ||
1964 | } | ||
1965 | } | ||
1966 | |||
1967 | pr_debug("FLL Fref=%u Fout=%u\n", Fref, Fout); | ||
1968 | |||
1969 | /* Apply the division for our remaining calculations */ | ||
1970 | Fref /= div; | ||
1971 | |||
1972 | if (Fref >= 3000000) | ||
1973 | fll_div->fll_loop_gain = 5; | ||
1974 | else | ||
1975 | fll_div->fll_loop_gain = 0; | ||
1976 | |||
1977 | if (Fref >= 48000) | ||
1978 | fll_div->fll_ref_freq = 0; | ||
1979 | else | ||
1980 | fll_div->fll_ref_freq = 1; | ||
1981 | |||
1982 | /* Fvco should be 90-100MHz; don't check the upper bound */ | ||
1983 | div = 2; | ||
1984 | while (Fout * div < 90000000) { | ||
1985 | div++; | ||
1986 | if (div > 64) { | ||
1987 | pr_err("Unable to find FLL_OUTDIV for Fout=%uHz\n", | ||
1988 | Fout); | ||
1989 | return -EINVAL; | ||
1990 | } | ||
1991 | } | ||
1992 | target = Fout * div; | ||
1993 | fll_div->fll_outdiv = div - 1; | ||
1994 | |||
1995 | pr_debug("FLL Fvco=%dHz\n", target); | ||
1996 | |||
1997 | /* Find an appropraite FLL_FRATIO and factor it out of the target */ | ||
1998 | for (i = 0; i < ARRAY_SIZE(fll_fratios); i++) { | ||
1999 | if (fll_fratios[i].min <= Fref && Fref <= fll_fratios[i].max) { | ||
2000 | fll_div->fll_fratio = fll_fratios[i].fll_fratio; | ||
2001 | fratio = fll_fratios[i].ratio; | ||
2002 | break; | ||
2003 | } | ||
2004 | } | ||
2005 | if (i == ARRAY_SIZE(fll_fratios)) { | ||
2006 | pr_err("Unable to find FLL_FRATIO for Fref=%uHz\n", Fref); | ||
2007 | return -EINVAL; | ||
2008 | } | ||
2009 | |||
2010 | fll_div->n = target / (fratio * Fref); | ||
2011 | |||
2012 | if (target % Fref == 0) { | ||
2013 | fll_div->theta = 0; | ||
2014 | fll_div->lambda = 0; | ||
2015 | } else { | ||
2016 | gcd_fll = gcd(target, fratio * Fref); | ||
2017 | |||
2018 | fll_div->theta = (target - (fll_div->n * fratio * Fref)) | ||
2019 | / gcd_fll; | ||
2020 | fll_div->lambda = (fratio * Fref) / gcd_fll; | ||
2021 | } | ||
2022 | |||
2023 | pr_debug("FLL N=%x THETA=%x LAMBDA=%x\n", | ||
2024 | fll_div->n, fll_div->theta, fll_div->lambda); | ||
2025 | pr_debug("FLL_FRATIO=%x FLL_OUTDIV=%x FLL_REFCLK_DIV=%x\n", | ||
2026 | fll_div->fll_fratio, fll_div->fll_outdiv, | ||
2027 | fll_div->fll_refclk_div); | ||
2028 | |||
2029 | return 0; | ||
2030 | } | ||
2031 | |||
2032 | static int wm8915_set_fll(struct snd_soc_codec *codec, int fll_id, int source, | ||
2033 | unsigned int Fref, unsigned int Fout) | ||
2034 | { | ||
2035 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
2036 | struct i2c_client *i2c = to_i2c_client(codec->dev); | ||
2037 | struct _fll_div fll_div; | ||
2038 | unsigned long timeout; | ||
2039 | int ret, reg; | ||
2040 | |||
2041 | /* Any change? */ | ||
2042 | if (source == wm8915->fll_src && Fref == wm8915->fll_fref && | ||
2043 | Fout == wm8915->fll_fout) | ||
2044 | return 0; | ||
2045 | |||
2046 | if (Fout == 0) { | ||
2047 | dev_dbg(codec->dev, "FLL disabled\n"); | ||
2048 | |||
2049 | wm8915->fll_fref = 0; | ||
2050 | wm8915->fll_fout = 0; | ||
2051 | |||
2052 | snd_soc_update_bits(codec, WM8915_FLL_CONTROL_1, | ||
2053 | WM8915_FLL_ENA, 0); | ||
2054 | |||
2055 | return 0; | ||
2056 | } | ||
2057 | |||
2058 | ret = fll_factors(&fll_div, Fref, Fout); | ||
2059 | if (ret != 0) | ||
2060 | return ret; | ||
2061 | |||
2062 | switch (source) { | ||
2063 | case WM8915_FLL_MCLK1: | ||
2064 | reg = 0; | ||
2065 | break; | ||
2066 | case WM8915_FLL_MCLK2: | ||
2067 | reg = 1; | ||
2068 | break; | ||
2069 | case WM8915_FLL_DACLRCLK1: | ||
2070 | reg = 2; | ||
2071 | break; | ||
2072 | case WM8915_FLL_BCLK1: | ||
2073 | reg = 3; | ||
2074 | break; | ||
2075 | default: | ||
2076 | dev_err(codec->dev, "Unknown FLL source %d\n", ret); | ||
2077 | return -EINVAL; | ||
2078 | } | ||
2079 | |||
2080 | reg |= fll_div.fll_refclk_div << WM8915_FLL_REFCLK_DIV_SHIFT; | ||
2081 | reg |= fll_div.fll_ref_freq << WM8915_FLL_REF_FREQ_SHIFT; | ||
2082 | |||
2083 | snd_soc_update_bits(codec, WM8915_FLL_CONTROL_5, | ||
2084 | WM8915_FLL_REFCLK_DIV_MASK | WM8915_FLL_REF_FREQ | | ||
2085 | WM8915_FLL_REFCLK_SRC_MASK, reg); | ||
2086 | |||
2087 | reg = 0; | ||
2088 | if (fll_div.theta || fll_div.lambda) | ||
2089 | reg |= WM8915_FLL_EFS_ENA | (3 << WM8915_FLL_LFSR_SEL_SHIFT); | ||
2090 | else | ||
2091 | reg |= 1 << WM8915_FLL_LFSR_SEL_SHIFT; | ||
2092 | snd_soc_write(codec, WM8915_FLL_EFS_2, reg); | ||
2093 | |||
2094 | snd_soc_update_bits(codec, WM8915_FLL_CONTROL_2, | ||
2095 | WM8915_FLL_OUTDIV_MASK | | ||
2096 | WM8915_FLL_FRATIO_MASK, | ||
2097 | (fll_div.fll_outdiv << WM8915_FLL_OUTDIV_SHIFT) | | ||
2098 | (fll_div.fll_fratio)); | ||
2099 | |||
2100 | snd_soc_write(codec, WM8915_FLL_CONTROL_3, fll_div.theta); | ||
2101 | |||
2102 | snd_soc_update_bits(codec, WM8915_FLL_CONTROL_4, | ||
2103 | WM8915_FLL_N_MASK | WM8915_FLL_LOOP_GAIN_MASK, | ||
2104 | (fll_div.n << WM8915_FLL_N_SHIFT) | | ||
2105 | fll_div.fll_loop_gain); | ||
2106 | |||
2107 | snd_soc_write(codec, WM8915_FLL_EFS_1, fll_div.lambda); | ||
2108 | |||
2109 | snd_soc_update_bits(codec, WM8915_FLL_CONTROL_1, | ||
2110 | WM8915_FLL_ENA, WM8915_FLL_ENA); | ||
2111 | |||
2112 | /* The FLL supports live reconfiguration - kick that in case we were | ||
2113 | * already enabled. | ||
2114 | */ | ||
2115 | snd_soc_write(codec, WM8915_FLL_CONTROL_6, WM8915_FLL_SWITCH_CLK); | ||
2116 | |||
2117 | /* Wait for the FLL to lock, using the interrupt if possible */ | ||
2118 | if (Fref > 1000000) | ||
2119 | timeout = usecs_to_jiffies(300); | ||
2120 | else | ||
2121 | timeout = msecs_to_jiffies(2); | ||
2122 | |||
2123 | /* Allow substantially longer if we've actually got the IRQ */ | ||
2124 | if (i2c->irq) | ||
2125 | timeout *= 1000; | ||
2126 | |||
2127 | ret = wait_for_completion_timeout(&wm8915->fll_lock, timeout); | ||
2128 | |||
2129 | if (ret == 0 && i2c->irq) { | ||
2130 | dev_err(codec->dev, "Timed out waiting for FLL\n"); | ||
2131 | ret = -ETIMEDOUT; | ||
2132 | } else { | ||
2133 | ret = 0; | ||
2134 | } | ||
2135 | |||
2136 | dev_dbg(codec->dev, "FLL configured for %dHz->%dHz\n", Fref, Fout); | ||
2137 | |||
2138 | wm8915->fll_fref = Fref; | ||
2139 | wm8915->fll_fout = Fout; | ||
2140 | wm8915->fll_src = source; | ||
2141 | |||
2142 | return ret; | ||
2143 | } | ||
2144 | |||
2145 | #ifdef CONFIG_GPIOLIB | ||
2146 | static inline struct wm8915_priv *gpio_to_wm8915(struct gpio_chip *chip) | ||
2147 | { | ||
2148 | return container_of(chip, struct wm8915_priv, gpio_chip); | ||
2149 | } | ||
2150 | |||
2151 | static void wm8915_gpio_set(struct gpio_chip *chip, unsigned offset, int value) | ||
2152 | { | ||
2153 | struct wm8915_priv *wm8915 = gpio_to_wm8915(chip); | ||
2154 | struct snd_soc_codec *codec = wm8915->codec; | ||
2155 | |||
2156 | snd_soc_update_bits(codec, WM8915_GPIO_1 + offset, | ||
2157 | WM8915_GP1_LVL, !!value << WM8915_GP1_LVL_SHIFT); | ||
2158 | } | ||
2159 | |||
2160 | static int wm8915_gpio_direction_out(struct gpio_chip *chip, | ||
2161 | unsigned offset, int value) | ||
2162 | { | ||
2163 | struct wm8915_priv *wm8915 = gpio_to_wm8915(chip); | ||
2164 | struct snd_soc_codec *codec = wm8915->codec; | ||
2165 | int val; | ||
2166 | |||
2167 | val = (1 << WM8915_GP1_FN_SHIFT) | (!!value << WM8915_GP1_LVL_SHIFT); | ||
2168 | |||
2169 | return snd_soc_update_bits(codec, WM8915_GPIO_1 + offset, | ||
2170 | WM8915_GP1_FN_MASK | WM8915_GP1_DIR | | ||
2171 | WM8915_GP1_LVL, val); | ||
2172 | } | ||
2173 | |||
2174 | static int wm8915_gpio_get(struct gpio_chip *chip, unsigned offset) | ||
2175 | { | ||
2176 | struct wm8915_priv *wm8915 = gpio_to_wm8915(chip); | ||
2177 | struct snd_soc_codec *codec = wm8915->codec; | ||
2178 | int ret; | ||
2179 | |||
2180 | ret = snd_soc_read(codec, WM8915_GPIO_1 + offset); | ||
2181 | if (ret < 0) | ||
2182 | return ret; | ||
2183 | |||
2184 | return (ret & WM8915_GP1_LVL) != 0; | ||
2185 | } | ||
2186 | |||
2187 | static int wm8915_gpio_direction_in(struct gpio_chip *chip, unsigned offset) | ||
2188 | { | ||
2189 | struct wm8915_priv *wm8915 = gpio_to_wm8915(chip); | ||
2190 | struct snd_soc_codec *codec = wm8915->codec; | ||
2191 | |||
2192 | return snd_soc_update_bits(codec, WM8915_GPIO_1 + offset, | ||
2193 | WM8915_GP1_FN_MASK | WM8915_GP1_DIR, | ||
2194 | (1 << WM8915_GP1_FN_SHIFT) | | ||
2195 | (1 << WM8915_GP1_DIR_SHIFT)); | ||
2196 | } | ||
2197 | |||
2198 | static struct gpio_chip wm8915_template_chip = { | ||
2199 | .label = "wm8915", | ||
2200 | .owner = THIS_MODULE, | ||
2201 | .direction_output = wm8915_gpio_direction_out, | ||
2202 | .set = wm8915_gpio_set, | ||
2203 | .direction_input = wm8915_gpio_direction_in, | ||
2204 | .get = wm8915_gpio_get, | ||
2205 | .can_sleep = 1, | ||
2206 | }; | ||
2207 | |||
2208 | static void wm8915_init_gpio(struct snd_soc_codec *codec) | ||
2209 | { | ||
2210 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
2211 | int ret; | ||
2212 | |||
2213 | wm8915->gpio_chip = wm8915_template_chip; | ||
2214 | wm8915->gpio_chip.ngpio = 5; | ||
2215 | wm8915->gpio_chip.dev = codec->dev; | ||
2216 | |||
2217 | if (wm8915->pdata.gpio_base) | ||
2218 | wm8915->gpio_chip.base = wm8915->pdata.gpio_base; | ||
2219 | else | ||
2220 | wm8915->gpio_chip.base = -1; | ||
2221 | |||
2222 | ret = gpiochip_add(&wm8915->gpio_chip); | ||
2223 | if (ret != 0) | ||
2224 | dev_err(codec->dev, "Failed to add GPIOs: %d\n", ret); | ||
2225 | } | ||
2226 | |||
2227 | static void wm8915_free_gpio(struct snd_soc_codec *codec) | ||
2228 | { | ||
2229 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
2230 | int ret; | ||
2231 | |||
2232 | ret = gpiochip_remove(&wm8915->gpio_chip); | ||
2233 | if (ret != 0) | ||
2234 | dev_err(codec->dev, "Failed to remove GPIOs: %d\n", ret); | ||
2235 | } | ||
2236 | #else | ||
2237 | static void wm8915_init_gpio(struct snd_soc_codec *codec) | ||
2238 | { | ||
2239 | } | ||
2240 | |||
2241 | static void wm8915_free_gpio(struct snd_soc_codec *codec) | ||
2242 | { | ||
2243 | } | ||
2244 | #endif | ||
2245 | |||
2246 | /** | ||
2247 | * wm8915_detect - Enable default WM8915 jack detection | ||
2248 | * | ||
2249 | * The WM8915 has advanced accessory detection support for headsets. | ||
2250 | * This function provides a default implementation which integrates | ||
2251 | * the majority of this functionality with minimal user configuration. | ||
2252 | * | ||
2253 | * This will detect headset, headphone and short circuit button and | ||
2254 | * will also detect inverted microphone ground connections and update | ||
2255 | * the polarity of the connections. | ||
2256 | */ | ||
2257 | int wm8915_detect(struct snd_soc_codec *codec, struct snd_soc_jack *jack, | ||
2258 | wm8915_polarity_fn polarity_cb) | ||
2259 | { | ||
2260 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
2261 | |||
2262 | wm8915->jack = jack; | ||
2263 | wm8915->detecting = true; | ||
2264 | wm8915->polarity_cb = polarity_cb; | ||
2265 | |||
2266 | if (wm8915->polarity_cb) | ||
2267 | wm8915->polarity_cb(codec, 0); | ||
2268 | |||
2269 | /* Clear discarge to avoid noise during detection */ | ||
2270 | snd_soc_update_bits(codec, WM8915_MICBIAS_1, | ||
2271 | WM8915_MICB1_DISCH, 0); | ||
2272 | snd_soc_update_bits(codec, WM8915_MICBIAS_2, | ||
2273 | WM8915_MICB2_DISCH, 0); | ||
2274 | |||
2275 | /* LDO2 powers the microphones, SYSCLK clocks detection */ | ||
2276 | snd_soc_dapm_force_enable_pin(&codec->dapm, "LDO2"); | ||
2277 | snd_soc_dapm_force_enable_pin(&codec->dapm, "SYSCLK"); | ||
2278 | |||
2279 | /* We start off just enabling microphone detection - even a | ||
2280 | * plain headphone will trigger detection. | ||
2281 | */ | ||
2282 | snd_soc_update_bits(codec, WM8915_MIC_DETECT_1, | ||
2283 | WM8915_MICD_ENA, WM8915_MICD_ENA); | ||
2284 | |||
2285 | /* Slowest detection rate, gives debounce for initial detection */ | ||
2286 | snd_soc_update_bits(codec, WM8915_MIC_DETECT_1, | ||
2287 | WM8915_MICD_RATE_MASK, | ||
2288 | WM8915_MICD_RATE_MASK); | ||
2289 | |||
2290 | /* Enable interrupts and we're off */ | ||
2291 | snd_soc_update_bits(codec, WM8915_INTERRUPT_STATUS_2_MASK, | ||
2292 | WM8915_IM_MICD_EINT, 0); | ||
2293 | |||
2294 | return 0; | ||
2295 | } | ||
2296 | EXPORT_SYMBOL_GPL(wm8915_detect); | ||
2297 | |||
2298 | static void wm8915_micd(struct snd_soc_codec *codec) | ||
2299 | { | ||
2300 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
2301 | int val, reg; | ||
2302 | |||
2303 | val = snd_soc_read(codec, WM8915_MIC_DETECT_3); | ||
2304 | |||
2305 | dev_dbg(codec->dev, "Microphone event: %x\n", val); | ||
2306 | |||
2307 | if (!(val & WM8915_MICD_VALID)) { | ||
2308 | dev_warn(codec->dev, "Microphone detection state invalid\n"); | ||
2309 | return; | ||
2310 | } | ||
2311 | |||
2312 | /* No accessory, reset everything and report removal */ | ||
2313 | if (!(val & WM8915_MICD_STS)) { | ||
2314 | dev_dbg(codec->dev, "Jack removal detected\n"); | ||
2315 | wm8915->jack_mic = false; | ||
2316 | wm8915->detecting = true; | ||
2317 | snd_soc_jack_report(wm8915->jack, 0, | ||
2318 | SND_JACK_HEADSET | SND_JACK_BTN_0); | ||
2319 | snd_soc_update_bits(codec, WM8915_MIC_DETECT_1, | ||
2320 | WM8915_MICD_RATE_MASK, | ||
2321 | WM8915_MICD_RATE_MASK); | ||
2322 | return; | ||
2323 | } | ||
2324 | |||
2325 | /* If the measurement is very high we've got a microphone but | ||
2326 | * do a little debounce to account for mechanical issues. | ||
2327 | */ | ||
2328 | if (val & 0x400) { | ||
2329 | dev_dbg(codec->dev, "Microphone detected\n"); | ||
2330 | snd_soc_jack_report(wm8915->jack, SND_JACK_HEADSET, | ||
2331 | SND_JACK_HEADSET | SND_JACK_BTN_0); | ||
2332 | wm8915->jack_mic = true; | ||
2333 | wm8915->detecting = false; | ||
2334 | |||
2335 | /* Increase poll rate to give better responsiveness | ||
2336 | * for buttons */ | ||
2337 | snd_soc_update_bits(codec, WM8915_MIC_DETECT_1, | ||
2338 | WM8915_MICD_RATE_MASK, | ||
2339 | 5 << WM8915_MICD_RATE_SHIFT); | ||
2340 | } | ||
2341 | |||
2342 | /* If we detected a lower impedence during initial startup | ||
2343 | * then we probably have the wrong polarity, flip it. Don't | ||
2344 | * do this for the lowest impedences to speed up detection of | ||
2345 | * plain headphones. | ||
2346 | */ | ||
2347 | if (wm8915->detecting && (val & 0x3f0)) { | ||
2348 | reg = snd_soc_read(codec, WM8915_ACCESSORY_DETECT_MODE_2); | ||
2349 | reg ^= WM8915_HPOUT1FB_SRC | WM8915_MICD_SRC | | ||
2350 | WM8915_MICD_BIAS_SRC; | ||
2351 | snd_soc_update_bits(codec, WM8915_ACCESSORY_DETECT_MODE_2, | ||
2352 | WM8915_HPOUT1FB_SRC | WM8915_MICD_SRC | | ||
2353 | WM8915_MICD_BIAS_SRC, reg); | ||
2354 | |||
2355 | if (wm8915->polarity_cb) | ||
2356 | wm8915->polarity_cb(codec, | ||
2357 | (reg & WM8915_MICD_SRC) != 0); | ||
2358 | |||
2359 | dev_dbg(codec->dev, "Set microphone polarity to %d\n", | ||
2360 | (reg & WM8915_MICD_SRC) != 0); | ||
2361 | |||
2362 | return; | ||
2363 | } | ||
2364 | |||
2365 | /* Don't distinguish between buttons, just report any low | ||
2366 | * impedence as BTN_0. | ||
2367 | */ | ||
2368 | if (val & 0x3fc) { | ||
2369 | if (wm8915->jack_mic) { | ||
2370 | dev_dbg(codec->dev, "Mic button detected\n"); | ||
2371 | snd_soc_jack_report(wm8915->jack, | ||
2372 | SND_JACK_HEADSET | SND_JACK_BTN_0, | ||
2373 | SND_JACK_HEADSET | SND_JACK_BTN_0); | ||
2374 | } else { | ||
2375 | dev_dbg(codec->dev, "Headphone detected\n"); | ||
2376 | snd_soc_jack_report(wm8915->jack, | ||
2377 | SND_JACK_HEADPHONE, | ||
2378 | SND_JACK_HEADSET | | ||
2379 | SND_JACK_BTN_0); | ||
2380 | |||
2381 | /* Increase the detection rate a bit for | ||
2382 | * responsiveness. | ||
2383 | */ | ||
2384 | snd_soc_update_bits(codec, WM8915_MIC_DETECT_1, | ||
2385 | WM8915_MICD_RATE_MASK, | ||
2386 | 7 << WM8915_MICD_RATE_SHIFT); | ||
2387 | |||
2388 | wm8915->detecting = false; | ||
2389 | } | ||
2390 | } | ||
2391 | } | ||
2392 | |||
2393 | static irqreturn_t wm8915_irq(int irq, void *data) | ||
2394 | { | ||
2395 | struct snd_soc_codec *codec = data; | ||
2396 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
2397 | int irq_val; | ||
2398 | |||
2399 | irq_val = snd_soc_read(codec, WM8915_INTERRUPT_STATUS_2); | ||
2400 | if (irq_val < 0) { | ||
2401 | dev_err(codec->dev, "Failed to read IRQ status: %d\n", | ||
2402 | irq_val); | ||
2403 | return IRQ_NONE; | ||
2404 | } | ||
2405 | irq_val &= ~snd_soc_read(codec, WM8915_INTERRUPT_STATUS_2_MASK); | ||
2406 | |||
2407 | if (irq_val & (WM8915_DCS_DONE_01_EINT | WM8915_DCS_DONE_23_EINT)) { | ||
2408 | dev_dbg(codec->dev, "DC servo IRQ\n"); | ||
2409 | complete(&wm8915->dcs_done); | ||
2410 | } | ||
2411 | |||
2412 | if (irq_val & WM8915_FIFOS_ERR_EINT) | ||
2413 | dev_err(codec->dev, "Digital core FIFO error\n"); | ||
2414 | |||
2415 | if (irq_val & WM8915_FLL_LOCK_EINT) { | ||
2416 | dev_dbg(codec->dev, "FLL locked\n"); | ||
2417 | complete(&wm8915->fll_lock); | ||
2418 | } | ||
2419 | |||
2420 | if (irq_val & WM8915_MICD_EINT) | ||
2421 | wm8915_micd(codec); | ||
2422 | |||
2423 | if (irq_val) { | ||
2424 | snd_soc_write(codec, WM8915_INTERRUPT_STATUS_2, irq_val); | ||
2425 | |||
2426 | return IRQ_HANDLED; | ||
2427 | } else { | ||
2428 | return IRQ_NONE; | ||
2429 | } | ||
2430 | } | ||
2431 | |||
2432 | static irqreturn_t wm8915_edge_irq(int irq, void *data) | ||
2433 | { | ||
2434 | irqreturn_t ret = IRQ_NONE; | ||
2435 | irqreturn_t val; | ||
2436 | |||
2437 | do { | ||
2438 | val = wm8915_irq(irq, data); | ||
2439 | if (val != IRQ_NONE) | ||
2440 | ret = val; | ||
2441 | } while (val != IRQ_NONE); | ||
2442 | |||
2443 | return ret; | ||
2444 | } | ||
2445 | |||
2446 | static void wm8915_retune_mobile_pdata(struct snd_soc_codec *codec) | ||
2447 | { | ||
2448 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
2449 | struct wm8915_pdata *pdata = &wm8915->pdata; | ||
2450 | |||
2451 | struct snd_kcontrol_new controls[] = { | ||
2452 | SOC_ENUM_EXT("DSP1 EQ Mode", | ||
2453 | wm8915->retune_mobile_enum, | ||
2454 | wm8915_get_retune_mobile_enum, | ||
2455 | wm8915_put_retune_mobile_enum), | ||
2456 | SOC_ENUM_EXT("DSP2 EQ Mode", | ||
2457 | wm8915->retune_mobile_enum, | ||
2458 | wm8915_get_retune_mobile_enum, | ||
2459 | wm8915_put_retune_mobile_enum), | ||
2460 | }; | ||
2461 | int ret, i, j; | ||
2462 | const char **t; | ||
2463 | |||
2464 | /* We need an array of texts for the enum API but the number | ||
2465 | * of texts is likely to be less than the number of | ||
2466 | * configurations due to the sample rate dependency of the | ||
2467 | * configurations. */ | ||
2468 | wm8915->num_retune_mobile_texts = 0; | ||
2469 | wm8915->retune_mobile_texts = NULL; | ||
2470 | for (i = 0; i < pdata->num_retune_mobile_cfgs; i++) { | ||
2471 | for (j = 0; j < wm8915->num_retune_mobile_texts; j++) { | ||
2472 | if (strcmp(pdata->retune_mobile_cfgs[i].name, | ||
2473 | wm8915->retune_mobile_texts[j]) == 0) | ||
2474 | break; | ||
2475 | } | ||
2476 | |||
2477 | if (j != wm8915->num_retune_mobile_texts) | ||
2478 | continue; | ||
2479 | |||
2480 | /* Expand the array... */ | ||
2481 | t = krealloc(wm8915->retune_mobile_texts, | ||
2482 | sizeof(char *) * | ||
2483 | (wm8915->num_retune_mobile_texts + 1), | ||
2484 | GFP_KERNEL); | ||
2485 | if (t == NULL) | ||
2486 | continue; | ||
2487 | |||
2488 | /* ...store the new entry... */ | ||
2489 | t[wm8915->num_retune_mobile_texts] = | ||
2490 | pdata->retune_mobile_cfgs[i].name; | ||
2491 | |||
2492 | /* ...and remember the new version. */ | ||
2493 | wm8915->num_retune_mobile_texts++; | ||
2494 | wm8915->retune_mobile_texts = t; | ||
2495 | } | ||
2496 | |||
2497 | dev_dbg(codec->dev, "Allocated %d unique ReTune Mobile names\n", | ||
2498 | wm8915->num_retune_mobile_texts); | ||
2499 | |||
2500 | wm8915->retune_mobile_enum.max = wm8915->num_retune_mobile_texts; | ||
2501 | wm8915->retune_mobile_enum.texts = wm8915->retune_mobile_texts; | ||
2502 | |||
2503 | ret = snd_soc_add_controls(codec, controls, ARRAY_SIZE(controls)); | ||
2504 | if (ret != 0) | ||
2505 | dev_err(codec->dev, | ||
2506 | "Failed to add ReTune Mobile controls: %d\n", ret); | ||
2507 | } | ||
2508 | |||
2509 | static int wm8915_probe(struct snd_soc_codec *codec) | ||
2510 | { | ||
2511 | int ret; | ||
2512 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
2513 | struct i2c_client *i2c = to_i2c_client(codec->dev); | ||
2514 | struct snd_soc_dapm_context *dapm = &codec->dapm; | ||
2515 | int i, irq_flags; | ||
2516 | |||
2517 | wm8915->codec = codec; | ||
2518 | |||
2519 | init_completion(&wm8915->dcs_done); | ||
2520 | init_completion(&wm8915->fll_lock); | ||
2521 | |||
2522 | dapm->idle_bias_off = true; | ||
2523 | dapm->bias_level = SND_SOC_BIAS_OFF; | ||
2524 | |||
2525 | ret = snd_soc_codec_set_cache_io(codec, 16, 16, SND_SOC_I2C); | ||
2526 | if (ret != 0) { | ||
2527 | dev_err(codec->dev, "Failed to set cache I/O: %d\n", ret); | ||
2528 | goto err; | ||
2529 | } | ||
2530 | |||
2531 | for (i = 0; i < ARRAY_SIZE(wm8915->supplies); i++) | ||
2532 | wm8915->supplies[i].supply = wm8915_supply_names[i]; | ||
2533 | |||
2534 | ret = regulator_bulk_get(codec->dev, ARRAY_SIZE(wm8915->supplies), | ||
2535 | wm8915->supplies); | ||
2536 | if (ret != 0) { | ||
2537 | dev_err(codec->dev, "Failed to request supplies: %d\n", ret); | ||
2538 | goto err; | ||
2539 | } | ||
2540 | |||
2541 | wm8915->disable_nb[0].notifier_call = wm8915_regulator_event_0; | ||
2542 | wm8915->disable_nb[1].notifier_call = wm8915_regulator_event_1; | ||
2543 | wm8915->disable_nb[2].notifier_call = wm8915_regulator_event_2; | ||
2544 | wm8915->disable_nb[3].notifier_call = wm8915_regulator_event_3; | ||
2545 | |||
2546 | /* This should really be moved into the regulator core */ | ||
2547 | for (i = 0; i < ARRAY_SIZE(wm8915->supplies); i++) { | ||
2548 | ret = regulator_register_notifier(wm8915->supplies[i].consumer, | ||
2549 | &wm8915->disable_nb[i]); | ||
2550 | if (ret != 0) { | ||
2551 | dev_err(codec->dev, | ||
2552 | "Failed to register regulator notifier: %d\n", | ||
2553 | ret); | ||
2554 | } | ||
2555 | } | ||
2556 | |||
2557 | ret = regulator_bulk_enable(ARRAY_SIZE(wm8915->supplies), | ||
2558 | wm8915->supplies); | ||
2559 | if (ret != 0) { | ||
2560 | dev_err(codec->dev, "Failed to enable supplies: %d\n", ret); | ||
2561 | goto err_get; | ||
2562 | } | ||
2563 | |||
2564 | if (wm8915->pdata.ldo_ena >= 0) { | ||
2565 | gpio_set_value_cansleep(wm8915->pdata.ldo_ena, 1); | ||
2566 | msleep(5); | ||
2567 | } | ||
2568 | |||
2569 | ret = snd_soc_read(codec, WM8915_SOFTWARE_RESET); | ||
2570 | if (ret < 0) { | ||
2571 | dev_err(codec->dev, "Failed to read ID register: %d\n", ret); | ||
2572 | goto err_enable; | ||
2573 | } | ||
2574 | if (ret != 0x8915) { | ||
2575 | dev_err(codec->dev, "Device is not a WM8915, ID %x\n", ret); | ||
2576 | ret = -EINVAL; | ||
2577 | goto err_enable; | ||
2578 | } | ||
2579 | |||
2580 | ret = snd_soc_read(codec, WM8915_CHIP_REVISION); | ||
2581 | if (ret < 0) { | ||
2582 | dev_err(codec->dev, "Failed to read device revision: %d\n", | ||
2583 | ret); | ||
2584 | goto err_enable; | ||
2585 | } | ||
2586 | |||
2587 | dev_info(codec->dev, "revision %c\n", | ||
2588 | (ret & WM8915_CHIP_REV_MASK) + 'A'); | ||
2589 | |||
2590 | if (wm8915->pdata.ldo_ena >= 0) { | ||
2591 | gpio_set_value_cansleep(wm8915->pdata.ldo_ena, 0); | ||
2592 | } else { | ||
2593 | ret = wm8915_reset(codec); | ||
2594 | if (ret < 0) { | ||
2595 | dev_err(codec->dev, "Failed to issue reset\n"); | ||
2596 | goto err_enable; | ||
2597 | } | ||
2598 | } | ||
2599 | |||
2600 | codec->cache_only = true; | ||
2601 | |||
2602 | /* Apply platform data settings */ | ||
2603 | snd_soc_update_bits(codec, WM8915_LINE_INPUT_CONTROL, | ||
2604 | WM8915_INL_MODE_MASK | WM8915_INR_MODE_MASK, | ||
2605 | wm8915->pdata.inl_mode << WM8915_INL_MODE_SHIFT | | ||
2606 | wm8915->pdata.inr_mode); | ||
2607 | |||
2608 | for (i = 0; i < ARRAY_SIZE(wm8915->pdata.gpio_default); i++) { | ||
2609 | if (!wm8915->pdata.gpio_default[i]) | ||
2610 | continue; | ||
2611 | |||
2612 | snd_soc_write(codec, WM8915_GPIO_1 + i, | ||
2613 | wm8915->pdata.gpio_default[i] & 0xffff); | ||
2614 | } | ||
2615 | |||
2616 | if (wm8915->pdata.spkmute_seq) | ||
2617 | snd_soc_update_bits(codec, WM8915_PDM_SPEAKER_MUTE_SEQUENCE, | ||
2618 | WM8915_SPK_MUTE_ENDIAN | | ||
2619 | WM8915_SPK_MUTE_SEQ1_MASK, | ||
2620 | wm8915->pdata.spkmute_seq); | ||
2621 | |||
2622 | snd_soc_update_bits(codec, WM8915_ACCESSORY_DETECT_MODE_2, | ||
2623 | WM8915_MICD_BIAS_SRC | WM8915_HPOUT1FB_SRC | | ||
2624 | WM8915_MICD_SRC, wm8915->pdata.micdet_def); | ||
2625 | |||
2626 | /* Latch volume update bits */ | ||
2627 | snd_soc_update_bits(codec, WM8915_LEFT_LINE_INPUT_VOLUME, | ||
2628 | WM8915_IN1_VU, WM8915_IN1_VU); | ||
2629 | snd_soc_update_bits(codec, WM8915_RIGHT_LINE_INPUT_VOLUME, | ||
2630 | WM8915_IN1_VU, WM8915_IN1_VU); | ||
2631 | |||
2632 | snd_soc_update_bits(codec, WM8915_DAC1_LEFT_VOLUME, | ||
2633 | WM8915_DAC1_VU, WM8915_DAC1_VU); | ||
2634 | snd_soc_update_bits(codec, WM8915_DAC1_RIGHT_VOLUME, | ||
2635 | WM8915_DAC1_VU, WM8915_DAC1_VU); | ||
2636 | snd_soc_update_bits(codec, WM8915_DAC2_LEFT_VOLUME, | ||
2637 | WM8915_DAC2_VU, WM8915_DAC2_VU); | ||
2638 | snd_soc_update_bits(codec, WM8915_DAC2_RIGHT_VOLUME, | ||
2639 | WM8915_DAC2_VU, WM8915_DAC2_VU); | ||
2640 | |||
2641 | snd_soc_update_bits(codec, WM8915_OUTPUT1_LEFT_VOLUME, | ||
2642 | WM8915_DAC1_VU, WM8915_DAC1_VU); | ||
2643 | snd_soc_update_bits(codec, WM8915_OUTPUT1_RIGHT_VOLUME, | ||
2644 | WM8915_DAC1_VU, WM8915_DAC1_VU); | ||
2645 | snd_soc_update_bits(codec, WM8915_OUTPUT2_LEFT_VOLUME, | ||
2646 | WM8915_DAC2_VU, WM8915_DAC2_VU); | ||
2647 | snd_soc_update_bits(codec, WM8915_OUTPUT2_RIGHT_VOLUME, | ||
2648 | WM8915_DAC2_VU, WM8915_DAC2_VU); | ||
2649 | |||
2650 | snd_soc_update_bits(codec, WM8915_DSP1_TX_LEFT_VOLUME, | ||
2651 | WM8915_DSP1TX_VU, WM8915_DSP1TX_VU); | ||
2652 | snd_soc_update_bits(codec, WM8915_DSP1_TX_RIGHT_VOLUME, | ||
2653 | WM8915_DSP1TX_VU, WM8915_DSP1TX_VU); | ||
2654 | snd_soc_update_bits(codec, WM8915_DSP2_TX_LEFT_VOLUME, | ||
2655 | WM8915_DSP2TX_VU, WM8915_DSP2TX_VU); | ||
2656 | snd_soc_update_bits(codec, WM8915_DSP2_TX_RIGHT_VOLUME, | ||
2657 | WM8915_DSP2TX_VU, WM8915_DSP2TX_VU); | ||
2658 | |||
2659 | snd_soc_update_bits(codec, WM8915_DSP1_RX_LEFT_VOLUME, | ||
2660 | WM8915_DSP1RX_VU, WM8915_DSP1RX_VU); | ||
2661 | snd_soc_update_bits(codec, WM8915_DSP1_RX_RIGHT_VOLUME, | ||
2662 | WM8915_DSP1RX_VU, WM8915_DSP1RX_VU); | ||
2663 | snd_soc_update_bits(codec, WM8915_DSP2_RX_LEFT_VOLUME, | ||
2664 | WM8915_DSP2RX_VU, WM8915_DSP2RX_VU); | ||
2665 | snd_soc_update_bits(codec, WM8915_DSP2_RX_RIGHT_VOLUME, | ||
2666 | WM8915_DSP2RX_VU, WM8915_DSP2RX_VU); | ||
2667 | |||
2668 | /* No support currently for the underclocked TDM modes and | ||
2669 | * pick a default TDM layout with each channel pair working with | ||
2670 | * slots 0 and 1. */ | ||
2671 | snd_soc_update_bits(codec, WM8915_AIF1RX_CHANNEL_0_CONFIGURATION, | ||
2672 | WM8915_AIF1RX_CHAN0_SLOTS_MASK | | ||
2673 | WM8915_AIF1RX_CHAN0_START_SLOT_MASK, | ||
2674 | 1 << WM8915_AIF1RX_CHAN0_SLOTS_SHIFT | 0); | ||
2675 | snd_soc_update_bits(codec, WM8915_AIF1RX_CHANNEL_1_CONFIGURATION, | ||
2676 | WM8915_AIF1RX_CHAN1_SLOTS_MASK | | ||
2677 | WM8915_AIF1RX_CHAN1_START_SLOT_MASK, | ||
2678 | 1 << WM8915_AIF1RX_CHAN1_SLOTS_SHIFT | 1); | ||
2679 | snd_soc_update_bits(codec, WM8915_AIF1RX_CHANNEL_2_CONFIGURATION, | ||
2680 | WM8915_AIF1RX_CHAN2_SLOTS_MASK | | ||
2681 | WM8915_AIF1RX_CHAN2_START_SLOT_MASK, | ||
2682 | 1 << WM8915_AIF1RX_CHAN2_SLOTS_SHIFT | 0); | ||
2683 | snd_soc_update_bits(codec, WM8915_AIF1RX_CHANNEL_3_CONFIGURATION, | ||
2684 | WM8915_AIF1RX_CHAN3_SLOTS_MASK | | ||
2685 | WM8915_AIF1RX_CHAN0_START_SLOT_MASK, | ||
2686 | 1 << WM8915_AIF1RX_CHAN3_SLOTS_SHIFT | 1); | ||
2687 | snd_soc_update_bits(codec, WM8915_AIF1RX_CHANNEL_4_CONFIGURATION, | ||
2688 | WM8915_AIF1RX_CHAN4_SLOTS_MASK | | ||
2689 | WM8915_AIF1RX_CHAN0_START_SLOT_MASK, | ||
2690 | 1 << WM8915_AIF1RX_CHAN4_SLOTS_SHIFT | 0); | ||
2691 | snd_soc_update_bits(codec, WM8915_AIF1RX_CHANNEL_5_CONFIGURATION, | ||
2692 | WM8915_AIF1RX_CHAN5_SLOTS_MASK | | ||
2693 | WM8915_AIF1RX_CHAN0_START_SLOT_MASK, | ||
2694 | 1 << WM8915_AIF1RX_CHAN5_SLOTS_SHIFT | 1); | ||
2695 | |||
2696 | snd_soc_update_bits(codec, WM8915_AIF2RX_CHANNEL_0_CONFIGURATION, | ||
2697 | WM8915_AIF2RX_CHAN0_SLOTS_MASK | | ||
2698 | WM8915_AIF2RX_CHAN0_START_SLOT_MASK, | ||
2699 | 1 << WM8915_AIF2RX_CHAN0_SLOTS_SHIFT | 0); | ||
2700 | snd_soc_update_bits(codec, WM8915_AIF2RX_CHANNEL_1_CONFIGURATION, | ||
2701 | WM8915_AIF2RX_CHAN1_SLOTS_MASK | | ||
2702 | WM8915_AIF2RX_CHAN1_START_SLOT_MASK, | ||
2703 | 1 << WM8915_AIF2RX_CHAN1_SLOTS_SHIFT | 1); | ||
2704 | |||
2705 | snd_soc_update_bits(codec, WM8915_AIF1TX_CHANNEL_0_CONFIGURATION, | ||
2706 | WM8915_AIF1TX_CHAN0_SLOTS_MASK | | ||
2707 | WM8915_AIF1TX_CHAN0_START_SLOT_MASK, | ||
2708 | 1 << WM8915_AIF1TX_CHAN0_SLOTS_SHIFT | 0); | ||
2709 | snd_soc_update_bits(codec, WM8915_AIF1TX_CHANNEL_1_CONFIGURATION, | ||
2710 | WM8915_AIF1TX_CHAN1_SLOTS_MASK | | ||
2711 | WM8915_AIF1TX_CHAN0_START_SLOT_MASK, | ||
2712 | 1 << WM8915_AIF1TX_CHAN1_SLOTS_SHIFT | 1); | ||
2713 | snd_soc_update_bits(codec, WM8915_AIF1TX_CHANNEL_2_CONFIGURATION, | ||
2714 | WM8915_AIF1TX_CHAN2_SLOTS_MASK | | ||
2715 | WM8915_AIF1TX_CHAN0_START_SLOT_MASK, | ||
2716 | 1 << WM8915_AIF1TX_CHAN2_SLOTS_SHIFT | 0); | ||
2717 | snd_soc_update_bits(codec, WM8915_AIF1TX_CHANNEL_3_CONFIGURATION, | ||
2718 | WM8915_AIF1TX_CHAN3_SLOTS_MASK | | ||
2719 | WM8915_AIF1TX_CHAN0_START_SLOT_MASK, | ||
2720 | 1 << WM8915_AIF1TX_CHAN3_SLOTS_SHIFT | 1); | ||
2721 | snd_soc_update_bits(codec, WM8915_AIF1TX_CHANNEL_4_CONFIGURATION, | ||
2722 | WM8915_AIF1TX_CHAN4_SLOTS_MASK | | ||
2723 | WM8915_AIF1TX_CHAN0_START_SLOT_MASK, | ||
2724 | 1 << WM8915_AIF1TX_CHAN4_SLOTS_SHIFT | 0); | ||
2725 | snd_soc_update_bits(codec, WM8915_AIF1TX_CHANNEL_5_CONFIGURATION, | ||
2726 | WM8915_AIF1TX_CHAN5_SLOTS_MASK | | ||
2727 | WM8915_AIF1TX_CHAN0_START_SLOT_MASK, | ||
2728 | 1 << WM8915_AIF1TX_CHAN5_SLOTS_SHIFT | 1); | ||
2729 | |||
2730 | snd_soc_update_bits(codec, WM8915_AIF2TX_CHANNEL_0_CONFIGURATION, | ||
2731 | WM8915_AIF2TX_CHAN0_SLOTS_MASK | | ||
2732 | WM8915_AIF2TX_CHAN0_START_SLOT_MASK, | ||
2733 | 1 << WM8915_AIF2TX_CHAN0_SLOTS_SHIFT | 0); | ||
2734 | snd_soc_update_bits(codec, WM8915_AIF1TX_CHANNEL_1_CONFIGURATION, | ||
2735 | WM8915_AIF2TX_CHAN1_SLOTS_MASK | | ||
2736 | WM8915_AIF2TX_CHAN1_START_SLOT_MASK, | ||
2737 | 1 << WM8915_AIF1TX_CHAN1_SLOTS_SHIFT | 1); | ||
2738 | |||
2739 | if (wm8915->pdata.num_retune_mobile_cfgs) | ||
2740 | wm8915_retune_mobile_pdata(codec); | ||
2741 | else | ||
2742 | snd_soc_add_controls(codec, wm8915_eq_controls, | ||
2743 | ARRAY_SIZE(wm8915_eq_controls)); | ||
2744 | |||
2745 | /* If the TX LRCLK pins are not in LRCLK mode configure the | ||
2746 | * AIFs to source their clocks from the RX LRCLKs. | ||
2747 | */ | ||
2748 | if ((snd_soc_read(codec, WM8915_GPIO_1))) | ||
2749 | snd_soc_update_bits(codec, WM8915_AIF1_TX_LRCLK_2, | ||
2750 | WM8915_AIF1TX_LRCLK_MODE, | ||
2751 | WM8915_AIF1TX_LRCLK_MODE); | ||
2752 | |||
2753 | if ((snd_soc_read(codec, WM8915_GPIO_2))) | ||
2754 | snd_soc_update_bits(codec, WM8915_AIF2_TX_LRCLK_2, | ||
2755 | WM8915_AIF2TX_LRCLK_MODE, | ||
2756 | WM8915_AIF2TX_LRCLK_MODE); | ||
2757 | |||
2758 | regulator_bulk_disable(ARRAY_SIZE(wm8915->supplies), wm8915->supplies); | ||
2759 | |||
2760 | wm8915_init_gpio(codec); | ||
2761 | |||
2762 | if (i2c->irq) { | ||
2763 | if (wm8915->pdata.irq_flags) | ||
2764 | irq_flags = wm8915->pdata.irq_flags; | ||
2765 | else | ||
2766 | irq_flags = IRQF_TRIGGER_LOW; | ||
2767 | |||
2768 | irq_flags |= IRQF_ONESHOT; | ||
2769 | |||
2770 | if (irq_flags & (IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING)) | ||
2771 | ret = request_threaded_irq(i2c->irq, NULL, | ||
2772 | wm8915_edge_irq, | ||
2773 | irq_flags, "wm8915", codec); | ||
2774 | else | ||
2775 | ret = request_threaded_irq(i2c->irq, NULL, wm8915_irq, | ||
2776 | irq_flags, "wm8915", codec); | ||
2777 | |||
2778 | if (ret == 0) { | ||
2779 | /* Unmask the interrupt */ | ||
2780 | snd_soc_update_bits(codec, WM8915_INTERRUPT_CONTROL, | ||
2781 | WM8915_IM_IRQ, 0); | ||
2782 | |||
2783 | /* Enable error reporting and DC servo status */ | ||
2784 | snd_soc_update_bits(codec, | ||
2785 | WM8915_INTERRUPT_STATUS_2_MASK, | ||
2786 | WM8915_IM_DCS_DONE_23_EINT | | ||
2787 | WM8915_IM_DCS_DONE_01_EINT | | ||
2788 | WM8915_IM_FLL_LOCK_EINT | | ||
2789 | WM8915_IM_FIFOS_ERR_EINT, | ||
2790 | 0); | ||
2791 | } else { | ||
2792 | dev_err(codec->dev, "Failed to request IRQ: %d\n", | ||
2793 | ret); | ||
2794 | } | ||
2795 | } | ||
2796 | |||
2797 | return 0; | ||
2798 | |||
2799 | err_enable: | ||
2800 | if (wm8915->pdata.ldo_ena >= 0) | ||
2801 | gpio_set_value_cansleep(wm8915->pdata.ldo_ena, 0); | ||
2802 | |||
2803 | regulator_bulk_disable(ARRAY_SIZE(wm8915->supplies), wm8915->supplies); | ||
2804 | err_get: | ||
2805 | regulator_bulk_free(ARRAY_SIZE(wm8915->supplies), wm8915->supplies); | ||
2806 | err: | ||
2807 | return ret; | ||
2808 | } | ||
2809 | |||
2810 | static int wm8915_remove(struct snd_soc_codec *codec) | ||
2811 | { | ||
2812 | struct wm8915_priv *wm8915 = snd_soc_codec_get_drvdata(codec); | ||
2813 | struct i2c_client *i2c = to_i2c_client(codec->dev); | ||
2814 | int i; | ||
2815 | |||
2816 | snd_soc_update_bits(codec, WM8915_INTERRUPT_CONTROL, | ||
2817 | WM8915_IM_IRQ, WM8915_IM_IRQ); | ||
2818 | |||
2819 | if (i2c->irq) | ||
2820 | free_irq(i2c->irq, codec); | ||
2821 | |||
2822 | wm8915_free_gpio(codec); | ||
2823 | |||
2824 | for (i = 0; i < ARRAY_SIZE(wm8915->supplies); i++) | ||
2825 | regulator_unregister_notifier(wm8915->supplies[i].consumer, | ||
2826 | &wm8915->disable_nb[i]); | ||
2827 | regulator_bulk_free(ARRAY_SIZE(wm8915->supplies), wm8915->supplies); | ||
2828 | |||
2829 | return 0; | ||
2830 | } | ||
2831 | |||
2832 | static struct snd_soc_codec_driver soc_codec_dev_wm8915 = { | ||
2833 | .probe = wm8915_probe, | ||
2834 | .remove = wm8915_remove, | ||
2835 | .set_bias_level = wm8915_set_bias_level, | ||
2836 | .seq_notifier = wm8915_seq_notifier, | ||
2837 | .reg_cache_size = WM8915_MAX_REGISTER + 1, | ||
2838 | .reg_word_size = sizeof(u16), | ||
2839 | .reg_cache_default = wm8915_reg, | ||
2840 | .volatile_register = wm8915_volatile_register, | ||
2841 | .readable_register = wm8915_readable_register, | ||
2842 | .compress_type = SND_SOC_RBTREE_COMPRESSION, | ||
2843 | .controls = wm8915_snd_controls, | ||
2844 | .num_controls = ARRAY_SIZE(wm8915_snd_controls), | ||
2845 | .dapm_widgets = wm8915_dapm_widgets, | ||
2846 | .num_dapm_widgets = ARRAY_SIZE(wm8915_dapm_widgets), | ||
2847 | .dapm_routes = wm8915_dapm_routes, | ||
2848 | .num_dapm_routes = ARRAY_SIZE(wm8915_dapm_routes), | ||
2849 | .set_pll = wm8915_set_fll, | ||
2850 | }; | ||
2851 | |||
2852 | #define WM8915_RATES (SNDRV_PCM_RATE_8000 | SNDRV_PCM_RATE_16000 |\ | ||
2853 | SNDRV_PCM_RATE_32000 | SNDRV_PCM_RATE_48000) | ||
2854 | #define WM8915_FORMATS (SNDRV_PCM_FMTBIT_S8 | SNDRV_PCM_FMTBIT_S16_LE |\ | ||
2855 | SNDRV_PCM_FMTBIT_S20_3LE | SNDRV_PCM_FMTBIT_S24_LE |\ | ||
2856 | SNDRV_PCM_FMTBIT_S32_LE) | ||
2857 | |||
2858 | static struct snd_soc_dai_ops wm8915_dai_ops = { | ||
2859 | .set_fmt = wm8915_set_fmt, | ||
2860 | .hw_params = wm8915_hw_params, | ||
2861 | .set_sysclk = wm8915_set_sysclk, | ||
2862 | }; | ||
2863 | |||
2864 | static struct snd_soc_dai_driver wm8915_dai[] = { | ||
2865 | { | ||
2866 | .name = "wm8915-aif1", | ||
2867 | .playback = { | ||
2868 | .stream_name = "AIF1 Playback", | ||
2869 | .channels_min = 1, | ||
2870 | .channels_max = 6, | ||
2871 | .rates = WM8915_RATES, | ||
2872 | .formats = WM8915_FORMATS, | ||
2873 | }, | ||
2874 | .capture = { | ||
2875 | .stream_name = "AIF1 Capture", | ||
2876 | .channels_min = 1, | ||
2877 | .channels_max = 6, | ||
2878 | .rates = WM8915_RATES, | ||
2879 | .formats = WM8915_FORMATS, | ||
2880 | }, | ||
2881 | .ops = &wm8915_dai_ops, | ||
2882 | }, | ||
2883 | { | ||
2884 | .name = "wm8915-aif2", | ||
2885 | .playback = { | ||
2886 | .stream_name = "AIF2 Playback", | ||
2887 | .channels_min = 1, | ||
2888 | .channels_max = 2, | ||
2889 | .rates = WM8915_RATES, | ||
2890 | .formats = WM8915_FORMATS, | ||
2891 | }, | ||
2892 | .capture = { | ||
2893 | .stream_name = "AIF2 Capture", | ||
2894 | .channels_min = 1, | ||
2895 | .channels_max = 2, | ||
2896 | .rates = WM8915_RATES, | ||
2897 | .formats = WM8915_FORMATS, | ||
2898 | }, | ||
2899 | .ops = &wm8915_dai_ops, | ||
2900 | }, | ||
2901 | }; | ||
2902 | |||
2903 | static __devinit int wm8915_i2c_probe(struct i2c_client *i2c, | ||
2904 | const struct i2c_device_id *id) | ||
2905 | { | ||
2906 | struct wm8915_priv *wm8915; | ||
2907 | int ret; | ||
2908 | |||
2909 | wm8915 = kzalloc(sizeof(struct wm8915_priv), GFP_KERNEL); | ||
2910 | if (wm8915 == NULL) | ||
2911 | return -ENOMEM; | ||
2912 | |||
2913 | i2c_set_clientdata(i2c, wm8915); | ||
2914 | |||
2915 | if (dev_get_platdata(&i2c->dev)) | ||
2916 | memcpy(&wm8915->pdata, dev_get_platdata(&i2c->dev), | ||
2917 | sizeof(wm8915->pdata)); | ||
2918 | |||
2919 | if (wm8915->pdata.ldo_ena > 0) { | ||
2920 | ret = gpio_request_one(wm8915->pdata.ldo_ena, | ||
2921 | GPIOF_OUT_INIT_LOW, "WM8915 ENA"); | ||
2922 | if (ret < 0) { | ||
2923 | dev_err(&i2c->dev, "Failed to request GPIO %d: %d\n", | ||
2924 | wm8915->pdata.ldo_ena, ret); | ||
2925 | goto err; | ||
2926 | } | ||
2927 | } | ||
2928 | |||
2929 | ret = snd_soc_register_codec(&i2c->dev, | ||
2930 | &soc_codec_dev_wm8915, wm8915_dai, | ||
2931 | ARRAY_SIZE(wm8915_dai)); | ||
2932 | if (ret < 0) | ||
2933 | goto err_gpio; | ||
2934 | |||
2935 | return ret; | ||
2936 | |||
2937 | err_gpio: | ||
2938 | if (wm8915->pdata.ldo_ena > 0) | ||
2939 | gpio_free(wm8915->pdata.ldo_ena); | ||
2940 | err: | ||
2941 | kfree(wm8915); | ||
2942 | |||
2943 | return ret; | ||
2944 | } | ||
2945 | |||
2946 | static __devexit int wm8915_i2c_remove(struct i2c_client *client) | ||
2947 | { | ||
2948 | struct wm8915_priv *wm8915 = i2c_get_clientdata(client); | ||
2949 | |||
2950 | snd_soc_unregister_codec(&client->dev); | ||
2951 | if (wm8915->pdata.ldo_ena > 0) | ||
2952 | gpio_free(wm8915->pdata.ldo_ena); | ||
2953 | kfree(i2c_get_clientdata(client)); | ||
2954 | return 0; | ||
2955 | } | ||
2956 | |||
2957 | static const struct i2c_device_id wm8915_i2c_id[] = { | ||
2958 | { "wm8915", 0 }, | ||
2959 | { } | ||
2960 | }; | ||
2961 | MODULE_DEVICE_TABLE(i2c, wm8915_i2c_id); | ||
2962 | |||
2963 | static struct i2c_driver wm8915_i2c_driver = { | ||
2964 | .driver = { | ||
2965 | .name = "wm8915", | ||
2966 | .owner = THIS_MODULE, | ||
2967 | }, | ||
2968 | .probe = wm8915_i2c_probe, | ||
2969 | .remove = __devexit_p(wm8915_i2c_remove), | ||
2970 | .id_table = wm8915_i2c_id, | ||
2971 | }; | ||
2972 | |||
2973 | static int __init wm8915_modinit(void) | ||
2974 | { | ||
2975 | int ret; | ||
2976 | |||
2977 | ret = i2c_add_driver(&wm8915_i2c_driver); | ||
2978 | if (ret != 0) { | ||
2979 | printk(KERN_ERR "Failed to register WM8915 I2C driver: %d\n", | ||
2980 | ret); | ||
2981 | } | ||
2982 | |||
2983 | return ret; | ||
2984 | } | ||
2985 | module_init(wm8915_modinit); | ||
2986 | |||
2987 | static void __exit wm8915_exit(void) | ||
2988 | { | ||
2989 | i2c_del_driver(&wm8915_i2c_driver); | ||
2990 | } | ||
2991 | module_exit(wm8915_exit); | ||
2992 | |||
2993 | MODULE_DESCRIPTION("ASoC WM8915 driver"); | ||
2994 | MODULE_AUTHOR("Mark Brown <broonie@opensource.wolfsonmicro.com>"); | ||
2995 | MODULE_LICENSE("GPL"); | ||
diff --git a/sound/soc/codecs/wm8915.h b/sound/soc/codecs/wm8915.h deleted file mode 100644 index 200ffd7bf953..000000000000 --- a/sound/soc/codecs/wm8915.h +++ /dev/null | |||
@@ -1,3717 +0,0 @@ | |||
1 | /* | ||
2 | * wm8915.h - WM8915 audio codec interface | ||
3 | * | ||
4 | * Copyright 2011 Wolfson Microelectronics PLC. | ||
5 | * Author: Mark Brown <broonie@opensource.wolfsonmicro.com> | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify it | ||
8 | * under the terms of the GNU General Public License as published by the | ||
9 | * Free Software Foundation; either version 2 of the License, or (at your | ||
10 | * option) any later version. | ||
11 | */ | ||
12 | |||
13 | #ifndef _WM8915_H | ||
14 | #define _WM8915_H | ||
15 | |||
16 | #define WM8915_SYSCLK_MCLK1 1 | ||
17 | #define WM8915_SYSCLK_MCLK2 2 | ||
18 | #define WM8915_SYSCLK_FLL 3 | ||
19 | |||
20 | #define WM8915_FLL_MCLK1 1 | ||
21 | #define WM8915_FLL_MCLK2 2 | ||
22 | #define WM8915_FLL_DACLRCLK1 3 | ||
23 | #define WM8915_FLL_BCLK1 4 | ||
24 | |||
25 | typedef void (*wm8915_polarity_fn)(struct snd_soc_codec *codec, int polarity); | ||
26 | |||
27 | int wm8915_detect(struct snd_soc_codec *codec, struct snd_soc_jack *jack, | ||
28 | wm8915_polarity_fn polarity_cb); | ||
29 | |||
30 | /* | ||
31 | * Register values. | ||
32 | */ | ||
33 | #define WM8915_SOFTWARE_RESET 0x00 | ||
34 | #define WM8915_POWER_MANAGEMENT_1 0x01 | ||
35 | #define WM8915_POWER_MANAGEMENT_2 0x02 | ||
36 | #define WM8915_POWER_MANAGEMENT_3 0x03 | ||
37 | #define WM8915_POWER_MANAGEMENT_4 0x04 | ||
38 | #define WM8915_POWER_MANAGEMENT_5 0x05 | ||
39 | #define WM8915_POWER_MANAGEMENT_6 0x06 | ||
40 | #define WM8915_POWER_MANAGEMENT_7 0x07 | ||
41 | #define WM8915_POWER_MANAGEMENT_8 0x08 | ||
42 | #define WM8915_LEFT_LINE_INPUT_VOLUME 0x10 | ||
43 | #define WM8915_RIGHT_LINE_INPUT_VOLUME 0x11 | ||
44 | #define WM8915_LINE_INPUT_CONTROL 0x12 | ||
45 | #define WM8915_DAC1_HPOUT1_VOLUME 0x15 | ||
46 | #define WM8915_DAC2_HPOUT2_VOLUME 0x16 | ||
47 | #define WM8915_DAC1_LEFT_VOLUME 0x18 | ||
48 | #define WM8915_DAC1_RIGHT_VOLUME 0x19 | ||
49 | #define WM8915_DAC2_LEFT_VOLUME 0x1A | ||
50 | #define WM8915_DAC2_RIGHT_VOLUME 0x1B | ||
51 | #define WM8915_OUTPUT1_LEFT_VOLUME 0x1C | ||
52 | #define WM8915_OUTPUT1_RIGHT_VOLUME 0x1D | ||
53 | #define WM8915_OUTPUT2_LEFT_VOLUME 0x1E | ||
54 | #define WM8915_OUTPUT2_RIGHT_VOLUME 0x1F | ||
55 | #define WM8915_MICBIAS_1 0x20 | ||
56 | #define WM8915_MICBIAS_2 0x21 | ||
57 | #define WM8915_LDO_1 0x28 | ||
58 | #define WM8915_LDO_2 0x29 | ||
59 | #define WM8915_ACCESSORY_DETECT_MODE_1 0x30 | ||
60 | #define WM8915_ACCESSORY_DETECT_MODE_2 0x31 | ||
61 | #define WM8915_HEADPHONE_DETECT_1 0x34 | ||
62 | #define WM8915_HEADPHONE_DETECT_2 0x35 | ||
63 | #define WM8915_MIC_DETECT_1 0x38 | ||
64 | #define WM8915_MIC_DETECT_2 0x39 | ||
65 | #define WM8915_MIC_DETECT_3 0x3A | ||
66 | #define WM8915_CHARGE_PUMP_1 0x40 | ||
67 | #define WM8915_CHARGE_PUMP_2 0x41 | ||
68 | #define WM8915_DC_SERVO_1 0x50 | ||
69 | #define WM8915_DC_SERVO_2 0x51 | ||
70 | #define WM8915_DC_SERVO_3 0x52 | ||
71 | #define WM8915_DC_SERVO_5 0x54 | ||
72 | #define WM8915_DC_SERVO_6 0x55 | ||
73 | #define WM8915_DC_SERVO_7 0x56 | ||
74 | #define WM8915_DC_SERVO_READBACK_0 0x57 | ||
75 | #define WM8915_ANALOGUE_HP_1 0x60 | ||
76 | #define WM8915_ANALOGUE_HP_2 0x61 | ||
77 | #define WM8915_CHIP_REVISION 0x100 | ||
78 | #define WM8915_CONTROL_INTERFACE_1 0x101 | ||
79 | #define WM8915_WRITE_SEQUENCER_CTRL_1 0x110 | ||
80 | #define WM8915_WRITE_SEQUENCER_CTRL_2 0x111 | ||
81 | #define WM8915_AIF_CLOCKING_1 0x200 | ||
82 | #define WM8915_AIF_CLOCKING_2 0x201 | ||
83 | #define WM8915_CLOCKING_1 0x208 | ||
84 | #define WM8915_CLOCKING_2 0x209 | ||
85 | #define WM8915_AIF_RATE 0x210 | ||
86 | #define WM8915_FLL_CONTROL_1 0x220 | ||
87 | #define WM8915_FLL_CONTROL_2 0x221 | ||
88 | #define WM8915_FLL_CONTROL_3 0x222 | ||
89 | #define WM8915_FLL_CONTROL_4 0x223 | ||
90 | #define WM8915_FLL_CONTROL_5 0x224 | ||
91 | #define WM8915_FLL_CONTROL_6 0x225 | ||
92 | #define WM8915_FLL_EFS_1 0x226 | ||
93 | #define WM8915_FLL_EFS_2 0x227 | ||
94 | #define WM8915_AIF1_CONTROL 0x300 | ||
95 | #define WM8915_AIF1_BCLK 0x301 | ||
96 | #define WM8915_AIF1_TX_LRCLK_1 0x302 | ||
97 | #define WM8915_AIF1_TX_LRCLK_2 0x303 | ||
98 | #define WM8915_AIF1_RX_LRCLK_1 0x304 | ||
99 | #define WM8915_AIF1_RX_LRCLK_2 0x305 | ||
100 | #define WM8915_AIF1TX_DATA_CONFIGURATION_1 0x306 | ||
101 | #define WM8915_AIF1TX_DATA_CONFIGURATION_2 0x307 | ||
102 | #define WM8915_AIF1RX_DATA_CONFIGURATION 0x308 | ||
103 | #define WM8915_AIF1TX_CHANNEL_0_CONFIGURATION 0x309 | ||
104 | #define WM8915_AIF1TX_CHANNEL_1_CONFIGURATION 0x30A | ||
105 | #define WM8915_AIF1TX_CHANNEL_2_CONFIGURATION 0x30B | ||
106 | #define WM8915_AIF1TX_CHANNEL_3_CONFIGURATION 0x30C | ||
107 | #define WM8915_AIF1TX_CHANNEL_4_CONFIGURATION 0x30D | ||
108 | #define WM8915_AIF1TX_CHANNEL_5_CONFIGURATION 0x30E | ||
109 | #define WM8915_AIF1RX_CHANNEL_0_CONFIGURATION 0x30F | ||
110 | #define WM8915_AIF1RX_CHANNEL_1_CONFIGURATION 0x310 | ||
111 | #define WM8915_AIF1RX_CHANNEL_2_CONFIGURATION 0x311 | ||
112 | #define WM8915_AIF1RX_CHANNEL_3_CONFIGURATION 0x312 | ||
113 | #define WM8915_AIF1RX_CHANNEL_4_CONFIGURATION 0x313 | ||
114 | #define WM8915_AIF1RX_CHANNEL_5_CONFIGURATION 0x314 | ||
115 | #define WM8915_AIF1RX_MONO_CONFIGURATION 0x315 | ||
116 | #define WM8915_AIF1TX_TEST 0x31A | ||
117 | #define WM8915_AIF2_CONTROL 0x320 | ||
118 | #define WM8915_AIF2_BCLK 0x321 | ||
119 | #define WM8915_AIF2_TX_LRCLK_1 0x322 | ||
120 | #define WM8915_AIF2_TX_LRCLK_2 0x323 | ||
121 | #define WM8915_AIF2_RX_LRCLK_1 0x324 | ||
122 | #define WM8915_AIF2_RX_LRCLK_2 0x325 | ||
123 | #define WM8915_AIF2TX_DATA_CONFIGURATION_1 0x326 | ||
124 | #define WM8915_AIF2TX_DATA_CONFIGURATION_2 0x327 | ||
125 | #define WM8915_AIF2RX_DATA_CONFIGURATION 0x328 | ||
126 | #define WM8915_AIF2TX_CHANNEL_0_CONFIGURATION 0x329 | ||
127 | #define WM8915_AIF2TX_CHANNEL_1_CONFIGURATION 0x32A | ||
128 | #define WM8915_AIF2RX_CHANNEL_0_CONFIGURATION 0x32B | ||
129 | #define WM8915_AIF2RX_CHANNEL_1_CONFIGURATION 0x32C | ||
130 | #define WM8915_AIF2RX_MONO_CONFIGURATION 0x32D | ||
131 | #define WM8915_AIF2TX_TEST 0x32F | ||
132 | #define WM8915_DSP1_TX_LEFT_VOLUME 0x400 | ||
133 | #define WM8915_DSP1_TX_RIGHT_VOLUME 0x401 | ||
134 | #define WM8915_DSP1_RX_LEFT_VOLUME 0x402 | ||
135 | #define WM8915_DSP1_RX_RIGHT_VOLUME 0x403 | ||
136 | #define WM8915_DSP1_TX_FILTERS 0x410 | ||
137 | #define WM8915_DSP1_RX_FILTERS_1 0x420 | ||
138 | #define WM8915_DSP1_RX_FILTERS_2 0x421 | ||
139 | #define WM8915_DSP1_DRC_1 0x440 | ||
140 | #define WM8915_DSP1_DRC_2 0x441 | ||
141 | #define WM8915_DSP1_DRC_3 0x442 | ||
142 | #define WM8915_DSP1_DRC_4 0x443 | ||
143 | #define WM8915_DSP1_DRC_5 0x444 | ||
144 | #define WM8915_DSP1_RX_EQ_GAINS_1 0x480 | ||
145 | #define WM8915_DSP1_RX_EQ_GAINS_2 0x481 | ||
146 | #define WM8915_DSP1_RX_EQ_BAND_1_A 0x482 | ||
147 | #define WM8915_DSP1_RX_EQ_BAND_1_B 0x483 | ||
148 | #define WM8915_DSP1_RX_EQ_BAND_1_PG 0x484 | ||
149 | #define WM8915_DSP1_RX_EQ_BAND_2_A 0x485 | ||
150 | #define WM8915_DSP1_RX_EQ_BAND_2_B 0x486 | ||
151 | #define WM8915_DSP1_RX_EQ_BAND_2_C 0x487 | ||
152 | #define WM8915_DSP1_RX_EQ_BAND_2_PG 0x488 | ||
153 | #define WM8915_DSP1_RX_EQ_BAND_3_A 0x489 | ||
154 | #define WM8915_DSP1_RX_EQ_BAND_3_B 0x48A | ||
155 | #define WM8915_DSP1_RX_EQ_BAND_3_C 0x48B | ||
156 | #define WM8915_DSP1_RX_EQ_BAND_3_PG 0x48C | ||
157 | #define WM8915_DSP1_RX_EQ_BAND_4_A 0x48D | ||
158 | #define WM8915_DSP1_RX_EQ_BAND_4_B 0x48E | ||
159 | #define WM8915_DSP1_RX_EQ_BAND_4_C 0x48F | ||
160 | #define WM8915_DSP1_RX_EQ_BAND_4_PG 0x490 | ||
161 | #define WM8915_DSP1_RX_EQ_BAND_5_A 0x491 | ||
162 | #define WM8915_DSP1_RX_EQ_BAND_5_B 0x492 | ||
163 | #define WM8915_DSP1_RX_EQ_BAND_5_PG 0x493 | ||
164 | #define WM8915_DSP2_TX_LEFT_VOLUME 0x500 | ||
165 | #define WM8915_DSP2_TX_RIGHT_VOLUME 0x501 | ||
166 | #define WM8915_DSP2_RX_LEFT_VOLUME 0x502 | ||
167 | #define WM8915_DSP2_RX_RIGHT_VOLUME 0x503 | ||
168 | #define WM8915_DSP2_TX_FILTERS 0x510 | ||
169 | #define WM8915_DSP2_RX_FILTERS_1 0x520 | ||
170 | #define WM8915_DSP2_RX_FILTERS_2 0x521 | ||
171 | #define WM8915_DSP2_DRC_1 0x540 | ||
172 | #define WM8915_DSP2_DRC_2 0x541 | ||
173 | #define WM8915_DSP2_DRC_3 0x542 | ||
174 | #define WM8915_DSP2_DRC_4 0x543 | ||
175 | #define WM8915_DSP2_DRC_5 0x544 | ||
176 | #define WM8915_DSP2_RX_EQ_GAINS_1 0x580 | ||
177 | #define WM8915_DSP2_RX_EQ_GAINS_2 0x581 | ||
178 | #define WM8915_DSP2_RX_EQ_BAND_1_A 0x582 | ||
179 | #define WM8915_DSP2_RX_EQ_BAND_1_B 0x583 | ||
180 | #define WM8915_DSP2_RX_EQ_BAND_1_PG 0x584 | ||
181 | #define WM8915_DSP2_RX_EQ_BAND_2_A 0x585 | ||
182 | #define WM8915_DSP2_RX_EQ_BAND_2_B 0x586 | ||
183 | #define WM8915_DSP2_RX_EQ_BAND_2_C 0x587 | ||
184 | #define WM8915_DSP2_RX_EQ_BAND_2_PG 0x588 | ||
185 | #define WM8915_DSP2_RX_EQ_BAND_3_A 0x589 | ||
186 | #define WM8915_DSP2_RX_EQ_BAND_3_B 0x58A | ||
187 | #define WM8915_DSP2_RX_EQ_BAND_3_C 0x58B | ||
188 | #define WM8915_DSP2_RX_EQ_BAND_3_PG 0x58C | ||
189 | #define WM8915_DSP2_RX_EQ_BAND_4_A 0x58D | ||
190 | #define WM8915_DSP2_RX_EQ_BAND_4_B 0x58E | ||
191 | #define WM8915_DSP2_RX_EQ_BAND_4_C 0x58F | ||
192 | #define WM8915_DSP2_RX_EQ_BAND_4_PG 0x590 | ||
193 | #define WM8915_DSP2_RX_EQ_BAND_5_A 0x591 | ||
194 | #define WM8915_DSP2_RX_EQ_BAND_5_B 0x592 | ||
195 | #define WM8915_DSP2_RX_EQ_BAND_5_PG 0x593 | ||
196 | #define WM8915_DAC1_MIXER_VOLUMES 0x600 | ||
197 | #define WM8915_DAC1_LEFT_MIXER_ROUTING 0x601 | ||
198 | #define WM8915_DAC1_RIGHT_MIXER_ROUTING 0x602 | ||
199 | #define WM8915_DAC2_MIXER_VOLUMES 0x603 | ||
200 | #define WM8915_DAC2_LEFT_MIXER_ROUTING 0x604 | ||
201 | #define WM8915_DAC2_RIGHT_MIXER_ROUTING 0x605 | ||
202 | #define WM8915_DSP1_TX_LEFT_MIXER_ROUTING 0x606 | ||
203 | #define WM8915_DSP1_TX_RIGHT_MIXER_ROUTING 0x607 | ||
204 | #define WM8915_DSP2_TX_LEFT_MIXER_ROUTING 0x608 | ||
205 | #define WM8915_DSP2_TX_RIGHT_MIXER_ROUTING 0x609 | ||
206 | #define WM8915_DSP_TX_MIXER_SELECT 0x60A | ||
207 | #define WM8915_DAC_SOFTMUTE 0x610 | ||
208 | #define WM8915_OVERSAMPLING 0x620 | ||
209 | #define WM8915_SIDETONE 0x621 | ||
210 | #define WM8915_GPIO_1 0x700 | ||
211 | #define WM8915_GPIO_2 0x701 | ||
212 | #define WM8915_GPIO_3 0x702 | ||
213 | #define WM8915_GPIO_4 0x703 | ||
214 | #define WM8915_GPIO_5 0x704 | ||
215 | #define WM8915_PULL_CONTROL_1 0x720 | ||
216 | #define WM8915_PULL_CONTROL_2 0x721 | ||
217 | #define WM8915_INTERRUPT_STATUS_1 0x730 | ||
218 | #define WM8915_INTERRUPT_STATUS_2 0x731 | ||
219 | #define WM8915_INTERRUPT_RAW_STATUS_2 0x732 | ||
220 | #define WM8915_INTERRUPT_STATUS_1_MASK 0x738 | ||
221 | #define WM8915_INTERRUPT_STATUS_2_MASK 0x739 | ||
222 | #define WM8915_INTERRUPT_CONTROL 0x740 | ||
223 | #define WM8915_LEFT_PDM_SPEAKER 0x800 | ||
224 | #define WM8915_RIGHT_PDM_SPEAKER 0x801 | ||
225 | #define WM8915_PDM_SPEAKER_MUTE_SEQUENCE 0x802 | ||
226 | #define WM8915_PDM_SPEAKER_VOLUME 0x803 | ||
227 | #define WM8915_WRITE_SEQUENCER_0 0x3000 | ||
228 | #define WM8915_WRITE_SEQUENCER_1 0x3001 | ||
229 | #define WM8915_WRITE_SEQUENCER_2 0x3002 | ||
230 | #define WM8915_WRITE_SEQUENCER_3 0x3003 | ||
231 | #define WM8915_WRITE_SEQUENCER_4 0x3004 | ||
232 | #define WM8915_WRITE_SEQUENCER_5 0x3005 | ||
233 | #define WM8915_WRITE_SEQUENCER_6 0x3006 | ||
234 | #define WM8915_WRITE_SEQUENCER_7 0x3007 | ||
235 | #define WM8915_WRITE_SEQUENCER_8 0x3008 | ||
236 | #define WM8915_WRITE_SEQUENCER_9 0x3009 | ||
237 | #define WM8915_WRITE_SEQUENCER_10 0x300A | ||
238 | #define WM8915_WRITE_SEQUENCER_11 0x300B | ||
239 | #define WM8915_WRITE_SEQUENCER_12 0x300C | ||
240 | #define WM8915_WRITE_SEQUENCER_13 0x300D | ||
241 | #define WM8915_WRITE_SEQUENCER_14 0x300E | ||
242 | #define WM8915_WRITE_SEQUENCER_15 0x300F | ||
243 | #define WM8915_WRITE_SEQUENCER_16 0x3010 | ||
244 | #define WM8915_WRITE_SEQUENCER_17 0x3011 | ||
245 | #define WM8915_WRITE_SEQUENCER_18 0x3012 | ||
246 | #define WM8915_WRITE_SEQUENCER_19 0x3013 | ||
247 | #define WM8915_WRITE_SEQUENCER_20 0x3014 | ||
248 | #define WM8915_WRITE_SEQUENCER_21 0x3015 | ||
249 | #define WM8915_WRITE_SEQUENCER_22 0x3016 | ||
250 | #define WM8915_WRITE_SEQUENCER_23 0x3017 | ||
251 | #define WM8915_WRITE_SEQUENCER_24 0x3018 | ||
252 | #define WM8915_WRITE_SEQUENCER_25 0x3019 | ||
253 | #define WM8915_WRITE_SEQUENCER_26 0x301A | ||
254 | #define WM8915_WRITE_SEQUENCER_27 0x301B | ||
255 | #define WM8915_WRITE_SEQUENCER_28 0x301C | ||
256 | #define WM8915_WRITE_SEQUENCER_29 0x301D | ||
257 | #define WM8915_WRITE_SEQUENCER_30 0x301E | ||
258 | #define WM8915_WRITE_SEQUENCER_31 0x301F | ||
259 | #define WM8915_WRITE_SEQUENCER_32 0x3020 | ||
260 | #define WM8915_WRITE_SEQUENCER_33 0x3021 | ||
261 | #define WM8915_WRITE_SEQUENCER_34 0x3022 | ||
262 | #define WM8915_WRITE_SEQUENCER_35 0x3023 | ||
263 | #define WM8915_WRITE_SEQUENCER_36 0x3024 | ||
264 | #define WM8915_WRITE_SEQUENCER_37 0x3025 | ||
265 | #define WM8915_WRITE_SEQUENCER_38 0x3026 | ||
266 | #define WM8915_WRITE_SEQUENCER_39 0x3027 | ||
267 | #define WM8915_WRITE_SEQUENCER_40 0x3028 | ||
268 | #define WM8915_WRITE_SEQUENCER_41 0x3029 | ||
269 | #define WM8915_WRITE_SEQUENCER_42 0x302A | ||
270 | #define WM8915_WRITE_SEQUENCER_43 0x302B | ||
271 | #define WM8915_WRITE_SEQUENCER_44 0x302C | ||
272 | #define WM8915_WRITE_SEQUENCER_45 0x302D | ||
273 | #define WM8915_WRITE_SEQUENCER_46 0x302E | ||
274 | #define WM8915_WRITE_SEQUENCER_47 0x302F | ||
275 | #define WM8915_WRITE_SEQUENCER_48 0x3030 | ||
276 | #define WM8915_WRITE_SEQUENCER_49 0x3031 | ||
277 | #define WM8915_WRITE_SEQUENCER_50 0x3032 | ||
278 | #define WM8915_WRITE_SEQUENCER_51 0x3033 | ||
279 | #define WM8915_WRITE_SEQUENCER_52 0x3034 | ||
280 | #define WM8915_WRITE_SEQUENCER_53 0x3035 | ||
281 | #define WM8915_WRITE_SEQUENCER_54 0x3036 | ||
282 | #define WM8915_WRITE_SEQUENCER_55 0x3037 | ||
283 | #define WM8915_WRITE_SEQUENCER_56 0x3038 | ||
284 | #define WM8915_WRITE_SEQUENCER_57 0x3039 | ||
285 | #define WM8915_WRITE_SEQUENCER_58 0x303A | ||
286 | #define WM8915_WRITE_SEQUENCER_59 0x303B | ||
287 | #define WM8915_WRITE_SEQUENCER_60 0x303C | ||
288 | #define WM8915_WRITE_SEQUENCER_61 0x303D | ||
289 | #define WM8915_WRITE_SEQUENCER_62 0x303E | ||
290 | #define WM8915_WRITE_SEQUENCER_63 0x303F | ||
291 | #define WM8915_WRITE_SEQUENCER_64 0x3040 | ||
292 | #define WM8915_WRITE_SEQUENCER_65 0x3041 | ||
293 | #define WM8915_WRITE_SEQUENCER_66 0x3042 | ||
294 | #define WM8915_WRITE_SEQUENCER_67 0x3043 | ||
295 | #define WM8915_WRITE_SEQUENCER_68 0x3044 | ||
296 | #define WM8915_WRITE_SEQUENCER_69 0x3045 | ||
297 | #define WM8915_WRITE_SEQUENCER_70 0x3046 | ||
298 | #define WM8915_WRITE_SEQUENCER_71 0x3047 | ||
299 | #define WM8915_WRITE_SEQUENCER_72 0x3048 | ||
300 | #define WM8915_WRITE_SEQUENCER_73 0x3049 | ||
301 | #define WM8915_WRITE_SEQUENCER_74 0x304A | ||
302 | #define WM8915_WRITE_SEQUENCER_75 0x304B | ||
303 | #define WM8915_WRITE_SEQUENCER_76 0x304C | ||
304 | #define WM8915_WRITE_SEQUENCER_77 0x304D | ||
305 | #define WM8915_WRITE_SEQUENCER_78 0x304E | ||
306 | #define WM8915_WRITE_SEQUENCER_79 0x304F | ||
307 | #define WM8915_WRITE_SEQUENCER_80 0x3050 | ||
308 | #define WM8915_WRITE_SEQUENCER_81 0x3051 | ||
309 | #define WM8915_WRITE_SEQUENCER_82 0x3052 | ||
310 | #define WM8915_WRITE_SEQUENCER_83 0x3053 | ||
311 | #define WM8915_WRITE_SEQUENCER_84 0x3054 | ||
312 | #define WM8915_WRITE_SEQUENCER_85 0x3055 | ||
313 | #define WM8915_WRITE_SEQUENCER_86 0x3056 | ||
314 | #define WM8915_WRITE_SEQUENCER_87 0x3057 | ||
315 | #define WM8915_WRITE_SEQUENCER_88 0x3058 | ||
316 | #define WM8915_WRITE_SEQUENCER_89 0x3059 | ||
317 | #define WM8915_WRITE_SEQUENCER_90 0x305A | ||
318 | #define WM8915_WRITE_SEQUENCER_91 0x305B | ||
319 | #define WM8915_WRITE_SEQUENCER_92 0x305C | ||
320 | #define WM8915_WRITE_SEQUENCER_93 0x305D | ||
321 | #define WM8915_WRITE_SEQUENCER_94 0x305E | ||
322 | #define WM8915_WRITE_SEQUENCER_95 0x305F | ||
323 | #define WM8915_WRITE_SEQUENCER_96 0x3060 | ||
324 | #define WM8915_WRITE_SEQUENCER_97 0x3061 | ||
325 | #define WM8915_WRITE_SEQUENCER_98 0x3062 | ||
326 | #define WM8915_WRITE_SEQUENCER_99 0x3063 | ||
327 | #define WM8915_WRITE_SEQUENCER_100 0x3064 | ||
328 | #define WM8915_WRITE_SEQUENCER_101 0x3065 | ||
329 | #define WM8915_WRITE_SEQUENCER_102 0x3066 | ||
330 | #define WM8915_WRITE_SEQUENCER_103 0x3067 | ||
331 | #define WM8915_WRITE_SEQUENCER_104 0x3068 | ||
332 | #define WM8915_WRITE_SEQUENCER_105 0x3069 | ||
333 | #define WM8915_WRITE_SEQUENCER_106 0x306A | ||
334 | #define WM8915_WRITE_SEQUENCER_107 0x306B | ||
335 | #define WM8915_WRITE_SEQUENCER_108 0x306C | ||
336 | #define WM8915_WRITE_SEQUENCER_109 0x306D | ||
337 | #define WM8915_WRITE_SEQUENCER_110 0x306E | ||
338 | #define WM8915_WRITE_SEQUENCER_111 0x306F | ||
339 | #define WM8915_WRITE_SEQUENCER_112 0x3070 | ||
340 | #define WM8915_WRITE_SEQUENCER_113 0x3071 | ||
341 | #define WM8915_WRITE_SEQUENCER_114 0x3072 | ||
342 | #define WM8915_WRITE_SEQUENCER_115 0x3073 | ||
343 | #define WM8915_WRITE_SEQUENCER_116 0x3074 | ||
344 | #define WM8915_WRITE_SEQUENCER_117 0x3075 | ||
345 | #define WM8915_WRITE_SEQUENCER_118 0x3076 | ||
346 | #define WM8915_WRITE_SEQUENCER_119 0x3077 | ||
347 | #define WM8915_WRITE_SEQUENCER_120 0x3078 | ||
348 | #define WM8915_WRITE_SEQUENCER_121 0x3079 | ||
349 | #define WM8915_WRITE_SEQUENCER_122 0x307A | ||
350 | #define WM8915_WRITE_SEQUENCER_123 0x307B | ||
351 | #define WM8915_WRITE_SEQUENCER_124 0x307C | ||
352 | #define WM8915_WRITE_SEQUENCER_125 0x307D | ||
353 | #define WM8915_WRITE_SEQUENCER_126 0x307E | ||
354 | #define WM8915_WRITE_SEQUENCER_127 0x307F | ||
355 | #define WM8915_WRITE_SEQUENCER_128 0x3080 | ||
356 | #define WM8915_WRITE_SEQUENCER_129 0x3081 | ||
357 | #define WM8915_WRITE_SEQUENCER_130 0x3082 | ||
358 | #define WM8915_WRITE_SEQUENCER_131 0x3083 | ||
359 | #define WM8915_WRITE_SEQUENCER_132 0x3084 | ||
360 | #define WM8915_WRITE_SEQUENCER_133 0x3085 | ||
361 | #define WM8915_WRITE_SEQUENCER_134 0x3086 | ||
362 | #define WM8915_WRITE_SEQUENCER_135 0x3087 | ||
363 | #define WM8915_WRITE_SEQUENCER_136 0x3088 | ||
364 | #define WM8915_WRITE_SEQUENCER_137 0x3089 | ||
365 | #define WM8915_WRITE_SEQUENCER_138 0x308A | ||
366 | #define WM8915_WRITE_SEQUENCER_139 0x308B | ||
367 | #define WM8915_WRITE_SEQUENCER_140 0x308C | ||
368 | #define WM8915_WRITE_SEQUENCER_141 0x308D | ||
369 | #define WM8915_WRITE_SEQUENCER_142 0x308E | ||
370 | #define WM8915_WRITE_SEQUENCER_143 0x308F | ||
371 | #define WM8915_WRITE_SEQUENCER_144 0x3090 | ||
372 | #define WM8915_WRITE_SEQUENCER_145 0x3091 | ||
373 | #define WM8915_WRITE_SEQUENCER_146 0x3092 | ||
374 | #define WM8915_WRITE_SEQUENCER_147 0x3093 | ||
375 | #define WM8915_WRITE_SEQUENCER_148 0x3094 | ||
376 | #define WM8915_WRITE_SEQUENCER_149 0x3095 | ||
377 | #define WM8915_WRITE_SEQUENCER_150 0x3096 | ||
378 | #define WM8915_WRITE_SEQUENCER_151 0x3097 | ||
379 | #define WM8915_WRITE_SEQUENCER_152 0x3098 | ||
380 | #define WM8915_WRITE_SEQUENCER_153 0x3099 | ||
381 | #define WM8915_WRITE_SEQUENCER_154 0x309A | ||
382 | #define WM8915_WRITE_SEQUENCER_155 0x309B | ||
383 | #define WM8915_WRITE_SEQUENCER_156 0x309C | ||
384 | #define WM8915_WRITE_SEQUENCER_157 0x309D | ||
385 | #define WM8915_WRITE_SEQUENCER_158 0x309E | ||
386 | #define WM8915_WRITE_SEQUENCER_159 0x309F | ||
387 | #define WM8915_WRITE_SEQUENCER_160 0x30A0 | ||
388 | #define WM8915_WRITE_SEQUENCER_161 0x30A1 | ||
389 | #define WM8915_WRITE_SEQUENCER_162 0x30A2 | ||
390 | #define WM8915_WRITE_SEQUENCER_163 0x30A3 | ||
391 | #define WM8915_WRITE_SEQUENCER_164 0x30A4 | ||
392 | #define WM8915_WRITE_SEQUENCER_165 0x30A5 | ||
393 | #define WM8915_WRITE_SEQUENCER_166 0x30A6 | ||
394 | #define WM8915_WRITE_SEQUENCER_167 0x30A7 | ||
395 | #define WM8915_WRITE_SEQUENCER_168 0x30A8 | ||
396 | #define WM8915_WRITE_SEQUENCER_169 0x30A9 | ||
397 | #define WM8915_WRITE_SEQUENCER_170 0x30AA | ||
398 | #define WM8915_WRITE_SEQUENCER_171 0x30AB | ||
399 | #define WM8915_WRITE_SEQUENCER_172 0x30AC | ||
400 | #define WM8915_WRITE_SEQUENCER_173 0x30AD | ||
401 | #define WM8915_WRITE_SEQUENCER_174 0x30AE | ||
402 | #define WM8915_WRITE_SEQUENCER_175 0x30AF | ||
403 | #define WM8915_WRITE_SEQUENCER_176 0x30B0 | ||
404 | #define WM8915_WRITE_SEQUENCER_177 0x30B1 | ||
405 | #define WM8915_WRITE_SEQUENCER_178 0x30B2 | ||
406 | #define WM8915_WRITE_SEQUENCER_179 0x30B3 | ||
407 | #define WM8915_WRITE_SEQUENCER_180 0x30B4 | ||
408 | #define WM8915_WRITE_SEQUENCER_181 0x30B5 | ||
409 | #define WM8915_WRITE_SEQUENCER_182 0x30B6 | ||
410 | #define WM8915_WRITE_SEQUENCER_183 0x30B7 | ||
411 | #define WM8915_WRITE_SEQUENCER_184 0x30B8 | ||
412 | #define WM8915_WRITE_SEQUENCER_185 0x30B9 | ||
413 | #define WM8915_WRITE_SEQUENCER_186 0x30BA | ||
414 | #define WM8915_WRITE_SEQUENCER_187 0x30BB | ||
415 | #define WM8915_WRITE_SEQUENCER_188 0x30BC | ||
416 | #define WM8915_WRITE_SEQUENCER_189 0x30BD | ||
417 | #define WM8915_WRITE_SEQUENCER_190 0x30BE | ||
418 | #define WM8915_WRITE_SEQUENCER_191 0x30BF | ||
419 | #define WM8915_WRITE_SEQUENCER_192 0x30C0 | ||
420 | #define WM8915_WRITE_SEQUENCER_193 0x30C1 | ||
421 | #define WM8915_WRITE_SEQUENCER_194 0x30C2 | ||
422 | #define WM8915_WRITE_SEQUENCER_195 0x30C3 | ||
423 | #define WM8915_WRITE_SEQUENCER_196 0x30C4 | ||
424 | #define WM8915_WRITE_SEQUENCER_197 0x30C5 | ||
425 | #define WM8915_WRITE_SEQUENCER_198 0x30C6 | ||
426 | #define WM8915_WRITE_SEQUENCER_199 0x30C7 | ||
427 | #define WM8915_WRITE_SEQUENCER_200 0x30C8 | ||
428 | #define WM8915_WRITE_SEQUENCER_201 0x30C9 | ||
429 | #define WM8915_WRITE_SEQUENCER_202 0x30CA | ||
430 | #define WM8915_WRITE_SEQUENCER_203 0x30CB | ||
431 | #define WM8915_WRITE_SEQUENCER_204 0x30CC | ||
432 | #define WM8915_WRITE_SEQUENCER_205 0x30CD | ||
433 | #define WM8915_WRITE_SEQUENCER_206 0x30CE | ||
434 | #define WM8915_WRITE_SEQUENCER_207 0x30CF | ||
435 | #define WM8915_WRITE_SEQUENCER_208 0x30D0 | ||
436 | #define WM8915_WRITE_SEQUENCER_209 0x30D1 | ||
437 | #define WM8915_WRITE_SEQUENCER_210 0x30D2 | ||
438 | #define WM8915_WRITE_SEQUENCER_211 0x30D3 | ||
439 | #define WM8915_WRITE_SEQUENCER_212 0x30D4 | ||
440 | #define WM8915_WRITE_SEQUENCER_213 0x30D5 | ||
441 | #define WM8915_WRITE_SEQUENCER_214 0x30D6 | ||
442 | #define WM8915_WRITE_SEQUENCER_215 0x30D7 | ||
443 | #define WM8915_WRITE_SEQUENCER_216 0x30D8 | ||
444 | #define WM8915_WRITE_SEQUENCER_217 0x30D9 | ||
445 | #define WM8915_WRITE_SEQUENCER_218 0x30DA | ||
446 | #define WM8915_WRITE_SEQUENCER_219 0x30DB | ||
447 | #define WM8915_WRITE_SEQUENCER_220 0x30DC | ||
448 | #define WM8915_WRITE_SEQUENCER_221 0x30DD | ||
449 | #define WM8915_WRITE_SEQUENCER_222 0x30DE | ||
450 | #define WM8915_WRITE_SEQUENCER_223 0x30DF | ||
451 | #define WM8915_WRITE_SEQUENCER_224 0x30E0 | ||
452 | #define WM8915_WRITE_SEQUENCER_225 0x30E1 | ||
453 | #define WM8915_WRITE_SEQUENCER_226 0x30E2 | ||
454 | #define WM8915_WRITE_SEQUENCER_227 0x30E3 | ||
455 | #define WM8915_WRITE_SEQUENCER_228 0x30E4 | ||
456 | #define WM8915_WRITE_SEQUENCER_229 0x30E5 | ||
457 | #define WM8915_WRITE_SEQUENCER_230 0x30E6 | ||
458 | #define WM8915_WRITE_SEQUENCER_231 0x30E7 | ||
459 | #define WM8915_WRITE_SEQUENCER_232 0x30E8 | ||
460 | #define WM8915_WRITE_SEQUENCER_233 0x30E9 | ||
461 | #define WM8915_WRITE_SEQUENCER_234 0x30EA | ||
462 | #define WM8915_WRITE_SEQUENCER_235 0x30EB | ||
463 | #define WM8915_WRITE_SEQUENCER_236 0x30EC | ||
464 | #define WM8915_WRITE_SEQUENCER_237 0x30ED | ||
465 | #define WM8915_WRITE_SEQUENCER_238 0x30EE | ||
466 | #define WM8915_WRITE_SEQUENCER_239 0x30EF | ||
467 | #define WM8915_WRITE_SEQUENCER_240 0x30F0 | ||
468 | #define WM8915_WRITE_SEQUENCER_241 0x30F1 | ||
469 | #define WM8915_WRITE_SEQUENCER_242 0x30F2 | ||
470 | #define WM8915_WRITE_SEQUENCER_243 0x30F3 | ||
471 | #define WM8915_WRITE_SEQUENCER_244 0x30F4 | ||
472 | #define WM8915_WRITE_SEQUENCER_245 0x30F5 | ||
473 | #define WM8915_WRITE_SEQUENCER_246 0x30F6 | ||
474 | #define WM8915_WRITE_SEQUENCER_247 0x30F7 | ||
475 | #define WM8915_WRITE_SEQUENCER_248 0x30F8 | ||
476 | #define WM8915_WRITE_SEQUENCER_249 0x30F9 | ||
477 | #define WM8915_WRITE_SEQUENCER_250 0x30FA | ||
478 | #define WM8915_WRITE_SEQUENCER_251 0x30FB | ||
479 | #define WM8915_WRITE_SEQUENCER_252 0x30FC | ||
480 | #define WM8915_WRITE_SEQUENCER_253 0x30FD | ||
481 | #define WM8915_WRITE_SEQUENCER_254 0x30FE | ||
482 | #define WM8915_WRITE_SEQUENCER_255 0x30FF | ||
483 | #define WM8915_WRITE_SEQUENCER_256 0x3100 | ||
484 | #define WM8915_WRITE_SEQUENCER_257 0x3101 | ||
485 | #define WM8915_WRITE_SEQUENCER_258 0x3102 | ||
486 | #define WM8915_WRITE_SEQUENCER_259 0x3103 | ||
487 | #define WM8915_WRITE_SEQUENCER_260 0x3104 | ||
488 | #define WM8915_WRITE_SEQUENCER_261 0x3105 | ||
489 | #define WM8915_WRITE_SEQUENCER_262 0x3106 | ||
490 | #define WM8915_WRITE_SEQUENCER_263 0x3107 | ||
491 | #define WM8915_WRITE_SEQUENCER_264 0x3108 | ||
492 | #define WM8915_WRITE_SEQUENCER_265 0x3109 | ||
493 | #define WM8915_WRITE_SEQUENCER_266 0x310A | ||
494 | #define WM8915_WRITE_SEQUENCER_267 0x310B | ||
495 | #define WM8915_WRITE_SEQUENCER_268 0x310C | ||
496 | #define WM8915_WRITE_SEQUENCER_269 0x310D | ||
497 | #define WM8915_WRITE_SEQUENCER_270 0x310E | ||
498 | #define WM8915_WRITE_SEQUENCER_271 0x310F | ||
499 | #define WM8915_WRITE_SEQUENCER_272 0x3110 | ||
500 | #define WM8915_WRITE_SEQUENCER_273 0x3111 | ||
501 | #define WM8915_WRITE_SEQUENCER_274 0x3112 | ||
502 | #define WM8915_WRITE_SEQUENCER_275 0x3113 | ||
503 | #define WM8915_WRITE_SEQUENCER_276 0x3114 | ||
504 | #define WM8915_WRITE_SEQUENCER_277 0x3115 | ||
505 | #define WM8915_WRITE_SEQUENCER_278 0x3116 | ||
506 | #define WM8915_WRITE_SEQUENCER_279 0x3117 | ||
507 | #define WM8915_WRITE_SEQUENCER_280 0x3118 | ||
508 | #define WM8915_WRITE_SEQUENCER_281 0x3119 | ||
509 | #define WM8915_WRITE_SEQUENCER_282 0x311A | ||
510 | #define WM8915_WRITE_SEQUENCER_283 0x311B | ||
511 | #define WM8915_WRITE_SEQUENCER_284 0x311C | ||
512 | #define WM8915_WRITE_SEQUENCER_285 0x311D | ||
513 | #define WM8915_WRITE_SEQUENCER_286 0x311E | ||
514 | #define WM8915_WRITE_SEQUENCER_287 0x311F | ||
515 | #define WM8915_WRITE_SEQUENCER_288 0x3120 | ||
516 | #define WM8915_WRITE_SEQUENCER_289 0x3121 | ||
517 | #define WM8915_WRITE_SEQUENCER_290 0x3122 | ||
518 | #define WM8915_WRITE_SEQUENCER_291 0x3123 | ||
519 | #define WM8915_WRITE_SEQUENCER_292 0x3124 | ||
520 | #define WM8915_WRITE_SEQUENCER_293 0x3125 | ||
521 | #define WM8915_WRITE_SEQUENCER_294 0x3126 | ||
522 | #define WM8915_WRITE_SEQUENCER_295 0x3127 | ||
523 | #define WM8915_WRITE_SEQUENCER_296 0x3128 | ||
524 | #define WM8915_WRITE_SEQUENCER_297 0x3129 | ||
525 | #define WM8915_WRITE_SEQUENCER_298 0x312A | ||
526 | #define WM8915_WRITE_SEQUENCER_299 0x312B | ||
527 | #define WM8915_WRITE_SEQUENCER_300 0x312C | ||
528 | #define WM8915_WRITE_SEQUENCER_301 0x312D | ||
529 | #define WM8915_WRITE_SEQUENCER_302 0x312E | ||
530 | #define WM8915_WRITE_SEQUENCER_303 0x312F | ||
531 | #define WM8915_WRITE_SEQUENCER_304 0x3130 | ||
532 | #define WM8915_WRITE_SEQUENCER_305 0x3131 | ||
533 | #define WM8915_WRITE_SEQUENCER_306 0x3132 | ||
534 | #define WM8915_WRITE_SEQUENCER_307 0x3133 | ||
535 | #define WM8915_WRITE_SEQUENCER_308 0x3134 | ||
536 | #define WM8915_WRITE_SEQUENCER_309 0x3135 | ||
537 | #define WM8915_WRITE_SEQUENCER_310 0x3136 | ||
538 | #define WM8915_WRITE_SEQUENCER_311 0x3137 | ||
539 | #define WM8915_WRITE_SEQUENCER_312 0x3138 | ||
540 | #define WM8915_WRITE_SEQUENCER_313 0x3139 | ||
541 | #define WM8915_WRITE_SEQUENCER_314 0x313A | ||
542 | #define WM8915_WRITE_SEQUENCER_315 0x313B | ||
543 | #define WM8915_WRITE_SEQUENCER_316 0x313C | ||
544 | #define WM8915_WRITE_SEQUENCER_317 0x313D | ||
545 | #define WM8915_WRITE_SEQUENCER_318 0x313E | ||
546 | #define WM8915_WRITE_SEQUENCER_319 0x313F | ||
547 | #define WM8915_WRITE_SEQUENCER_320 0x3140 | ||
548 | #define WM8915_WRITE_SEQUENCER_321 0x3141 | ||
549 | #define WM8915_WRITE_SEQUENCER_322 0x3142 | ||
550 | #define WM8915_WRITE_SEQUENCER_323 0x3143 | ||
551 | #define WM8915_WRITE_SEQUENCER_324 0x3144 | ||
552 | #define WM8915_WRITE_SEQUENCER_325 0x3145 | ||
553 | #define WM8915_WRITE_SEQUENCER_326 0x3146 | ||
554 | #define WM8915_WRITE_SEQUENCER_327 0x3147 | ||
555 | #define WM8915_WRITE_SEQUENCER_328 0x3148 | ||
556 | #define WM8915_WRITE_SEQUENCER_329 0x3149 | ||
557 | #define WM8915_WRITE_SEQUENCER_330 0x314A | ||
558 | #define WM8915_WRITE_SEQUENCER_331 0x314B | ||
559 | #define WM8915_WRITE_SEQUENCER_332 0x314C | ||
560 | #define WM8915_WRITE_SEQUENCER_333 0x314D | ||
561 | #define WM8915_WRITE_SEQUENCER_334 0x314E | ||
562 | #define WM8915_WRITE_SEQUENCER_335 0x314F | ||
563 | #define WM8915_WRITE_SEQUENCER_336 0x3150 | ||
564 | #define WM8915_WRITE_SEQUENCER_337 0x3151 | ||
565 | #define WM8915_WRITE_SEQUENCER_338 0x3152 | ||
566 | #define WM8915_WRITE_SEQUENCER_339 0x3153 | ||
567 | #define WM8915_WRITE_SEQUENCER_340 0x3154 | ||
568 | #define WM8915_WRITE_SEQUENCER_341 0x3155 | ||
569 | #define WM8915_WRITE_SEQUENCER_342 0x3156 | ||
570 | #define WM8915_WRITE_SEQUENCER_343 0x3157 | ||
571 | #define WM8915_WRITE_SEQUENCER_344 0x3158 | ||
572 | #define WM8915_WRITE_SEQUENCER_345 0x3159 | ||
573 | #define WM8915_WRITE_SEQUENCER_346 0x315A | ||
574 | #define WM8915_WRITE_SEQUENCER_347 0x315B | ||
575 | #define WM8915_WRITE_SEQUENCER_348 0x315C | ||
576 | #define WM8915_WRITE_SEQUENCER_349 0x315D | ||
577 | #define WM8915_WRITE_SEQUENCER_350 0x315E | ||
578 | #define WM8915_WRITE_SEQUENCER_351 0x315F | ||
579 | #define WM8915_WRITE_SEQUENCER_352 0x3160 | ||
580 | #define WM8915_WRITE_SEQUENCER_353 0x3161 | ||
581 | #define WM8915_WRITE_SEQUENCER_354 0x3162 | ||
582 | #define WM8915_WRITE_SEQUENCER_355 0x3163 | ||
583 | #define WM8915_WRITE_SEQUENCER_356 0x3164 | ||
584 | #define WM8915_WRITE_SEQUENCER_357 0x3165 | ||
585 | #define WM8915_WRITE_SEQUENCER_358 0x3166 | ||
586 | #define WM8915_WRITE_SEQUENCER_359 0x3167 | ||
587 | #define WM8915_WRITE_SEQUENCER_360 0x3168 | ||
588 | #define WM8915_WRITE_SEQUENCER_361 0x3169 | ||
589 | #define WM8915_WRITE_SEQUENCER_362 0x316A | ||
590 | #define WM8915_WRITE_SEQUENCER_363 0x316B | ||
591 | #define WM8915_WRITE_SEQUENCER_364 0x316C | ||
592 | #define WM8915_WRITE_SEQUENCER_365 0x316D | ||
593 | #define WM8915_WRITE_SEQUENCER_366 0x316E | ||
594 | #define WM8915_WRITE_SEQUENCER_367 0x316F | ||
595 | #define WM8915_WRITE_SEQUENCER_368 0x3170 | ||
596 | #define WM8915_WRITE_SEQUENCER_369 0x3171 | ||
597 | #define WM8915_WRITE_SEQUENCER_370 0x3172 | ||
598 | #define WM8915_WRITE_SEQUENCER_371 0x3173 | ||
599 | #define WM8915_WRITE_SEQUENCER_372 0x3174 | ||
600 | #define WM8915_WRITE_SEQUENCER_373 0x3175 | ||
601 | #define WM8915_WRITE_SEQUENCER_374 0x3176 | ||
602 | #define WM8915_WRITE_SEQUENCER_375 0x3177 | ||
603 | #define WM8915_WRITE_SEQUENCER_376 0x3178 | ||
604 | #define WM8915_WRITE_SEQUENCER_377 0x3179 | ||
605 | #define WM8915_WRITE_SEQUENCER_378 0x317A | ||
606 | #define WM8915_WRITE_SEQUENCER_379 0x317B | ||
607 | #define WM8915_WRITE_SEQUENCER_380 0x317C | ||
608 | #define WM8915_WRITE_SEQUENCER_381 0x317D | ||
609 | #define WM8915_WRITE_SEQUENCER_382 0x317E | ||
610 | #define WM8915_WRITE_SEQUENCER_383 0x317F | ||
611 | #define WM8915_WRITE_SEQUENCER_384 0x3180 | ||
612 | #define WM8915_WRITE_SEQUENCER_385 0x3181 | ||
613 | #define WM8915_WRITE_SEQUENCER_386 0x3182 | ||
614 | #define WM8915_WRITE_SEQUENCER_387 0x3183 | ||
615 | #define WM8915_WRITE_SEQUENCER_388 0x3184 | ||
616 | #define WM8915_WRITE_SEQUENCER_389 0x3185 | ||
617 | #define WM8915_WRITE_SEQUENCER_390 0x3186 | ||
618 | #define WM8915_WRITE_SEQUENCER_391 0x3187 | ||
619 | #define WM8915_WRITE_SEQUENCER_392 0x3188 | ||
620 | #define WM8915_WRITE_SEQUENCER_393 0x3189 | ||
621 | #define WM8915_WRITE_SEQUENCER_394 0x318A | ||
622 | #define WM8915_WRITE_SEQUENCER_395 0x318B | ||
623 | #define WM8915_WRITE_SEQUENCER_396 0x318C | ||
624 | #define WM8915_WRITE_SEQUENCER_397 0x318D | ||
625 | #define WM8915_WRITE_SEQUENCER_398 0x318E | ||
626 | #define WM8915_WRITE_SEQUENCER_399 0x318F | ||
627 | #define WM8915_WRITE_SEQUENCER_400 0x3190 | ||
628 | #define WM8915_WRITE_SEQUENCER_401 0x3191 | ||
629 | #define WM8915_WRITE_SEQUENCER_402 0x3192 | ||
630 | #define WM8915_WRITE_SEQUENCER_403 0x3193 | ||
631 | #define WM8915_WRITE_SEQUENCER_404 0x3194 | ||
632 | #define WM8915_WRITE_SEQUENCER_405 0x3195 | ||
633 | #define WM8915_WRITE_SEQUENCER_406 0x3196 | ||
634 | #define WM8915_WRITE_SEQUENCER_407 0x3197 | ||
635 | #define WM8915_WRITE_SEQUENCER_408 0x3198 | ||
636 | #define WM8915_WRITE_SEQUENCER_409 0x3199 | ||
637 | #define WM8915_WRITE_SEQUENCER_410 0x319A | ||
638 | #define WM8915_WRITE_SEQUENCER_411 0x319B | ||
639 | #define WM8915_WRITE_SEQUENCER_412 0x319C | ||
640 | #define WM8915_WRITE_SEQUENCER_413 0x319D | ||
641 | #define WM8915_WRITE_SEQUENCER_414 0x319E | ||
642 | #define WM8915_WRITE_SEQUENCER_415 0x319F | ||
643 | #define WM8915_WRITE_SEQUENCER_416 0x31A0 | ||
644 | #define WM8915_WRITE_SEQUENCER_417 0x31A1 | ||
645 | #define WM8915_WRITE_SEQUENCER_418 0x31A2 | ||
646 | #define WM8915_WRITE_SEQUENCER_419 0x31A3 | ||
647 | #define WM8915_WRITE_SEQUENCER_420 0x31A4 | ||
648 | #define WM8915_WRITE_SEQUENCER_421 0x31A5 | ||
649 | #define WM8915_WRITE_SEQUENCER_422 0x31A6 | ||
650 | #define WM8915_WRITE_SEQUENCER_423 0x31A7 | ||
651 | #define WM8915_WRITE_SEQUENCER_424 0x31A8 | ||
652 | #define WM8915_WRITE_SEQUENCER_425 0x31A9 | ||
653 | #define WM8915_WRITE_SEQUENCER_426 0x31AA | ||
654 | #define WM8915_WRITE_SEQUENCER_427 0x31AB | ||
655 | #define WM8915_WRITE_SEQUENCER_428 0x31AC | ||
656 | #define WM8915_WRITE_SEQUENCER_429 0x31AD | ||
657 | #define WM8915_WRITE_SEQUENCER_430 0x31AE | ||
658 | #define WM8915_WRITE_SEQUENCER_431 0x31AF | ||
659 | #define WM8915_WRITE_SEQUENCER_432 0x31B0 | ||
660 | #define WM8915_WRITE_SEQUENCER_433 0x31B1 | ||
661 | #define WM8915_WRITE_SEQUENCER_434 0x31B2 | ||
662 | #define WM8915_WRITE_SEQUENCER_435 0x31B3 | ||
663 | #define WM8915_WRITE_SEQUENCER_436 0x31B4 | ||
664 | #define WM8915_WRITE_SEQUENCER_437 0x31B5 | ||
665 | #define WM8915_WRITE_SEQUENCER_438 0x31B6 | ||
666 | #define WM8915_WRITE_SEQUENCER_439 0x31B7 | ||
667 | #define WM8915_WRITE_SEQUENCER_440 0x31B8 | ||
668 | #define WM8915_WRITE_SEQUENCER_441 0x31B9 | ||
669 | #define WM8915_WRITE_SEQUENCER_442 0x31BA | ||
670 | #define WM8915_WRITE_SEQUENCER_443 0x31BB | ||
671 | #define WM8915_WRITE_SEQUENCER_444 0x31BC | ||
672 | #define WM8915_WRITE_SEQUENCER_445 0x31BD | ||
673 | #define WM8915_WRITE_SEQUENCER_446 0x31BE | ||
674 | #define WM8915_WRITE_SEQUENCER_447 0x31BF | ||
675 | #define WM8915_WRITE_SEQUENCER_448 0x31C0 | ||
676 | #define WM8915_WRITE_SEQUENCER_449 0x31C1 | ||
677 | #define WM8915_WRITE_SEQUENCER_450 0x31C2 | ||
678 | #define WM8915_WRITE_SEQUENCER_451 0x31C3 | ||
679 | #define WM8915_WRITE_SEQUENCER_452 0x31C4 | ||
680 | #define WM8915_WRITE_SEQUENCER_453 0x31C5 | ||
681 | #define WM8915_WRITE_SEQUENCER_454 0x31C6 | ||
682 | #define WM8915_WRITE_SEQUENCER_455 0x31C7 | ||
683 | #define WM8915_WRITE_SEQUENCER_456 0x31C8 | ||
684 | #define WM8915_WRITE_SEQUENCER_457 0x31C9 | ||
685 | #define WM8915_WRITE_SEQUENCER_458 0x31CA | ||
686 | #define WM8915_WRITE_SEQUENCER_459 0x31CB | ||
687 | #define WM8915_WRITE_SEQUENCER_460 0x31CC | ||
688 | #define WM8915_WRITE_SEQUENCER_461 0x31CD | ||
689 | #define WM8915_WRITE_SEQUENCER_462 0x31CE | ||
690 | #define WM8915_WRITE_SEQUENCER_463 0x31CF | ||
691 | #define WM8915_WRITE_SEQUENCER_464 0x31D0 | ||
692 | #define WM8915_WRITE_SEQUENCER_465 0x31D1 | ||
693 | #define WM8915_WRITE_SEQUENCER_466 0x31D2 | ||
694 | #define WM8915_WRITE_SEQUENCER_467 0x31D3 | ||
695 | #define WM8915_WRITE_SEQUENCER_468 0x31D4 | ||
696 | #define WM8915_WRITE_SEQUENCER_469 0x31D5 | ||
697 | #define WM8915_WRITE_SEQUENCER_470 0x31D6 | ||
698 | #define WM8915_WRITE_SEQUENCER_471 0x31D7 | ||
699 | #define WM8915_WRITE_SEQUENCER_472 0x31D8 | ||
700 | #define WM8915_WRITE_SEQUENCER_473 0x31D9 | ||
701 | #define WM8915_WRITE_SEQUENCER_474 0x31DA | ||
702 | #define WM8915_WRITE_SEQUENCER_475 0x31DB | ||
703 | #define WM8915_WRITE_SEQUENCER_476 0x31DC | ||
704 | #define WM8915_WRITE_SEQUENCER_477 0x31DD | ||
705 | #define WM8915_WRITE_SEQUENCER_478 0x31DE | ||
706 | #define WM8915_WRITE_SEQUENCER_479 0x31DF | ||
707 | #define WM8915_WRITE_SEQUENCER_480 0x31E0 | ||
708 | #define WM8915_WRITE_SEQUENCER_481 0x31E1 | ||
709 | #define WM8915_WRITE_SEQUENCER_482 0x31E2 | ||
710 | #define WM8915_WRITE_SEQUENCER_483 0x31E3 | ||
711 | #define WM8915_WRITE_SEQUENCER_484 0x31E4 | ||
712 | #define WM8915_WRITE_SEQUENCER_485 0x31E5 | ||
713 | #define WM8915_WRITE_SEQUENCER_486 0x31E6 | ||
714 | #define WM8915_WRITE_SEQUENCER_487 0x31E7 | ||
715 | #define WM8915_WRITE_SEQUENCER_488 0x31E8 | ||
716 | #define WM8915_WRITE_SEQUENCER_489 0x31E9 | ||
717 | #define WM8915_WRITE_SEQUENCER_490 0x31EA | ||
718 | #define WM8915_WRITE_SEQUENCER_491 0x31EB | ||
719 | #define WM8915_WRITE_SEQUENCER_492 0x31EC | ||
720 | #define WM8915_WRITE_SEQUENCER_493 0x31ED | ||
721 | #define WM8915_WRITE_SEQUENCER_494 0x31EE | ||
722 | #define WM8915_WRITE_SEQUENCER_495 0x31EF | ||
723 | #define WM8915_WRITE_SEQUENCER_496 0x31F0 | ||
724 | #define WM8915_WRITE_SEQUENCER_497 0x31F1 | ||
725 | #define WM8915_WRITE_SEQUENCER_498 0x31F2 | ||
726 | #define WM8915_WRITE_SEQUENCER_499 0x31F3 | ||
727 | #define WM8915_WRITE_SEQUENCER_500 0x31F4 | ||
728 | #define WM8915_WRITE_SEQUENCER_501 0x31F5 | ||
729 | #define WM8915_WRITE_SEQUENCER_502 0x31F6 | ||
730 | #define WM8915_WRITE_SEQUENCER_503 0x31F7 | ||
731 | #define WM8915_WRITE_SEQUENCER_504 0x31F8 | ||
732 | #define WM8915_WRITE_SEQUENCER_505 0x31F9 | ||
733 | #define WM8915_WRITE_SEQUENCER_506 0x31FA | ||
734 | #define WM8915_WRITE_SEQUENCER_507 0x31FB | ||
735 | #define WM8915_WRITE_SEQUENCER_508 0x31FC | ||
736 | #define WM8915_WRITE_SEQUENCER_509 0x31FD | ||
737 | #define WM8915_WRITE_SEQUENCER_510 0x31FE | ||
738 | #define WM8915_WRITE_SEQUENCER_511 0x31FF | ||
739 | |||
740 | #define WM8915_REGISTER_COUNT 706 | ||
741 | #define WM8915_MAX_REGISTER 0x31FF | ||
742 | |||
743 | /* | ||
744 | * Field Definitions. | ||
745 | */ | ||
746 | |||
747 | /* | ||
748 | * R0 (0x00) - Software Reset | ||
749 | */ | ||
750 | #define WM8915_SW_RESET_MASK 0xFFFF /* SW_RESET - [15:0] */ | ||
751 | #define WM8915_SW_RESET_SHIFT 0 /* SW_RESET - [15:0] */ | ||
752 | #define WM8915_SW_RESET_WIDTH 16 /* SW_RESET - [15:0] */ | ||
753 | |||
754 | /* | ||
755 | * R1 (0x01) - Power Management (1) | ||
756 | */ | ||
757 | #define WM8915_MICB2_ENA 0x0200 /* MICB2_ENA */ | ||
758 | #define WM8915_MICB2_ENA_MASK 0x0200 /* MICB2_ENA */ | ||
759 | #define WM8915_MICB2_ENA_SHIFT 9 /* MICB2_ENA */ | ||
760 | #define WM8915_MICB2_ENA_WIDTH 1 /* MICB2_ENA */ | ||
761 | #define WM8915_MICB1_ENA 0x0100 /* MICB1_ENA */ | ||
762 | #define WM8915_MICB1_ENA_MASK 0x0100 /* MICB1_ENA */ | ||
763 | #define WM8915_MICB1_ENA_SHIFT 8 /* MICB1_ENA */ | ||
764 | #define WM8915_MICB1_ENA_WIDTH 1 /* MICB1_ENA */ | ||
765 | #define WM8915_HPOUT2L_ENA 0x0080 /* HPOUT2L_ENA */ | ||
766 | #define WM8915_HPOUT2L_ENA_MASK 0x0080 /* HPOUT2L_ENA */ | ||
767 | #define WM8915_HPOUT2L_ENA_SHIFT 7 /* HPOUT2L_ENA */ | ||
768 | #define WM8915_HPOUT2L_ENA_WIDTH 1 /* HPOUT2L_ENA */ | ||
769 | #define WM8915_HPOUT2R_ENA 0x0040 /* HPOUT2R_ENA */ | ||
770 | #define WM8915_HPOUT2R_ENA_MASK 0x0040 /* HPOUT2R_ENA */ | ||
771 | #define WM8915_HPOUT2R_ENA_SHIFT 6 /* HPOUT2R_ENA */ | ||
772 | #define WM8915_HPOUT2R_ENA_WIDTH 1 /* HPOUT2R_ENA */ | ||
773 | #define WM8915_HPOUT1L_ENA 0x0020 /* HPOUT1L_ENA */ | ||
774 | #define WM8915_HPOUT1L_ENA_MASK 0x0020 /* HPOUT1L_ENA */ | ||
775 | #define WM8915_HPOUT1L_ENA_SHIFT 5 /* HPOUT1L_ENA */ | ||
776 | #define WM8915_HPOUT1L_ENA_WIDTH 1 /* HPOUT1L_ENA */ | ||
777 | #define WM8915_HPOUT1R_ENA 0x0010 /* HPOUT1R_ENA */ | ||
778 | #define WM8915_HPOUT1R_ENA_MASK 0x0010 /* HPOUT1R_ENA */ | ||
779 | #define WM8915_HPOUT1R_ENA_SHIFT 4 /* HPOUT1R_ENA */ | ||
780 | #define WM8915_HPOUT1R_ENA_WIDTH 1 /* HPOUT1R_ENA */ | ||
781 | #define WM8915_BG_ENA 0x0001 /* BG_ENA */ | ||
782 | #define WM8915_BG_ENA_MASK 0x0001 /* BG_ENA */ | ||
783 | #define WM8915_BG_ENA_SHIFT 0 /* BG_ENA */ | ||
784 | #define WM8915_BG_ENA_WIDTH 1 /* BG_ENA */ | ||
785 | |||
786 | /* | ||
787 | * R2 (0x02) - Power Management (2) | ||
788 | */ | ||
789 | #define WM8915_OPCLK_ENA 0x0800 /* OPCLK_ENA */ | ||
790 | #define WM8915_OPCLK_ENA_MASK 0x0800 /* OPCLK_ENA */ | ||
791 | #define WM8915_OPCLK_ENA_SHIFT 11 /* OPCLK_ENA */ | ||
792 | #define WM8915_OPCLK_ENA_WIDTH 1 /* OPCLK_ENA */ | ||
793 | #define WM8915_INL_ENA 0x0020 /* INL_ENA */ | ||
794 | #define WM8915_INL_ENA_MASK 0x0020 /* INL_ENA */ | ||
795 | #define WM8915_INL_ENA_SHIFT 5 /* INL_ENA */ | ||
796 | #define WM8915_INL_ENA_WIDTH 1 /* INL_ENA */ | ||
797 | #define WM8915_INR_ENA 0x0010 /* INR_ENA */ | ||
798 | #define WM8915_INR_ENA_MASK 0x0010 /* INR_ENA */ | ||
799 | #define WM8915_INR_ENA_SHIFT 4 /* INR_ENA */ | ||
800 | #define WM8915_INR_ENA_WIDTH 1 /* INR_ENA */ | ||
801 | #define WM8915_LDO2_ENA 0x0002 /* LDO2_ENA */ | ||
802 | #define WM8915_LDO2_ENA_MASK 0x0002 /* LDO2_ENA */ | ||
803 | #define WM8915_LDO2_ENA_SHIFT 1 /* LDO2_ENA */ | ||
804 | #define WM8915_LDO2_ENA_WIDTH 1 /* LDO2_ENA */ | ||
805 | |||
806 | /* | ||
807 | * R3 (0x03) - Power Management (3) | ||
808 | */ | ||
809 | #define WM8915_DSP2RXL_ENA 0x0800 /* DSP2RXL_ENA */ | ||
810 | #define WM8915_DSP2RXL_ENA_MASK 0x0800 /* DSP2RXL_ENA */ | ||
811 | #define WM8915_DSP2RXL_ENA_SHIFT 11 /* DSP2RXL_ENA */ | ||
812 | #define WM8915_DSP2RXL_ENA_WIDTH 1 /* DSP2RXL_ENA */ | ||
813 | #define WM8915_DSP2RXR_ENA 0x0400 /* DSP2RXR_ENA */ | ||
814 | #define WM8915_DSP2RXR_ENA_MASK 0x0400 /* DSP2RXR_ENA */ | ||
815 | #define WM8915_DSP2RXR_ENA_SHIFT 10 /* DSP2RXR_ENA */ | ||
816 | #define WM8915_DSP2RXR_ENA_WIDTH 1 /* DSP2RXR_ENA */ | ||
817 | #define WM8915_DSP1RXL_ENA 0x0200 /* DSP1RXL_ENA */ | ||
818 | #define WM8915_DSP1RXL_ENA_MASK 0x0200 /* DSP1RXL_ENA */ | ||
819 | #define WM8915_DSP1RXL_ENA_SHIFT 9 /* DSP1RXL_ENA */ | ||
820 | #define WM8915_DSP1RXL_ENA_WIDTH 1 /* DSP1RXL_ENA */ | ||
821 | #define WM8915_DSP1RXR_ENA 0x0100 /* DSP1RXR_ENA */ | ||
822 | #define WM8915_DSP1RXR_ENA_MASK 0x0100 /* DSP1RXR_ENA */ | ||
823 | #define WM8915_DSP1RXR_ENA_SHIFT 8 /* DSP1RXR_ENA */ | ||
824 | #define WM8915_DSP1RXR_ENA_WIDTH 1 /* DSP1RXR_ENA */ | ||
825 | #define WM8915_DMIC2L_ENA 0x0020 /* DMIC2L_ENA */ | ||
826 | #define WM8915_DMIC2L_ENA_MASK 0x0020 /* DMIC2L_ENA */ | ||
827 | #define WM8915_DMIC2L_ENA_SHIFT 5 /* DMIC2L_ENA */ | ||
828 | #define WM8915_DMIC2L_ENA_WIDTH 1 /* DMIC2L_ENA */ | ||
829 | #define WM8915_DMIC2R_ENA 0x0010 /* DMIC2R_ENA */ | ||
830 | #define WM8915_DMIC2R_ENA_MASK 0x0010 /* DMIC2R_ENA */ | ||
831 | #define WM8915_DMIC2R_ENA_SHIFT 4 /* DMIC2R_ENA */ | ||
832 | #define WM8915_DMIC2R_ENA_WIDTH 1 /* DMIC2R_ENA */ | ||
833 | #define WM8915_DMIC1L_ENA 0x0008 /* DMIC1L_ENA */ | ||
834 | #define WM8915_DMIC1L_ENA_MASK 0x0008 /* DMIC1L_ENA */ | ||
835 | #define WM8915_DMIC1L_ENA_SHIFT 3 /* DMIC1L_ENA */ | ||
836 | #define WM8915_DMIC1L_ENA_WIDTH 1 /* DMIC1L_ENA */ | ||
837 | #define WM8915_DMIC1R_ENA 0x0004 /* DMIC1R_ENA */ | ||
838 | #define WM8915_DMIC1R_ENA_MASK 0x0004 /* DMIC1R_ENA */ | ||
839 | #define WM8915_DMIC1R_ENA_SHIFT 2 /* DMIC1R_ENA */ | ||
840 | #define WM8915_DMIC1R_ENA_WIDTH 1 /* DMIC1R_ENA */ | ||
841 | #define WM8915_ADCL_ENA 0x0002 /* ADCL_ENA */ | ||
842 | #define WM8915_ADCL_ENA_MASK 0x0002 /* ADCL_ENA */ | ||
843 | #define WM8915_ADCL_ENA_SHIFT 1 /* ADCL_ENA */ | ||
844 | #define WM8915_ADCL_ENA_WIDTH 1 /* ADCL_ENA */ | ||
845 | #define WM8915_ADCR_ENA 0x0001 /* ADCR_ENA */ | ||
846 | #define WM8915_ADCR_ENA_MASK 0x0001 /* ADCR_ENA */ | ||
847 | #define WM8915_ADCR_ENA_SHIFT 0 /* ADCR_ENA */ | ||
848 | #define WM8915_ADCR_ENA_WIDTH 1 /* ADCR_ENA */ | ||
849 | |||
850 | /* | ||
851 | * R4 (0x04) - Power Management (4) | ||
852 | */ | ||
853 | #define WM8915_AIF2RX_CHAN1_ENA 0x0200 /* AIF2RX_CHAN1_ENA */ | ||
854 | #define WM8915_AIF2RX_CHAN1_ENA_MASK 0x0200 /* AIF2RX_CHAN1_ENA */ | ||
855 | #define WM8915_AIF2RX_CHAN1_ENA_SHIFT 9 /* AIF2RX_CHAN1_ENA */ | ||
856 | #define WM8915_AIF2RX_CHAN1_ENA_WIDTH 1 /* AIF2RX_CHAN1_ENA */ | ||
857 | #define WM8915_AIF2RX_CHAN0_ENA 0x0100 /* AIF2RX_CHAN0_ENA */ | ||
858 | #define WM8915_AIF2RX_CHAN0_ENA_MASK 0x0100 /* AIF2RX_CHAN0_ENA */ | ||
859 | #define WM8915_AIF2RX_CHAN0_ENA_SHIFT 8 /* AIF2RX_CHAN0_ENA */ | ||
860 | #define WM8915_AIF2RX_CHAN0_ENA_WIDTH 1 /* AIF2RX_CHAN0_ENA */ | ||
861 | #define WM8915_AIF1RX_CHAN5_ENA 0x0020 /* AIF1RX_CHAN5_ENA */ | ||
862 | #define WM8915_AIF1RX_CHAN5_ENA_MASK 0x0020 /* AIF1RX_CHAN5_ENA */ | ||
863 | #define WM8915_AIF1RX_CHAN5_ENA_SHIFT 5 /* AIF1RX_CHAN5_ENA */ | ||
864 | #define WM8915_AIF1RX_CHAN5_ENA_WIDTH 1 /* AIF1RX_CHAN5_ENA */ | ||
865 | #define WM8915_AIF1RX_CHAN4_ENA 0x0010 /* AIF1RX_CHAN4_ENA */ | ||
866 | #define WM8915_AIF1RX_CHAN4_ENA_MASK 0x0010 /* AIF1RX_CHAN4_ENA */ | ||
867 | #define WM8915_AIF1RX_CHAN4_ENA_SHIFT 4 /* AIF1RX_CHAN4_ENA */ | ||
868 | #define WM8915_AIF1RX_CHAN4_ENA_WIDTH 1 /* AIF1RX_CHAN4_ENA */ | ||
869 | #define WM8915_AIF1RX_CHAN3_ENA 0x0008 /* AIF1RX_CHAN3_ENA */ | ||
870 | #define WM8915_AIF1RX_CHAN3_ENA_MASK 0x0008 /* AIF1RX_CHAN3_ENA */ | ||
871 | #define WM8915_AIF1RX_CHAN3_ENA_SHIFT 3 /* AIF1RX_CHAN3_ENA */ | ||
872 | #define WM8915_AIF1RX_CHAN3_ENA_WIDTH 1 /* AIF1RX_CHAN3_ENA */ | ||
873 | #define WM8915_AIF1RX_CHAN2_ENA 0x0004 /* AIF1RX_CHAN2_ENA */ | ||
874 | #define WM8915_AIF1RX_CHAN2_ENA_MASK 0x0004 /* AIF1RX_CHAN2_ENA */ | ||
875 | #define WM8915_AIF1RX_CHAN2_ENA_SHIFT 2 /* AIF1RX_CHAN2_ENA */ | ||
876 | #define WM8915_AIF1RX_CHAN2_ENA_WIDTH 1 /* AIF1RX_CHAN2_ENA */ | ||
877 | #define WM8915_AIF1RX_CHAN1_ENA 0x0002 /* AIF1RX_CHAN1_ENA */ | ||
878 | #define WM8915_AIF1RX_CHAN1_ENA_MASK 0x0002 /* AIF1RX_CHAN1_ENA */ | ||
879 | #define WM8915_AIF1RX_CHAN1_ENA_SHIFT 1 /* AIF1RX_CHAN1_ENA */ | ||
880 | #define WM8915_AIF1RX_CHAN1_ENA_WIDTH 1 /* AIF1RX_CHAN1_ENA */ | ||
881 | #define WM8915_AIF1RX_CHAN0_ENA 0x0001 /* AIF1RX_CHAN0_ENA */ | ||
882 | #define WM8915_AIF1RX_CHAN0_ENA_MASK 0x0001 /* AIF1RX_CHAN0_ENA */ | ||
883 | #define WM8915_AIF1RX_CHAN0_ENA_SHIFT 0 /* AIF1RX_CHAN0_ENA */ | ||
884 | #define WM8915_AIF1RX_CHAN0_ENA_WIDTH 1 /* AIF1RX_CHAN0_ENA */ | ||
885 | |||
886 | /* | ||
887 | * R5 (0x05) - Power Management (5) | ||
888 | */ | ||
889 | #define WM8915_DSP2TXL_ENA 0x0800 /* DSP2TXL_ENA */ | ||
890 | #define WM8915_DSP2TXL_ENA_MASK 0x0800 /* DSP2TXL_ENA */ | ||
891 | #define WM8915_DSP2TXL_ENA_SHIFT 11 /* DSP2TXL_ENA */ | ||
892 | #define WM8915_DSP2TXL_ENA_WIDTH 1 /* DSP2TXL_ENA */ | ||
893 | #define WM8915_DSP2TXR_ENA 0x0400 /* DSP2TXR_ENA */ | ||
894 | #define WM8915_DSP2TXR_ENA_MASK 0x0400 /* DSP2TXR_ENA */ | ||
895 | #define WM8915_DSP2TXR_ENA_SHIFT 10 /* DSP2TXR_ENA */ | ||
896 | #define WM8915_DSP2TXR_ENA_WIDTH 1 /* DSP2TXR_ENA */ | ||
897 | #define WM8915_DSP1TXL_ENA 0x0200 /* DSP1TXL_ENA */ | ||
898 | #define WM8915_DSP1TXL_ENA_MASK 0x0200 /* DSP1TXL_ENA */ | ||
899 | #define WM8915_DSP1TXL_ENA_SHIFT 9 /* DSP1TXL_ENA */ | ||
900 | #define WM8915_DSP1TXL_ENA_WIDTH 1 /* DSP1TXL_ENA */ | ||
901 | #define WM8915_DSP1TXR_ENA 0x0100 /* DSP1TXR_ENA */ | ||
902 | #define WM8915_DSP1TXR_ENA_MASK 0x0100 /* DSP1TXR_ENA */ | ||
903 | #define WM8915_DSP1TXR_ENA_SHIFT 8 /* DSP1TXR_ENA */ | ||
904 | #define WM8915_DSP1TXR_ENA_WIDTH 1 /* DSP1TXR_ENA */ | ||
905 | #define WM8915_DAC2L_ENA 0x0008 /* DAC2L_ENA */ | ||
906 | #define WM8915_DAC2L_ENA_MASK 0x0008 /* DAC2L_ENA */ | ||
907 | #define WM8915_DAC2L_ENA_SHIFT 3 /* DAC2L_ENA */ | ||
908 | #define WM8915_DAC2L_ENA_WIDTH 1 /* DAC2L_ENA */ | ||
909 | #define WM8915_DAC2R_ENA 0x0004 /* DAC2R_ENA */ | ||
910 | #define WM8915_DAC2R_ENA_MASK 0x0004 /* DAC2R_ENA */ | ||
911 | #define WM8915_DAC2R_ENA_SHIFT 2 /* DAC2R_ENA */ | ||
912 | #define WM8915_DAC2R_ENA_WIDTH 1 /* DAC2R_ENA */ | ||
913 | #define WM8915_DAC1L_ENA 0x0002 /* DAC1L_ENA */ | ||
914 | #define WM8915_DAC1L_ENA_MASK 0x0002 /* DAC1L_ENA */ | ||
915 | #define WM8915_DAC1L_ENA_SHIFT 1 /* DAC1L_ENA */ | ||
916 | #define WM8915_DAC1L_ENA_WIDTH 1 /* DAC1L_ENA */ | ||
917 | #define WM8915_DAC1R_ENA 0x0001 /* DAC1R_ENA */ | ||
918 | #define WM8915_DAC1R_ENA_MASK 0x0001 /* DAC1R_ENA */ | ||
919 | #define WM8915_DAC1R_ENA_SHIFT 0 /* DAC1R_ENA */ | ||
920 | #define WM8915_DAC1R_ENA_WIDTH 1 /* DAC1R_ENA */ | ||
921 | |||
922 | /* | ||
923 | * R6 (0x06) - Power Management (6) | ||
924 | */ | ||
925 | #define WM8915_AIF2TX_CHAN1_ENA 0x0200 /* AIF2TX_CHAN1_ENA */ | ||
926 | #define WM8915_AIF2TX_CHAN1_ENA_MASK 0x0200 /* AIF2TX_CHAN1_ENA */ | ||
927 | #define WM8915_AIF2TX_CHAN1_ENA_SHIFT 9 /* AIF2TX_CHAN1_ENA */ | ||
928 | #define WM8915_AIF2TX_CHAN1_ENA_WIDTH 1 /* AIF2TX_CHAN1_ENA */ | ||
929 | #define WM8915_AIF2TX_CHAN0_ENA 0x0100 /* AIF2TX_CHAN0_ENA */ | ||
930 | #define WM8915_AIF2TX_CHAN0_ENA_MASK 0x0100 /* AIF2TX_CHAN0_ENA */ | ||
931 | #define WM8915_AIF2TX_CHAN0_ENA_SHIFT 8 /* AIF2TX_CHAN0_ENA */ | ||
932 | #define WM8915_AIF2TX_CHAN0_ENA_WIDTH 1 /* AIF2TX_CHAN0_ENA */ | ||
933 | #define WM8915_AIF1TX_CHAN5_ENA 0x0020 /* AIF1TX_CHAN5_ENA */ | ||
934 | #define WM8915_AIF1TX_CHAN5_ENA_MASK 0x0020 /* AIF1TX_CHAN5_ENA */ | ||
935 | #define WM8915_AIF1TX_CHAN5_ENA_SHIFT 5 /* AIF1TX_CHAN5_ENA */ | ||
936 | #define WM8915_AIF1TX_CHAN5_ENA_WIDTH 1 /* AIF1TX_CHAN5_ENA */ | ||
937 | #define WM8915_AIF1TX_CHAN4_ENA 0x0010 /* AIF1TX_CHAN4_ENA */ | ||
938 | #define WM8915_AIF1TX_CHAN4_ENA_MASK 0x0010 /* AIF1TX_CHAN4_ENA */ | ||
939 | #define WM8915_AIF1TX_CHAN4_ENA_SHIFT 4 /* AIF1TX_CHAN4_ENA */ | ||
940 | #define WM8915_AIF1TX_CHAN4_ENA_WIDTH 1 /* AIF1TX_CHAN4_ENA */ | ||
941 | #define WM8915_AIF1TX_CHAN3_ENA 0x0008 /* AIF1TX_CHAN3_ENA */ | ||
942 | #define WM8915_AIF1TX_CHAN3_ENA_MASK 0x0008 /* AIF1TX_CHAN3_ENA */ | ||
943 | #define WM8915_AIF1TX_CHAN3_ENA_SHIFT 3 /* AIF1TX_CHAN3_ENA */ | ||
944 | #define WM8915_AIF1TX_CHAN3_ENA_WIDTH 1 /* AIF1TX_CHAN3_ENA */ | ||
945 | #define WM8915_AIF1TX_CHAN2_ENA 0x0004 /* AIF1TX_CHAN2_ENA */ | ||
946 | #define WM8915_AIF1TX_CHAN2_ENA_MASK 0x0004 /* AIF1TX_CHAN2_ENA */ | ||
947 | #define WM8915_AIF1TX_CHAN2_ENA_SHIFT 2 /* AIF1TX_CHAN2_ENA */ | ||
948 | #define WM8915_AIF1TX_CHAN2_ENA_WIDTH 1 /* AIF1TX_CHAN2_ENA */ | ||
949 | #define WM8915_AIF1TX_CHAN1_ENA 0x0002 /* AIF1TX_CHAN1_ENA */ | ||
950 | #define WM8915_AIF1TX_CHAN1_ENA_MASK 0x0002 /* AIF1TX_CHAN1_ENA */ | ||
951 | #define WM8915_AIF1TX_CHAN1_ENA_SHIFT 1 /* AIF1TX_CHAN1_ENA */ | ||
952 | #define WM8915_AIF1TX_CHAN1_ENA_WIDTH 1 /* AIF1TX_CHAN1_ENA */ | ||
953 | #define WM8915_AIF1TX_CHAN0_ENA 0x0001 /* AIF1TX_CHAN0_ENA */ | ||
954 | #define WM8915_AIF1TX_CHAN0_ENA_MASK 0x0001 /* AIF1TX_CHAN0_ENA */ | ||
955 | #define WM8915_AIF1TX_CHAN0_ENA_SHIFT 0 /* AIF1TX_CHAN0_ENA */ | ||
956 | #define WM8915_AIF1TX_CHAN0_ENA_WIDTH 1 /* AIF1TX_CHAN0_ENA */ | ||
957 | |||
958 | /* | ||
959 | * R7 (0x07) - Power Management (7) | ||
960 | */ | ||
961 | #define WM8915_DMIC2_FN 0x0200 /* DMIC2_FN */ | ||
962 | #define WM8915_DMIC2_FN_MASK 0x0200 /* DMIC2_FN */ | ||
963 | #define WM8915_DMIC2_FN_SHIFT 9 /* DMIC2_FN */ | ||
964 | #define WM8915_DMIC2_FN_WIDTH 1 /* DMIC2_FN */ | ||
965 | #define WM8915_DMIC1_FN 0x0100 /* DMIC1_FN */ | ||
966 | #define WM8915_DMIC1_FN_MASK 0x0100 /* DMIC1_FN */ | ||
967 | #define WM8915_DMIC1_FN_SHIFT 8 /* DMIC1_FN */ | ||
968 | #define WM8915_DMIC1_FN_WIDTH 1 /* DMIC1_FN */ | ||
969 | #define WM8915_ADC_DMIC_DSP2R_ENA 0x0080 /* ADC_DMIC_DSP2R_ENA */ | ||
970 | #define WM8915_ADC_DMIC_DSP2R_ENA_MASK 0x0080 /* ADC_DMIC_DSP2R_ENA */ | ||
971 | #define WM8915_ADC_DMIC_DSP2R_ENA_SHIFT 7 /* ADC_DMIC_DSP2R_ENA */ | ||
972 | #define WM8915_ADC_DMIC_DSP2R_ENA_WIDTH 1 /* ADC_DMIC_DSP2R_ENA */ | ||
973 | #define WM8915_ADC_DMIC_DSP2L_ENA 0x0040 /* ADC_DMIC_DSP2L_ENA */ | ||
974 | #define WM8915_ADC_DMIC_DSP2L_ENA_MASK 0x0040 /* ADC_DMIC_DSP2L_ENA */ | ||
975 | #define WM8915_ADC_DMIC_DSP2L_ENA_SHIFT 6 /* ADC_DMIC_DSP2L_ENA */ | ||
976 | #define WM8915_ADC_DMIC_DSP2L_ENA_WIDTH 1 /* ADC_DMIC_DSP2L_ENA */ | ||
977 | #define WM8915_ADC_DMIC_SRC2_MASK 0x0030 /* ADC_DMIC_SRC2 - [5:4] */ | ||
978 | #define WM8915_ADC_DMIC_SRC2_SHIFT 4 /* ADC_DMIC_SRC2 - [5:4] */ | ||
979 | #define WM8915_ADC_DMIC_SRC2_WIDTH 2 /* ADC_DMIC_SRC2 - [5:4] */ | ||
980 | #define WM8915_ADC_DMIC_DSP1R_ENA 0x0008 /* ADC_DMIC_DSP1R_ENA */ | ||
981 | #define WM8915_ADC_DMIC_DSP1R_ENA_MASK 0x0008 /* ADC_DMIC_DSP1R_ENA */ | ||
982 | #define WM8915_ADC_DMIC_DSP1R_ENA_SHIFT 3 /* ADC_DMIC_DSP1R_ENA */ | ||
983 | #define WM8915_ADC_DMIC_DSP1R_ENA_WIDTH 1 /* ADC_DMIC_DSP1R_ENA */ | ||
984 | #define WM8915_ADC_DMIC_DSP1L_ENA 0x0004 /* ADC_DMIC_DSP1L_ENA */ | ||
985 | #define WM8915_ADC_DMIC_DSP1L_ENA_MASK 0x0004 /* ADC_DMIC_DSP1L_ENA */ | ||
986 | #define WM8915_ADC_DMIC_DSP1L_ENA_SHIFT 2 /* ADC_DMIC_DSP1L_ENA */ | ||
987 | #define WM8915_ADC_DMIC_DSP1L_ENA_WIDTH 1 /* ADC_DMIC_DSP1L_ENA */ | ||
988 | #define WM8915_ADC_DMIC_SRC1_MASK 0x0003 /* ADC_DMIC_SRC1 - [1:0] */ | ||
989 | #define WM8915_ADC_DMIC_SRC1_SHIFT 0 /* ADC_DMIC_SRC1 - [1:0] */ | ||
990 | #define WM8915_ADC_DMIC_SRC1_WIDTH 2 /* ADC_DMIC_SRC1 - [1:0] */ | ||
991 | |||
992 | /* | ||
993 | * R8 (0x08) - Power Management (8) | ||
994 | */ | ||
995 | #define WM8915_AIF2TX_SRC_MASK 0x00C0 /* AIF2TX_SRC - [7:6] */ | ||
996 | #define WM8915_AIF2TX_SRC_SHIFT 6 /* AIF2TX_SRC - [7:6] */ | ||
997 | #define WM8915_AIF2TX_SRC_WIDTH 2 /* AIF2TX_SRC - [7:6] */ | ||
998 | #define WM8915_DSP2RX_SRC 0x0010 /* DSP2RX_SRC */ | ||
999 | #define WM8915_DSP2RX_SRC_MASK 0x0010 /* DSP2RX_SRC */ | ||
1000 | #define WM8915_DSP2RX_SRC_SHIFT 4 /* DSP2RX_SRC */ | ||
1001 | #define WM8915_DSP2RX_SRC_WIDTH 1 /* DSP2RX_SRC */ | ||
1002 | #define WM8915_DSP1RX_SRC 0x0001 /* DSP1RX_SRC */ | ||
1003 | #define WM8915_DSP1RX_SRC_MASK 0x0001 /* DSP1RX_SRC */ | ||
1004 | #define WM8915_DSP1RX_SRC_SHIFT 0 /* DSP1RX_SRC */ | ||
1005 | #define WM8915_DSP1RX_SRC_WIDTH 1 /* DSP1RX_SRC */ | ||
1006 | |||
1007 | /* | ||
1008 | * R16 (0x10) - Left Line Input Volume | ||
1009 | */ | ||
1010 | #define WM8915_IN1_VU 0x0080 /* IN1_VU */ | ||
1011 | #define WM8915_IN1_VU_MASK 0x0080 /* IN1_VU */ | ||
1012 | #define WM8915_IN1_VU_SHIFT 7 /* IN1_VU */ | ||
1013 | #define WM8915_IN1_VU_WIDTH 1 /* IN1_VU */ | ||
1014 | #define WM8915_IN1L_ZC 0x0020 /* IN1L_ZC */ | ||
1015 | #define WM8915_IN1L_ZC_MASK 0x0020 /* IN1L_ZC */ | ||
1016 | #define WM8915_IN1L_ZC_SHIFT 5 /* IN1L_ZC */ | ||
1017 | #define WM8915_IN1L_ZC_WIDTH 1 /* IN1L_ZC */ | ||
1018 | #define WM8915_IN1L_VOL_MASK 0x001F /* IN1L_VOL - [4:0] */ | ||
1019 | #define WM8915_IN1L_VOL_SHIFT 0 /* IN1L_VOL - [4:0] */ | ||
1020 | #define WM8915_IN1L_VOL_WIDTH 5 /* IN1L_VOL - [4:0] */ | ||
1021 | |||
1022 | /* | ||
1023 | * R17 (0x11) - Right Line Input Volume | ||
1024 | */ | ||
1025 | #define WM8915_IN1_VU 0x0080 /* IN1_VU */ | ||
1026 | #define WM8915_IN1_VU_MASK 0x0080 /* IN1_VU */ | ||
1027 | #define WM8915_IN1_VU_SHIFT 7 /* IN1_VU */ | ||
1028 | #define WM8915_IN1_VU_WIDTH 1 /* IN1_VU */ | ||
1029 | #define WM8915_IN1R_ZC 0x0020 /* IN1R_ZC */ | ||
1030 | #define WM8915_IN1R_ZC_MASK 0x0020 /* IN1R_ZC */ | ||
1031 | #define WM8915_IN1R_ZC_SHIFT 5 /* IN1R_ZC */ | ||
1032 | #define WM8915_IN1R_ZC_WIDTH 1 /* IN1R_ZC */ | ||
1033 | #define WM8915_IN1R_VOL_MASK 0x001F /* IN1R_VOL - [4:0] */ | ||
1034 | #define WM8915_IN1R_VOL_SHIFT 0 /* IN1R_VOL - [4:0] */ | ||
1035 | #define WM8915_IN1R_VOL_WIDTH 5 /* IN1R_VOL - [4:0] */ | ||
1036 | |||
1037 | /* | ||
1038 | * R18 (0x12) - Line Input Control | ||
1039 | */ | ||
1040 | #define WM8915_INL_MODE_MASK 0x000C /* INL_MODE - [3:2] */ | ||
1041 | #define WM8915_INL_MODE_SHIFT 2 /* INL_MODE - [3:2] */ | ||
1042 | #define WM8915_INL_MODE_WIDTH 2 /* INL_MODE - [3:2] */ | ||
1043 | #define WM8915_INR_MODE_MASK 0x0003 /* INR_MODE - [1:0] */ | ||
1044 | #define WM8915_INR_MODE_SHIFT 0 /* INR_MODE - [1:0] */ | ||
1045 | #define WM8915_INR_MODE_WIDTH 2 /* INR_MODE - [1:0] */ | ||
1046 | |||
1047 | /* | ||
1048 | * R21 (0x15) - DAC1 HPOUT1 Volume | ||
1049 | */ | ||
1050 | #define WM8915_DAC1R_HPOUT1R_VOL_MASK 0x00F0 /* DAC1R_HPOUT1R_VOL - [7:4] */ | ||
1051 | #define WM8915_DAC1R_HPOUT1R_VOL_SHIFT 4 /* DAC1R_HPOUT1R_VOL - [7:4] */ | ||
1052 | #define WM8915_DAC1R_HPOUT1R_VOL_WIDTH 4 /* DAC1R_HPOUT1R_VOL - [7:4] */ | ||
1053 | #define WM8915_DAC1L_HPOUT1L_VOL_MASK 0x000F /* DAC1L_HPOUT1L_VOL - [3:0] */ | ||
1054 | #define WM8915_DAC1L_HPOUT1L_VOL_SHIFT 0 /* DAC1L_HPOUT1L_VOL - [3:0] */ | ||
1055 | #define WM8915_DAC1L_HPOUT1L_VOL_WIDTH 4 /* DAC1L_HPOUT1L_VOL - [3:0] */ | ||
1056 | |||
1057 | /* | ||
1058 | * R22 (0x16) - DAC2 HPOUT2 Volume | ||
1059 | */ | ||
1060 | #define WM8915_DAC2R_HPOUT2R_VOL_MASK 0x00F0 /* DAC2R_HPOUT2R_VOL - [7:4] */ | ||
1061 | #define WM8915_DAC2R_HPOUT2R_VOL_SHIFT 4 /* DAC2R_HPOUT2R_VOL - [7:4] */ | ||
1062 | #define WM8915_DAC2R_HPOUT2R_VOL_WIDTH 4 /* DAC2R_HPOUT2R_VOL - [7:4] */ | ||
1063 | #define WM8915_DAC2L_HPOUT2L_VOL_MASK 0x000F /* DAC2L_HPOUT2L_VOL - [3:0] */ | ||
1064 | #define WM8915_DAC2L_HPOUT2L_VOL_SHIFT 0 /* DAC2L_HPOUT2L_VOL - [3:0] */ | ||
1065 | #define WM8915_DAC2L_HPOUT2L_VOL_WIDTH 4 /* DAC2L_HPOUT2L_VOL - [3:0] */ | ||
1066 | |||
1067 | /* | ||
1068 | * R24 (0x18) - DAC1 Left Volume | ||
1069 | */ | ||
1070 | #define WM8915_DAC1L_MUTE 0x0200 /* DAC1L_MUTE */ | ||
1071 | #define WM8915_DAC1L_MUTE_MASK 0x0200 /* DAC1L_MUTE */ | ||
1072 | #define WM8915_DAC1L_MUTE_SHIFT 9 /* DAC1L_MUTE */ | ||
1073 | #define WM8915_DAC1L_MUTE_WIDTH 1 /* DAC1L_MUTE */ | ||
1074 | #define WM8915_DAC1_VU 0x0100 /* DAC1_VU */ | ||
1075 | #define WM8915_DAC1_VU_MASK 0x0100 /* DAC1_VU */ | ||
1076 | #define WM8915_DAC1_VU_SHIFT 8 /* DAC1_VU */ | ||
1077 | #define WM8915_DAC1_VU_WIDTH 1 /* DAC1_VU */ | ||
1078 | #define WM8915_DAC1L_VOL_MASK 0x00FF /* DAC1L_VOL - [7:0] */ | ||
1079 | #define WM8915_DAC1L_VOL_SHIFT 0 /* DAC1L_VOL - [7:0] */ | ||
1080 | #define WM8915_DAC1L_VOL_WIDTH 8 /* DAC1L_VOL - [7:0] */ | ||
1081 | |||
1082 | /* | ||
1083 | * R25 (0x19) - DAC1 Right Volume | ||
1084 | */ | ||
1085 | #define WM8915_DAC1R_MUTE 0x0200 /* DAC1R_MUTE */ | ||
1086 | #define WM8915_DAC1R_MUTE_MASK 0x0200 /* DAC1R_MUTE */ | ||
1087 | #define WM8915_DAC1R_MUTE_SHIFT 9 /* DAC1R_MUTE */ | ||
1088 | #define WM8915_DAC1R_MUTE_WIDTH 1 /* DAC1R_MUTE */ | ||
1089 | #define WM8915_DAC1_VU 0x0100 /* DAC1_VU */ | ||
1090 | #define WM8915_DAC1_VU_MASK 0x0100 /* DAC1_VU */ | ||
1091 | #define WM8915_DAC1_VU_SHIFT 8 /* DAC1_VU */ | ||
1092 | #define WM8915_DAC1_VU_WIDTH 1 /* DAC1_VU */ | ||
1093 | #define WM8915_DAC1R_VOL_MASK 0x00FF /* DAC1R_VOL - [7:0] */ | ||
1094 | #define WM8915_DAC1R_VOL_SHIFT 0 /* DAC1R_VOL - [7:0] */ | ||
1095 | #define WM8915_DAC1R_VOL_WIDTH 8 /* DAC1R_VOL - [7:0] */ | ||
1096 | |||
1097 | /* | ||
1098 | * R26 (0x1A) - DAC2 Left Volume | ||
1099 | */ | ||
1100 | #define WM8915_DAC2L_MUTE 0x0200 /* DAC2L_MUTE */ | ||
1101 | #define WM8915_DAC2L_MUTE_MASK 0x0200 /* DAC2L_MUTE */ | ||
1102 | #define WM8915_DAC2L_MUTE_SHIFT 9 /* DAC2L_MUTE */ | ||
1103 | #define WM8915_DAC2L_MUTE_WIDTH 1 /* DAC2L_MUTE */ | ||
1104 | #define WM8915_DAC2_VU 0x0100 /* DAC2_VU */ | ||
1105 | #define WM8915_DAC2_VU_MASK 0x0100 /* DAC2_VU */ | ||
1106 | #define WM8915_DAC2_VU_SHIFT 8 /* DAC2_VU */ | ||
1107 | #define WM8915_DAC2_VU_WIDTH 1 /* DAC2_VU */ | ||
1108 | #define WM8915_DAC2L_VOL_MASK 0x00FF /* DAC2L_VOL - [7:0] */ | ||
1109 | #define WM8915_DAC2L_VOL_SHIFT 0 /* DAC2L_VOL - [7:0] */ | ||
1110 | #define WM8915_DAC2L_VOL_WIDTH 8 /* DAC2L_VOL - [7:0] */ | ||
1111 | |||
1112 | /* | ||
1113 | * R27 (0x1B) - DAC2 Right Volume | ||
1114 | */ | ||
1115 | #define WM8915_DAC2R_MUTE 0x0200 /* DAC2R_MUTE */ | ||
1116 | #define WM8915_DAC2R_MUTE_MASK 0x0200 /* DAC2R_MUTE */ | ||
1117 | #define WM8915_DAC2R_MUTE_SHIFT 9 /* DAC2R_MUTE */ | ||
1118 | #define WM8915_DAC2R_MUTE_WIDTH 1 /* DAC2R_MUTE */ | ||
1119 | #define WM8915_DAC2_VU 0x0100 /* DAC2_VU */ | ||
1120 | #define WM8915_DAC2_VU_MASK 0x0100 /* DAC2_VU */ | ||
1121 | #define WM8915_DAC2_VU_SHIFT 8 /* DAC2_VU */ | ||
1122 | #define WM8915_DAC2_VU_WIDTH 1 /* DAC2_VU */ | ||
1123 | #define WM8915_DAC2R_VOL_MASK 0x00FF /* DAC2R_VOL - [7:0] */ | ||
1124 | #define WM8915_DAC2R_VOL_SHIFT 0 /* DAC2R_VOL - [7:0] */ | ||
1125 | #define WM8915_DAC2R_VOL_WIDTH 8 /* DAC2R_VOL - [7:0] */ | ||
1126 | |||
1127 | /* | ||
1128 | * R28 (0x1C) - Output1 Left Volume | ||
1129 | */ | ||
1130 | #define WM8915_DAC1_VU 0x0100 /* DAC1_VU */ | ||
1131 | #define WM8915_DAC1_VU_MASK 0x0100 /* DAC1_VU */ | ||
1132 | #define WM8915_DAC1_VU_SHIFT 8 /* DAC1_VU */ | ||
1133 | #define WM8915_DAC1_VU_WIDTH 1 /* DAC1_VU */ | ||
1134 | #define WM8915_HPOUT1L_ZC 0x0080 /* HPOUT1L_ZC */ | ||
1135 | #define WM8915_HPOUT1L_ZC_MASK 0x0080 /* HPOUT1L_ZC */ | ||
1136 | #define WM8915_HPOUT1L_ZC_SHIFT 7 /* HPOUT1L_ZC */ | ||
1137 | #define WM8915_HPOUT1L_ZC_WIDTH 1 /* HPOUT1L_ZC */ | ||
1138 | #define WM8915_HPOUT1L_VOL_MASK 0x000F /* HPOUT1L_VOL - [3:0] */ | ||
1139 | #define WM8915_HPOUT1L_VOL_SHIFT 0 /* HPOUT1L_VOL - [3:0] */ | ||
1140 | #define WM8915_HPOUT1L_VOL_WIDTH 4 /* HPOUT1L_VOL - [3:0] */ | ||
1141 | |||
1142 | /* | ||
1143 | * R29 (0x1D) - Output1 Right Volume | ||
1144 | */ | ||
1145 | #define WM8915_DAC1_VU 0x0100 /* DAC1_VU */ | ||
1146 | #define WM8915_DAC1_VU_MASK 0x0100 /* DAC1_VU */ | ||
1147 | #define WM8915_DAC1_VU_SHIFT 8 /* DAC1_VU */ | ||
1148 | #define WM8915_DAC1_VU_WIDTH 1 /* DAC1_VU */ | ||
1149 | #define WM8915_HPOUT1R_ZC 0x0080 /* HPOUT1R_ZC */ | ||
1150 | #define WM8915_HPOUT1R_ZC_MASK 0x0080 /* HPOUT1R_ZC */ | ||
1151 | #define WM8915_HPOUT1R_ZC_SHIFT 7 /* HPOUT1R_ZC */ | ||
1152 | #define WM8915_HPOUT1R_ZC_WIDTH 1 /* HPOUT1R_ZC */ | ||
1153 | #define WM8915_HPOUT1R_VOL_MASK 0x000F /* HPOUT1R_VOL - [3:0] */ | ||
1154 | #define WM8915_HPOUT1R_VOL_SHIFT 0 /* HPOUT1R_VOL - [3:0] */ | ||
1155 | #define WM8915_HPOUT1R_VOL_WIDTH 4 /* HPOUT1R_VOL - [3:0] */ | ||
1156 | |||
1157 | /* | ||
1158 | * R30 (0x1E) - Output2 Left Volume | ||
1159 | */ | ||
1160 | #define WM8915_DAC2_VU 0x0100 /* DAC2_VU */ | ||
1161 | #define WM8915_DAC2_VU_MASK 0x0100 /* DAC2_VU */ | ||
1162 | #define WM8915_DAC2_VU_SHIFT 8 /* DAC2_VU */ | ||
1163 | #define WM8915_DAC2_VU_WIDTH 1 /* DAC2_VU */ | ||
1164 | #define WM8915_HPOUT2L_ZC 0x0080 /* HPOUT2L_ZC */ | ||
1165 | #define WM8915_HPOUT2L_ZC_MASK 0x0080 /* HPOUT2L_ZC */ | ||
1166 | #define WM8915_HPOUT2L_ZC_SHIFT 7 /* HPOUT2L_ZC */ | ||
1167 | #define WM8915_HPOUT2L_ZC_WIDTH 1 /* HPOUT2L_ZC */ | ||
1168 | #define WM8915_HPOUT2L_VOL_MASK 0x000F /* HPOUT2L_VOL - [3:0] */ | ||
1169 | #define WM8915_HPOUT2L_VOL_SHIFT 0 /* HPOUT2L_VOL - [3:0] */ | ||
1170 | #define WM8915_HPOUT2L_VOL_WIDTH 4 /* HPOUT2L_VOL - [3:0] */ | ||
1171 | |||
1172 | /* | ||
1173 | * R31 (0x1F) - Output2 Right Volume | ||
1174 | */ | ||
1175 | #define WM8915_DAC2_VU 0x0100 /* DAC2_VU */ | ||
1176 | #define WM8915_DAC2_VU_MASK 0x0100 /* DAC2_VU */ | ||
1177 | #define WM8915_DAC2_VU_SHIFT 8 /* DAC2_VU */ | ||
1178 | #define WM8915_DAC2_VU_WIDTH 1 /* DAC2_VU */ | ||
1179 | #define WM8915_HPOUT2R_ZC 0x0080 /* HPOUT2R_ZC */ | ||
1180 | #define WM8915_HPOUT2R_ZC_MASK 0x0080 /* HPOUT2R_ZC */ | ||
1181 | #define WM8915_HPOUT2R_ZC_SHIFT 7 /* HPOUT2R_ZC */ | ||
1182 | #define WM8915_HPOUT2R_ZC_WIDTH 1 /* HPOUT2R_ZC */ | ||
1183 | #define WM8915_HPOUT2R_VOL_MASK 0x000F /* HPOUT2R_VOL - [3:0] */ | ||
1184 | #define WM8915_HPOUT2R_VOL_SHIFT 0 /* HPOUT2R_VOL - [3:0] */ | ||
1185 | #define WM8915_HPOUT2R_VOL_WIDTH 4 /* HPOUT2R_VOL - [3:0] */ | ||
1186 | |||
1187 | /* | ||
1188 | * R32 (0x20) - MICBIAS (1) | ||
1189 | */ | ||
1190 | #define WM8915_MICB1_RATE 0x0020 /* MICB1_RATE */ | ||
1191 | #define WM8915_MICB1_RATE_MASK 0x0020 /* MICB1_RATE */ | ||
1192 | #define WM8915_MICB1_RATE_SHIFT 5 /* MICB1_RATE */ | ||
1193 | #define WM8915_MICB1_RATE_WIDTH 1 /* MICB1_RATE */ | ||
1194 | #define WM8915_MICB1_MODE 0x0010 /* MICB1_MODE */ | ||
1195 | #define WM8915_MICB1_MODE_MASK 0x0010 /* MICB1_MODE */ | ||
1196 | #define WM8915_MICB1_MODE_SHIFT 4 /* MICB1_MODE */ | ||
1197 | #define WM8915_MICB1_MODE_WIDTH 1 /* MICB1_MODE */ | ||
1198 | #define WM8915_MICB1_LVL_MASK 0x000E /* MICB1_LVL - [3:1] */ | ||
1199 | #define WM8915_MICB1_LVL_SHIFT 1 /* MICB1_LVL - [3:1] */ | ||
1200 | #define WM8915_MICB1_LVL_WIDTH 3 /* MICB1_LVL - [3:1] */ | ||
1201 | #define WM8915_MICB1_DISCH 0x0001 /* MICB1_DISCH */ | ||
1202 | #define WM8915_MICB1_DISCH_MASK 0x0001 /* MICB1_DISCH */ | ||
1203 | #define WM8915_MICB1_DISCH_SHIFT 0 /* MICB1_DISCH */ | ||
1204 | #define WM8915_MICB1_DISCH_WIDTH 1 /* MICB1_DISCH */ | ||
1205 | |||
1206 | /* | ||
1207 | * R33 (0x21) - MICBIAS (2) | ||
1208 | */ | ||
1209 | #define WM8915_MICB2_RATE 0x0020 /* MICB2_RATE */ | ||
1210 | #define WM8915_MICB2_RATE_MASK 0x0020 /* MICB2_RATE */ | ||
1211 | #define WM8915_MICB2_RATE_SHIFT 5 /* MICB2_RATE */ | ||
1212 | #define WM8915_MICB2_RATE_WIDTH 1 /* MICB2_RATE */ | ||
1213 | #define WM8915_MICB2_MODE 0x0010 /* MICB2_MODE */ | ||
1214 | #define WM8915_MICB2_MODE_MASK 0x0010 /* MICB2_MODE */ | ||
1215 | #define WM8915_MICB2_MODE_SHIFT 4 /* MICB2_MODE */ | ||
1216 | #define WM8915_MICB2_MODE_WIDTH 1 /* MICB2_MODE */ | ||
1217 | #define WM8915_MICB2_LVL_MASK 0x000E /* MICB2_LVL - [3:1] */ | ||
1218 | #define WM8915_MICB2_LVL_SHIFT 1 /* MICB2_LVL - [3:1] */ | ||
1219 | #define WM8915_MICB2_LVL_WIDTH 3 /* MICB2_LVL - [3:1] */ | ||
1220 | #define WM8915_MICB2_DISCH 0x0001 /* MICB2_DISCH */ | ||
1221 | #define WM8915_MICB2_DISCH_MASK 0x0001 /* MICB2_DISCH */ | ||
1222 | #define WM8915_MICB2_DISCH_SHIFT 0 /* MICB2_DISCH */ | ||
1223 | #define WM8915_MICB2_DISCH_WIDTH 1 /* MICB2_DISCH */ | ||
1224 | |||
1225 | /* | ||
1226 | * R40 (0x28) - LDO 1 | ||
1227 | */ | ||
1228 | #define WM8915_LDO1_MODE 0x0020 /* LDO1_MODE */ | ||
1229 | #define WM8915_LDO1_MODE_MASK 0x0020 /* LDO1_MODE */ | ||
1230 | #define WM8915_LDO1_MODE_SHIFT 5 /* LDO1_MODE */ | ||
1231 | #define WM8915_LDO1_MODE_WIDTH 1 /* LDO1_MODE */ | ||
1232 | #define WM8915_LDO1_VSEL_MASK 0x0006 /* LDO1_VSEL - [2:1] */ | ||
1233 | #define WM8915_LDO1_VSEL_SHIFT 1 /* LDO1_VSEL - [2:1] */ | ||
1234 | #define WM8915_LDO1_VSEL_WIDTH 2 /* LDO1_VSEL - [2:1] */ | ||
1235 | #define WM8915_LDO1_DISCH 0x0001 /* LDO1_DISCH */ | ||
1236 | #define WM8915_LDO1_DISCH_MASK 0x0001 /* LDO1_DISCH */ | ||
1237 | #define WM8915_LDO1_DISCH_SHIFT 0 /* LDO1_DISCH */ | ||
1238 | #define WM8915_LDO1_DISCH_WIDTH 1 /* LDO1_DISCH */ | ||
1239 | |||
1240 | /* | ||
1241 | * R41 (0x29) - LDO 2 | ||
1242 | */ | ||
1243 | #define WM8915_LDO2_MODE 0x0020 /* LDO2_MODE */ | ||
1244 | #define WM8915_LDO2_MODE_MASK 0x0020 /* LDO2_MODE */ | ||
1245 | #define WM8915_LDO2_MODE_SHIFT 5 /* LDO2_MODE */ | ||
1246 | #define WM8915_LDO2_MODE_WIDTH 1 /* LDO2_MODE */ | ||
1247 | #define WM8915_LDO2_VSEL_MASK 0x001E /* LDO2_VSEL - [4:1] */ | ||
1248 | #define WM8915_LDO2_VSEL_SHIFT 1 /* LDO2_VSEL - [4:1] */ | ||
1249 | #define WM8915_LDO2_VSEL_WIDTH 4 /* LDO2_VSEL - [4:1] */ | ||
1250 | #define WM8915_LDO2_DISCH 0x0001 /* LDO2_DISCH */ | ||
1251 | #define WM8915_LDO2_DISCH_MASK 0x0001 /* LDO2_DISCH */ | ||
1252 | #define WM8915_LDO2_DISCH_SHIFT 0 /* LDO2_DISCH */ | ||
1253 | #define WM8915_LDO2_DISCH_WIDTH 1 /* LDO2_DISCH */ | ||
1254 | |||
1255 | /* | ||
1256 | * R48 (0x30) - Accessory Detect Mode 1 | ||
1257 | */ | ||
1258 | #define WM8915_JD_MODE_MASK 0x0003 /* JD_MODE - [1:0] */ | ||
1259 | #define WM8915_JD_MODE_SHIFT 0 /* JD_MODE - [1:0] */ | ||
1260 | #define WM8915_JD_MODE_WIDTH 2 /* JD_MODE - [1:0] */ | ||
1261 | |||
1262 | /* | ||
1263 | * R49 (0x31) - Accessory Detect Mode 2 | ||
1264 | */ | ||
1265 | #define WM8915_HPOUT1FB_SRC 0x0004 /* HPOUT1FB_SRC */ | ||
1266 | #define WM8915_HPOUT1FB_SRC_MASK 0x0004 /* HPOUT1FB_SRC */ | ||
1267 | #define WM8915_HPOUT1FB_SRC_SHIFT 2 /* HPOUT1FB_SRC */ | ||
1268 | #define WM8915_HPOUT1FB_SRC_WIDTH 1 /* HPOUT1FB_SRC */ | ||
1269 | #define WM8915_MICD_SRC 0x0002 /* MICD_SRC */ | ||
1270 | #define WM8915_MICD_SRC_MASK 0x0002 /* MICD_SRC */ | ||
1271 | #define WM8915_MICD_SRC_SHIFT 1 /* MICD_SRC */ | ||
1272 | #define WM8915_MICD_SRC_WIDTH 1 /* MICD_SRC */ | ||
1273 | #define WM8915_MICD_BIAS_SRC 0x0001 /* MICD_BIAS_SRC */ | ||
1274 | #define WM8915_MICD_BIAS_SRC_MASK 0x0001 /* MICD_BIAS_SRC */ | ||
1275 | #define WM8915_MICD_BIAS_SRC_SHIFT 0 /* MICD_BIAS_SRC */ | ||
1276 | #define WM8915_MICD_BIAS_SRC_WIDTH 1 /* MICD_BIAS_SRC */ | ||
1277 | |||
1278 | /* | ||
1279 | * R52 (0x34) - Headphone Detect 1 | ||
1280 | */ | ||
1281 | #define WM8915_HP_HOLDTIME_MASK 0x00E0 /* HP_HOLDTIME - [7:5] */ | ||
1282 | #define WM8915_HP_HOLDTIME_SHIFT 5 /* HP_HOLDTIME - [7:5] */ | ||
1283 | #define WM8915_HP_HOLDTIME_WIDTH 3 /* HP_HOLDTIME - [7:5] */ | ||
1284 | #define WM8915_HP_CLK_DIV_MASK 0x0018 /* HP_CLK_DIV - [4:3] */ | ||
1285 | #define WM8915_HP_CLK_DIV_SHIFT 3 /* HP_CLK_DIV - [4:3] */ | ||
1286 | #define WM8915_HP_CLK_DIV_WIDTH 2 /* HP_CLK_DIV - [4:3] */ | ||
1287 | #define WM8915_HP_STEP_SIZE 0x0002 /* HP_STEP_SIZE */ | ||
1288 | #define WM8915_HP_STEP_SIZE_MASK 0x0002 /* HP_STEP_SIZE */ | ||
1289 | #define WM8915_HP_STEP_SIZE_SHIFT 1 /* HP_STEP_SIZE */ | ||
1290 | #define WM8915_HP_STEP_SIZE_WIDTH 1 /* HP_STEP_SIZE */ | ||
1291 | #define WM8915_HP_POLL 0x0001 /* HP_POLL */ | ||
1292 | #define WM8915_HP_POLL_MASK 0x0001 /* HP_POLL */ | ||
1293 | #define WM8915_HP_POLL_SHIFT 0 /* HP_POLL */ | ||
1294 | #define WM8915_HP_POLL_WIDTH 1 /* HP_POLL */ | ||
1295 | |||
1296 | /* | ||
1297 | * R53 (0x35) - Headphone Detect 2 | ||
1298 | */ | ||
1299 | #define WM8915_HP_DONE 0x0080 /* HP_DONE */ | ||
1300 | #define WM8915_HP_DONE_MASK 0x0080 /* HP_DONE */ | ||
1301 | #define WM8915_HP_DONE_SHIFT 7 /* HP_DONE */ | ||
1302 | #define WM8915_HP_DONE_WIDTH 1 /* HP_DONE */ | ||
1303 | #define WM8915_HP_LVL_MASK 0x007F /* HP_LVL - [6:0] */ | ||
1304 | #define WM8915_HP_LVL_SHIFT 0 /* HP_LVL - [6:0] */ | ||
1305 | #define WM8915_HP_LVL_WIDTH 7 /* HP_LVL - [6:0] */ | ||
1306 | |||
1307 | /* | ||
1308 | * R56 (0x38) - Mic Detect 1 | ||
1309 | */ | ||
1310 | #define WM8915_MICD_BIAS_STARTTIME_MASK 0xF000 /* MICD_BIAS_STARTTIME - [15:12] */ | ||
1311 | #define WM8915_MICD_BIAS_STARTTIME_SHIFT 12 /* MICD_BIAS_STARTTIME - [15:12] */ | ||
1312 | #define WM8915_MICD_BIAS_STARTTIME_WIDTH 4 /* MICD_BIAS_STARTTIME - [15:12] */ | ||
1313 | #define WM8915_MICD_RATE_MASK 0x0F00 /* MICD_RATE - [11:8] */ | ||
1314 | #define WM8915_MICD_RATE_SHIFT 8 /* MICD_RATE - [11:8] */ | ||
1315 | #define WM8915_MICD_RATE_WIDTH 4 /* MICD_RATE - [11:8] */ | ||
1316 | #define WM8915_MICD_DBTIME 0x0002 /* MICD_DBTIME */ | ||
1317 | #define WM8915_MICD_DBTIME_MASK 0x0002 /* MICD_DBTIME */ | ||
1318 | #define WM8915_MICD_DBTIME_SHIFT 1 /* MICD_DBTIME */ | ||
1319 | #define WM8915_MICD_DBTIME_WIDTH 1 /* MICD_DBTIME */ | ||
1320 | #define WM8915_MICD_ENA 0x0001 /* MICD_ENA */ | ||
1321 | #define WM8915_MICD_ENA_MASK 0x0001 /* MICD_ENA */ | ||
1322 | #define WM8915_MICD_ENA_SHIFT 0 /* MICD_ENA */ | ||
1323 | #define WM8915_MICD_ENA_WIDTH 1 /* MICD_ENA */ | ||
1324 | |||
1325 | /* | ||
1326 | * R57 (0x39) - Mic Detect 2 | ||
1327 | */ | ||
1328 | #define WM8915_MICD_LVL_SEL_MASK 0x00FF /* MICD_LVL_SEL - [7:0] */ | ||
1329 | #define WM8915_MICD_LVL_SEL_SHIFT 0 /* MICD_LVL_SEL - [7:0] */ | ||
1330 | #define WM8915_MICD_LVL_SEL_WIDTH 8 /* MICD_LVL_SEL - [7:0] */ | ||
1331 | |||
1332 | /* | ||
1333 | * R58 (0x3A) - Mic Detect 3 | ||
1334 | */ | ||
1335 | #define WM8915_MICD_LVL_MASK 0x07FC /* MICD_LVL - [10:2] */ | ||
1336 | #define WM8915_MICD_LVL_SHIFT 2 /* MICD_LVL - [10:2] */ | ||
1337 | #define WM8915_MICD_LVL_WIDTH 9 /* MICD_LVL - [10:2] */ | ||
1338 | #define WM8915_MICD_VALID 0x0002 /* MICD_VALID */ | ||
1339 | #define WM8915_MICD_VALID_MASK 0x0002 /* MICD_VALID */ | ||
1340 | #define WM8915_MICD_VALID_SHIFT 1 /* MICD_VALID */ | ||
1341 | #define WM8915_MICD_VALID_WIDTH 1 /* MICD_VALID */ | ||
1342 | #define WM8915_MICD_STS 0x0001 /* MICD_STS */ | ||
1343 | #define WM8915_MICD_STS_MASK 0x0001 /* MICD_STS */ | ||
1344 | #define WM8915_MICD_STS_SHIFT 0 /* MICD_STS */ | ||
1345 | #define WM8915_MICD_STS_WIDTH 1 /* MICD_STS */ | ||
1346 | |||
1347 | /* | ||
1348 | * R64 (0x40) - Charge Pump (1) | ||
1349 | */ | ||
1350 | #define WM8915_CP_ENA 0x8000 /* CP_ENA */ | ||
1351 | #define WM8915_CP_ENA_MASK 0x8000 /* CP_ENA */ | ||
1352 | #define WM8915_CP_ENA_SHIFT 15 /* CP_ENA */ | ||
1353 | #define WM8915_CP_ENA_WIDTH 1 /* CP_ENA */ | ||
1354 | |||
1355 | /* | ||
1356 | * R65 (0x41) - Charge Pump (2) | ||
1357 | */ | ||
1358 | #define WM8915_CP_DISCH 0x8000 /* CP_DISCH */ | ||
1359 | #define WM8915_CP_DISCH_MASK 0x8000 /* CP_DISCH */ | ||
1360 | #define WM8915_CP_DISCH_SHIFT 15 /* CP_DISCH */ | ||
1361 | #define WM8915_CP_DISCH_WIDTH 1 /* CP_DISCH */ | ||
1362 | |||
1363 | /* | ||
1364 | * R80 (0x50) - DC Servo (1) | ||
1365 | */ | ||
1366 | #define WM8915_DCS_ENA_CHAN_3 0x0008 /* DCS_ENA_CHAN_3 */ | ||
1367 | #define WM8915_DCS_ENA_CHAN_3_MASK 0x0008 /* DCS_ENA_CHAN_3 */ | ||
1368 | #define WM8915_DCS_ENA_CHAN_3_SHIFT 3 /* DCS_ENA_CHAN_3 */ | ||
1369 | #define WM8915_DCS_ENA_CHAN_3_WIDTH 1 /* DCS_ENA_CHAN_3 */ | ||
1370 | #define WM8915_DCS_ENA_CHAN_2 0x0004 /* DCS_ENA_CHAN_2 */ | ||
1371 | #define WM8915_DCS_ENA_CHAN_2_MASK 0x0004 /* DCS_ENA_CHAN_2 */ | ||
1372 | #define WM8915_DCS_ENA_CHAN_2_SHIFT 2 /* DCS_ENA_CHAN_2 */ | ||
1373 | #define WM8915_DCS_ENA_CHAN_2_WIDTH 1 /* DCS_ENA_CHAN_2 */ | ||
1374 | #define WM8915_DCS_ENA_CHAN_1 0x0002 /* DCS_ENA_CHAN_1 */ | ||
1375 | #define WM8915_DCS_ENA_CHAN_1_MASK 0x0002 /* DCS_ENA_CHAN_1 */ | ||
1376 | #define WM8915_DCS_ENA_CHAN_1_SHIFT 1 /* DCS_ENA_CHAN_1 */ | ||
1377 | #define WM8915_DCS_ENA_CHAN_1_WIDTH 1 /* DCS_ENA_CHAN_1 */ | ||
1378 | #define WM8915_DCS_ENA_CHAN_0 0x0001 /* DCS_ENA_CHAN_0 */ | ||
1379 | #define WM8915_DCS_ENA_CHAN_0_MASK 0x0001 /* DCS_ENA_CHAN_0 */ | ||
1380 | #define WM8915_DCS_ENA_CHAN_0_SHIFT 0 /* DCS_ENA_CHAN_0 */ | ||
1381 | #define WM8915_DCS_ENA_CHAN_0_WIDTH 1 /* DCS_ENA_CHAN_0 */ | ||
1382 | |||
1383 | /* | ||
1384 | * R81 (0x51) - DC Servo (2) | ||
1385 | */ | ||
1386 | #define WM8915_DCS_TRIG_SINGLE_3 0x8000 /* DCS_TRIG_SINGLE_3 */ | ||
1387 | #define WM8915_DCS_TRIG_SINGLE_3_MASK 0x8000 /* DCS_TRIG_SINGLE_3 */ | ||
1388 | #define WM8915_DCS_TRIG_SINGLE_3_SHIFT 15 /* DCS_TRIG_SINGLE_3 */ | ||
1389 | #define WM8915_DCS_TRIG_SINGLE_3_WIDTH 1 /* DCS_TRIG_SINGLE_3 */ | ||
1390 | #define WM8915_DCS_TRIG_SINGLE_2 0x4000 /* DCS_TRIG_SINGLE_2 */ | ||
1391 | #define WM8915_DCS_TRIG_SINGLE_2_MASK 0x4000 /* DCS_TRIG_SINGLE_2 */ | ||
1392 | #define WM8915_DCS_TRIG_SINGLE_2_SHIFT 14 /* DCS_TRIG_SINGLE_2 */ | ||
1393 | #define WM8915_DCS_TRIG_SINGLE_2_WIDTH 1 /* DCS_TRIG_SINGLE_2 */ | ||
1394 | #define WM8915_DCS_TRIG_SINGLE_1 0x2000 /* DCS_TRIG_SINGLE_1 */ | ||
1395 | #define WM8915_DCS_TRIG_SINGLE_1_MASK 0x2000 /* DCS_TRIG_SINGLE_1 */ | ||
1396 | #define WM8915_DCS_TRIG_SINGLE_1_SHIFT 13 /* DCS_TRIG_SINGLE_1 */ | ||
1397 | #define WM8915_DCS_TRIG_SINGLE_1_WIDTH 1 /* DCS_TRIG_SINGLE_1 */ | ||
1398 | #define WM8915_DCS_TRIG_SINGLE_0 0x1000 /* DCS_TRIG_SINGLE_0 */ | ||
1399 | #define WM8915_DCS_TRIG_SINGLE_0_MASK 0x1000 /* DCS_TRIG_SINGLE_0 */ | ||
1400 | #define WM8915_DCS_TRIG_SINGLE_0_SHIFT 12 /* DCS_TRIG_SINGLE_0 */ | ||
1401 | #define WM8915_DCS_TRIG_SINGLE_0_WIDTH 1 /* DCS_TRIG_SINGLE_0 */ | ||
1402 | #define WM8915_DCS_TRIG_SERIES_3 0x0800 /* DCS_TRIG_SERIES_3 */ | ||
1403 | #define WM8915_DCS_TRIG_SERIES_3_MASK 0x0800 /* DCS_TRIG_SERIES_3 */ | ||
1404 | #define WM8915_DCS_TRIG_SERIES_3_SHIFT 11 /* DCS_TRIG_SERIES_3 */ | ||
1405 | #define WM8915_DCS_TRIG_SERIES_3_WIDTH 1 /* DCS_TRIG_SERIES_3 */ | ||
1406 | #define WM8915_DCS_TRIG_SERIES_2 0x0400 /* DCS_TRIG_SERIES_2 */ | ||
1407 | #define WM8915_DCS_TRIG_SERIES_2_MASK 0x0400 /* DCS_TRIG_SERIES_2 */ | ||
1408 | #define WM8915_DCS_TRIG_SERIES_2_SHIFT 10 /* DCS_TRIG_SERIES_2 */ | ||
1409 | #define WM8915_DCS_TRIG_SERIES_2_WIDTH 1 /* DCS_TRIG_SERIES_2 */ | ||
1410 | #define WM8915_DCS_TRIG_SERIES_1 0x0200 /* DCS_TRIG_SERIES_1 */ | ||
1411 | #define WM8915_DCS_TRIG_SERIES_1_MASK 0x0200 /* DCS_TRIG_SERIES_1 */ | ||
1412 | #define WM8915_DCS_TRIG_SERIES_1_SHIFT 9 /* DCS_TRIG_SERIES_1 */ | ||
1413 | #define WM8915_DCS_TRIG_SERIES_1_WIDTH 1 /* DCS_TRIG_SERIES_1 */ | ||
1414 | #define WM8915_DCS_TRIG_SERIES_0 0x0100 /* DCS_TRIG_SERIES_0 */ | ||
1415 | #define WM8915_DCS_TRIG_SERIES_0_MASK 0x0100 /* DCS_TRIG_SERIES_0 */ | ||
1416 | #define WM8915_DCS_TRIG_SERIES_0_SHIFT 8 /* DCS_TRIG_SERIES_0 */ | ||
1417 | #define WM8915_DCS_TRIG_SERIES_0_WIDTH 1 /* DCS_TRIG_SERIES_0 */ | ||
1418 | #define WM8915_DCS_TRIG_STARTUP_3 0x0080 /* DCS_TRIG_STARTUP_3 */ | ||
1419 | #define WM8915_DCS_TRIG_STARTUP_3_MASK 0x0080 /* DCS_TRIG_STARTUP_3 */ | ||
1420 | #define WM8915_DCS_TRIG_STARTUP_3_SHIFT 7 /* DCS_TRIG_STARTUP_3 */ | ||
1421 | #define WM8915_DCS_TRIG_STARTUP_3_WIDTH 1 /* DCS_TRIG_STARTUP_3 */ | ||
1422 | #define WM8915_DCS_TRIG_STARTUP_2 0x0040 /* DCS_TRIG_STARTUP_2 */ | ||
1423 | #define WM8915_DCS_TRIG_STARTUP_2_MASK 0x0040 /* DCS_TRIG_STARTUP_2 */ | ||
1424 | #define WM8915_DCS_TRIG_STARTUP_2_SHIFT 6 /* DCS_TRIG_STARTUP_2 */ | ||
1425 | #define WM8915_DCS_TRIG_STARTUP_2_WIDTH 1 /* DCS_TRIG_STARTUP_2 */ | ||
1426 | #define WM8915_DCS_TRIG_STARTUP_1 0x0020 /* DCS_TRIG_STARTUP_1 */ | ||
1427 | #define WM8915_DCS_TRIG_STARTUP_1_MASK 0x0020 /* DCS_TRIG_STARTUP_1 */ | ||
1428 | #define WM8915_DCS_TRIG_STARTUP_1_SHIFT 5 /* DCS_TRIG_STARTUP_1 */ | ||
1429 | #define WM8915_DCS_TRIG_STARTUP_1_WIDTH 1 /* DCS_TRIG_STARTUP_1 */ | ||
1430 | #define WM8915_DCS_TRIG_STARTUP_0 0x0010 /* DCS_TRIG_STARTUP_0 */ | ||
1431 | #define WM8915_DCS_TRIG_STARTUP_0_MASK 0x0010 /* DCS_TRIG_STARTUP_0 */ | ||
1432 | #define WM8915_DCS_TRIG_STARTUP_0_SHIFT 4 /* DCS_TRIG_STARTUP_0 */ | ||
1433 | #define WM8915_DCS_TRIG_STARTUP_0_WIDTH 1 /* DCS_TRIG_STARTUP_0 */ | ||
1434 | #define WM8915_DCS_TRIG_DAC_WR_3 0x0008 /* DCS_TRIG_DAC_WR_3 */ | ||
1435 | #define WM8915_DCS_TRIG_DAC_WR_3_MASK 0x0008 /* DCS_TRIG_DAC_WR_3 */ | ||
1436 | #define WM8915_DCS_TRIG_DAC_WR_3_SHIFT 3 /* DCS_TRIG_DAC_WR_3 */ | ||
1437 | #define WM8915_DCS_TRIG_DAC_WR_3_WIDTH 1 /* DCS_TRIG_DAC_WR_3 */ | ||
1438 | #define WM8915_DCS_TRIG_DAC_WR_2 0x0004 /* DCS_TRIG_DAC_WR_2 */ | ||
1439 | #define WM8915_DCS_TRIG_DAC_WR_2_MASK 0x0004 /* DCS_TRIG_DAC_WR_2 */ | ||
1440 | #define WM8915_DCS_TRIG_DAC_WR_2_SHIFT 2 /* DCS_TRIG_DAC_WR_2 */ | ||
1441 | #define WM8915_DCS_TRIG_DAC_WR_2_WIDTH 1 /* DCS_TRIG_DAC_WR_2 */ | ||
1442 | #define WM8915_DCS_TRIG_DAC_WR_1 0x0002 /* DCS_TRIG_DAC_WR_1 */ | ||
1443 | #define WM8915_DCS_TRIG_DAC_WR_1_MASK 0x0002 /* DCS_TRIG_DAC_WR_1 */ | ||
1444 | #define WM8915_DCS_TRIG_DAC_WR_1_SHIFT 1 /* DCS_TRIG_DAC_WR_1 */ | ||
1445 | #define WM8915_DCS_TRIG_DAC_WR_1_WIDTH 1 /* DCS_TRIG_DAC_WR_1 */ | ||
1446 | #define WM8915_DCS_TRIG_DAC_WR_0 0x0001 /* DCS_TRIG_DAC_WR_0 */ | ||
1447 | #define WM8915_DCS_TRIG_DAC_WR_0_MASK 0x0001 /* DCS_TRIG_DAC_WR_0 */ | ||
1448 | #define WM8915_DCS_TRIG_DAC_WR_0_SHIFT 0 /* DCS_TRIG_DAC_WR_0 */ | ||
1449 | #define WM8915_DCS_TRIG_DAC_WR_0_WIDTH 1 /* DCS_TRIG_DAC_WR_0 */ | ||
1450 | |||
1451 | /* | ||
1452 | * R82 (0x52) - DC Servo (3) | ||
1453 | */ | ||
1454 | #define WM8915_DCS_TIMER_PERIOD_23_MASK 0x0F00 /* DCS_TIMER_PERIOD_23 - [11:8] */ | ||
1455 | #define WM8915_DCS_TIMER_PERIOD_23_SHIFT 8 /* DCS_TIMER_PERIOD_23 - [11:8] */ | ||
1456 | #define WM8915_DCS_TIMER_PERIOD_23_WIDTH 4 /* DCS_TIMER_PERIOD_23 - [11:8] */ | ||
1457 | #define WM8915_DCS_TIMER_PERIOD_01_MASK 0x000F /* DCS_TIMER_PERIOD_01 - [3:0] */ | ||
1458 | #define WM8915_DCS_TIMER_PERIOD_01_SHIFT 0 /* DCS_TIMER_PERIOD_01 - [3:0] */ | ||
1459 | #define WM8915_DCS_TIMER_PERIOD_01_WIDTH 4 /* DCS_TIMER_PERIOD_01 - [3:0] */ | ||
1460 | |||
1461 | /* | ||
1462 | * R84 (0x54) - DC Servo (5) | ||
1463 | */ | ||
1464 | #define WM8915_DCS_SERIES_NO_23_MASK 0x7F00 /* DCS_SERIES_NO_23 - [14:8] */ | ||
1465 | #define WM8915_DCS_SERIES_NO_23_SHIFT 8 /* DCS_SERIES_NO_23 - [14:8] */ | ||
1466 | #define WM8915_DCS_SERIES_NO_23_WIDTH 7 /* DCS_SERIES_NO_23 - [14:8] */ | ||
1467 | #define WM8915_DCS_SERIES_NO_01_MASK 0x007F /* DCS_SERIES_NO_01 - [6:0] */ | ||
1468 | #define WM8915_DCS_SERIES_NO_01_SHIFT 0 /* DCS_SERIES_NO_01 - [6:0] */ | ||
1469 | #define WM8915_DCS_SERIES_NO_01_WIDTH 7 /* DCS_SERIES_NO_01 - [6:0] */ | ||
1470 | |||
1471 | /* | ||
1472 | * R85 (0x55) - DC Servo (6) | ||
1473 | */ | ||
1474 | #define WM8915_DCS_DAC_WR_VAL_3_MASK 0xFF00 /* DCS_DAC_WR_VAL_3 - [15:8] */ | ||
1475 | #define WM8915_DCS_DAC_WR_VAL_3_SHIFT 8 /* DCS_DAC_WR_VAL_3 - [15:8] */ | ||
1476 | #define WM8915_DCS_DAC_WR_VAL_3_WIDTH 8 /* DCS_DAC_WR_VAL_3 - [15:8] */ | ||
1477 | #define WM8915_DCS_DAC_WR_VAL_2_MASK 0x00FF /* DCS_DAC_WR_VAL_2 - [7:0] */ | ||
1478 | #define WM8915_DCS_DAC_WR_VAL_2_SHIFT 0 /* DCS_DAC_WR_VAL_2 - [7:0] */ | ||
1479 | #define WM8915_DCS_DAC_WR_VAL_2_WIDTH 8 /* DCS_DAC_WR_VAL_2 - [7:0] */ | ||
1480 | |||
1481 | /* | ||
1482 | * R86 (0x56) - DC Servo (7) | ||
1483 | */ | ||
1484 | #define WM8915_DCS_DAC_WR_VAL_1_MASK 0xFF00 /* DCS_DAC_WR_VAL_1 - [15:8] */ | ||
1485 | #define WM8915_DCS_DAC_WR_VAL_1_SHIFT 8 /* DCS_DAC_WR_VAL_1 - [15:8] */ | ||
1486 | #define WM8915_DCS_DAC_WR_VAL_1_WIDTH 8 /* DCS_DAC_WR_VAL_1 - [15:8] */ | ||
1487 | #define WM8915_DCS_DAC_WR_VAL_0_MASK 0x00FF /* DCS_DAC_WR_VAL_0 - [7:0] */ | ||
1488 | #define WM8915_DCS_DAC_WR_VAL_0_SHIFT 0 /* DCS_DAC_WR_VAL_0 - [7:0] */ | ||
1489 | #define WM8915_DCS_DAC_WR_VAL_0_WIDTH 8 /* DCS_DAC_WR_VAL_0 - [7:0] */ | ||
1490 | |||
1491 | /* | ||
1492 | * R87 (0x57) - DC Servo Readback 0 | ||
1493 | */ | ||
1494 | #define WM8915_DCS_CAL_COMPLETE_MASK 0x0F00 /* DCS_CAL_COMPLETE - [11:8] */ | ||
1495 | #define WM8915_DCS_CAL_COMPLETE_SHIFT 8 /* DCS_CAL_COMPLETE - [11:8] */ | ||
1496 | #define WM8915_DCS_CAL_COMPLETE_WIDTH 4 /* DCS_CAL_COMPLETE - [11:8] */ | ||
1497 | #define WM8915_DCS_DAC_WR_COMPLETE_MASK 0x00F0 /* DCS_DAC_WR_COMPLETE - [7:4] */ | ||
1498 | #define WM8915_DCS_DAC_WR_COMPLETE_SHIFT 4 /* DCS_DAC_WR_COMPLETE - [7:4] */ | ||
1499 | #define WM8915_DCS_DAC_WR_COMPLETE_WIDTH 4 /* DCS_DAC_WR_COMPLETE - [7:4] */ | ||
1500 | #define WM8915_DCS_STARTUP_COMPLETE_MASK 0x000F /* DCS_STARTUP_COMPLETE - [3:0] */ | ||
1501 | #define WM8915_DCS_STARTUP_COMPLETE_SHIFT 0 /* DCS_STARTUP_COMPLETE - [3:0] */ | ||
1502 | #define WM8915_DCS_STARTUP_COMPLETE_WIDTH 4 /* DCS_STARTUP_COMPLETE - [3:0] */ | ||
1503 | |||
1504 | /* | ||
1505 | * R96 (0x60) - Analogue HP (1) | ||
1506 | */ | ||
1507 | #define WM8915_HPOUT1L_RMV_SHORT 0x0080 /* HPOUT1L_RMV_SHORT */ | ||
1508 | #define WM8915_HPOUT1L_RMV_SHORT_MASK 0x0080 /* HPOUT1L_RMV_SHORT */ | ||
1509 | #define WM8915_HPOUT1L_RMV_SHORT_SHIFT 7 /* HPOUT1L_RMV_SHORT */ | ||
1510 | #define WM8915_HPOUT1L_RMV_SHORT_WIDTH 1 /* HPOUT1L_RMV_SHORT */ | ||
1511 | #define WM8915_HPOUT1L_OUTP 0x0040 /* HPOUT1L_OUTP */ | ||
1512 | #define WM8915_HPOUT1L_OUTP_MASK 0x0040 /* HPOUT1L_OUTP */ | ||
1513 | #define WM8915_HPOUT1L_OUTP_SHIFT 6 /* HPOUT1L_OUTP */ | ||
1514 | #define WM8915_HPOUT1L_OUTP_WIDTH 1 /* HPOUT1L_OUTP */ | ||
1515 | #define WM8915_HPOUT1L_DLY 0x0020 /* HPOUT1L_DLY */ | ||
1516 | #define WM8915_HPOUT1L_DLY_MASK 0x0020 /* HPOUT1L_DLY */ | ||
1517 | #define WM8915_HPOUT1L_DLY_SHIFT 5 /* HPOUT1L_DLY */ | ||
1518 | #define WM8915_HPOUT1L_DLY_WIDTH 1 /* HPOUT1L_DLY */ | ||
1519 | #define WM8915_HPOUT1R_RMV_SHORT 0x0008 /* HPOUT1R_RMV_SHORT */ | ||
1520 | #define WM8915_HPOUT1R_RMV_SHORT_MASK 0x0008 /* HPOUT1R_RMV_SHORT */ | ||
1521 | #define WM8915_HPOUT1R_RMV_SHORT_SHIFT 3 /* HPOUT1R_RMV_SHORT */ | ||
1522 | #define WM8915_HPOUT1R_RMV_SHORT_WIDTH 1 /* HPOUT1R_RMV_SHORT */ | ||
1523 | #define WM8915_HPOUT1R_OUTP 0x0004 /* HPOUT1R_OUTP */ | ||
1524 | #define WM8915_HPOUT1R_OUTP_MASK 0x0004 /* HPOUT1R_OUTP */ | ||
1525 | #define WM8915_HPOUT1R_OUTP_SHIFT 2 /* HPOUT1R_OUTP */ | ||
1526 | #define WM8915_HPOUT1R_OUTP_WIDTH 1 /* HPOUT1R_OUTP */ | ||
1527 | #define WM8915_HPOUT1R_DLY 0x0002 /* HPOUT1R_DLY */ | ||
1528 | #define WM8915_HPOUT1R_DLY_MASK 0x0002 /* HPOUT1R_DLY */ | ||
1529 | #define WM8915_HPOUT1R_DLY_SHIFT 1 /* HPOUT1R_DLY */ | ||
1530 | #define WM8915_HPOUT1R_DLY_WIDTH 1 /* HPOUT1R_DLY */ | ||
1531 | |||
1532 | /* | ||
1533 | * R97 (0x61) - Analogue HP (2) | ||
1534 | */ | ||
1535 | #define WM8915_HPOUT2L_RMV_SHORT 0x0080 /* HPOUT2L_RMV_SHORT */ | ||
1536 | #define WM8915_HPOUT2L_RMV_SHORT_MASK 0x0080 /* HPOUT2L_RMV_SHORT */ | ||
1537 | #define WM8915_HPOUT2L_RMV_SHORT_SHIFT 7 /* HPOUT2L_RMV_SHORT */ | ||
1538 | #define WM8915_HPOUT2L_RMV_SHORT_WIDTH 1 /* HPOUT2L_RMV_SHORT */ | ||
1539 | #define WM8915_HPOUT2L_OUTP 0x0040 /* HPOUT2L_OUTP */ | ||
1540 | #define WM8915_HPOUT2L_OUTP_MASK 0x0040 /* HPOUT2L_OUTP */ | ||
1541 | #define WM8915_HPOUT2L_OUTP_SHIFT 6 /* HPOUT2L_OUTP */ | ||
1542 | #define WM8915_HPOUT2L_OUTP_WIDTH 1 /* HPOUT2L_OUTP */ | ||
1543 | #define WM8915_HPOUT2L_DLY 0x0020 /* HPOUT2L_DLY */ | ||
1544 | #define WM8915_HPOUT2L_DLY_MASK 0x0020 /* HPOUT2L_DLY */ | ||
1545 | #define WM8915_HPOUT2L_DLY_SHIFT 5 /* HPOUT2L_DLY */ | ||
1546 | #define WM8915_HPOUT2L_DLY_WIDTH 1 /* HPOUT2L_DLY */ | ||
1547 | #define WM8915_HPOUT2R_RMV_SHORT 0x0008 /* HPOUT2R_RMV_SHORT */ | ||
1548 | #define WM8915_HPOUT2R_RMV_SHORT_MASK 0x0008 /* HPOUT2R_RMV_SHORT */ | ||
1549 | #define WM8915_HPOUT2R_RMV_SHORT_SHIFT 3 /* HPOUT2R_RMV_SHORT */ | ||
1550 | #define WM8915_HPOUT2R_RMV_SHORT_WIDTH 1 /* HPOUT2R_RMV_SHORT */ | ||
1551 | #define WM8915_HPOUT2R_OUTP 0x0004 /* HPOUT2R_OUTP */ | ||
1552 | #define WM8915_HPOUT2R_OUTP_MASK 0x0004 /* HPOUT2R_OUTP */ | ||
1553 | #define WM8915_HPOUT2R_OUTP_SHIFT 2 /* HPOUT2R_OUTP */ | ||
1554 | #define WM8915_HPOUT2R_OUTP_WIDTH 1 /* HPOUT2R_OUTP */ | ||
1555 | #define WM8915_HPOUT2R_DLY 0x0002 /* HPOUT2R_DLY */ | ||
1556 | #define WM8915_HPOUT2R_DLY_MASK 0x0002 /* HPOUT2R_DLY */ | ||
1557 | #define WM8915_HPOUT2R_DLY_SHIFT 1 /* HPOUT2R_DLY */ | ||
1558 | #define WM8915_HPOUT2R_DLY_WIDTH 1 /* HPOUT2R_DLY */ | ||
1559 | |||
1560 | /* | ||
1561 | * R256 (0x100) - Chip Revision | ||
1562 | */ | ||
1563 | #define WM8915_CHIP_REV_MASK 0x000F /* CHIP_REV - [3:0] */ | ||
1564 | #define WM8915_CHIP_REV_SHIFT 0 /* CHIP_REV - [3:0] */ | ||
1565 | #define WM8915_CHIP_REV_WIDTH 4 /* CHIP_REV - [3:0] */ | ||
1566 | |||
1567 | /* | ||
1568 | * R257 (0x101) - Control Interface (1) | ||
1569 | */ | ||
1570 | #define WM8915_AUTO_INC 0x0004 /* AUTO_INC */ | ||
1571 | #define WM8915_AUTO_INC_MASK 0x0004 /* AUTO_INC */ | ||
1572 | #define WM8915_AUTO_INC_SHIFT 2 /* AUTO_INC */ | ||
1573 | #define WM8915_AUTO_INC_WIDTH 1 /* AUTO_INC */ | ||
1574 | |||
1575 | /* | ||
1576 | * R272 (0x110) - Write Sequencer Ctrl (1) | ||
1577 | */ | ||
1578 | #define WM8915_WSEQ_ENA 0x8000 /* WSEQ_ENA */ | ||
1579 | #define WM8915_WSEQ_ENA_MASK 0x8000 /* WSEQ_ENA */ | ||
1580 | #define WM8915_WSEQ_ENA_SHIFT 15 /* WSEQ_ENA */ | ||
1581 | #define WM8915_WSEQ_ENA_WIDTH 1 /* WSEQ_ENA */ | ||
1582 | #define WM8915_WSEQ_ABORT 0x0200 /* WSEQ_ABORT */ | ||
1583 | #define WM8915_WSEQ_ABORT_MASK 0x0200 /* WSEQ_ABORT */ | ||
1584 | #define WM8915_WSEQ_ABORT_SHIFT 9 /* WSEQ_ABORT */ | ||
1585 | #define WM8915_WSEQ_ABORT_WIDTH 1 /* WSEQ_ABORT */ | ||
1586 | #define WM8915_WSEQ_START 0x0100 /* WSEQ_START */ | ||
1587 | #define WM8915_WSEQ_START_MASK 0x0100 /* WSEQ_START */ | ||
1588 | #define WM8915_WSEQ_START_SHIFT 8 /* WSEQ_START */ | ||
1589 | #define WM8915_WSEQ_START_WIDTH 1 /* WSEQ_START */ | ||
1590 | #define WM8915_WSEQ_START_INDEX_MASK 0x007F /* WSEQ_START_INDEX - [6:0] */ | ||
1591 | #define WM8915_WSEQ_START_INDEX_SHIFT 0 /* WSEQ_START_INDEX - [6:0] */ | ||
1592 | #define WM8915_WSEQ_START_INDEX_WIDTH 7 /* WSEQ_START_INDEX - [6:0] */ | ||
1593 | |||
1594 | /* | ||
1595 | * R273 (0x111) - Write Sequencer Ctrl (2) | ||
1596 | */ | ||
1597 | #define WM8915_WSEQ_BUSY 0x0100 /* WSEQ_BUSY */ | ||
1598 | #define WM8915_WSEQ_BUSY_MASK 0x0100 /* WSEQ_BUSY */ | ||
1599 | #define WM8915_WSEQ_BUSY_SHIFT 8 /* WSEQ_BUSY */ | ||
1600 | #define WM8915_WSEQ_BUSY_WIDTH 1 /* WSEQ_BUSY */ | ||
1601 | #define WM8915_WSEQ_CURRENT_INDEX_MASK 0x007F /* WSEQ_CURRENT_INDEX - [6:0] */ | ||
1602 | #define WM8915_WSEQ_CURRENT_INDEX_SHIFT 0 /* WSEQ_CURRENT_INDEX - [6:0] */ | ||
1603 | #define WM8915_WSEQ_CURRENT_INDEX_WIDTH 7 /* WSEQ_CURRENT_INDEX - [6:0] */ | ||
1604 | |||
1605 | /* | ||
1606 | * R512 (0x200) - AIF Clocking (1) | ||
1607 | */ | ||
1608 | #define WM8915_SYSCLK_SRC_MASK 0x0018 /* SYSCLK_SRC - [4:3] */ | ||
1609 | #define WM8915_SYSCLK_SRC_SHIFT 3 /* SYSCLK_SRC - [4:3] */ | ||
1610 | #define WM8915_SYSCLK_SRC_WIDTH 2 /* SYSCLK_SRC - [4:3] */ | ||
1611 | #define WM8915_SYSCLK_INV 0x0004 /* SYSCLK_INV */ | ||
1612 | #define WM8915_SYSCLK_INV_MASK 0x0004 /* SYSCLK_INV */ | ||
1613 | #define WM8915_SYSCLK_INV_SHIFT 2 /* SYSCLK_INV */ | ||
1614 | #define WM8915_SYSCLK_INV_WIDTH 1 /* SYSCLK_INV */ | ||
1615 | #define WM8915_SYSCLK_DIV 0x0002 /* SYSCLK_DIV */ | ||
1616 | #define WM8915_SYSCLK_DIV_MASK 0x0002 /* SYSCLK_DIV */ | ||
1617 | #define WM8915_SYSCLK_DIV_SHIFT 1 /* SYSCLK_DIV */ | ||
1618 | #define WM8915_SYSCLK_DIV_WIDTH 1 /* SYSCLK_DIV */ | ||
1619 | #define WM8915_SYSCLK_ENA 0x0001 /* SYSCLK_ENA */ | ||
1620 | #define WM8915_SYSCLK_ENA_MASK 0x0001 /* SYSCLK_ENA */ | ||
1621 | #define WM8915_SYSCLK_ENA_SHIFT 0 /* SYSCLK_ENA */ | ||
1622 | #define WM8915_SYSCLK_ENA_WIDTH 1 /* SYSCLK_ENA */ | ||
1623 | |||
1624 | /* | ||
1625 | * R513 (0x201) - AIF Clocking (2) | ||
1626 | */ | ||
1627 | #define WM8915_DSP2_DIV_MASK 0x0018 /* DSP2_DIV - [4:3] */ | ||
1628 | #define WM8915_DSP2_DIV_SHIFT 3 /* DSP2_DIV - [4:3] */ | ||
1629 | #define WM8915_DSP2_DIV_WIDTH 2 /* DSP2_DIV - [4:3] */ | ||
1630 | #define WM8915_DSP1_DIV_MASK 0x0003 /* DSP1_DIV - [1:0] */ | ||
1631 | #define WM8915_DSP1_DIV_SHIFT 0 /* DSP1_DIV - [1:0] */ | ||
1632 | #define WM8915_DSP1_DIV_WIDTH 2 /* DSP1_DIV - [1:0] */ | ||
1633 | |||
1634 | /* | ||
1635 | * R520 (0x208) - Clocking (1) | ||
1636 | */ | ||
1637 | #define WM8915_LFCLK_ENA 0x0020 /* LFCLK_ENA */ | ||
1638 | #define WM8915_LFCLK_ENA_MASK 0x0020 /* LFCLK_ENA */ | ||
1639 | #define WM8915_LFCLK_ENA_SHIFT 5 /* LFCLK_ENA */ | ||
1640 | #define WM8915_LFCLK_ENA_WIDTH 1 /* LFCLK_ENA */ | ||
1641 | #define WM8915_TOCLK_ENA 0x0010 /* TOCLK_ENA */ | ||
1642 | #define WM8915_TOCLK_ENA_MASK 0x0010 /* TOCLK_ENA */ | ||
1643 | #define WM8915_TOCLK_ENA_SHIFT 4 /* TOCLK_ENA */ | ||
1644 | #define WM8915_TOCLK_ENA_WIDTH 1 /* TOCLK_ENA */ | ||
1645 | #define WM8915_AIFCLK_ENA 0x0004 /* AIFCLK_ENA */ | ||
1646 | #define WM8915_AIFCLK_ENA_MASK 0x0004 /* AIFCLK_ENA */ | ||
1647 | #define WM8915_AIFCLK_ENA_SHIFT 2 /* AIFCLK_ENA */ | ||
1648 | #define WM8915_AIFCLK_ENA_WIDTH 1 /* AIFCLK_ENA */ | ||
1649 | #define WM8915_SYSDSPCLK_ENA 0x0002 /* SYSDSPCLK_ENA */ | ||
1650 | #define WM8915_SYSDSPCLK_ENA_MASK 0x0002 /* SYSDSPCLK_ENA */ | ||
1651 | #define WM8915_SYSDSPCLK_ENA_SHIFT 1 /* SYSDSPCLK_ENA */ | ||
1652 | #define WM8915_SYSDSPCLK_ENA_WIDTH 1 /* SYSDSPCLK_ENA */ | ||
1653 | |||
1654 | /* | ||
1655 | * R521 (0x209) - Clocking (2) | ||
1656 | */ | ||
1657 | #define WM8915_TOCLK_DIV_MASK 0x0700 /* TOCLK_DIV - [10:8] */ | ||
1658 | #define WM8915_TOCLK_DIV_SHIFT 8 /* TOCLK_DIV - [10:8] */ | ||
1659 | #define WM8915_TOCLK_DIV_WIDTH 3 /* TOCLK_DIV - [10:8] */ | ||
1660 | #define WM8915_DBCLK_DIV_MASK 0x00F0 /* DBCLK_DIV - [7:4] */ | ||
1661 | #define WM8915_DBCLK_DIV_SHIFT 4 /* DBCLK_DIV - [7:4] */ | ||
1662 | #define WM8915_DBCLK_DIV_WIDTH 4 /* DBCLK_DIV - [7:4] */ | ||
1663 | #define WM8915_OPCLK_DIV_MASK 0x0007 /* OPCLK_DIV - [2:0] */ | ||
1664 | #define WM8915_OPCLK_DIV_SHIFT 0 /* OPCLK_DIV - [2:0] */ | ||
1665 | #define WM8915_OPCLK_DIV_WIDTH 3 /* OPCLK_DIV - [2:0] */ | ||
1666 | |||
1667 | /* | ||
1668 | * R528 (0x210) - AIF Rate | ||
1669 | */ | ||
1670 | #define WM8915_SYSCLK_RATE 0x0001 /* SYSCLK_RATE */ | ||
1671 | #define WM8915_SYSCLK_RATE_MASK 0x0001 /* SYSCLK_RATE */ | ||
1672 | #define WM8915_SYSCLK_RATE_SHIFT 0 /* SYSCLK_RATE */ | ||
1673 | #define WM8915_SYSCLK_RATE_WIDTH 1 /* SYSCLK_RATE */ | ||
1674 | |||
1675 | /* | ||
1676 | * R544 (0x220) - FLL Control (1) | ||
1677 | */ | ||
1678 | #define WM8915_FLL_OSC_ENA 0x0002 /* FLL_OSC_ENA */ | ||
1679 | #define WM8915_FLL_OSC_ENA_MASK 0x0002 /* FLL_OSC_ENA */ | ||
1680 | #define WM8915_FLL_OSC_ENA_SHIFT 1 /* FLL_OSC_ENA */ | ||
1681 | #define WM8915_FLL_OSC_ENA_WIDTH 1 /* FLL_OSC_ENA */ | ||
1682 | #define WM8915_FLL_ENA 0x0001 /* FLL_ENA */ | ||
1683 | #define WM8915_FLL_ENA_MASK 0x0001 /* FLL_ENA */ | ||
1684 | #define WM8915_FLL_ENA_SHIFT 0 /* FLL_ENA */ | ||
1685 | #define WM8915_FLL_ENA_WIDTH 1 /* FLL_ENA */ | ||
1686 | |||
1687 | /* | ||
1688 | * R545 (0x221) - FLL Control (2) | ||
1689 | */ | ||
1690 | #define WM8915_FLL_OUTDIV_MASK 0x3F00 /* FLL_OUTDIV - [13:8] */ | ||
1691 | #define WM8915_FLL_OUTDIV_SHIFT 8 /* FLL_OUTDIV - [13:8] */ | ||
1692 | #define WM8915_FLL_OUTDIV_WIDTH 6 /* FLL_OUTDIV - [13:8] */ | ||
1693 | #define WM8915_FLL_FRATIO_MASK 0x0007 /* FLL_FRATIO - [2:0] */ | ||
1694 | #define WM8915_FLL_FRATIO_SHIFT 0 /* FLL_FRATIO - [2:0] */ | ||
1695 | #define WM8915_FLL_FRATIO_WIDTH 3 /* FLL_FRATIO - [2:0] */ | ||
1696 | |||
1697 | /* | ||
1698 | * R546 (0x222) - FLL Control (3) | ||
1699 | */ | ||
1700 | #define WM8915_FLL_THETA_MASK 0xFFFF /* FLL_THETA - [15:0] */ | ||
1701 | #define WM8915_FLL_THETA_SHIFT 0 /* FLL_THETA - [15:0] */ | ||
1702 | #define WM8915_FLL_THETA_WIDTH 16 /* FLL_THETA - [15:0] */ | ||
1703 | |||
1704 | /* | ||
1705 | * R547 (0x223) - FLL Control (4) | ||
1706 | */ | ||
1707 | #define WM8915_FLL_N_MASK 0x7FE0 /* FLL_N - [14:5] */ | ||
1708 | #define WM8915_FLL_N_SHIFT 5 /* FLL_N - [14:5] */ | ||
1709 | #define WM8915_FLL_N_WIDTH 10 /* FLL_N - [14:5] */ | ||
1710 | #define WM8915_FLL_LOOP_GAIN_MASK 0x000F /* FLL_LOOP_GAIN - [3:0] */ | ||
1711 | #define WM8915_FLL_LOOP_GAIN_SHIFT 0 /* FLL_LOOP_GAIN - [3:0] */ | ||
1712 | #define WM8915_FLL_LOOP_GAIN_WIDTH 4 /* FLL_LOOP_GAIN - [3:0] */ | ||
1713 | |||
1714 | /* | ||
1715 | * R548 (0x224) - FLL Control (5) | ||
1716 | */ | ||
1717 | #define WM8915_FLL_FRC_NCO_VAL_MASK 0x1F80 /* FLL_FRC_NCO_VAL - [12:7] */ | ||
1718 | #define WM8915_FLL_FRC_NCO_VAL_SHIFT 7 /* FLL_FRC_NCO_VAL - [12:7] */ | ||
1719 | #define WM8915_FLL_FRC_NCO_VAL_WIDTH 6 /* FLL_FRC_NCO_VAL - [12:7] */ | ||
1720 | #define WM8915_FLL_FRC_NCO 0x0040 /* FLL_FRC_NCO */ | ||
1721 | #define WM8915_FLL_FRC_NCO_MASK 0x0040 /* FLL_FRC_NCO */ | ||
1722 | #define WM8915_FLL_FRC_NCO_SHIFT 6 /* FLL_FRC_NCO */ | ||
1723 | #define WM8915_FLL_FRC_NCO_WIDTH 1 /* FLL_FRC_NCO */ | ||
1724 | #define WM8915_FLL_REFCLK_DIV_MASK 0x0018 /* FLL_REFCLK_DIV - [4:3] */ | ||
1725 | #define WM8915_FLL_REFCLK_DIV_SHIFT 3 /* FLL_REFCLK_DIV - [4:3] */ | ||
1726 | #define WM8915_FLL_REFCLK_DIV_WIDTH 2 /* FLL_REFCLK_DIV - [4:3] */ | ||
1727 | #define WM8915_FLL_REF_FREQ 0x0004 /* FLL_REF_FREQ */ | ||
1728 | #define WM8915_FLL_REF_FREQ_MASK 0x0004 /* FLL_REF_FREQ */ | ||
1729 | #define WM8915_FLL_REF_FREQ_SHIFT 2 /* FLL_REF_FREQ */ | ||
1730 | #define WM8915_FLL_REF_FREQ_WIDTH 1 /* FLL_REF_FREQ */ | ||
1731 | #define WM8915_FLL_REFCLK_SRC_MASK 0x0003 /* FLL_REFCLK_SRC - [1:0] */ | ||
1732 | #define WM8915_FLL_REFCLK_SRC_SHIFT 0 /* FLL_REFCLK_SRC - [1:0] */ | ||
1733 | #define WM8915_FLL_REFCLK_SRC_WIDTH 2 /* FLL_REFCLK_SRC - [1:0] */ | ||
1734 | |||
1735 | /* | ||
1736 | * R549 (0x225) - FLL Control (6) | ||
1737 | */ | ||
1738 | #define WM8915_FLL_REFCLK_SRC_STS_MASK 0x000C /* FLL_REFCLK_SRC_STS - [3:2] */ | ||
1739 | #define WM8915_FLL_REFCLK_SRC_STS_SHIFT 2 /* FLL_REFCLK_SRC_STS - [3:2] */ | ||
1740 | #define WM8915_FLL_REFCLK_SRC_STS_WIDTH 2 /* FLL_REFCLK_SRC_STS - [3:2] */ | ||
1741 | #define WM8915_FLL_SWITCH_CLK 0x0001 /* FLL_SWITCH_CLK */ | ||
1742 | #define WM8915_FLL_SWITCH_CLK_MASK 0x0001 /* FLL_SWITCH_CLK */ | ||
1743 | #define WM8915_FLL_SWITCH_CLK_SHIFT 0 /* FLL_SWITCH_CLK */ | ||
1744 | #define WM8915_FLL_SWITCH_CLK_WIDTH 1 /* FLL_SWITCH_CLK */ | ||
1745 | |||
1746 | /* | ||
1747 | * R550 (0x226) - FLL EFS 1 | ||
1748 | */ | ||
1749 | #define WM8915_FLL_LAMBDA_MASK 0xFFFF /* FLL_LAMBDA - [15:0] */ | ||
1750 | #define WM8915_FLL_LAMBDA_SHIFT 0 /* FLL_LAMBDA - [15:0] */ | ||
1751 | #define WM8915_FLL_LAMBDA_WIDTH 16 /* FLL_LAMBDA - [15:0] */ | ||
1752 | |||
1753 | /* | ||
1754 | * R551 (0x227) - FLL EFS 2 | ||
1755 | */ | ||
1756 | #define WM8915_FLL_LFSR_SEL_MASK 0x0006 /* FLL_LFSR_SEL - [2:1] */ | ||
1757 | #define WM8915_FLL_LFSR_SEL_SHIFT 1 /* FLL_LFSR_SEL - [2:1] */ | ||
1758 | #define WM8915_FLL_LFSR_SEL_WIDTH 2 /* FLL_LFSR_SEL - [2:1] */ | ||
1759 | #define WM8915_FLL_EFS_ENA 0x0001 /* FLL_EFS_ENA */ | ||
1760 | #define WM8915_FLL_EFS_ENA_MASK 0x0001 /* FLL_EFS_ENA */ | ||
1761 | #define WM8915_FLL_EFS_ENA_SHIFT 0 /* FLL_EFS_ENA */ | ||
1762 | #define WM8915_FLL_EFS_ENA_WIDTH 1 /* FLL_EFS_ENA */ | ||
1763 | |||
1764 | /* | ||
1765 | * R768 (0x300) - AIF1 Control | ||
1766 | */ | ||
1767 | #define WM8915_AIF1_TRI 0x0004 /* AIF1_TRI */ | ||
1768 | #define WM8915_AIF1_TRI_MASK 0x0004 /* AIF1_TRI */ | ||
1769 | #define WM8915_AIF1_TRI_SHIFT 2 /* AIF1_TRI */ | ||
1770 | #define WM8915_AIF1_TRI_WIDTH 1 /* AIF1_TRI */ | ||
1771 | #define WM8915_AIF1_FMT_MASK 0x0003 /* AIF1_FMT - [1:0] */ | ||
1772 | #define WM8915_AIF1_FMT_SHIFT 0 /* AIF1_FMT - [1:0] */ | ||
1773 | #define WM8915_AIF1_FMT_WIDTH 2 /* AIF1_FMT - [1:0] */ | ||
1774 | |||
1775 | /* | ||
1776 | * R769 (0x301) - AIF1 BCLK | ||
1777 | */ | ||
1778 | #define WM8915_AIF1_BCLK_INV 0x0400 /* AIF1_BCLK_INV */ | ||
1779 | #define WM8915_AIF1_BCLK_INV_MASK 0x0400 /* AIF1_BCLK_INV */ | ||
1780 | #define WM8915_AIF1_BCLK_INV_SHIFT 10 /* AIF1_BCLK_INV */ | ||
1781 | #define WM8915_AIF1_BCLK_INV_WIDTH 1 /* AIF1_BCLK_INV */ | ||
1782 | #define WM8915_AIF1_BCLK_FRC 0x0200 /* AIF1_BCLK_FRC */ | ||
1783 | #define WM8915_AIF1_BCLK_FRC_MASK 0x0200 /* AIF1_BCLK_FRC */ | ||
1784 | #define WM8915_AIF1_BCLK_FRC_SHIFT 9 /* AIF1_BCLK_FRC */ | ||
1785 | #define WM8915_AIF1_BCLK_FRC_WIDTH 1 /* AIF1_BCLK_FRC */ | ||
1786 | #define WM8915_AIF1_BCLK_MSTR 0x0100 /* AIF1_BCLK_MSTR */ | ||
1787 | #define WM8915_AIF1_BCLK_MSTR_MASK 0x0100 /* AIF1_BCLK_MSTR */ | ||
1788 | #define WM8915_AIF1_BCLK_MSTR_SHIFT 8 /* AIF1_BCLK_MSTR */ | ||
1789 | #define WM8915_AIF1_BCLK_MSTR_WIDTH 1 /* AIF1_BCLK_MSTR */ | ||
1790 | #define WM8915_AIF1_BCLK_DIV_MASK 0x000F /* AIF1_BCLK_DIV - [3:0] */ | ||
1791 | #define WM8915_AIF1_BCLK_DIV_SHIFT 0 /* AIF1_BCLK_DIV - [3:0] */ | ||
1792 | #define WM8915_AIF1_BCLK_DIV_WIDTH 4 /* AIF1_BCLK_DIV - [3:0] */ | ||
1793 | |||
1794 | /* | ||
1795 | * R770 (0x302) - AIF1 TX LRCLK(1) | ||
1796 | */ | ||
1797 | #define WM8915_AIF1TX_RATE_MASK 0x07FF /* AIF1TX_RATE - [10:0] */ | ||
1798 | #define WM8915_AIF1TX_RATE_SHIFT 0 /* AIF1TX_RATE - [10:0] */ | ||
1799 | #define WM8915_AIF1TX_RATE_WIDTH 11 /* AIF1TX_RATE - [10:0] */ | ||
1800 | |||
1801 | /* | ||
1802 | * R771 (0x303) - AIF1 TX LRCLK(2) | ||
1803 | */ | ||
1804 | #define WM8915_AIF1TX_LRCLK_MODE 0x0008 /* AIF1TX_LRCLK_MODE */ | ||
1805 | #define WM8915_AIF1TX_LRCLK_MODE_MASK 0x0008 /* AIF1TX_LRCLK_MODE */ | ||
1806 | #define WM8915_AIF1TX_LRCLK_MODE_SHIFT 3 /* AIF1TX_LRCLK_MODE */ | ||
1807 | #define WM8915_AIF1TX_LRCLK_MODE_WIDTH 1 /* AIF1TX_LRCLK_MODE */ | ||
1808 | #define WM8915_AIF1TX_LRCLK_INV 0x0004 /* AIF1TX_LRCLK_INV */ | ||
1809 | #define WM8915_AIF1TX_LRCLK_INV_MASK 0x0004 /* AIF1TX_LRCLK_INV */ | ||
1810 | #define WM8915_AIF1TX_LRCLK_INV_SHIFT 2 /* AIF1TX_LRCLK_INV */ | ||
1811 | #define WM8915_AIF1TX_LRCLK_INV_WIDTH 1 /* AIF1TX_LRCLK_INV */ | ||
1812 | #define WM8915_AIF1TX_LRCLK_FRC 0x0002 /* AIF1TX_LRCLK_FRC */ | ||
1813 | #define WM8915_AIF1TX_LRCLK_FRC_MASK 0x0002 /* AIF1TX_LRCLK_FRC */ | ||
1814 | #define WM8915_AIF1TX_LRCLK_FRC_SHIFT 1 /* AIF1TX_LRCLK_FRC */ | ||
1815 | #define WM8915_AIF1TX_LRCLK_FRC_WIDTH 1 /* AIF1TX_LRCLK_FRC */ | ||
1816 | #define WM8915_AIF1TX_LRCLK_MSTR 0x0001 /* AIF1TX_LRCLK_MSTR */ | ||
1817 | #define WM8915_AIF1TX_LRCLK_MSTR_MASK 0x0001 /* AIF1TX_LRCLK_MSTR */ | ||
1818 | #define WM8915_AIF1TX_LRCLK_MSTR_SHIFT 0 /* AIF1TX_LRCLK_MSTR */ | ||
1819 | #define WM8915_AIF1TX_LRCLK_MSTR_WIDTH 1 /* AIF1TX_LRCLK_MSTR */ | ||
1820 | |||
1821 | /* | ||
1822 | * R772 (0x304) - AIF1 RX LRCLK(1) | ||
1823 | */ | ||
1824 | #define WM8915_AIF1RX_RATE_MASK 0x07FF /* AIF1RX_RATE - [10:0] */ | ||
1825 | #define WM8915_AIF1RX_RATE_SHIFT 0 /* AIF1RX_RATE - [10:0] */ | ||
1826 | #define WM8915_AIF1RX_RATE_WIDTH 11 /* AIF1RX_RATE - [10:0] */ | ||
1827 | |||
1828 | /* | ||
1829 | * R773 (0x305) - AIF1 RX LRCLK(2) | ||
1830 | */ | ||
1831 | #define WM8915_AIF1RX_LRCLK_INV 0x0004 /* AIF1RX_LRCLK_INV */ | ||
1832 | #define WM8915_AIF1RX_LRCLK_INV_MASK 0x0004 /* AIF1RX_LRCLK_INV */ | ||
1833 | #define WM8915_AIF1RX_LRCLK_INV_SHIFT 2 /* AIF1RX_LRCLK_INV */ | ||
1834 | #define WM8915_AIF1RX_LRCLK_INV_WIDTH 1 /* AIF1RX_LRCLK_INV */ | ||
1835 | #define WM8915_AIF1RX_LRCLK_FRC 0x0002 /* AIF1RX_LRCLK_FRC */ | ||
1836 | #define WM8915_AIF1RX_LRCLK_FRC_MASK 0x0002 /* AIF1RX_LRCLK_FRC */ | ||
1837 | #define WM8915_AIF1RX_LRCLK_FRC_SHIFT 1 /* AIF1RX_LRCLK_FRC */ | ||
1838 | #define WM8915_AIF1RX_LRCLK_FRC_WIDTH 1 /* AIF1RX_LRCLK_FRC */ | ||
1839 | #define WM8915_AIF1RX_LRCLK_MSTR 0x0001 /* AIF1RX_LRCLK_MSTR */ | ||
1840 | #define WM8915_AIF1RX_LRCLK_MSTR_MASK 0x0001 /* AIF1RX_LRCLK_MSTR */ | ||
1841 | #define WM8915_AIF1RX_LRCLK_MSTR_SHIFT 0 /* AIF1RX_LRCLK_MSTR */ | ||
1842 | #define WM8915_AIF1RX_LRCLK_MSTR_WIDTH 1 /* AIF1RX_LRCLK_MSTR */ | ||
1843 | |||
1844 | /* | ||
1845 | * R774 (0x306) - AIF1TX Data Configuration (1) | ||
1846 | */ | ||
1847 | #define WM8915_AIF1TX_WL_MASK 0xFF00 /* AIF1TX_WL - [15:8] */ | ||
1848 | #define WM8915_AIF1TX_WL_SHIFT 8 /* AIF1TX_WL - [15:8] */ | ||
1849 | #define WM8915_AIF1TX_WL_WIDTH 8 /* AIF1TX_WL - [15:8] */ | ||
1850 | #define WM8915_AIF1TX_SLOT_LEN_MASK 0x00FF /* AIF1TX_SLOT_LEN - [7:0] */ | ||
1851 | #define WM8915_AIF1TX_SLOT_LEN_SHIFT 0 /* AIF1TX_SLOT_LEN - [7:0] */ | ||
1852 | #define WM8915_AIF1TX_SLOT_LEN_WIDTH 8 /* AIF1TX_SLOT_LEN - [7:0] */ | ||
1853 | |||
1854 | /* | ||
1855 | * R775 (0x307) - AIF1TX Data Configuration (2) | ||
1856 | */ | ||
1857 | #define WM8915_AIF1TX_DAT_TRI 0x0001 /* AIF1TX_DAT_TRI */ | ||
1858 | #define WM8915_AIF1TX_DAT_TRI_MASK 0x0001 /* AIF1TX_DAT_TRI */ | ||
1859 | #define WM8915_AIF1TX_DAT_TRI_SHIFT 0 /* AIF1TX_DAT_TRI */ | ||
1860 | #define WM8915_AIF1TX_DAT_TRI_WIDTH 1 /* AIF1TX_DAT_TRI */ | ||
1861 | |||
1862 | /* | ||
1863 | * R776 (0x308) - AIF1RX Data Configuration | ||
1864 | */ | ||
1865 | #define WM8915_AIF1RX_WL_MASK 0xFF00 /* AIF1RX_WL - [15:8] */ | ||
1866 | #define WM8915_AIF1RX_WL_SHIFT 8 /* AIF1RX_WL - [15:8] */ | ||
1867 | #define WM8915_AIF1RX_WL_WIDTH 8 /* AIF1RX_WL - [15:8] */ | ||
1868 | #define WM8915_AIF1RX_SLOT_LEN_MASK 0x00FF /* AIF1RX_SLOT_LEN - [7:0] */ | ||
1869 | #define WM8915_AIF1RX_SLOT_LEN_SHIFT 0 /* AIF1RX_SLOT_LEN - [7:0] */ | ||
1870 | #define WM8915_AIF1RX_SLOT_LEN_WIDTH 8 /* AIF1RX_SLOT_LEN - [7:0] */ | ||
1871 | |||
1872 | /* | ||
1873 | * R777 (0x309) - AIF1TX Channel 0 Configuration | ||
1874 | */ | ||
1875 | #define WM8915_AIF1TX_CHAN0_DAT_INV 0x8000 /* AIF1TX_CHAN0_DAT_INV */ | ||
1876 | #define WM8915_AIF1TX_CHAN0_DAT_INV_MASK 0x8000 /* AIF1TX_CHAN0_DAT_INV */ | ||
1877 | #define WM8915_AIF1TX_CHAN0_DAT_INV_SHIFT 15 /* AIF1TX_CHAN0_DAT_INV */ | ||
1878 | #define WM8915_AIF1TX_CHAN0_DAT_INV_WIDTH 1 /* AIF1TX_CHAN0_DAT_INV */ | ||
1879 | #define WM8915_AIF1TX_CHAN0_SPACING_MASK 0x7E00 /* AIF1TX_CHAN0_SPACING - [14:9] */ | ||
1880 | #define WM8915_AIF1TX_CHAN0_SPACING_SHIFT 9 /* AIF1TX_CHAN0_SPACING - [14:9] */ | ||
1881 | #define WM8915_AIF1TX_CHAN0_SPACING_WIDTH 6 /* AIF1TX_CHAN0_SPACING - [14:9] */ | ||
1882 | #define WM8915_AIF1TX_CHAN0_SLOTS_MASK 0x01C0 /* AIF1TX_CHAN0_SLOTS - [8:6] */ | ||
1883 | #define WM8915_AIF1TX_CHAN0_SLOTS_SHIFT 6 /* AIF1TX_CHAN0_SLOTS - [8:6] */ | ||
1884 | #define WM8915_AIF1TX_CHAN0_SLOTS_WIDTH 3 /* AIF1TX_CHAN0_SLOTS - [8:6] */ | ||
1885 | #define WM8915_AIF1TX_CHAN0_START_SLOT_MASK 0x003F /* AIF1TX_CHAN0_START_SLOT - [5:0] */ | ||
1886 | #define WM8915_AIF1TX_CHAN0_START_SLOT_SHIFT 0 /* AIF1TX_CHAN0_START_SLOT - [5:0] */ | ||
1887 | #define WM8915_AIF1TX_CHAN0_START_SLOT_WIDTH 6 /* AIF1TX_CHAN0_START_SLOT - [5:0] */ | ||
1888 | |||
1889 | /* | ||
1890 | * R778 (0x30A) - AIF1TX Channel 1 Configuration | ||
1891 | */ | ||
1892 | #define WM8915_AIF1TX_CHAN1_DAT_INV 0x8000 /* AIF1TX_CHAN1_DAT_INV */ | ||
1893 | #define WM8915_AIF1TX_CHAN1_DAT_INV_MASK 0x8000 /* AIF1TX_CHAN1_DAT_INV */ | ||
1894 | #define WM8915_AIF1TX_CHAN1_DAT_INV_SHIFT 15 /* AIF1TX_CHAN1_DAT_INV */ | ||
1895 | #define WM8915_AIF1TX_CHAN1_DAT_INV_WIDTH 1 /* AIF1TX_CHAN1_DAT_INV */ | ||
1896 | #define WM8915_AIF1TX_CHAN1_SPACING_MASK 0x7E00 /* AIF1TX_CHAN1_SPACING - [14:9] */ | ||
1897 | #define WM8915_AIF1TX_CHAN1_SPACING_SHIFT 9 /* AIF1TX_CHAN1_SPACING - [14:9] */ | ||
1898 | #define WM8915_AIF1TX_CHAN1_SPACING_WIDTH 6 /* AIF1TX_CHAN1_SPACING - [14:9] */ | ||
1899 | #define WM8915_AIF1TX_CHAN1_SLOTS_MASK 0x01C0 /* AIF1TX_CHAN1_SLOTS - [8:6] */ | ||
1900 | #define WM8915_AIF1TX_CHAN1_SLOTS_SHIFT 6 /* AIF1TX_CHAN1_SLOTS - [8:6] */ | ||
1901 | #define WM8915_AIF1TX_CHAN1_SLOTS_WIDTH 3 /* AIF1TX_CHAN1_SLOTS - [8:6] */ | ||
1902 | #define WM8915_AIF1TX_CHAN1_START_SLOT_MASK 0x003F /* AIF1TX_CHAN1_START_SLOT - [5:0] */ | ||
1903 | #define WM8915_AIF1TX_CHAN1_START_SLOT_SHIFT 0 /* AIF1TX_CHAN1_START_SLOT - [5:0] */ | ||
1904 | #define WM8915_AIF1TX_CHAN1_START_SLOT_WIDTH 6 /* AIF1TX_CHAN1_START_SLOT - [5:0] */ | ||
1905 | |||
1906 | /* | ||
1907 | * R779 (0x30B) - AIF1TX Channel 2 Configuration | ||
1908 | */ | ||
1909 | #define WM8915_AIF1TX_CHAN2_DAT_INV 0x8000 /* AIF1TX_CHAN2_DAT_INV */ | ||
1910 | #define WM8915_AIF1TX_CHAN2_DAT_INV_MASK 0x8000 /* AIF1TX_CHAN2_DAT_INV */ | ||
1911 | #define WM8915_AIF1TX_CHAN2_DAT_INV_SHIFT 15 /* AIF1TX_CHAN2_DAT_INV */ | ||
1912 | #define WM8915_AIF1TX_CHAN2_DAT_INV_WIDTH 1 /* AIF1TX_CHAN2_DAT_INV */ | ||
1913 | #define WM8915_AIF1TX_CHAN2_SPACING_MASK 0x7E00 /* AIF1TX_CHAN2_SPACING - [14:9] */ | ||
1914 | #define WM8915_AIF1TX_CHAN2_SPACING_SHIFT 9 /* AIF1TX_CHAN2_SPACING - [14:9] */ | ||
1915 | #define WM8915_AIF1TX_CHAN2_SPACING_WIDTH 6 /* AIF1TX_CHAN2_SPACING - [14:9] */ | ||
1916 | #define WM8915_AIF1TX_CHAN2_SLOTS_MASK 0x01C0 /* AIF1TX_CHAN2_SLOTS - [8:6] */ | ||
1917 | #define WM8915_AIF1TX_CHAN2_SLOTS_SHIFT 6 /* AIF1TX_CHAN2_SLOTS - [8:6] */ | ||
1918 | #define WM8915_AIF1TX_CHAN2_SLOTS_WIDTH 3 /* AIF1TX_CHAN2_SLOTS - [8:6] */ | ||
1919 | #define WM8915_AIF1TX_CHAN2_START_SLOT_MASK 0x003F /* AIF1TX_CHAN2_START_SLOT - [5:0] */ | ||
1920 | #define WM8915_AIF1TX_CHAN2_START_SLOT_SHIFT 0 /* AIF1TX_CHAN2_START_SLOT - [5:0] */ | ||
1921 | #define WM8915_AIF1TX_CHAN2_START_SLOT_WIDTH 6 /* AIF1TX_CHAN2_START_SLOT - [5:0] */ | ||
1922 | |||
1923 | /* | ||
1924 | * R780 (0x30C) - AIF1TX Channel 3 Configuration | ||
1925 | */ | ||
1926 | #define WM8915_AIF1TX_CHAN3_DAT_INV 0x8000 /* AIF1TX_CHAN3_DAT_INV */ | ||
1927 | #define WM8915_AIF1TX_CHAN3_DAT_INV_MASK 0x8000 /* AIF1TX_CHAN3_DAT_INV */ | ||
1928 | #define WM8915_AIF1TX_CHAN3_DAT_INV_SHIFT 15 /* AIF1TX_CHAN3_DAT_INV */ | ||
1929 | #define WM8915_AIF1TX_CHAN3_DAT_INV_WIDTH 1 /* AIF1TX_CHAN3_DAT_INV */ | ||
1930 | #define WM8915_AIF1TX_CHAN3_SPACING_MASK 0x7E00 /* AIF1TX_CHAN3_SPACING - [14:9] */ | ||
1931 | #define WM8915_AIF1TX_CHAN3_SPACING_SHIFT 9 /* AIF1TX_CHAN3_SPACING - [14:9] */ | ||
1932 | #define WM8915_AIF1TX_CHAN3_SPACING_WIDTH 6 /* AIF1TX_CHAN3_SPACING - [14:9] */ | ||
1933 | #define WM8915_AIF1TX_CHAN3_SLOTS_MASK 0x01C0 /* AIF1TX_CHAN3_SLOTS - [8:6] */ | ||
1934 | #define WM8915_AIF1TX_CHAN3_SLOTS_SHIFT 6 /* AIF1TX_CHAN3_SLOTS - [8:6] */ | ||
1935 | #define WM8915_AIF1TX_CHAN3_SLOTS_WIDTH 3 /* AIF1TX_CHAN3_SLOTS - [8:6] */ | ||
1936 | #define WM8915_AIF1TX_CHAN3_START_SLOT_MASK 0x003F /* AIF1TX_CHAN3_START_SLOT - [5:0] */ | ||
1937 | #define WM8915_AIF1TX_CHAN3_START_SLOT_SHIFT 0 /* AIF1TX_CHAN3_START_SLOT - [5:0] */ | ||
1938 | #define WM8915_AIF1TX_CHAN3_START_SLOT_WIDTH 6 /* AIF1TX_CHAN3_START_SLOT - [5:0] */ | ||
1939 | |||
1940 | /* | ||
1941 | * R781 (0x30D) - AIF1TX Channel 4 Configuration | ||
1942 | */ | ||
1943 | #define WM8915_AIF1TX_CHAN4_DAT_INV 0x8000 /* AIF1TX_CHAN4_DAT_INV */ | ||
1944 | #define WM8915_AIF1TX_CHAN4_DAT_INV_MASK 0x8000 /* AIF1TX_CHAN4_DAT_INV */ | ||
1945 | #define WM8915_AIF1TX_CHAN4_DAT_INV_SHIFT 15 /* AIF1TX_CHAN4_DAT_INV */ | ||
1946 | #define WM8915_AIF1TX_CHAN4_DAT_INV_WIDTH 1 /* AIF1TX_CHAN4_DAT_INV */ | ||
1947 | #define WM8915_AIF1TX_CHAN4_SPACING_MASK 0x7E00 /* AIF1TX_CHAN4_SPACING - [14:9] */ | ||
1948 | #define WM8915_AIF1TX_CHAN4_SPACING_SHIFT 9 /* AIF1TX_CHAN4_SPACING - [14:9] */ | ||
1949 | #define WM8915_AIF1TX_CHAN4_SPACING_WIDTH 6 /* AIF1TX_CHAN4_SPACING - [14:9] */ | ||
1950 | #define WM8915_AIF1TX_CHAN4_SLOTS_MASK 0x01C0 /* AIF1TX_CHAN4_SLOTS - [8:6] */ | ||
1951 | #define WM8915_AIF1TX_CHAN4_SLOTS_SHIFT 6 /* AIF1TX_CHAN4_SLOTS - [8:6] */ | ||
1952 | #define WM8915_AIF1TX_CHAN4_SLOTS_WIDTH 3 /* AIF1TX_CHAN4_SLOTS - [8:6] */ | ||
1953 | #define WM8915_AIF1TX_CHAN4_START_SLOT_MASK 0x003F /* AIF1TX_CHAN4_START_SLOT - [5:0] */ | ||
1954 | #define WM8915_AIF1TX_CHAN4_START_SLOT_SHIFT 0 /* AIF1TX_CHAN4_START_SLOT - [5:0] */ | ||
1955 | #define WM8915_AIF1TX_CHAN4_START_SLOT_WIDTH 6 /* AIF1TX_CHAN4_START_SLOT - [5:0] */ | ||
1956 | |||
1957 | /* | ||
1958 | * R782 (0x30E) - AIF1TX Channel 5 Configuration | ||
1959 | */ | ||
1960 | #define WM8915_AIF1TX_CHAN5_DAT_INV 0x8000 /* AIF1TX_CHAN5_DAT_INV */ | ||
1961 | #define WM8915_AIF1TX_CHAN5_DAT_INV_MASK 0x8000 /* AIF1TX_CHAN5_DAT_INV */ | ||
1962 | #define WM8915_AIF1TX_CHAN5_DAT_INV_SHIFT 15 /* AIF1TX_CHAN5_DAT_INV */ | ||
1963 | #define WM8915_AIF1TX_CHAN5_DAT_INV_WIDTH 1 /* AIF1TX_CHAN5_DAT_INV */ | ||
1964 | #define WM8915_AIF1TX_CHAN5_SPACING_MASK 0x7E00 /* AIF1TX_CHAN5_SPACING - [14:9] */ | ||
1965 | #define WM8915_AIF1TX_CHAN5_SPACING_SHIFT 9 /* AIF1TX_CHAN5_SPACING - [14:9] */ | ||
1966 | #define WM8915_AIF1TX_CHAN5_SPACING_WIDTH 6 /* AIF1TX_CHAN5_SPACING - [14:9] */ | ||
1967 | #define WM8915_AIF1TX_CHAN5_SLOTS_MASK 0x01C0 /* AIF1TX_CHAN5_SLOTS - [8:6] */ | ||
1968 | #define WM8915_AIF1TX_CHAN5_SLOTS_SHIFT 6 /* AIF1TX_CHAN5_SLOTS - [8:6] */ | ||
1969 | #define WM8915_AIF1TX_CHAN5_SLOTS_WIDTH 3 /* AIF1TX_CHAN5_SLOTS - [8:6] */ | ||
1970 | #define WM8915_AIF1TX_CHAN5_START_SLOT_MASK 0x003F /* AIF1TX_CHAN5_START_SLOT - [5:0] */ | ||
1971 | #define WM8915_AIF1TX_CHAN5_START_SLOT_SHIFT 0 /* AIF1TX_CHAN5_START_SLOT - [5:0] */ | ||
1972 | #define WM8915_AIF1TX_CHAN5_START_SLOT_WIDTH 6 /* AIF1TX_CHAN5_START_SLOT - [5:0] */ | ||
1973 | |||
1974 | /* | ||
1975 | * R783 (0x30F) - AIF1RX Channel 0 Configuration | ||
1976 | */ | ||
1977 | #define WM8915_AIF1RX_CHAN0_DAT_INV 0x8000 /* AIF1RX_CHAN0_DAT_INV */ | ||
1978 | #define WM8915_AIF1RX_CHAN0_DAT_INV_MASK 0x8000 /* AIF1RX_CHAN0_DAT_INV */ | ||
1979 | #define WM8915_AIF1RX_CHAN0_DAT_INV_SHIFT 15 /* AIF1RX_CHAN0_DAT_INV */ | ||
1980 | #define WM8915_AIF1RX_CHAN0_DAT_INV_WIDTH 1 /* AIF1RX_CHAN0_DAT_INV */ | ||
1981 | #define WM8915_AIF1RX_CHAN0_SPACING_MASK 0x7E00 /* AIF1RX_CHAN0_SPACING - [14:9] */ | ||
1982 | #define WM8915_AIF1RX_CHAN0_SPACING_SHIFT 9 /* AIF1RX_CHAN0_SPACING - [14:9] */ | ||
1983 | #define WM8915_AIF1RX_CHAN0_SPACING_WIDTH 6 /* AIF1RX_CHAN0_SPACING - [14:9] */ | ||
1984 | #define WM8915_AIF1RX_CHAN0_SLOTS_MASK 0x01C0 /* AIF1RX_CHAN0_SLOTS - [8:6] */ | ||
1985 | #define WM8915_AIF1RX_CHAN0_SLOTS_SHIFT 6 /* AIF1RX_CHAN0_SLOTS - [8:6] */ | ||
1986 | #define WM8915_AIF1RX_CHAN0_SLOTS_WIDTH 3 /* AIF1RX_CHAN0_SLOTS - [8:6] */ | ||
1987 | #define WM8915_AIF1RX_CHAN0_START_SLOT_MASK 0x003F /* AIF1RX_CHAN0_START_SLOT - [5:0] */ | ||
1988 | #define WM8915_AIF1RX_CHAN0_START_SLOT_SHIFT 0 /* AIF1RX_CHAN0_START_SLOT - [5:0] */ | ||
1989 | #define WM8915_AIF1RX_CHAN0_START_SLOT_WIDTH 6 /* AIF1RX_CHAN0_START_SLOT - [5:0] */ | ||
1990 | |||
1991 | /* | ||
1992 | * R784 (0x310) - AIF1RX Channel 1 Configuration | ||
1993 | */ | ||
1994 | #define WM8915_AIF1RX_CHAN1_DAT_INV 0x8000 /* AIF1RX_CHAN1_DAT_INV */ | ||
1995 | #define WM8915_AIF1RX_CHAN1_DAT_INV_MASK 0x8000 /* AIF1RX_CHAN1_DAT_INV */ | ||
1996 | #define WM8915_AIF1RX_CHAN1_DAT_INV_SHIFT 15 /* AIF1RX_CHAN1_DAT_INV */ | ||
1997 | #define WM8915_AIF1RX_CHAN1_DAT_INV_WIDTH 1 /* AIF1RX_CHAN1_DAT_INV */ | ||
1998 | #define WM8915_AIF1RX_CHAN1_SPACING_MASK 0x7E00 /* AIF1RX_CHAN1_SPACING - [14:9] */ | ||
1999 | #define WM8915_AIF1RX_CHAN1_SPACING_SHIFT 9 /* AIF1RX_CHAN1_SPACING - [14:9] */ | ||
2000 | #define WM8915_AIF1RX_CHAN1_SPACING_WIDTH 6 /* AIF1RX_CHAN1_SPACING - [14:9] */ | ||
2001 | #define WM8915_AIF1RX_CHAN1_SLOTS_MASK 0x01C0 /* AIF1RX_CHAN1_SLOTS - [8:6] */ | ||
2002 | #define WM8915_AIF1RX_CHAN1_SLOTS_SHIFT 6 /* AIF1RX_CHAN1_SLOTS - [8:6] */ | ||
2003 | #define WM8915_AIF1RX_CHAN1_SLOTS_WIDTH 3 /* AIF1RX_CHAN1_SLOTS - [8:6] */ | ||
2004 | #define WM8915_AIF1RX_CHAN1_START_SLOT_MASK 0x003F /* AIF1RX_CHAN1_START_SLOT - [5:0] */ | ||
2005 | #define WM8915_AIF1RX_CHAN1_START_SLOT_SHIFT 0 /* AIF1RX_CHAN1_START_SLOT - [5:0] */ | ||
2006 | #define WM8915_AIF1RX_CHAN1_START_SLOT_WIDTH 6 /* AIF1RX_CHAN1_START_SLOT - [5:0] */ | ||
2007 | |||
2008 | /* | ||
2009 | * R785 (0x311) - AIF1RX Channel 2 Configuration | ||
2010 | */ | ||
2011 | #define WM8915_AIF1RX_CHAN2_DAT_INV 0x8000 /* AIF1RX_CHAN2_DAT_INV */ | ||
2012 | #define WM8915_AIF1RX_CHAN2_DAT_INV_MASK 0x8000 /* AIF1RX_CHAN2_DAT_INV */ | ||
2013 | #define WM8915_AIF1RX_CHAN2_DAT_INV_SHIFT 15 /* AIF1RX_CHAN2_DAT_INV */ | ||
2014 | #define WM8915_AIF1RX_CHAN2_DAT_INV_WIDTH 1 /* AIF1RX_CHAN2_DAT_INV */ | ||
2015 | #define WM8915_AIF1RX_CHAN2_SPACING_MASK 0x7E00 /* AIF1RX_CHAN2_SPACING - [14:9] */ | ||
2016 | #define WM8915_AIF1RX_CHAN2_SPACING_SHIFT 9 /* AIF1RX_CHAN2_SPACING - [14:9] */ | ||
2017 | #define WM8915_AIF1RX_CHAN2_SPACING_WIDTH 6 /* AIF1RX_CHAN2_SPACING - [14:9] */ | ||
2018 | #define WM8915_AIF1RX_CHAN2_SLOTS_MASK 0x01C0 /* AIF1RX_CHAN2_SLOTS - [8:6] */ | ||
2019 | #define WM8915_AIF1RX_CHAN2_SLOTS_SHIFT 6 /* AIF1RX_CHAN2_SLOTS - [8:6] */ | ||
2020 | #define WM8915_AIF1RX_CHAN2_SLOTS_WIDTH 3 /* AIF1RX_CHAN2_SLOTS - [8:6] */ | ||
2021 | #define WM8915_AIF1RX_CHAN2_START_SLOT_MASK 0x003F /* AIF1RX_CHAN2_START_SLOT - [5:0] */ | ||
2022 | #define WM8915_AIF1RX_CHAN2_START_SLOT_SHIFT 0 /* AIF1RX_CHAN2_START_SLOT - [5:0] */ | ||
2023 | #define WM8915_AIF1RX_CHAN2_START_SLOT_WIDTH 6 /* AIF1RX_CHAN2_START_SLOT - [5:0] */ | ||
2024 | |||
2025 | /* | ||
2026 | * R786 (0x312) - AIF1RX Channel 3 Configuration | ||
2027 | */ | ||
2028 | #define WM8915_AIF1RX_CHAN3_DAT_INV 0x8000 /* AIF1RX_CHAN3_DAT_INV */ | ||
2029 | #define WM8915_AIF1RX_CHAN3_DAT_INV_MASK 0x8000 /* AIF1RX_CHAN3_DAT_INV */ | ||
2030 | #define WM8915_AIF1RX_CHAN3_DAT_INV_SHIFT 15 /* AIF1RX_CHAN3_DAT_INV */ | ||
2031 | #define WM8915_AIF1RX_CHAN3_DAT_INV_WIDTH 1 /* AIF1RX_CHAN3_DAT_INV */ | ||
2032 | #define WM8915_AIF1RX_CHAN3_SPACING_MASK 0x7E00 /* AIF1RX_CHAN3_SPACING - [14:9] */ | ||
2033 | #define WM8915_AIF1RX_CHAN3_SPACING_SHIFT 9 /* AIF1RX_CHAN3_SPACING - [14:9] */ | ||
2034 | #define WM8915_AIF1RX_CHAN3_SPACING_WIDTH 6 /* AIF1RX_CHAN3_SPACING - [14:9] */ | ||
2035 | #define WM8915_AIF1RX_CHAN3_SLOTS_MASK 0x01C0 /* AIF1RX_CHAN3_SLOTS - [8:6] */ | ||
2036 | #define WM8915_AIF1RX_CHAN3_SLOTS_SHIFT 6 /* AIF1RX_CHAN3_SLOTS - [8:6] */ | ||
2037 | #define WM8915_AIF1RX_CHAN3_SLOTS_WIDTH 3 /* AIF1RX_CHAN3_SLOTS - [8:6] */ | ||
2038 | #define WM8915_AIF1RX_CHAN3_START_SLOT_MASK 0x003F /* AIF1RX_CHAN3_START_SLOT - [5:0] */ | ||
2039 | #define WM8915_AIF1RX_CHAN3_START_SLOT_SHIFT 0 /* AIF1RX_CHAN3_START_SLOT - [5:0] */ | ||
2040 | #define WM8915_AIF1RX_CHAN3_START_SLOT_WIDTH 6 /* AIF1RX_CHAN3_START_SLOT - [5:0] */ | ||
2041 | |||
2042 | /* | ||
2043 | * R787 (0x313) - AIF1RX Channel 4 Configuration | ||
2044 | */ | ||
2045 | #define WM8915_AIF1RX_CHAN4_DAT_INV 0x8000 /* AIF1RX_CHAN4_DAT_INV */ | ||
2046 | #define WM8915_AIF1RX_CHAN4_DAT_INV_MASK 0x8000 /* AIF1RX_CHAN4_DAT_INV */ | ||
2047 | #define WM8915_AIF1RX_CHAN4_DAT_INV_SHIFT 15 /* AIF1RX_CHAN4_DAT_INV */ | ||
2048 | #define WM8915_AIF1RX_CHAN4_DAT_INV_WIDTH 1 /* AIF1RX_CHAN4_DAT_INV */ | ||
2049 | #define WM8915_AIF1RX_CHAN4_SPACING_MASK 0x7E00 /* AIF1RX_CHAN4_SPACING - [14:9] */ | ||
2050 | #define WM8915_AIF1RX_CHAN4_SPACING_SHIFT 9 /* AIF1RX_CHAN4_SPACING - [14:9] */ | ||
2051 | #define WM8915_AIF1RX_CHAN4_SPACING_WIDTH 6 /* AIF1RX_CHAN4_SPACING - [14:9] */ | ||
2052 | #define WM8915_AIF1RX_CHAN4_SLOTS_MASK 0x01C0 /* AIF1RX_CHAN4_SLOTS - [8:6] */ | ||
2053 | #define WM8915_AIF1RX_CHAN4_SLOTS_SHIFT 6 /* AIF1RX_CHAN4_SLOTS - [8:6] */ | ||
2054 | #define WM8915_AIF1RX_CHAN4_SLOTS_WIDTH 3 /* AIF1RX_CHAN4_SLOTS - [8:6] */ | ||
2055 | #define WM8915_AIF1RX_CHAN4_START_SLOT_MASK 0x003F /* AIF1RX_CHAN4_START_SLOT - [5:0] */ | ||
2056 | #define WM8915_AIF1RX_CHAN4_START_SLOT_SHIFT 0 /* AIF1RX_CHAN4_START_SLOT - [5:0] */ | ||
2057 | #define WM8915_AIF1RX_CHAN4_START_SLOT_WIDTH 6 /* AIF1RX_CHAN4_START_SLOT - [5:0] */ | ||
2058 | |||
2059 | /* | ||
2060 | * R788 (0x314) - AIF1RX Channel 5 Configuration | ||
2061 | */ | ||
2062 | #define WM8915_AIF1RX_CHAN5_DAT_INV 0x8000 /* AIF1RX_CHAN5_DAT_INV */ | ||
2063 | #define WM8915_AIF1RX_CHAN5_DAT_INV_MASK 0x8000 /* AIF1RX_CHAN5_DAT_INV */ | ||
2064 | #define WM8915_AIF1RX_CHAN5_DAT_INV_SHIFT 15 /* AIF1RX_CHAN5_DAT_INV */ | ||
2065 | #define WM8915_AIF1RX_CHAN5_DAT_INV_WIDTH 1 /* AIF1RX_CHAN5_DAT_INV */ | ||
2066 | #define WM8915_AIF1RX_CHAN5_SPACING_MASK 0x7E00 /* AIF1RX_CHAN5_SPACING - [14:9] */ | ||
2067 | #define WM8915_AIF1RX_CHAN5_SPACING_SHIFT 9 /* AIF1RX_CHAN5_SPACING - [14:9] */ | ||
2068 | #define WM8915_AIF1RX_CHAN5_SPACING_WIDTH 6 /* AIF1RX_CHAN5_SPACING - [14:9] */ | ||
2069 | #define WM8915_AIF1RX_CHAN5_SLOTS_MASK 0x01C0 /* AIF1RX_CHAN5_SLOTS - [8:6] */ | ||
2070 | #define WM8915_AIF1RX_CHAN5_SLOTS_SHIFT 6 /* AIF1RX_CHAN5_SLOTS - [8:6] */ | ||
2071 | #define WM8915_AIF1RX_CHAN5_SLOTS_WIDTH 3 /* AIF1RX_CHAN5_SLOTS - [8:6] */ | ||
2072 | #define WM8915_AIF1RX_CHAN5_START_SLOT_MASK 0x003F /* AIF1RX_CHAN5_START_SLOT - [5:0] */ | ||
2073 | #define WM8915_AIF1RX_CHAN5_START_SLOT_SHIFT 0 /* AIF1RX_CHAN5_START_SLOT - [5:0] */ | ||
2074 | #define WM8915_AIF1RX_CHAN5_START_SLOT_WIDTH 6 /* AIF1RX_CHAN5_START_SLOT - [5:0] */ | ||
2075 | |||
2076 | /* | ||
2077 | * R789 (0x315) - AIF1RX Mono Configuration | ||
2078 | */ | ||
2079 | #define WM8915_AIF1RX_CHAN4_MONO_MODE 0x0004 /* AIF1RX_CHAN4_MONO_MODE */ | ||
2080 | #define WM8915_AIF1RX_CHAN4_MONO_MODE_MASK 0x0004 /* AIF1RX_CHAN4_MONO_MODE */ | ||
2081 | #define WM8915_AIF1RX_CHAN4_MONO_MODE_SHIFT 2 /* AIF1RX_CHAN4_MONO_MODE */ | ||
2082 | #define WM8915_AIF1RX_CHAN4_MONO_MODE_WIDTH 1 /* AIF1RX_CHAN4_MONO_MODE */ | ||
2083 | #define WM8915_AIF1RX_CHAN2_MONO_MODE 0x0002 /* AIF1RX_CHAN2_MONO_MODE */ | ||
2084 | #define WM8915_AIF1RX_CHAN2_MONO_MODE_MASK 0x0002 /* AIF1RX_CHAN2_MONO_MODE */ | ||
2085 | #define WM8915_AIF1RX_CHAN2_MONO_MODE_SHIFT 1 /* AIF1RX_CHAN2_MONO_MODE */ | ||
2086 | #define WM8915_AIF1RX_CHAN2_MONO_MODE_WIDTH 1 /* AIF1RX_CHAN2_MONO_MODE */ | ||
2087 | #define WM8915_AIF1RX_CHAN0_MONO_MODE 0x0001 /* AIF1RX_CHAN0_MONO_MODE */ | ||
2088 | #define WM8915_AIF1RX_CHAN0_MONO_MODE_MASK 0x0001 /* AIF1RX_CHAN0_MONO_MODE */ | ||
2089 | #define WM8915_AIF1RX_CHAN0_MONO_MODE_SHIFT 0 /* AIF1RX_CHAN0_MONO_MODE */ | ||
2090 | #define WM8915_AIF1RX_CHAN0_MONO_MODE_WIDTH 1 /* AIF1RX_CHAN0_MONO_MODE */ | ||
2091 | |||
2092 | /* | ||
2093 | * R794 (0x31A) - AIF1TX Test | ||
2094 | */ | ||
2095 | #define WM8915_AIF1TX45_DITHER_ENA 0x0004 /* AIF1TX45_DITHER_ENA */ | ||
2096 | #define WM8915_AIF1TX45_DITHER_ENA_MASK 0x0004 /* AIF1TX45_DITHER_ENA */ | ||
2097 | #define WM8915_AIF1TX45_DITHER_ENA_SHIFT 2 /* AIF1TX45_DITHER_ENA */ | ||
2098 | #define WM8915_AIF1TX45_DITHER_ENA_WIDTH 1 /* AIF1TX45_DITHER_ENA */ | ||
2099 | #define WM8915_AIF1TX23_DITHER_ENA 0x0002 /* AIF1TX23_DITHER_ENA */ | ||
2100 | #define WM8915_AIF1TX23_DITHER_ENA_MASK 0x0002 /* AIF1TX23_DITHER_ENA */ | ||
2101 | #define WM8915_AIF1TX23_DITHER_ENA_SHIFT 1 /* AIF1TX23_DITHER_ENA */ | ||
2102 | #define WM8915_AIF1TX23_DITHER_ENA_WIDTH 1 /* AIF1TX23_DITHER_ENA */ | ||
2103 | #define WM8915_AIF1TX01_DITHER_ENA 0x0001 /* AIF1TX01_DITHER_ENA */ | ||
2104 | #define WM8915_AIF1TX01_DITHER_ENA_MASK 0x0001 /* AIF1TX01_DITHER_ENA */ | ||
2105 | #define WM8915_AIF1TX01_DITHER_ENA_SHIFT 0 /* AIF1TX01_DITHER_ENA */ | ||
2106 | #define WM8915_AIF1TX01_DITHER_ENA_WIDTH 1 /* AIF1TX01_DITHER_ENA */ | ||
2107 | |||
2108 | /* | ||
2109 | * R800 (0x320) - AIF2 Control | ||
2110 | */ | ||
2111 | #define WM8915_AIF2_TRI 0x0004 /* AIF2_TRI */ | ||
2112 | #define WM8915_AIF2_TRI_MASK 0x0004 /* AIF2_TRI */ | ||
2113 | #define WM8915_AIF2_TRI_SHIFT 2 /* AIF2_TRI */ | ||
2114 | #define WM8915_AIF2_TRI_WIDTH 1 /* AIF2_TRI */ | ||
2115 | #define WM8915_AIF2_FMT_MASK 0x0003 /* AIF2_FMT - [1:0] */ | ||
2116 | #define WM8915_AIF2_FMT_SHIFT 0 /* AIF2_FMT - [1:0] */ | ||
2117 | #define WM8915_AIF2_FMT_WIDTH 2 /* AIF2_FMT - [1:0] */ | ||
2118 | |||
2119 | /* | ||
2120 | * R801 (0x321) - AIF2 BCLK | ||
2121 | */ | ||
2122 | #define WM8915_AIF2_BCLK_INV 0x0400 /* AIF2_BCLK_INV */ | ||
2123 | #define WM8915_AIF2_BCLK_INV_MASK 0x0400 /* AIF2_BCLK_INV */ | ||
2124 | #define WM8915_AIF2_BCLK_INV_SHIFT 10 /* AIF2_BCLK_INV */ | ||
2125 | #define WM8915_AIF2_BCLK_INV_WIDTH 1 /* AIF2_BCLK_INV */ | ||
2126 | #define WM8915_AIF2_BCLK_FRC 0x0200 /* AIF2_BCLK_FRC */ | ||
2127 | #define WM8915_AIF2_BCLK_FRC_MASK 0x0200 /* AIF2_BCLK_FRC */ | ||
2128 | #define WM8915_AIF2_BCLK_FRC_SHIFT 9 /* AIF2_BCLK_FRC */ | ||
2129 | #define WM8915_AIF2_BCLK_FRC_WIDTH 1 /* AIF2_BCLK_FRC */ | ||
2130 | #define WM8915_AIF2_BCLK_MSTR 0x0100 /* AIF2_BCLK_MSTR */ | ||
2131 | #define WM8915_AIF2_BCLK_MSTR_MASK 0x0100 /* AIF2_BCLK_MSTR */ | ||
2132 | #define WM8915_AIF2_BCLK_MSTR_SHIFT 8 /* AIF2_BCLK_MSTR */ | ||
2133 | #define WM8915_AIF2_BCLK_MSTR_WIDTH 1 /* AIF2_BCLK_MSTR */ | ||
2134 | #define WM8915_AIF2_BCLK_DIV_MASK 0x000F /* AIF2_BCLK_DIV - [3:0] */ | ||
2135 | #define WM8915_AIF2_BCLK_DIV_SHIFT 0 /* AIF2_BCLK_DIV - [3:0] */ | ||
2136 | #define WM8915_AIF2_BCLK_DIV_WIDTH 4 /* AIF2_BCLK_DIV - [3:0] */ | ||
2137 | |||
2138 | /* | ||
2139 | * R802 (0x322) - AIF2 TX LRCLK(1) | ||
2140 | */ | ||
2141 | #define WM8915_AIF2TX_RATE_MASK 0x07FF /* AIF2TX_RATE - [10:0] */ | ||
2142 | #define WM8915_AIF2TX_RATE_SHIFT 0 /* AIF2TX_RATE - [10:0] */ | ||
2143 | #define WM8915_AIF2TX_RATE_WIDTH 11 /* AIF2TX_RATE - [10:0] */ | ||
2144 | |||
2145 | /* | ||
2146 | * R803 (0x323) - AIF2 TX LRCLK(2) | ||
2147 | */ | ||
2148 | #define WM8915_AIF2TX_LRCLK_MODE 0x0008 /* AIF2TX_LRCLK_MODE */ | ||
2149 | #define WM8915_AIF2TX_LRCLK_MODE_MASK 0x0008 /* AIF2TX_LRCLK_MODE */ | ||
2150 | #define WM8915_AIF2TX_LRCLK_MODE_SHIFT 3 /* AIF2TX_LRCLK_MODE */ | ||
2151 | #define WM8915_AIF2TX_LRCLK_MODE_WIDTH 1 /* AIF2TX_LRCLK_MODE */ | ||
2152 | #define WM8915_AIF2TX_LRCLK_INV 0x0004 /* AIF2TX_LRCLK_INV */ | ||
2153 | #define WM8915_AIF2TX_LRCLK_INV_MASK 0x0004 /* AIF2TX_LRCLK_INV */ | ||
2154 | #define WM8915_AIF2TX_LRCLK_INV_SHIFT 2 /* AIF2TX_LRCLK_INV */ | ||
2155 | #define WM8915_AIF2TX_LRCLK_INV_WIDTH 1 /* AIF2TX_LRCLK_INV */ | ||
2156 | #define WM8915_AIF2TX_LRCLK_FRC 0x0002 /* AIF2TX_LRCLK_FRC */ | ||
2157 | #define WM8915_AIF2TX_LRCLK_FRC_MASK 0x0002 /* AIF2TX_LRCLK_FRC */ | ||
2158 | #define WM8915_AIF2TX_LRCLK_FRC_SHIFT 1 /* AIF2TX_LRCLK_FRC */ | ||
2159 | #define WM8915_AIF2TX_LRCLK_FRC_WIDTH 1 /* AIF2TX_LRCLK_FRC */ | ||
2160 | #define WM8915_AIF2TX_LRCLK_MSTR 0x0001 /* AIF2TX_LRCLK_MSTR */ | ||
2161 | #define WM8915_AIF2TX_LRCLK_MSTR_MASK 0x0001 /* AIF2TX_LRCLK_MSTR */ | ||
2162 | #define WM8915_AIF2TX_LRCLK_MSTR_SHIFT 0 /* AIF2TX_LRCLK_MSTR */ | ||
2163 | #define WM8915_AIF2TX_LRCLK_MSTR_WIDTH 1 /* AIF2TX_LRCLK_MSTR */ | ||
2164 | |||
2165 | /* | ||
2166 | * R804 (0x324) - AIF2 RX LRCLK(1) | ||
2167 | */ | ||
2168 | #define WM8915_AIF2RX_RATE_MASK 0x07FF /* AIF2RX_RATE - [10:0] */ | ||
2169 | #define WM8915_AIF2RX_RATE_SHIFT 0 /* AIF2RX_RATE - [10:0] */ | ||
2170 | #define WM8915_AIF2RX_RATE_WIDTH 11 /* AIF2RX_RATE - [10:0] */ | ||
2171 | |||
2172 | /* | ||
2173 | * R805 (0x325) - AIF2 RX LRCLK(2) | ||
2174 | */ | ||
2175 | #define WM8915_AIF2RX_LRCLK_INV 0x0004 /* AIF2RX_LRCLK_INV */ | ||
2176 | #define WM8915_AIF2RX_LRCLK_INV_MASK 0x0004 /* AIF2RX_LRCLK_INV */ | ||
2177 | #define WM8915_AIF2RX_LRCLK_INV_SHIFT 2 /* AIF2RX_LRCLK_INV */ | ||
2178 | #define WM8915_AIF2RX_LRCLK_INV_WIDTH 1 /* AIF2RX_LRCLK_INV */ | ||
2179 | #define WM8915_AIF2RX_LRCLK_FRC 0x0002 /* AIF2RX_LRCLK_FRC */ | ||
2180 | #define WM8915_AIF2RX_LRCLK_FRC_MASK 0x0002 /* AIF2RX_LRCLK_FRC */ | ||
2181 | #define WM8915_AIF2RX_LRCLK_FRC_SHIFT 1 /* AIF2RX_LRCLK_FRC */ | ||
2182 | #define WM8915_AIF2RX_LRCLK_FRC_WIDTH 1 /* AIF2RX_LRCLK_FRC */ | ||
2183 | #define WM8915_AIF2RX_LRCLK_MSTR 0x0001 /* AIF2RX_LRCLK_MSTR */ | ||
2184 | #define WM8915_AIF2RX_LRCLK_MSTR_MASK 0x0001 /* AIF2RX_LRCLK_MSTR */ | ||
2185 | #define WM8915_AIF2RX_LRCLK_MSTR_SHIFT 0 /* AIF2RX_LRCLK_MSTR */ | ||
2186 | #define WM8915_AIF2RX_LRCLK_MSTR_WIDTH 1 /* AIF2RX_LRCLK_MSTR */ | ||
2187 | |||
2188 | /* | ||
2189 | * R806 (0x326) - AIF2TX Data Configuration (1) | ||
2190 | */ | ||
2191 | #define WM8915_AIF2TX_WL_MASK 0xFF00 /* AIF2TX_WL - [15:8] */ | ||
2192 | #define WM8915_AIF2TX_WL_SHIFT 8 /* AIF2TX_WL - [15:8] */ | ||
2193 | #define WM8915_AIF2TX_WL_WIDTH 8 /* AIF2TX_WL - [15:8] */ | ||
2194 | #define WM8915_AIF2TX_SLOT_LEN_MASK 0x00FF /* AIF2TX_SLOT_LEN - [7:0] */ | ||
2195 | #define WM8915_AIF2TX_SLOT_LEN_SHIFT 0 /* AIF2TX_SLOT_LEN - [7:0] */ | ||
2196 | #define WM8915_AIF2TX_SLOT_LEN_WIDTH 8 /* AIF2TX_SLOT_LEN - [7:0] */ | ||
2197 | |||
2198 | /* | ||
2199 | * R807 (0x327) - AIF2TX Data Configuration (2) | ||
2200 | */ | ||
2201 | #define WM8915_AIF2TX_DAT_TRI 0x0001 /* AIF2TX_DAT_TRI */ | ||
2202 | #define WM8915_AIF2TX_DAT_TRI_MASK 0x0001 /* AIF2TX_DAT_TRI */ | ||
2203 | #define WM8915_AIF2TX_DAT_TRI_SHIFT 0 /* AIF2TX_DAT_TRI */ | ||
2204 | #define WM8915_AIF2TX_DAT_TRI_WIDTH 1 /* AIF2TX_DAT_TRI */ | ||
2205 | |||
2206 | /* | ||
2207 | * R808 (0x328) - AIF2RX Data Configuration | ||
2208 | */ | ||
2209 | #define WM8915_AIF2RX_WL_MASK 0xFF00 /* AIF2RX_WL - [15:8] */ | ||
2210 | #define WM8915_AIF2RX_WL_SHIFT 8 /* AIF2RX_WL - [15:8] */ | ||
2211 | #define WM8915_AIF2RX_WL_WIDTH 8 /* AIF2RX_WL - [15:8] */ | ||
2212 | #define WM8915_AIF2RX_SLOT_LEN_MASK 0x00FF /* AIF2RX_SLOT_LEN - [7:0] */ | ||
2213 | #define WM8915_AIF2RX_SLOT_LEN_SHIFT 0 /* AIF2RX_SLOT_LEN - [7:0] */ | ||
2214 | #define WM8915_AIF2RX_SLOT_LEN_WIDTH 8 /* AIF2RX_SLOT_LEN - [7:0] */ | ||
2215 | |||
2216 | /* | ||
2217 | * R809 (0x329) - AIF2TX Channel 0 Configuration | ||
2218 | */ | ||
2219 | #define WM8915_AIF2TX_CHAN0_DAT_INV 0x8000 /* AIF2TX_CHAN0_DAT_INV */ | ||
2220 | #define WM8915_AIF2TX_CHAN0_DAT_INV_MASK 0x8000 /* AIF2TX_CHAN0_DAT_INV */ | ||
2221 | #define WM8915_AIF2TX_CHAN0_DAT_INV_SHIFT 15 /* AIF2TX_CHAN0_DAT_INV */ | ||
2222 | #define WM8915_AIF2TX_CHAN0_DAT_INV_WIDTH 1 /* AIF2TX_CHAN0_DAT_INV */ | ||
2223 | #define WM8915_AIF2TX_CHAN0_SPACING_MASK 0x7E00 /* AIF2TX_CHAN0_SPACING - [14:9] */ | ||
2224 | #define WM8915_AIF2TX_CHAN0_SPACING_SHIFT 9 /* AIF2TX_CHAN0_SPACING - [14:9] */ | ||
2225 | #define WM8915_AIF2TX_CHAN0_SPACING_WIDTH 6 /* AIF2TX_CHAN0_SPACING - [14:9] */ | ||
2226 | #define WM8915_AIF2TX_CHAN0_SLOTS_MASK 0x01C0 /* AIF2TX_CHAN0_SLOTS - [8:6] */ | ||
2227 | #define WM8915_AIF2TX_CHAN0_SLOTS_SHIFT 6 /* AIF2TX_CHAN0_SLOTS - [8:6] */ | ||
2228 | #define WM8915_AIF2TX_CHAN0_SLOTS_WIDTH 3 /* AIF2TX_CHAN0_SLOTS - [8:6] */ | ||
2229 | #define WM8915_AIF2TX_CHAN0_START_SLOT_MASK 0x003F /* AIF2TX_CHAN0_START_SLOT - [5:0] */ | ||
2230 | #define WM8915_AIF2TX_CHAN0_START_SLOT_SHIFT 0 /* AIF2TX_CHAN0_START_SLOT - [5:0] */ | ||
2231 | #define WM8915_AIF2TX_CHAN0_START_SLOT_WIDTH 6 /* AIF2TX_CHAN0_START_SLOT - [5:0] */ | ||
2232 | |||
2233 | /* | ||
2234 | * R810 (0x32A) - AIF2TX Channel 1 Configuration | ||
2235 | */ | ||
2236 | #define WM8915_AIF2TX_CHAN1_DAT_INV 0x8000 /* AIF2TX_CHAN1_DAT_INV */ | ||
2237 | #define WM8915_AIF2TX_CHAN1_DAT_INV_MASK 0x8000 /* AIF2TX_CHAN1_DAT_INV */ | ||
2238 | #define WM8915_AIF2TX_CHAN1_DAT_INV_SHIFT 15 /* AIF2TX_CHAN1_DAT_INV */ | ||
2239 | #define WM8915_AIF2TX_CHAN1_DAT_INV_WIDTH 1 /* AIF2TX_CHAN1_DAT_INV */ | ||
2240 | #define WM8915_AIF2TX_CHAN1_SPACING_MASK 0x7E00 /* AIF2TX_CHAN1_SPACING - [14:9] */ | ||
2241 | #define WM8915_AIF2TX_CHAN1_SPACING_SHIFT 9 /* AIF2TX_CHAN1_SPACING - [14:9] */ | ||
2242 | #define WM8915_AIF2TX_CHAN1_SPACING_WIDTH 6 /* AIF2TX_CHAN1_SPACING - [14:9] */ | ||
2243 | #define WM8915_AIF2TX_CHAN1_SLOTS_MASK 0x01C0 /* AIF2TX_CHAN1_SLOTS - [8:6] */ | ||
2244 | #define WM8915_AIF2TX_CHAN1_SLOTS_SHIFT 6 /* AIF2TX_CHAN1_SLOTS - [8:6] */ | ||
2245 | #define WM8915_AIF2TX_CHAN1_SLOTS_WIDTH 3 /* AIF2TX_CHAN1_SLOTS - [8:6] */ | ||
2246 | #define WM8915_AIF2TX_CHAN1_START_SLOT_MASK 0x003F /* AIF2TX_CHAN1_START_SLOT - [5:0] */ | ||
2247 | #define WM8915_AIF2TX_CHAN1_START_SLOT_SHIFT 0 /* AIF2TX_CHAN1_START_SLOT - [5:0] */ | ||
2248 | #define WM8915_AIF2TX_CHAN1_START_SLOT_WIDTH 6 /* AIF2TX_CHAN1_START_SLOT - [5:0] */ | ||
2249 | |||
2250 | /* | ||
2251 | * R811 (0x32B) - AIF2RX Channel 0 Configuration | ||
2252 | */ | ||
2253 | #define WM8915_AIF2RX_CHAN0_DAT_INV 0x8000 /* AIF2RX_CHAN0_DAT_INV */ | ||
2254 | #define WM8915_AIF2RX_CHAN0_DAT_INV_MASK 0x8000 /* AIF2RX_CHAN0_DAT_INV */ | ||
2255 | #define WM8915_AIF2RX_CHAN0_DAT_INV_SHIFT 15 /* AIF2RX_CHAN0_DAT_INV */ | ||
2256 | #define WM8915_AIF2RX_CHAN0_DAT_INV_WIDTH 1 /* AIF2RX_CHAN0_DAT_INV */ | ||
2257 | #define WM8915_AIF2RX_CHAN0_SPACING_MASK 0x7E00 /* AIF2RX_CHAN0_SPACING - [14:9] */ | ||
2258 | #define WM8915_AIF2RX_CHAN0_SPACING_SHIFT 9 /* AIF2RX_CHAN0_SPACING - [14:9] */ | ||
2259 | #define WM8915_AIF2RX_CHAN0_SPACING_WIDTH 6 /* AIF2RX_CHAN0_SPACING - [14:9] */ | ||
2260 | #define WM8915_AIF2RX_CHAN0_SLOTS_MASK 0x01C0 /* AIF2RX_CHAN0_SLOTS - [8:6] */ | ||
2261 | #define WM8915_AIF2RX_CHAN0_SLOTS_SHIFT 6 /* AIF2RX_CHAN0_SLOTS - [8:6] */ | ||
2262 | #define WM8915_AIF2RX_CHAN0_SLOTS_WIDTH 3 /* AIF2RX_CHAN0_SLOTS - [8:6] */ | ||
2263 | #define WM8915_AIF2RX_CHAN0_START_SLOT_MASK 0x003F /* AIF2RX_CHAN0_START_SLOT - [5:0] */ | ||
2264 | #define WM8915_AIF2RX_CHAN0_START_SLOT_SHIFT 0 /* AIF2RX_CHAN0_START_SLOT - [5:0] */ | ||
2265 | #define WM8915_AIF2RX_CHAN0_START_SLOT_WIDTH 6 /* AIF2RX_CHAN0_START_SLOT - [5:0] */ | ||
2266 | |||
2267 | /* | ||
2268 | * R812 (0x32C) - AIF2RX Channel 1 Configuration | ||
2269 | */ | ||
2270 | #define WM8915_AIF2RX_CHAN1_DAT_INV 0x8000 /* AIF2RX_CHAN1_DAT_INV */ | ||
2271 | #define WM8915_AIF2RX_CHAN1_DAT_INV_MASK 0x8000 /* AIF2RX_CHAN1_DAT_INV */ | ||
2272 | #define WM8915_AIF2RX_CHAN1_DAT_INV_SHIFT 15 /* AIF2RX_CHAN1_DAT_INV */ | ||
2273 | #define WM8915_AIF2RX_CHAN1_DAT_INV_WIDTH 1 /* AIF2RX_CHAN1_DAT_INV */ | ||
2274 | #define WM8915_AIF2RX_CHAN1_SPACING_MASK 0x7E00 /* AIF2RX_CHAN1_SPACING - [14:9] */ | ||
2275 | #define WM8915_AIF2RX_CHAN1_SPACING_SHIFT 9 /* AIF2RX_CHAN1_SPACING - [14:9] */ | ||
2276 | #define WM8915_AIF2RX_CHAN1_SPACING_WIDTH 6 /* AIF2RX_CHAN1_SPACING - [14:9] */ | ||
2277 | #define WM8915_AIF2RX_CHAN1_SLOTS_MASK 0x01C0 /* AIF2RX_CHAN1_SLOTS - [8:6] */ | ||
2278 | #define WM8915_AIF2RX_CHAN1_SLOTS_SHIFT 6 /* AIF2RX_CHAN1_SLOTS - [8:6] */ | ||
2279 | #define WM8915_AIF2RX_CHAN1_SLOTS_WIDTH 3 /* AIF2RX_CHAN1_SLOTS - [8:6] */ | ||
2280 | #define WM8915_AIF2RX_CHAN1_START_SLOT_MASK 0x003F /* AIF2RX_CHAN1_START_SLOT - [5:0] */ | ||
2281 | #define WM8915_AIF2RX_CHAN1_START_SLOT_SHIFT 0 /* AIF2RX_CHAN1_START_SLOT - [5:0] */ | ||
2282 | #define WM8915_AIF2RX_CHAN1_START_SLOT_WIDTH 6 /* AIF2RX_CHAN1_START_SLOT - [5:0] */ | ||
2283 | |||
2284 | /* | ||
2285 | * R813 (0x32D) - AIF2RX Mono Configuration | ||
2286 | */ | ||
2287 | #define WM8915_AIF2RX_CHAN0_MONO_MODE 0x0001 /* AIF2RX_CHAN0_MONO_MODE */ | ||
2288 | #define WM8915_AIF2RX_CHAN0_MONO_MODE_MASK 0x0001 /* AIF2RX_CHAN0_MONO_MODE */ | ||
2289 | #define WM8915_AIF2RX_CHAN0_MONO_MODE_SHIFT 0 /* AIF2RX_CHAN0_MONO_MODE */ | ||
2290 | #define WM8915_AIF2RX_CHAN0_MONO_MODE_WIDTH 1 /* AIF2RX_CHAN0_MONO_MODE */ | ||
2291 | |||
2292 | /* | ||
2293 | * R815 (0x32F) - AIF2TX Test | ||
2294 | */ | ||
2295 | #define WM8915_AIF2TX_DITHER_ENA 0x0001 /* AIF2TX_DITHER_ENA */ | ||
2296 | #define WM8915_AIF2TX_DITHER_ENA_MASK 0x0001 /* AIF2TX_DITHER_ENA */ | ||
2297 | #define WM8915_AIF2TX_DITHER_ENA_SHIFT 0 /* AIF2TX_DITHER_ENA */ | ||
2298 | #define WM8915_AIF2TX_DITHER_ENA_WIDTH 1 /* AIF2TX_DITHER_ENA */ | ||
2299 | |||
2300 | /* | ||
2301 | * R1024 (0x400) - DSP1 TX Left Volume | ||
2302 | */ | ||
2303 | #define WM8915_DSP1TX_VU 0x0100 /* DSP1TX_VU */ | ||
2304 | #define WM8915_DSP1TX_VU_MASK 0x0100 /* DSP1TX_VU */ | ||
2305 | #define WM8915_DSP1TX_VU_SHIFT 8 /* DSP1TX_VU */ | ||
2306 | #define WM8915_DSP1TX_VU_WIDTH 1 /* DSP1TX_VU */ | ||
2307 | #define WM8915_DSP1TXL_VOL_MASK 0x00FF /* DSP1TXL_VOL - [7:0] */ | ||
2308 | #define WM8915_DSP1TXL_VOL_SHIFT 0 /* DSP1TXL_VOL - [7:0] */ | ||
2309 | #define WM8915_DSP1TXL_VOL_WIDTH 8 /* DSP1TXL_VOL - [7:0] */ | ||
2310 | |||
2311 | /* | ||
2312 | * R1025 (0x401) - DSP1 TX Right Volume | ||
2313 | */ | ||
2314 | #define WM8915_DSP1TX_VU 0x0100 /* DSP1TX_VU */ | ||
2315 | #define WM8915_DSP1TX_VU_MASK 0x0100 /* DSP1TX_VU */ | ||
2316 | #define WM8915_DSP1TX_VU_SHIFT 8 /* DSP1TX_VU */ | ||
2317 | #define WM8915_DSP1TX_VU_WIDTH 1 /* DSP1TX_VU */ | ||
2318 | #define WM8915_DSP1TXR_VOL_MASK 0x00FF /* DSP1TXR_VOL - [7:0] */ | ||
2319 | #define WM8915_DSP1TXR_VOL_SHIFT 0 /* DSP1TXR_VOL - [7:0] */ | ||
2320 | #define WM8915_DSP1TXR_VOL_WIDTH 8 /* DSP1TXR_VOL - [7:0] */ | ||
2321 | |||
2322 | /* | ||
2323 | * R1026 (0x402) - DSP1 RX Left Volume | ||
2324 | */ | ||
2325 | #define WM8915_DSP1RX_VU 0x0100 /* DSP1RX_VU */ | ||
2326 | #define WM8915_DSP1RX_VU_MASK 0x0100 /* DSP1RX_VU */ | ||
2327 | #define WM8915_DSP1RX_VU_SHIFT 8 /* DSP1RX_VU */ | ||
2328 | #define WM8915_DSP1RX_VU_WIDTH 1 /* DSP1RX_VU */ | ||
2329 | #define WM8915_DSP1RXL_VOL_MASK 0x00FF /* DSP1RXL_VOL - [7:0] */ | ||
2330 | #define WM8915_DSP1RXL_VOL_SHIFT 0 /* DSP1RXL_VOL - [7:0] */ | ||
2331 | #define WM8915_DSP1RXL_VOL_WIDTH 8 /* DSP1RXL_VOL - [7:0] */ | ||
2332 | |||
2333 | /* | ||
2334 | * R1027 (0x403) - DSP1 RX Right Volume | ||
2335 | */ | ||
2336 | #define WM8915_DSP1RX_VU 0x0100 /* DSP1RX_VU */ | ||
2337 | #define WM8915_DSP1RX_VU_MASK 0x0100 /* DSP1RX_VU */ | ||
2338 | #define WM8915_DSP1RX_VU_SHIFT 8 /* DSP1RX_VU */ | ||
2339 | #define WM8915_DSP1RX_VU_WIDTH 1 /* DSP1RX_VU */ | ||
2340 | #define WM8915_DSP1RXR_VOL_MASK 0x00FF /* DSP1RXR_VOL - [7:0] */ | ||
2341 | #define WM8915_DSP1RXR_VOL_SHIFT 0 /* DSP1RXR_VOL - [7:0] */ | ||
2342 | #define WM8915_DSP1RXR_VOL_WIDTH 8 /* DSP1RXR_VOL - [7:0] */ | ||
2343 | |||
2344 | /* | ||
2345 | * R1040 (0x410) - DSP1 TX Filters | ||
2346 | */ | ||
2347 | #define WM8915_DSP1TX_NF 0x2000 /* DSP1TX_NF */ | ||
2348 | #define WM8915_DSP1TX_NF_MASK 0x2000 /* DSP1TX_NF */ | ||
2349 | #define WM8915_DSP1TX_NF_SHIFT 13 /* DSP1TX_NF */ | ||
2350 | #define WM8915_DSP1TX_NF_WIDTH 1 /* DSP1TX_NF */ | ||
2351 | #define WM8915_DSP1TXL_HPF 0x1000 /* DSP1TXL_HPF */ | ||
2352 | #define WM8915_DSP1TXL_HPF_MASK 0x1000 /* DSP1TXL_HPF */ | ||
2353 | #define WM8915_DSP1TXL_HPF_SHIFT 12 /* DSP1TXL_HPF */ | ||
2354 | #define WM8915_DSP1TXL_HPF_WIDTH 1 /* DSP1TXL_HPF */ | ||
2355 | #define WM8915_DSP1TXR_HPF 0x0800 /* DSP1TXR_HPF */ | ||
2356 | #define WM8915_DSP1TXR_HPF_MASK 0x0800 /* DSP1TXR_HPF */ | ||
2357 | #define WM8915_DSP1TXR_HPF_SHIFT 11 /* DSP1TXR_HPF */ | ||
2358 | #define WM8915_DSP1TXR_HPF_WIDTH 1 /* DSP1TXR_HPF */ | ||
2359 | #define WM8915_DSP1TX_HPF_MODE_MASK 0x0018 /* DSP1TX_HPF_MODE - [4:3] */ | ||
2360 | #define WM8915_DSP1TX_HPF_MODE_SHIFT 3 /* DSP1TX_HPF_MODE - [4:3] */ | ||
2361 | #define WM8915_DSP1TX_HPF_MODE_WIDTH 2 /* DSP1TX_HPF_MODE - [4:3] */ | ||
2362 | #define WM8915_DSP1TX_HPF_CUT_MASK 0x0007 /* DSP1TX_HPF_CUT - [2:0] */ | ||
2363 | #define WM8915_DSP1TX_HPF_CUT_SHIFT 0 /* DSP1TX_HPF_CUT - [2:0] */ | ||
2364 | #define WM8915_DSP1TX_HPF_CUT_WIDTH 3 /* DSP1TX_HPF_CUT - [2:0] */ | ||
2365 | |||
2366 | /* | ||
2367 | * R1056 (0x420) - DSP1 RX Filters (1) | ||
2368 | */ | ||
2369 | #define WM8915_DSP1RX_MUTE 0x0200 /* DSP1RX_MUTE */ | ||
2370 | #define WM8915_DSP1RX_MUTE_MASK 0x0200 /* DSP1RX_MUTE */ | ||
2371 | #define WM8915_DSP1RX_MUTE_SHIFT 9 /* DSP1RX_MUTE */ | ||
2372 | #define WM8915_DSP1RX_MUTE_WIDTH 1 /* DSP1RX_MUTE */ | ||
2373 | #define WM8915_DSP1RX_MONO 0x0080 /* DSP1RX_MONO */ | ||
2374 | #define WM8915_DSP1RX_MONO_MASK 0x0080 /* DSP1RX_MONO */ | ||
2375 | #define WM8915_DSP1RX_MONO_SHIFT 7 /* DSP1RX_MONO */ | ||
2376 | #define WM8915_DSP1RX_MONO_WIDTH 1 /* DSP1RX_MONO */ | ||
2377 | #define WM8915_DSP1RX_MUTERATE 0x0020 /* DSP1RX_MUTERATE */ | ||
2378 | #define WM8915_DSP1RX_MUTERATE_MASK 0x0020 /* DSP1RX_MUTERATE */ | ||
2379 | #define WM8915_DSP1RX_MUTERATE_SHIFT 5 /* DSP1RX_MUTERATE */ | ||
2380 | #define WM8915_DSP1RX_MUTERATE_WIDTH 1 /* DSP1RX_MUTERATE */ | ||
2381 | #define WM8915_DSP1RX_UNMUTE_RAMP 0x0010 /* DSP1RX_UNMUTE_RAMP */ | ||
2382 | #define WM8915_DSP1RX_UNMUTE_RAMP_MASK 0x0010 /* DSP1RX_UNMUTE_RAMP */ | ||
2383 | #define WM8915_DSP1RX_UNMUTE_RAMP_SHIFT 4 /* DSP1RX_UNMUTE_RAMP */ | ||
2384 | #define WM8915_DSP1RX_UNMUTE_RAMP_WIDTH 1 /* DSP1RX_UNMUTE_RAMP */ | ||
2385 | |||
2386 | /* | ||
2387 | * R1057 (0x421) - DSP1 RX Filters (2) | ||
2388 | */ | ||
2389 | #define WM8915_DSP1RX_3D_GAIN_MASK 0x3E00 /* DSP1RX_3D_GAIN - [13:9] */ | ||
2390 | #define WM8915_DSP1RX_3D_GAIN_SHIFT 9 /* DSP1RX_3D_GAIN - [13:9] */ | ||
2391 | #define WM8915_DSP1RX_3D_GAIN_WIDTH 5 /* DSP1RX_3D_GAIN - [13:9] */ | ||
2392 | #define WM8915_DSP1RX_3D_ENA 0x0100 /* DSP1RX_3D_ENA */ | ||
2393 | #define WM8915_DSP1RX_3D_ENA_MASK 0x0100 /* DSP1RX_3D_ENA */ | ||
2394 | #define WM8915_DSP1RX_3D_ENA_SHIFT 8 /* DSP1RX_3D_ENA */ | ||
2395 | #define WM8915_DSP1RX_3D_ENA_WIDTH 1 /* DSP1RX_3D_ENA */ | ||
2396 | |||
2397 | /* | ||
2398 | * R1088 (0x440) - DSP1 DRC (1) | ||
2399 | */ | ||
2400 | #define WM8915_DSP1DRC_SIG_DET_RMS_MASK 0xF800 /* DSP1DRC_SIG_DET_RMS - [15:11] */ | ||
2401 | #define WM8915_DSP1DRC_SIG_DET_RMS_SHIFT 11 /* DSP1DRC_SIG_DET_RMS - [15:11] */ | ||
2402 | #define WM8915_DSP1DRC_SIG_DET_RMS_WIDTH 5 /* DSP1DRC_SIG_DET_RMS - [15:11] */ | ||
2403 | #define WM8915_DSP1DRC_SIG_DET_PK_MASK 0x0600 /* DSP1DRC_SIG_DET_PK - [10:9] */ | ||
2404 | #define WM8915_DSP1DRC_SIG_DET_PK_SHIFT 9 /* DSP1DRC_SIG_DET_PK - [10:9] */ | ||
2405 | #define WM8915_DSP1DRC_SIG_DET_PK_WIDTH 2 /* DSP1DRC_SIG_DET_PK - [10:9] */ | ||
2406 | #define WM8915_DSP1DRC_NG_ENA 0x0100 /* DSP1DRC_NG_ENA */ | ||
2407 | #define WM8915_DSP1DRC_NG_ENA_MASK 0x0100 /* DSP1DRC_NG_ENA */ | ||
2408 | #define WM8915_DSP1DRC_NG_ENA_SHIFT 8 /* DSP1DRC_NG_ENA */ | ||
2409 | #define WM8915_DSP1DRC_NG_ENA_WIDTH 1 /* DSP1DRC_NG_ENA */ | ||
2410 | #define WM8915_DSP1DRC_SIG_DET_MODE 0x0080 /* DSP1DRC_SIG_DET_MODE */ | ||
2411 | #define WM8915_DSP1DRC_SIG_DET_MODE_MASK 0x0080 /* DSP1DRC_SIG_DET_MODE */ | ||
2412 | #define WM8915_DSP1DRC_SIG_DET_MODE_SHIFT 7 /* DSP1DRC_SIG_DET_MODE */ | ||
2413 | #define WM8915_DSP1DRC_SIG_DET_MODE_WIDTH 1 /* DSP1DRC_SIG_DET_MODE */ | ||
2414 | #define WM8915_DSP1DRC_SIG_DET 0x0040 /* DSP1DRC_SIG_DET */ | ||
2415 | #define WM8915_DSP1DRC_SIG_DET_MASK 0x0040 /* DSP1DRC_SIG_DET */ | ||
2416 | #define WM8915_DSP1DRC_SIG_DET_SHIFT 6 /* DSP1DRC_SIG_DET */ | ||
2417 | #define WM8915_DSP1DRC_SIG_DET_WIDTH 1 /* DSP1DRC_SIG_DET */ | ||
2418 | #define WM8915_DSP1DRC_KNEE2_OP_ENA 0x0020 /* DSP1DRC_KNEE2_OP_ENA */ | ||
2419 | #define WM8915_DSP1DRC_KNEE2_OP_ENA_MASK 0x0020 /* DSP1DRC_KNEE2_OP_ENA */ | ||
2420 | #define WM8915_DSP1DRC_KNEE2_OP_ENA_SHIFT 5 /* DSP1DRC_KNEE2_OP_ENA */ | ||
2421 | #define WM8915_DSP1DRC_KNEE2_OP_ENA_WIDTH 1 /* DSP1DRC_KNEE2_OP_ENA */ | ||
2422 | #define WM8915_DSP1DRC_QR 0x0010 /* DSP1DRC_QR */ | ||
2423 | #define WM8915_DSP1DRC_QR_MASK 0x0010 /* DSP1DRC_QR */ | ||
2424 | #define WM8915_DSP1DRC_QR_SHIFT 4 /* DSP1DRC_QR */ | ||
2425 | #define WM8915_DSP1DRC_QR_WIDTH 1 /* DSP1DRC_QR */ | ||
2426 | #define WM8915_DSP1DRC_ANTICLIP 0x0008 /* DSP1DRC_ANTICLIP */ | ||
2427 | #define WM8915_DSP1DRC_ANTICLIP_MASK 0x0008 /* DSP1DRC_ANTICLIP */ | ||
2428 | #define WM8915_DSP1DRC_ANTICLIP_SHIFT 3 /* DSP1DRC_ANTICLIP */ | ||
2429 | #define WM8915_DSP1DRC_ANTICLIP_WIDTH 1 /* DSP1DRC_ANTICLIP */ | ||
2430 | #define WM8915_DSP1RX_DRC_ENA 0x0004 /* DSP1RX_DRC_ENA */ | ||
2431 | #define WM8915_DSP1RX_DRC_ENA_MASK 0x0004 /* DSP1RX_DRC_ENA */ | ||
2432 | #define WM8915_DSP1RX_DRC_ENA_SHIFT 2 /* DSP1RX_DRC_ENA */ | ||
2433 | #define WM8915_DSP1RX_DRC_ENA_WIDTH 1 /* DSP1RX_DRC_ENA */ | ||
2434 | #define WM8915_DSP1TXL_DRC_ENA 0x0002 /* DSP1TXL_DRC_ENA */ | ||
2435 | #define WM8915_DSP1TXL_DRC_ENA_MASK 0x0002 /* DSP1TXL_DRC_ENA */ | ||
2436 | #define WM8915_DSP1TXL_DRC_ENA_SHIFT 1 /* DSP1TXL_DRC_ENA */ | ||
2437 | #define WM8915_DSP1TXL_DRC_ENA_WIDTH 1 /* DSP1TXL_DRC_ENA */ | ||
2438 | #define WM8915_DSP1TXR_DRC_ENA 0x0001 /* DSP1TXR_DRC_ENA */ | ||
2439 | #define WM8915_DSP1TXR_DRC_ENA_MASK 0x0001 /* DSP1TXR_DRC_ENA */ | ||
2440 | #define WM8915_DSP1TXR_DRC_ENA_SHIFT 0 /* DSP1TXR_DRC_ENA */ | ||
2441 | #define WM8915_DSP1TXR_DRC_ENA_WIDTH 1 /* DSP1TXR_DRC_ENA */ | ||
2442 | |||
2443 | /* | ||
2444 | * R1089 (0x441) - DSP1 DRC (2) | ||
2445 | */ | ||
2446 | #define WM8915_DSP1DRC_ATK_MASK 0x1E00 /* DSP1DRC_ATK - [12:9] */ | ||
2447 | #define WM8915_DSP1DRC_ATK_SHIFT 9 /* DSP1DRC_ATK - [12:9] */ | ||
2448 | #define WM8915_DSP1DRC_ATK_WIDTH 4 /* DSP1DRC_ATK - [12:9] */ | ||
2449 | #define WM8915_DSP1DRC_DCY_MASK 0x01E0 /* DSP1DRC_DCY - [8:5] */ | ||
2450 | #define WM8915_DSP1DRC_DCY_SHIFT 5 /* DSP1DRC_DCY - [8:5] */ | ||
2451 | #define WM8915_DSP1DRC_DCY_WIDTH 4 /* DSP1DRC_DCY - [8:5] */ | ||
2452 | #define WM8915_DSP1DRC_MINGAIN_MASK 0x001C /* DSP1DRC_MINGAIN - [4:2] */ | ||
2453 | #define WM8915_DSP1DRC_MINGAIN_SHIFT 2 /* DSP1DRC_MINGAIN - [4:2] */ | ||
2454 | #define WM8915_DSP1DRC_MINGAIN_WIDTH 3 /* DSP1DRC_MINGAIN - [4:2] */ | ||
2455 | #define WM8915_DSP1DRC_MAXGAIN_MASK 0x0003 /* DSP1DRC_MAXGAIN - [1:0] */ | ||
2456 | #define WM8915_DSP1DRC_MAXGAIN_SHIFT 0 /* DSP1DRC_MAXGAIN - [1:0] */ | ||
2457 | #define WM8915_DSP1DRC_MAXGAIN_WIDTH 2 /* DSP1DRC_MAXGAIN - [1:0] */ | ||
2458 | |||
2459 | /* | ||
2460 | * R1090 (0x442) - DSP1 DRC (3) | ||
2461 | */ | ||
2462 | #define WM8915_DSP1DRC_NG_MINGAIN_MASK 0xF000 /* DSP1DRC_NG_MINGAIN - [15:12] */ | ||
2463 | #define WM8915_DSP1DRC_NG_MINGAIN_SHIFT 12 /* DSP1DRC_NG_MINGAIN - [15:12] */ | ||
2464 | #define WM8915_DSP1DRC_NG_MINGAIN_WIDTH 4 /* DSP1DRC_NG_MINGAIN - [15:12] */ | ||
2465 | #define WM8915_DSP1DRC_NG_EXP_MASK 0x0C00 /* DSP1DRC_NG_EXP - [11:10] */ | ||
2466 | #define WM8915_DSP1DRC_NG_EXP_SHIFT 10 /* DSP1DRC_NG_EXP - [11:10] */ | ||
2467 | #define WM8915_DSP1DRC_NG_EXP_WIDTH 2 /* DSP1DRC_NG_EXP - [11:10] */ | ||
2468 | #define WM8915_DSP1DRC_QR_THR_MASK 0x0300 /* DSP1DRC_QR_THR - [9:8] */ | ||
2469 | #define WM8915_DSP1DRC_QR_THR_SHIFT 8 /* DSP1DRC_QR_THR - [9:8] */ | ||
2470 | #define WM8915_DSP1DRC_QR_THR_WIDTH 2 /* DSP1DRC_QR_THR - [9:8] */ | ||
2471 | #define WM8915_DSP1DRC_QR_DCY_MASK 0x00C0 /* DSP1DRC_QR_DCY - [7:6] */ | ||
2472 | #define WM8915_DSP1DRC_QR_DCY_SHIFT 6 /* DSP1DRC_QR_DCY - [7:6] */ | ||
2473 | #define WM8915_DSP1DRC_QR_DCY_WIDTH 2 /* DSP1DRC_QR_DCY - [7:6] */ | ||
2474 | #define WM8915_DSP1DRC_HI_COMP_MASK 0x0038 /* DSP1DRC_HI_COMP - [5:3] */ | ||
2475 | #define WM8915_DSP1DRC_HI_COMP_SHIFT 3 /* DSP1DRC_HI_COMP - [5:3] */ | ||
2476 | #define WM8915_DSP1DRC_HI_COMP_WIDTH 3 /* DSP1DRC_HI_COMP - [5:3] */ | ||
2477 | #define WM8915_DSP1DRC_LO_COMP_MASK 0x0007 /* DSP1DRC_LO_COMP - [2:0] */ | ||
2478 | #define WM8915_DSP1DRC_LO_COMP_SHIFT 0 /* DSP1DRC_LO_COMP - [2:0] */ | ||
2479 | #define WM8915_DSP1DRC_LO_COMP_WIDTH 3 /* DSP1DRC_LO_COMP - [2:0] */ | ||
2480 | |||
2481 | /* | ||
2482 | * R1091 (0x443) - DSP1 DRC (4) | ||
2483 | */ | ||
2484 | #define WM8915_DSP1DRC_KNEE_IP_MASK 0x07E0 /* DSP1DRC_KNEE_IP - [10:5] */ | ||
2485 | #define WM8915_DSP1DRC_KNEE_IP_SHIFT 5 /* DSP1DRC_KNEE_IP - [10:5] */ | ||
2486 | #define WM8915_DSP1DRC_KNEE_IP_WIDTH 6 /* DSP1DRC_KNEE_IP - [10:5] */ | ||
2487 | #define WM8915_DSP1DRC_KNEE_OP_MASK 0x001F /* DSP1DRC_KNEE_OP - [4:0] */ | ||
2488 | #define WM8915_DSP1DRC_KNEE_OP_SHIFT 0 /* DSP1DRC_KNEE_OP - [4:0] */ | ||
2489 | #define WM8915_DSP1DRC_KNEE_OP_WIDTH 5 /* DSP1DRC_KNEE_OP - [4:0] */ | ||
2490 | |||
2491 | /* | ||
2492 | * R1092 (0x444) - DSP1 DRC (5) | ||
2493 | */ | ||
2494 | #define WM8915_DSP1DRC_KNEE2_IP_MASK 0x03E0 /* DSP1DRC_KNEE2_IP - [9:5] */ | ||
2495 | #define WM8915_DSP1DRC_KNEE2_IP_SHIFT 5 /* DSP1DRC_KNEE2_IP - [9:5] */ | ||
2496 | #define WM8915_DSP1DRC_KNEE2_IP_WIDTH 5 /* DSP1DRC_KNEE2_IP - [9:5] */ | ||
2497 | #define WM8915_DSP1DRC_KNEE2_OP_MASK 0x001F /* DSP1DRC_KNEE2_OP - [4:0] */ | ||
2498 | #define WM8915_DSP1DRC_KNEE2_OP_SHIFT 0 /* DSP1DRC_KNEE2_OP - [4:0] */ | ||
2499 | #define WM8915_DSP1DRC_KNEE2_OP_WIDTH 5 /* DSP1DRC_KNEE2_OP - [4:0] */ | ||
2500 | |||
2501 | /* | ||
2502 | * R1152 (0x480) - DSP1 RX EQ Gains (1) | ||
2503 | */ | ||
2504 | #define WM8915_DSP1RX_EQ_B1_GAIN_MASK 0xF800 /* DSP1RX_EQ_B1_GAIN - [15:11] */ | ||
2505 | #define WM8915_DSP1RX_EQ_B1_GAIN_SHIFT 11 /* DSP1RX_EQ_B1_GAIN - [15:11] */ | ||
2506 | #define WM8915_DSP1RX_EQ_B1_GAIN_WIDTH 5 /* DSP1RX_EQ_B1_GAIN - [15:11] */ | ||
2507 | #define WM8915_DSP1RX_EQ_B2_GAIN_MASK 0x07C0 /* DSP1RX_EQ_B2_GAIN - [10:6] */ | ||
2508 | #define WM8915_DSP1RX_EQ_B2_GAIN_SHIFT 6 /* DSP1RX_EQ_B2_GAIN - [10:6] */ | ||
2509 | #define WM8915_DSP1RX_EQ_B2_GAIN_WIDTH 5 /* DSP1RX_EQ_B2_GAIN - [10:6] */ | ||
2510 | #define WM8915_DSP1RX_EQ_B3_GAIN_MASK 0x003E /* DSP1RX_EQ_B3_GAIN - [5:1] */ | ||
2511 | #define WM8915_DSP1RX_EQ_B3_GAIN_SHIFT 1 /* DSP1RX_EQ_B3_GAIN - [5:1] */ | ||
2512 | #define WM8915_DSP1RX_EQ_B3_GAIN_WIDTH 5 /* DSP1RX_EQ_B3_GAIN - [5:1] */ | ||
2513 | #define WM8915_DSP1RX_EQ_ENA 0x0001 /* DSP1RX_EQ_ENA */ | ||
2514 | #define WM8915_DSP1RX_EQ_ENA_MASK 0x0001 /* DSP1RX_EQ_ENA */ | ||
2515 | #define WM8915_DSP1RX_EQ_ENA_SHIFT 0 /* DSP1RX_EQ_ENA */ | ||
2516 | #define WM8915_DSP1RX_EQ_ENA_WIDTH 1 /* DSP1RX_EQ_ENA */ | ||
2517 | |||
2518 | /* | ||
2519 | * R1153 (0x481) - DSP1 RX EQ Gains (2) | ||
2520 | */ | ||
2521 | #define WM8915_DSP1RX_EQ_B4_GAIN_MASK 0xF800 /* DSP1RX_EQ_B4_GAIN - [15:11] */ | ||
2522 | #define WM8915_DSP1RX_EQ_B4_GAIN_SHIFT 11 /* DSP1RX_EQ_B4_GAIN - [15:11] */ | ||
2523 | #define WM8915_DSP1RX_EQ_B4_GAIN_WIDTH 5 /* DSP1RX_EQ_B4_GAIN - [15:11] */ | ||
2524 | #define WM8915_DSP1RX_EQ_B5_GAIN_MASK 0x07C0 /* DSP1RX_EQ_B5_GAIN - [10:6] */ | ||
2525 | #define WM8915_DSP1RX_EQ_B5_GAIN_SHIFT 6 /* DSP1RX_EQ_B5_GAIN - [10:6] */ | ||
2526 | #define WM8915_DSP1RX_EQ_B5_GAIN_WIDTH 5 /* DSP1RX_EQ_B5_GAIN - [10:6] */ | ||
2527 | |||
2528 | /* | ||
2529 | * R1154 (0x482) - DSP1 RX EQ Band 1 A | ||
2530 | */ | ||
2531 | #define WM8915_DSP1RX_EQ_B1_A_MASK 0xFFFF /* DSP1RX_EQ_B1_A - [15:0] */ | ||
2532 | #define WM8915_DSP1RX_EQ_B1_A_SHIFT 0 /* DSP1RX_EQ_B1_A - [15:0] */ | ||
2533 | #define WM8915_DSP1RX_EQ_B1_A_WIDTH 16 /* DSP1RX_EQ_B1_A - [15:0] */ | ||
2534 | |||
2535 | /* | ||
2536 | * R1155 (0x483) - DSP1 RX EQ Band 1 B | ||
2537 | */ | ||
2538 | #define WM8915_DSP1RX_EQ_B1_B_MASK 0xFFFF /* DSP1RX_EQ_B1_B - [15:0] */ | ||
2539 | #define WM8915_DSP1RX_EQ_B1_B_SHIFT 0 /* DSP1RX_EQ_B1_B - [15:0] */ | ||
2540 | #define WM8915_DSP1RX_EQ_B1_B_WIDTH 16 /* DSP1RX_EQ_B1_B - [15:0] */ | ||
2541 | |||
2542 | /* | ||
2543 | * R1156 (0x484) - DSP1 RX EQ Band 1 PG | ||
2544 | */ | ||
2545 | #define WM8915_DSP1RX_EQ_B1_PG_MASK 0xFFFF /* DSP1RX_EQ_B1_PG - [15:0] */ | ||
2546 | #define WM8915_DSP1RX_EQ_B1_PG_SHIFT 0 /* DSP1RX_EQ_B1_PG - [15:0] */ | ||
2547 | #define WM8915_DSP1RX_EQ_B1_PG_WIDTH 16 /* DSP1RX_EQ_B1_PG - [15:0] */ | ||
2548 | |||
2549 | /* | ||
2550 | * R1157 (0x485) - DSP1 RX EQ Band 2 A | ||
2551 | */ | ||
2552 | #define WM8915_DSP1RX_EQ_B2_A_MASK 0xFFFF /* DSP1RX_EQ_B2_A - [15:0] */ | ||
2553 | #define WM8915_DSP1RX_EQ_B2_A_SHIFT 0 /* DSP1RX_EQ_B2_A - [15:0] */ | ||
2554 | #define WM8915_DSP1RX_EQ_B2_A_WIDTH 16 /* DSP1RX_EQ_B2_A - [15:0] */ | ||
2555 | |||
2556 | /* | ||
2557 | * R1158 (0x486) - DSP1 RX EQ Band 2 B | ||
2558 | */ | ||
2559 | #define WM8915_DSP1RX_EQ_B2_B_MASK 0xFFFF /* DSP1RX_EQ_B2_B - [15:0] */ | ||
2560 | #define WM8915_DSP1RX_EQ_B2_B_SHIFT 0 /* DSP1RX_EQ_B2_B - [15:0] */ | ||
2561 | #define WM8915_DSP1RX_EQ_B2_B_WIDTH 16 /* DSP1RX_EQ_B2_B - [15:0] */ | ||
2562 | |||
2563 | /* | ||
2564 | * R1159 (0x487) - DSP1 RX EQ Band 2 C | ||
2565 | */ | ||
2566 | #define WM8915_DSP1RX_EQ_B2_C_MASK 0xFFFF /* DSP1RX_EQ_B2_C - [15:0] */ | ||
2567 | #define WM8915_DSP1RX_EQ_B2_C_SHIFT 0 /* DSP1RX_EQ_B2_C - [15:0] */ | ||
2568 | #define WM8915_DSP1RX_EQ_B2_C_WIDTH 16 /* DSP1RX_EQ_B2_C - [15:0] */ | ||
2569 | |||
2570 | /* | ||
2571 | * R1160 (0x488) - DSP1 RX EQ Band 2 PG | ||
2572 | */ | ||
2573 | #define WM8915_DSP1RX_EQ_B2_PG_MASK 0xFFFF /* DSP1RX_EQ_B2_PG - [15:0] */ | ||
2574 | #define WM8915_DSP1RX_EQ_B2_PG_SHIFT 0 /* DSP1RX_EQ_B2_PG - [15:0] */ | ||
2575 | #define WM8915_DSP1RX_EQ_B2_PG_WIDTH 16 /* DSP1RX_EQ_B2_PG - [15:0] */ | ||
2576 | |||
2577 | /* | ||
2578 | * R1161 (0x489) - DSP1 RX EQ Band 3 A | ||
2579 | */ | ||
2580 | #define WM8915_DSP1RX_EQ_B3_A_MASK 0xFFFF /* DSP1RX_EQ_B3_A - [15:0] */ | ||
2581 | #define WM8915_DSP1RX_EQ_B3_A_SHIFT 0 /* DSP1RX_EQ_B3_A - [15:0] */ | ||
2582 | #define WM8915_DSP1RX_EQ_B3_A_WIDTH 16 /* DSP1RX_EQ_B3_A - [15:0] */ | ||
2583 | |||
2584 | /* | ||
2585 | * R1162 (0x48A) - DSP1 RX EQ Band 3 B | ||
2586 | */ | ||
2587 | #define WM8915_DSP1RX_EQ_B3_B_MASK 0xFFFF /* DSP1RX_EQ_B3_B - [15:0] */ | ||
2588 | #define WM8915_DSP1RX_EQ_B3_B_SHIFT 0 /* DSP1RX_EQ_B3_B - [15:0] */ | ||
2589 | #define WM8915_DSP1RX_EQ_B3_B_WIDTH 16 /* DSP1RX_EQ_B3_B - [15:0] */ | ||
2590 | |||
2591 | /* | ||
2592 | * R1163 (0x48B) - DSP1 RX EQ Band 3 C | ||
2593 | */ | ||
2594 | #define WM8915_DSP1RX_EQ_B3_C_MASK 0xFFFF /* DSP1RX_EQ_B3_C - [15:0] */ | ||
2595 | #define WM8915_DSP1RX_EQ_B3_C_SHIFT 0 /* DSP1RX_EQ_B3_C - [15:0] */ | ||
2596 | #define WM8915_DSP1RX_EQ_B3_C_WIDTH 16 /* DSP1RX_EQ_B3_C - [15:0] */ | ||
2597 | |||
2598 | /* | ||
2599 | * R1164 (0x48C) - DSP1 RX EQ Band 3 PG | ||
2600 | */ | ||
2601 | #define WM8915_DSP1RX_EQ_B3_PG_MASK 0xFFFF /* DSP1RX_EQ_B3_PG - [15:0] */ | ||
2602 | #define WM8915_DSP1RX_EQ_B3_PG_SHIFT 0 /* DSP1RX_EQ_B3_PG - [15:0] */ | ||
2603 | #define WM8915_DSP1RX_EQ_B3_PG_WIDTH 16 /* DSP1RX_EQ_B3_PG - [15:0] */ | ||
2604 | |||
2605 | /* | ||
2606 | * R1165 (0x48D) - DSP1 RX EQ Band 4 A | ||
2607 | */ | ||
2608 | #define WM8915_DSP1RX_EQ_B4_A_MASK 0xFFFF /* DSP1RX_EQ_B4_A - [15:0] */ | ||
2609 | #define WM8915_DSP1RX_EQ_B4_A_SHIFT 0 /* DSP1RX_EQ_B4_A - [15:0] */ | ||
2610 | #define WM8915_DSP1RX_EQ_B4_A_WIDTH 16 /* DSP1RX_EQ_B4_A - [15:0] */ | ||
2611 | |||
2612 | /* | ||
2613 | * R1166 (0x48E) - DSP1 RX EQ Band 4 B | ||
2614 | */ | ||
2615 | #define WM8915_DSP1RX_EQ_B4_B_MASK 0xFFFF /* DSP1RX_EQ_B4_B - [15:0] */ | ||
2616 | #define WM8915_DSP1RX_EQ_B4_B_SHIFT 0 /* DSP1RX_EQ_B4_B - [15:0] */ | ||
2617 | #define WM8915_DSP1RX_EQ_B4_B_WIDTH 16 /* DSP1RX_EQ_B4_B - [15:0] */ | ||
2618 | |||
2619 | /* | ||
2620 | * R1167 (0x48F) - DSP1 RX EQ Band 4 C | ||
2621 | */ | ||
2622 | #define WM8915_DSP1RX_EQ_B4_C_MASK 0xFFFF /* DSP1RX_EQ_B4_C - [15:0] */ | ||
2623 | #define WM8915_DSP1RX_EQ_B4_C_SHIFT 0 /* DSP1RX_EQ_B4_C - [15:0] */ | ||
2624 | #define WM8915_DSP1RX_EQ_B4_C_WIDTH 16 /* DSP1RX_EQ_B4_C - [15:0] */ | ||
2625 | |||
2626 | /* | ||
2627 | * R1168 (0x490) - DSP1 RX EQ Band 4 PG | ||
2628 | */ | ||
2629 | #define WM8915_DSP1RX_EQ_B4_PG_MASK 0xFFFF /* DSP1RX_EQ_B4_PG - [15:0] */ | ||
2630 | #define WM8915_DSP1RX_EQ_B4_PG_SHIFT 0 /* DSP1RX_EQ_B4_PG - [15:0] */ | ||
2631 | #define WM8915_DSP1RX_EQ_B4_PG_WIDTH 16 /* DSP1RX_EQ_B4_PG - [15:0] */ | ||
2632 | |||
2633 | /* | ||
2634 | * R1169 (0x491) - DSP1 RX EQ Band 5 A | ||
2635 | */ | ||
2636 | #define WM8915_DSP1RX_EQ_B5_A_MASK 0xFFFF /* DSP1RX_EQ_B5_A - [15:0] */ | ||
2637 | #define WM8915_DSP1RX_EQ_B5_A_SHIFT 0 /* DSP1RX_EQ_B5_A - [15:0] */ | ||
2638 | #define WM8915_DSP1RX_EQ_B5_A_WIDTH 16 /* DSP1RX_EQ_B5_A - [15:0] */ | ||
2639 | |||
2640 | /* | ||
2641 | * R1170 (0x492) - DSP1 RX EQ Band 5 B | ||
2642 | */ | ||
2643 | #define WM8915_DSP1RX_EQ_B5_B_MASK 0xFFFF /* DSP1RX_EQ_B5_B - [15:0] */ | ||
2644 | #define WM8915_DSP1RX_EQ_B5_B_SHIFT 0 /* DSP1RX_EQ_B5_B - [15:0] */ | ||
2645 | #define WM8915_DSP1RX_EQ_B5_B_WIDTH 16 /* DSP1RX_EQ_B5_B - [15:0] */ | ||
2646 | |||
2647 | /* | ||
2648 | * R1171 (0x493) - DSP1 RX EQ Band 5 PG | ||
2649 | */ | ||
2650 | #define WM8915_DSP1RX_EQ_B5_PG_MASK 0xFFFF /* DSP1RX_EQ_B5_PG - [15:0] */ | ||
2651 | #define WM8915_DSP1RX_EQ_B5_PG_SHIFT 0 /* DSP1RX_EQ_B5_PG - [15:0] */ | ||
2652 | #define WM8915_DSP1RX_EQ_B5_PG_WIDTH 16 /* DSP1RX_EQ_B5_PG - [15:0] */ | ||
2653 | |||
2654 | /* | ||
2655 | * R1280 (0x500) - DSP2 TX Left Volume | ||
2656 | */ | ||
2657 | #define WM8915_DSP2TX_VU 0x0100 /* DSP2TX_VU */ | ||
2658 | #define WM8915_DSP2TX_VU_MASK 0x0100 /* DSP2TX_VU */ | ||
2659 | #define WM8915_DSP2TX_VU_SHIFT 8 /* DSP2TX_VU */ | ||
2660 | #define WM8915_DSP2TX_VU_WIDTH 1 /* DSP2TX_VU */ | ||
2661 | #define WM8915_DSP2TXL_VOL_MASK 0x00FF /* DSP2TXL_VOL - [7:0] */ | ||
2662 | #define WM8915_DSP2TXL_VOL_SHIFT 0 /* DSP2TXL_VOL - [7:0] */ | ||
2663 | #define WM8915_DSP2TXL_VOL_WIDTH 8 /* DSP2TXL_VOL - [7:0] */ | ||
2664 | |||
2665 | /* | ||
2666 | * R1281 (0x501) - DSP2 TX Right Volume | ||
2667 | */ | ||
2668 | #define WM8915_DSP2TX_VU 0x0100 /* DSP2TX_VU */ | ||
2669 | #define WM8915_DSP2TX_VU_MASK 0x0100 /* DSP2TX_VU */ | ||
2670 | #define WM8915_DSP2TX_VU_SHIFT 8 /* DSP2TX_VU */ | ||
2671 | #define WM8915_DSP2TX_VU_WIDTH 1 /* DSP2TX_VU */ | ||
2672 | #define WM8915_DSP2TXR_VOL_MASK 0x00FF /* DSP2TXR_VOL - [7:0] */ | ||
2673 | #define WM8915_DSP2TXR_VOL_SHIFT 0 /* DSP2TXR_VOL - [7:0] */ | ||
2674 | #define WM8915_DSP2TXR_VOL_WIDTH 8 /* DSP2TXR_VOL - [7:0] */ | ||
2675 | |||
2676 | /* | ||
2677 | * R1282 (0x502) - DSP2 RX Left Volume | ||
2678 | */ | ||
2679 | #define WM8915_DSP2RX_VU 0x0100 /* DSP2RX_VU */ | ||
2680 | #define WM8915_DSP2RX_VU_MASK 0x0100 /* DSP2RX_VU */ | ||
2681 | #define WM8915_DSP2RX_VU_SHIFT 8 /* DSP2RX_VU */ | ||
2682 | #define WM8915_DSP2RX_VU_WIDTH 1 /* DSP2RX_VU */ | ||
2683 | #define WM8915_DSP2RXL_VOL_MASK 0x00FF /* DSP2RXL_VOL - [7:0] */ | ||
2684 | #define WM8915_DSP2RXL_VOL_SHIFT 0 /* DSP2RXL_VOL - [7:0] */ | ||
2685 | #define WM8915_DSP2RXL_VOL_WIDTH 8 /* DSP2RXL_VOL - [7:0] */ | ||
2686 | |||
2687 | /* | ||
2688 | * R1283 (0x503) - DSP2 RX Right Volume | ||
2689 | */ | ||
2690 | #define WM8915_DSP2RX_VU 0x0100 /* DSP2RX_VU */ | ||
2691 | #define WM8915_DSP2RX_VU_MASK 0x0100 /* DSP2RX_VU */ | ||
2692 | #define WM8915_DSP2RX_VU_SHIFT 8 /* DSP2RX_VU */ | ||
2693 | #define WM8915_DSP2RX_VU_WIDTH 1 /* DSP2RX_VU */ | ||
2694 | #define WM8915_DSP2RXR_VOL_MASK 0x00FF /* DSP2RXR_VOL - [7:0] */ | ||
2695 | #define WM8915_DSP2RXR_VOL_SHIFT 0 /* DSP2RXR_VOL - [7:0] */ | ||
2696 | #define WM8915_DSP2RXR_VOL_WIDTH 8 /* DSP2RXR_VOL - [7:0] */ | ||
2697 | |||
2698 | /* | ||
2699 | * R1296 (0x510) - DSP2 TX Filters | ||
2700 | */ | ||
2701 | #define WM8915_DSP2TX_NF 0x2000 /* DSP2TX_NF */ | ||
2702 | #define WM8915_DSP2TX_NF_MASK 0x2000 /* DSP2TX_NF */ | ||
2703 | #define WM8915_DSP2TX_NF_SHIFT 13 /* DSP2TX_NF */ | ||
2704 | #define WM8915_DSP2TX_NF_WIDTH 1 /* DSP2TX_NF */ | ||
2705 | #define WM8915_DSP2TXL_HPF 0x1000 /* DSP2TXL_HPF */ | ||
2706 | #define WM8915_DSP2TXL_HPF_MASK 0x1000 /* DSP2TXL_HPF */ | ||
2707 | #define WM8915_DSP2TXL_HPF_SHIFT 12 /* DSP2TXL_HPF */ | ||
2708 | #define WM8915_DSP2TXL_HPF_WIDTH 1 /* DSP2TXL_HPF */ | ||
2709 | #define WM8915_DSP2TXR_HPF 0x0800 /* DSP2TXR_HPF */ | ||
2710 | #define WM8915_DSP2TXR_HPF_MASK 0x0800 /* DSP2TXR_HPF */ | ||
2711 | #define WM8915_DSP2TXR_HPF_SHIFT 11 /* DSP2TXR_HPF */ | ||
2712 | #define WM8915_DSP2TXR_HPF_WIDTH 1 /* DSP2TXR_HPF */ | ||
2713 | #define WM8915_DSP2TX_HPF_MODE_MASK 0x0018 /* DSP2TX_HPF_MODE - [4:3] */ | ||
2714 | #define WM8915_DSP2TX_HPF_MODE_SHIFT 3 /* DSP2TX_HPF_MODE - [4:3] */ | ||
2715 | #define WM8915_DSP2TX_HPF_MODE_WIDTH 2 /* DSP2TX_HPF_MODE - [4:3] */ | ||
2716 | #define WM8915_DSP2TX_HPF_CUT_MASK 0x0007 /* DSP2TX_HPF_CUT - [2:0] */ | ||
2717 | #define WM8915_DSP2TX_HPF_CUT_SHIFT 0 /* DSP2TX_HPF_CUT - [2:0] */ | ||
2718 | #define WM8915_DSP2TX_HPF_CUT_WIDTH 3 /* DSP2TX_HPF_CUT - [2:0] */ | ||
2719 | |||
2720 | /* | ||
2721 | * R1312 (0x520) - DSP2 RX Filters (1) | ||
2722 | */ | ||
2723 | #define WM8915_DSP2RX_MUTE 0x0200 /* DSP2RX_MUTE */ | ||
2724 | #define WM8915_DSP2RX_MUTE_MASK 0x0200 /* DSP2RX_MUTE */ | ||
2725 | #define WM8915_DSP2RX_MUTE_SHIFT 9 /* DSP2RX_MUTE */ | ||
2726 | #define WM8915_DSP2RX_MUTE_WIDTH 1 /* DSP2RX_MUTE */ | ||
2727 | #define WM8915_DSP2RX_MONO 0x0080 /* DSP2RX_MONO */ | ||
2728 | #define WM8915_DSP2RX_MONO_MASK 0x0080 /* DSP2RX_MONO */ | ||
2729 | #define WM8915_DSP2RX_MONO_SHIFT 7 /* DSP2RX_MONO */ | ||
2730 | #define WM8915_DSP2RX_MONO_WIDTH 1 /* DSP2RX_MONO */ | ||
2731 | #define WM8915_DSP2RX_MUTERATE 0x0020 /* DSP2RX_MUTERATE */ | ||
2732 | #define WM8915_DSP2RX_MUTERATE_MASK 0x0020 /* DSP2RX_MUTERATE */ | ||
2733 | #define WM8915_DSP2RX_MUTERATE_SHIFT 5 /* DSP2RX_MUTERATE */ | ||
2734 | #define WM8915_DSP2RX_MUTERATE_WIDTH 1 /* DSP2RX_MUTERATE */ | ||
2735 | #define WM8915_DSP2RX_UNMUTE_RAMP 0x0010 /* DSP2RX_UNMUTE_RAMP */ | ||
2736 | #define WM8915_DSP2RX_UNMUTE_RAMP_MASK 0x0010 /* DSP2RX_UNMUTE_RAMP */ | ||
2737 | #define WM8915_DSP2RX_UNMUTE_RAMP_SHIFT 4 /* DSP2RX_UNMUTE_RAMP */ | ||
2738 | #define WM8915_DSP2RX_UNMUTE_RAMP_WIDTH 1 /* DSP2RX_UNMUTE_RAMP */ | ||
2739 | |||
2740 | /* | ||
2741 | * R1313 (0x521) - DSP2 RX Filters (2) | ||
2742 | */ | ||
2743 | #define WM8915_DSP2RX_3D_GAIN_MASK 0x3E00 /* DSP2RX_3D_GAIN - [13:9] */ | ||
2744 | #define WM8915_DSP2RX_3D_GAIN_SHIFT 9 /* DSP2RX_3D_GAIN - [13:9] */ | ||
2745 | #define WM8915_DSP2RX_3D_GAIN_WIDTH 5 /* DSP2RX_3D_GAIN - [13:9] */ | ||
2746 | #define WM8915_DSP2RX_3D_ENA 0x0100 /* DSP2RX_3D_ENA */ | ||
2747 | #define WM8915_DSP2RX_3D_ENA_MASK 0x0100 /* DSP2RX_3D_ENA */ | ||
2748 | #define WM8915_DSP2RX_3D_ENA_SHIFT 8 /* DSP2RX_3D_ENA */ | ||
2749 | #define WM8915_DSP2RX_3D_ENA_WIDTH 1 /* DSP2RX_3D_ENA */ | ||
2750 | |||
2751 | /* | ||
2752 | * R1344 (0x540) - DSP2 DRC (1) | ||
2753 | */ | ||
2754 | #define WM8915_DSP2DRC_SIG_DET_RMS_MASK 0xF800 /* DSP2DRC_SIG_DET_RMS - [15:11] */ | ||
2755 | #define WM8915_DSP2DRC_SIG_DET_RMS_SHIFT 11 /* DSP2DRC_SIG_DET_RMS - [15:11] */ | ||
2756 | #define WM8915_DSP2DRC_SIG_DET_RMS_WIDTH 5 /* DSP2DRC_SIG_DET_RMS - [15:11] */ | ||
2757 | #define WM8915_DSP2DRC_SIG_DET_PK_MASK 0x0600 /* DSP2DRC_SIG_DET_PK - [10:9] */ | ||
2758 | #define WM8915_DSP2DRC_SIG_DET_PK_SHIFT 9 /* DSP2DRC_SIG_DET_PK - [10:9] */ | ||
2759 | #define WM8915_DSP2DRC_SIG_DET_PK_WIDTH 2 /* DSP2DRC_SIG_DET_PK - [10:9] */ | ||
2760 | #define WM8915_DSP2DRC_NG_ENA 0x0100 /* DSP2DRC_NG_ENA */ | ||
2761 | #define WM8915_DSP2DRC_NG_ENA_MASK 0x0100 /* DSP2DRC_NG_ENA */ | ||
2762 | #define WM8915_DSP2DRC_NG_ENA_SHIFT 8 /* DSP2DRC_NG_ENA */ | ||
2763 | #define WM8915_DSP2DRC_NG_ENA_WIDTH 1 /* DSP2DRC_NG_ENA */ | ||
2764 | #define WM8915_DSP2DRC_SIG_DET_MODE 0x0080 /* DSP2DRC_SIG_DET_MODE */ | ||
2765 | #define WM8915_DSP2DRC_SIG_DET_MODE_MASK 0x0080 /* DSP2DRC_SIG_DET_MODE */ | ||
2766 | #define WM8915_DSP2DRC_SIG_DET_MODE_SHIFT 7 /* DSP2DRC_SIG_DET_MODE */ | ||
2767 | #define WM8915_DSP2DRC_SIG_DET_MODE_WIDTH 1 /* DSP2DRC_SIG_DET_MODE */ | ||
2768 | #define WM8915_DSP2DRC_SIG_DET 0x0040 /* DSP2DRC_SIG_DET */ | ||
2769 | #define WM8915_DSP2DRC_SIG_DET_MASK 0x0040 /* DSP2DRC_SIG_DET */ | ||
2770 | #define WM8915_DSP2DRC_SIG_DET_SHIFT 6 /* DSP2DRC_SIG_DET */ | ||
2771 | #define WM8915_DSP2DRC_SIG_DET_WIDTH 1 /* DSP2DRC_SIG_DET */ | ||
2772 | #define WM8915_DSP2DRC_KNEE2_OP_ENA 0x0020 /* DSP2DRC_KNEE2_OP_ENA */ | ||
2773 | #define WM8915_DSP2DRC_KNEE2_OP_ENA_MASK 0x0020 /* DSP2DRC_KNEE2_OP_ENA */ | ||
2774 | #define WM8915_DSP2DRC_KNEE2_OP_ENA_SHIFT 5 /* DSP2DRC_KNEE2_OP_ENA */ | ||
2775 | #define WM8915_DSP2DRC_KNEE2_OP_ENA_WIDTH 1 /* DSP2DRC_KNEE2_OP_ENA */ | ||
2776 | #define WM8915_DSP2DRC_QR 0x0010 /* DSP2DRC_QR */ | ||
2777 | #define WM8915_DSP2DRC_QR_MASK 0x0010 /* DSP2DRC_QR */ | ||
2778 | #define WM8915_DSP2DRC_QR_SHIFT 4 /* DSP2DRC_QR */ | ||
2779 | #define WM8915_DSP2DRC_QR_WIDTH 1 /* DSP2DRC_QR */ | ||
2780 | #define WM8915_DSP2DRC_ANTICLIP 0x0008 /* DSP2DRC_ANTICLIP */ | ||
2781 | #define WM8915_DSP2DRC_ANTICLIP_MASK 0x0008 /* DSP2DRC_ANTICLIP */ | ||
2782 | #define WM8915_DSP2DRC_ANTICLIP_SHIFT 3 /* DSP2DRC_ANTICLIP */ | ||
2783 | #define WM8915_DSP2DRC_ANTICLIP_WIDTH 1 /* DSP2DRC_ANTICLIP */ | ||
2784 | #define WM8915_DSP2RX_DRC_ENA 0x0004 /* DSP2RX_DRC_ENA */ | ||
2785 | #define WM8915_DSP2RX_DRC_ENA_MASK 0x0004 /* DSP2RX_DRC_ENA */ | ||
2786 | #define WM8915_DSP2RX_DRC_ENA_SHIFT 2 /* DSP2RX_DRC_ENA */ | ||
2787 | #define WM8915_DSP2RX_DRC_ENA_WIDTH 1 /* DSP2RX_DRC_ENA */ | ||
2788 | #define WM8915_DSP2TXL_DRC_ENA 0x0002 /* DSP2TXL_DRC_ENA */ | ||
2789 | #define WM8915_DSP2TXL_DRC_ENA_MASK 0x0002 /* DSP2TXL_DRC_ENA */ | ||
2790 | #define WM8915_DSP2TXL_DRC_ENA_SHIFT 1 /* DSP2TXL_DRC_ENA */ | ||
2791 | #define WM8915_DSP2TXL_DRC_ENA_WIDTH 1 /* DSP2TXL_DRC_ENA */ | ||
2792 | #define WM8915_DSP2TXR_DRC_ENA 0x0001 /* DSP2TXR_DRC_ENA */ | ||
2793 | #define WM8915_DSP2TXR_DRC_ENA_MASK 0x0001 /* DSP2TXR_DRC_ENA */ | ||
2794 | #define WM8915_DSP2TXR_DRC_ENA_SHIFT 0 /* DSP2TXR_DRC_ENA */ | ||
2795 | #define WM8915_DSP2TXR_DRC_ENA_WIDTH 1 /* DSP2TXR_DRC_ENA */ | ||
2796 | |||
2797 | /* | ||
2798 | * R1345 (0x541) - DSP2 DRC (2) | ||
2799 | */ | ||
2800 | #define WM8915_DSP2DRC_ATK_MASK 0x1E00 /* DSP2DRC_ATK - [12:9] */ | ||
2801 | #define WM8915_DSP2DRC_ATK_SHIFT 9 /* DSP2DRC_ATK - [12:9] */ | ||
2802 | #define WM8915_DSP2DRC_ATK_WIDTH 4 /* DSP2DRC_ATK - [12:9] */ | ||
2803 | #define WM8915_DSP2DRC_DCY_MASK 0x01E0 /* DSP2DRC_DCY - [8:5] */ | ||
2804 | #define WM8915_DSP2DRC_DCY_SHIFT 5 /* DSP2DRC_DCY - [8:5] */ | ||
2805 | #define WM8915_DSP2DRC_DCY_WIDTH 4 /* DSP2DRC_DCY - [8:5] */ | ||
2806 | #define WM8915_DSP2DRC_MINGAIN_MASK 0x001C /* DSP2DRC_MINGAIN - [4:2] */ | ||
2807 | #define WM8915_DSP2DRC_MINGAIN_SHIFT 2 /* DSP2DRC_MINGAIN - [4:2] */ | ||
2808 | #define WM8915_DSP2DRC_MINGAIN_WIDTH 3 /* DSP2DRC_MINGAIN - [4:2] */ | ||
2809 | #define WM8915_DSP2DRC_MAXGAIN_MASK 0x0003 /* DSP2DRC_MAXGAIN - [1:0] */ | ||
2810 | #define WM8915_DSP2DRC_MAXGAIN_SHIFT 0 /* DSP2DRC_MAXGAIN - [1:0] */ | ||
2811 | #define WM8915_DSP2DRC_MAXGAIN_WIDTH 2 /* DSP2DRC_MAXGAIN - [1:0] */ | ||
2812 | |||
2813 | /* | ||
2814 | * R1346 (0x542) - DSP2 DRC (3) | ||
2815 | */ | ||
2816 | #define WM8915_DSP2DRC_NG_MINGAIN_MASK 0xF000 /* DSP2DRC_NG_MINGAIN - [15:12] */ | ||
2817 | #define WM8915_DSP2DRC_NG_MINGAIN_SHIFT 12 /* DSP2DRC_NG_MINGAIN - [15:12] */ | ||
2818 | #define WM8915_DSP2DRC_NG_MINGAIN_WIDTH 4 /* DSP2DRC_NG_MINGAIN - [15:12] */ | ||
2819 | #define WM8915_DSP2DRC_NG_EXP_MASK 0x0C00 /* DSP2DRC_NG_EXP - [11:10] */ | ||
2820 | #define WM8915_DSP2DRC_NG_EXP_SHIFT 10 /* DSP2DRC_NG_EXP - [11:10] */ | ||
2821 | #define WM8915_DSP2DRC_NG_EXP_WIDTH 2 /* DSP2DRC_NG_EXP - [11:10] */ | ||
2822 | #define WM8915_DSP2DRC_QR_THR_MASK 0x0300 /* DSP2DRC_QR_THR - [9:8] */ | ||
2823 | #define WM8915_DSP2DRC_QR_THR_SHIFT 8 /* DSP2DRC_QR_THR - [9:8] */ | ||
2824 | #define WM8915_DSP2DRC_QR_THR_WIDTH 2 /* DSP2DRC_QR_THR - [9:8] */ | ||
2825 | #define WM8915_DSP2DRC_QR_DCY_MASK 0x00C0 /* DSP2DRC_QR_DCY - [7:6] */ | ||
2826 | #define WM8915_DSP2DRC_QR_DCY_SHIFT 6 /* DSP2DRC_QR_DCY - [7:6] */ | ||
2827 | #define WM8915_DSP2DRC_QR_DCY_WIDTH 2 /* DSP2DRC_QR_DCY - [7:6] */ | ||
2828 | #define WM8915_DSP2DRC_HI_COMP_MASK 0x0038 /* DSP2DRC_HI_COMP - [5:3] */ | ||
2829 | #define WM8915_DSP2DRC_HI_COMP_SHIFT 3 /* DSP2DRC_HI_COMP - [5:3] */ | ||
2830 | #define WM8915_DSP2DRC_HI_COMP_WIDTH 3 /* DSP2DRC_HI_COMP - [5:3] */ | ||
2831 | #define WM8915_DSP2DRC_LO_COMP_MASK 0x0007 /* DSP2DRC_LO_COMP - [2:0] */ | ||
2832 | #define WM8915_DSP2DRC_LO_COMP_SHIFT 0 /* DSP2DRC_LO_COMP - [2:0] */ | ||
2833 | #define WM8915_DSP2DRC_LO_COMP_WIDTH 3 /* DSP2DRC_LO_COMP - [2:0] */ | ||
2834 | |||
2835 | /* | ||
2836 | * R1347 (0x543) - DSP2 DRC (4) | ||
2837 | */ | ||
2838 | #define WM8915_DSP2DRC_KNEE_IP_MASK 0x07E0 /* DSP2DRC_KNEE_IP - [10:5] */ | ||
2839 | #define WM8915_DSP2DRC_KNEE_IP_SHIFT 5 /* DSP2DRC_KNEE_IP - [10:5] */ | ||
2840 | #define WM8915_DSP2DRC_KNEE_IP_WIDTH 6 /* DSP2DRC_KNEE_IP - [10:5] */ | ||
2841 | #define WM8915_DSP2DRC_KNEE_OP_MASK 0x001F /* DSP2DRC_KNEE_OP - [4:0] */ | ||
2842 | #define WM8915_DSP2DRC_KNEE_OP_SHIFT 0 /* DSP2DRC_KNEE_OP - [4:0] */ | ||
2843 | #define WM8915_DSP2DRC_KNEE_OP_WIDTH 5 /* DSP2DRC_KNEE_OP - [4:0] */ | ||
2844 | |||
2845 | /* | ||
2846 | * R1348 (0x544) - DSP2 DRC (5) | ||
2847 | */ | ||
2848 | #define WM8915_DSP2DRC_KNEE2_IP_MASK 0x03E0 /* DSP2DRC_KNEE2_IP - [9:5] */ | ||
2849 | #define WM8915_DSP2DRC_KNEE2_IP_SHIFT 5 /* DSP2DRC_KNEE2_IP - [9:5] */ | ||
2850 | #define WM8915_DSP2DRC_KNEE2_IP_WIDTH 5 /* DSP2DRC_KNEE2_IP - [9:5] */ | ||
2851 | #define WM8915_DSP2DRC_KNEE2_OP_MASK 0x001F /* DSP2DRC_KNEE2_OP - [4:0] */ | ||
2852 | #define WM8915_DSP2DRC_KNEE2_OP_SHIFT 0 /* DSP2DRC_KNEE2_OP - [4:0] */ | ||
2853 | #define WM8915_DSP2DRC_KNEE2_OP_WIDTH 5 /* DSP2DRC_KNEE2_OP - [4:0] */ | ||
2854 | |||
2855 | /* | ||
2856 | * R1408 (0x580) - DSP2 RX EQ Gains (1) | ||
2857 | */ | ||
2858 | #define WM8915_DSP2RX_EQ_B1_GAIN_MASK 0xF800 /* DSP2RX_EQ_B1_GAIN - [15:11] */ | ||
2859 | #define WM8915_DSP2RX_EQ_B1_GAIN_SHIFT 11 /* DSP2RX_EQ_B1_GAIN - [15:11] */ | ||
2860 | #define WM8915_DSP2RX_EQ_B1_GAIN_WIDTH 5 /* DSP2RX_EQ_B1_GAIN - [15:11] */ | ||
2861 | #define WM8915_DSP2RX_EQ_B2_GAIN_MASK 0x07C0 /* DSP2RX_EQ_B2_GAIN - [10:6] */ | ||
2862 | #define WM8915_DSP2RX_EQ_B2_GAIN_SHIFT 6 /* DSP2RX_EQ_B2_GAIN - [10:6] */ | ||
2863 | #define WM8915_DSP2RX_EQ_B2_GAIN_WIDTH 5 /* DSP2RX_EQ_B2_GAIN - [10:6] */ | ||
2864 | #define WM8915_DSP2RX_EQ_B3_GAIN_MASK 0x003E /* DSP2RX_EQ_B3_GAIN - [5:1] */ | ||
2865 | #define WM8915_DSP2RX_EQ_B3_GAIN_SHIFT 1 /* DSP2RX_EQ_B3_GAIN - [5:1] */ | ||
2866 | #define WM8915_DSP2RX_EQ_B3_GAIN_WIDTH 5 /* DSP2RX_EQ_B3_GAIN - [5:1] */ | ||
2867 | #define WM8915_DSP2RX_EQ_ENA 0x0001 /* DSP2RX_EQ_ENA */ | ||
2868 | #define WM8915_DSP2RX_EQ_ENA_MASK 0x0001 /* DSP2RX_EQ_ENA */ | ||
2869 | #define WM8915_DSP2RX_EQ_ENA_SHIFT 0 /* DSP2RX_EQ_ENA */ | ||
2870 | #define WM8915_DSP2RX_EQ_ENA_WIDTH 1 /* DSP2RX_EQ_ENA */ | ||
2871 | |||
2872 | /* | ||
2873 | * R1409 (0x581) - DSP2 RX EQ Gains (2) | ||
2874 | */ | ||
2875 | #define WM8915_DSP2RX_EQ_B4_GAIN_MASK 0xF800 /* DSP2RX_EQ_B4_GAIN - [15:11] */ | ||
2876 | #define WM8915_DSP2RX_EQ_B4_GAIN_SHIFT 11 /* DSP2RX_EQ_B4_GAIN - [15:11] */ | ||
2877 | #define WM8915_DSP2RX_EQ_B4_GAIN_WIDTH 5 /* DSP2RX_EQ_B4_GAIN - [15:11] */ | ||
2878 | #define WM8915_DSP2RX_EQ_B5_GAIN_MASK 0x07C0 /* DSP2RX_EQ_B5_GAIN - [10:6] */ | ||
2879 | #define WM8915_DSP2RX_EQ_B5_GAIN_SHIFT 6 /* DSP2RX_EQ_B5_GAIN - [10:6] */ | ||
2880 | #define WM8915_DSP2RX_EQ_B5_GAIN_WIDTH 5 /* DSP2RX_EQ_B5_GAIN - [10:6] */ | ||
2881 | |||
2882 | /* | ||
2883 | * R1410 (0x582) - DSP2 RX EQ Band 1 A | ||
2884 | */ | ||
2885 | #define WM8915_DSP2RX_EQ_B1_A_MASK 0xFFFF /* DSP2RX_EQ_B1_A - [15:0] */ | ||
2886 | #define WM8915_DSP2RX_EQ_B1_A_SHIFT 0 /* DSP2RX_EQ_B1_A - [15:0] */ | ||
2887 | #define WM8915_DSP2RX_EQ_B1_A_WIDTH 16 /* DSP2RX_EQ_B1_A - [15:0] */ | ||
2888 | |||
2889 | /* | ||
2890 | * R1411 (0x583) - DSP2 RX EQ Band 1 B | ||
2891 | */ | ||
2892 | #define WM8915_DSP2RX_EQ_B1_B_MASK 0xFFFF /* DSP2RX_EQ_B1_B - [15:0] */ | ||
2893 | #define WM8915_DSP2RX_EQ_B1_B_SHIFT 0 /* DSP2RX_EQ_B1_B - [15:0] */ | ||
2894 | #define WM8915_DSP2RX_EQ_B1_B_WIDTH 16 /* DSP2RX_EQ_B1_B - [15:0] */ | ||
2895 | |||
2896 | /* | ||
2897 | * R1412 (0x584) - DSP2 RX EQ Band 1 PG | ||
2898 | */ | ||
2899 | #define WM8915_DSP2RX_EQ_B1_PG_MASK 0xFFFF /* DSP2RX_EQ_B1_PG - [15:0] */ | ||
2900 | #define WM8915_DSP2RX_EQ_B1_PG_SHIFT 0 /* DSP2RX_EQ_B1_PG - [15:0] */ | ||
2901 | #define WM8915_DSP2RX_EQ_B1_PG_WIDTH 16 /* DSP2RX_EQ_B1_PG - [15:0] */ | ||
2902 | |||
2903 | /* | ||
2904 | * R1413 (0x585) - DSP2 RX EQ Band 2 A | ||
2905 | */ | ||
2906 | #define WM8915_DSP2RX_EQ_B2_A_MASK 0xFFFF /* DSP2RX_EQ_B2_A - [15:0] */ | ||
2907 | #define WM8915_DSP2RX_EQ_B2_A_SHIFT 0 /* DSP2RX_EQ_B2_A - [15:0] */ | ||
2908 | #define WM8915_DSP2RX_EQ_B2_A_WIDTH 16 /* DSP2RX_EQ_B2_A - [15:0] */ | ||
2909 | |||
2910 | /* | ||
2911 | * R1414 (0x586) - DSP2 RX EQ Band 2 B | ||
2912 | */ | ||
2913 | #define WM8915_DSP2RX_EQ_B2_B_MASK 0xFFFF /* DSP2RX_EQ_B2_B - [15:0] */ | ||
2914 | #define WM8915_DSP2RX_EQ_B2_B_SHIFT 0 /* DSP2RX_EQ_B2_B - [15:0] */ | ||
2915 | #define WM8915_DSP2RX_EQ_B2_B_WIDTH 16 /* DSP2RX_EQ_B2_B - [15:0] */ | ||
2916 | |||
2917 | /* | ||
2918 | * R1415 (0x587) - DSP2 RX EQ Band 2 C | ||
2919 | */ | ||
2920 | #define WM8915_DSP2RX_EQ_B2_C_MASK 0xFFFF /* DSP2RX_EQ_B2_C - [15:0] */ | ||
2921 | #define WM8915_DSP2RX_EQ_B2_C_SHIFT 0 /* DSP2RX_EQ_B2_C - [15:0] */ | ||
2922 | #define WM8915_DSP2RX_EQ_B2_C_WIDTH 16 /* DSP2RX_EQ_B2_C - [15:0] */ | ||
2923 | |||
2924 | /* | ||
2925 | * R1416 (0x588) - DSP2 RX EQ Band 2 PG | ||
2926 | */ | ||
2927 | #define WM8915_DSP2RX_EQ_B2_PG_MASK 0xFFFF /* DSP2RX_EQ_B2_PG - [15:0] */ | ||
2928 | #define WM8915_DSP2RX_EQ_B2_PG_SHIFT 0 /* DSP2RX_EQ_B2_PG - [15:0] */ | ||
2929 | #define WM8915_DSP2RX_EQ_B2_PG_WIDTH 16 /* DSP2RX_EQ_B2_PG - [15:0] */ | ||
2930 | |||
2931 | /* | ||
2932 | * R1417 (0x589) - DSP2 RX EQ Band 3 A | ||
2933 | */ | ||
2934 | #define WM8915_DSP2RX_EQ_B3_A_MASK 0xFFFF /* DSP2RX_EQ_B3_A - [15:0] */ | ||
2935 | #define WM8915_DSP2RX_EQ_B3_A_SHIFT 0 /* DSP2RX_EQ_B3_A - [15:0] */ | ||
2936 | #define WM8915_DSP2RX_EQ_B3_A_WIDTH 16 /* DSP2RX_EQ_B3_A - [15:0] */ | ||
2937 | |||
2938 | /* | ||
2939 | * R1418 (0x58A) - DSP2 RX EQ Band 3 B | ||
2940 | */ | ||
2941 | #define WM8915_DSP2RX_EQ_B3_B_MASK 0xFFFF /* DSP2RX_EQ_B3_B - [15:0] */ | ||
2942 | #define WM8915_DSP2RX_EQ_B3_B_SHIFT 0 /* DSP2RX_EQ_B3_B - [15:0] */ | ||
2943 | #define WM8915_DSP2RX_EQ_B3_B_WIDTH 16 /* DSP2RX_EQ_B3_B - [15:0] */ | ||
2944 | |||
2945 | /* | ||
2946 | * R1419 (0x58B) - DSP2 RX EQ Band 3 C | ||
2947 | */ | ||
2948 | #define WM8915_DSP2RX_EQ_B3_C_MASK 0xFFFF /* DSP2RX_EQ_B3_C - [15:0] */ | ||
2949 | #define WM8915_DSP2RX_EQ_B3_C_SHIFT 0 /* DSP2RX_EQ_B3_C - [15:0] */ | ||
2950 | #define WM8915_DSP2RX_EQ_B3_C_WIDTH 16 /* DSP2RX_EQ_B3_C - [15:0] */ | ||
2951 | |||
2952 | /* | ||
2953 | * R1420 (0x58C) - DSP2 RX EQ Band 3 PG | ||
2954 | */ | ||
2955 | #define WM8915_DSP2RX_EQ_B3_PG_MASK 0xFFFF /* DSP2RX_EQ_B3_PG - [15:0] */ | ||
2956 | #define WM8915_DSP2RX_EQ_B3_PG_SHIFT 0 /* DSP2RX_EQ_B3_PG - [15:0] */ | ||
2957 | #define WM8915_DSP2RX_EQ_B3_PG_WIDTH 16 /* DSP2RX_EQ_B3_PG - [15:0] */ | ||
2958 | |||
2959 | /* | ||
2960 | * R1421 (0x58D) - DSP2 RX EQ Band 4 A | ||
2961 | */ | ||
2962 | #define WM8915_DSP2RX_EQ_B4_A_MASK 0xFFFF /* DSP2RX_EQ_B4_A - [15:0] */ | ||
2963 | #define WM8915_DSP2RX_EQ_B4_A_SHIFT 0 /* DSP2RX_EQ_B4_A - [15:0] */ | ||
2964 | #define WM8915_DSP2RX_EQ_B4_A_WIDTH 16 /* DSP2RX_EQ_B4_A - [15:0] */ | ||
2965 | |||
2966 | /* | ||
2967 | * R1422 (0x58E) - DSP2 RX EQ Band 4 B | ||
2968 | */ | ||
2969 | #define WM8915_DSP2RX_EQ_B4_B_MASK 0xFFFF /* DSP2RX_EQ_B4_B - [15:0] */ | ||
2970 | #define WM8915_DSP2RX_EQ_B4_B_SHIFT 0 /* DSP2RX_EQ_B4_B - [15:0] */ | ||
2971 | #define WM8915_DSP2RX_EQ_B4_B_WIDTH 16 /* DSP2RX_EQ_B4_B - [15:0] */ | ||
2972 | |||
2973 | /* | ||
2974 | * R1423 (0x58F) - DSP2 RX EQ Band 4 C | ||
2975 | */ | ||
2976 | #define WM8915_DSP2RX_EQ_B4_C_MASK 0xFFFF /* DSP2RX_EQ_B4_C - [15:0] */ | ||
2977 | #define WM8915_DSP2RX_EQ_B4_C_SHIFT 0 /* DSP2RX_EQ_B4_C - [15:0] */ | ||
2978 | #define WM8915_DSP2RX_EQ_B4_C_WIDTH 16 /* DSP2RX_EQ_B4_C - [15:0] */ | ||
2979 | |||
2980 | /* | ||
2981 | * R1424 (0x590) - DSP2 RX EQ Band 4 PG | ||
2982 | */ | ||
2983 | #define WM8915_DSP2RX_EQ_B4_PG_MASK 0xFFFF /* DSP2RX_EQ_B4_PG - [15:0] */ | ||
2984 | #define WM8915_DSP2RX_EQ_B4_PG_SHIFT 0 /* DSP2RX_EQ_B4_PG - [15:0] */ | ||
2985 | #define WM8915_DSP2RX_EQ_B4_PG_WIDTH 16 /* DSP2RX_EQ_B4_PG - [15:0] */ | ||
2986 | |||
2987 | /* | ||
2988 | * R1425 (0x591) - DSP2 RX EQ Band 5 A | ||
2989 | */ | ||
2990 | #define WM8915_DSP2RX_EQ_B5_A_MASK 0xFFFF /* DSP2RX_EQ_B5_A - [15:0] */ | ||
2991 | #define WM8915_DSP2RX_EQ_B5_A_SHIFT 0 /* DSP2RX_EQ_B5_A - [15:0] */ | ||
2992 | #define WM8915_DSP2RX_EQ_B5_A_WIDTH 16 /* DSP2RX_EQ_B5_A - [15:0] */ | ||
2993 | |||
2994 | /* | ||
2995 | * R1426 (0x592) - DSP2 RX EQ Band 5 B | ||
2996 | */ | ||
2997 | #define WM8915_DSP2RX_EQ_B5_B_MASK 0xFFFF /* DSP2RX_EQ_B5_B - [15:0] */ | ||
2998 | #define WM8915_DSP2RX_EQ_B5_B_SHIFT 0 /* DSP2RX_EQ_B5_B - [15:0] */ | ||
2999 | #define WM8915_DSP2RX_EQ_B5_B_WIDTH 16 /* DSP2RX_EQ_B5_B - [15:0] */ | ||
3000 | |||
3001 | /* | ||
3002 | * R1427 (0x593) - DSP2 RX EQ Band 5 PG | ||
3003 | */ | ||
3004 | #define WM8915_DSP2RX_EQ_B5_PG_MASK 0xFFFF /* DSP2RX_EQ_B5_PG - [15:0] */ | ||
3005 | #define WM8915_DSP2RX_EQ_B5_PG_SHIFT 0 /* DSP2RX_EQ_B5_PG - [15:0] */ | ||
3006 | #define WM8915_DSP2RX_EQ_B5_PG_WIDTH 16 /* DSP2RX_EQ_B5_PG - [15:0] */ | ||
3007 | |||
3008 | /* | ||
3009 | * R1536 (0x600) - DAC1 Mixer Volumes | ||
3010 | */ | ||
3011 | #define WM8915_ADCR_DAC1_VOL_MASK 0x03E0 /* ADCR_DAC1_VOL - [9:5] */ | ||
3012 | #define WM8915_ADCR_DAC1_VOL_SHIFT 5 /* ADCR_DAC1_VOL - [9:5] */ | ||
3013 | #define WM8915_ADCR_DAC1_VOL_WIDTH 5 /* ADCR_DAC1_VOL - [9:5] */ | ||
3014 | #define WM8915_ADCL_DAC1_VOL_MASK 0x001F /* ADCL_DAC1_VOL - [4:0] */ | ||
3015 | #define WM8915_ADCL_DAC1_VOL_SHIFT 0 /* ADCL_DAC1_VOL - [4:0] */ | ||
3016 | #define WM8915_ADCL_DAC1_VOL_WIDTH 5 /* ADCL_DAC1_VOL - [4:0] */ | ||
3017 | |||
3018 | /* | ||
3019 | * R1537 (0x601) - DAC1 Left Mixer Routing | ||
3020 | */ | ||
3021 | #define WM8915_ADCR_TO_DAC1L 0x0020 /* ADCR_TO_DAC1L */ | ||
3022 | #define WM8915_ADCR_TO_DAC1L_MASK 0x0020 /* ADCR_TO_DAC1L */ | ||
3023 | #define WM8915_ADCR_TO_DAC1L_SHIFT 5 /* ADCR_TO_DAC1L */ | ||
3024 | #define WM8915_ADCR_TO_DAC1L_WIDTH 1 /* ADCR_TO_DAC1L */ | ||
3025 | #define WM8915_ADCL_TO_DAC1L 0x0010 /* ADCL_TO_DAC1L */ | ||
3026 | #define WM8915_ADCL_TO_DAC1L_MASK 0x0010 /* ADCL_TO_DAC1L */ | ||
3027 | #define WM8915_ADCL_TO_DAC1L_SHIFT 4 /* ADCL_TO_DAC1L */ | ||
3028 | #define WM8915_ADCL_TO_DAC1L_WIDTH 1 /* ADCL_TO_DAC1L */ | ||
3029 | #define WM8915_DSP2RXL_TO_DAC1L 0x0002 /* DSP2RXL_TO_DAC1L */ | ||
3030 | #define WM8915_DSP2RXL_TO_DAC1L_MASK 0x0002 /* DSP2RXL_TO_DAC1L */ | ||
3031 | #define WM8915_DSP2RXL_TO_DAC1L_SHIFT 1 /* DSP2RXL_TO_DAC1L */ | ||
3032 | #define WM8915_DSP2RXL_TO_DAC1L_WIDTH 1 /* DSP2RXL_TO_DAC1L */ | ||
3033 | #define WM8915_DSP1RXL_TO_DAC1L 0x0001 /* DSP1RXL_TO_DAC1L */ | ||
3034 | #define WM8915_DSP1RXL_TO_DAC1L_MASK 0x0001 /* DSP1RXL_TO_DAC1L */ | ||
3035 | #define WM8915_DSP1RXL_TO_DAC1L_SHIFT 0 /* DSP1RXL_TO_DAC1L */ | ||
3036 | #define WM8915_DSP1RXL_TO_DAC1L_WIDTH 1 /* DSP1RXL_TO_DAC1L */ | ||
3037 | |||
3038 | /* | ||
3039 | * R1538 (0x602) - DAC1 Right Mixer Routing | ||
3040 | */ | ||
3041 | #define WM8915_ADCR_TO_DAC1R 0x0020 /* ADCR_TO_DAC1R */ | ||
3042 | #define WM8915_ADCR_TO_DAC1R_MASK 0x0020 /* ADCR_TO_DAC1R */ | ||
3043 | #define WM8915_ADCR_TO_DAC1R_SHIFT 5 /* ADCR_TO_DAC1R */ | ||
3044 | #define WM8915_ADCR_TO_DAC1R_WIDTH 1 /* ADCR_TO_DAC1R */ | ||
3045 | #define WM8915_ADCL_TO_DAC1R 0x0010 /* ADCL_TO_DAC1R */ | ||
3046 | #define WM8915_ADCL_TO_DAC1R_MASK 0x0010 /* ADCL_TO_DAC1R */ | ||
3047 | #define WM8915_ADCL_TO_DAC1R_SHIFT 4 /* ADCL_TO_DAC1R */ | ||
3048 | #define WM8915_ADCL_TO_DAC1R_WIDTH 1 /* ADCL_TO_DAC1R */ | ||
3049 | #define WM8915_DSP2RXR_TO_DAC1R 0x0002 /* DSP2RXR_TO_DAC1R */ | ||
3050 | #define WM8915_DSP2RXR_TO_DAC1R_MASK 0x0002 /* DSP2RXR_TO_DAC1R */ | ||
3051 | #define WM8915_DSP2RXR_TO_DAC1R_SHIFT 1 /* DSP2RXR_TO_DAC1R */ | ||
3052 | #define WM8915_DSP2RXR_TO_DAC1R_WIDTH 1 /* DSP2RXR_TO_DAC1R */ | ||
3053 | #define WM8915_DSP1RXR_TO_DAC1R 0x0001 /* DSP1RXR_TO_DAC1R */ | ||
3054 | #define WM8915_DSP1RXR_TO_DAC1R_MASK 0x0001 /* DSP1RXR_TO_DAC1R */ | ||
3055 | #define WM8915_DSP1RXR_TO_DAC1R_SHIFT 0 /* DSP1RXR_TO_DAC1R */ | ||
3056 | #define WM8915_DSP1RXR_TO_DAC1R_WIDTH 1 /* DSP1RXR_TO_DAC1R */ | ||
3057 | |||
3058 | /* | ||
3059 | * R1539 (0x603) - DAC2 Mixer Volumes | ||
3060 | */ | ||
3061 | #define WM8915_ADCR_DAC2_VOL_MASK 0x03E0 /* ADCR_DAC2_VOL - [9:5] */ | ||
3062 | #define WM8915_ADCR_DAC2_VOL_SHIFT 5 /* ADCR_DAC2_VOL - [9:5] */ | ||
3063 | #define WM8915_ADCR_DAC2_VOL_WIDTH 5 /* ADCR_DAC2_VOL - [9:5] */ | ||
3064 | #define WM8915_ADCL_DAC2_VOL_MASK 0x001F /* ADCL_DAC2_VOL - [4:0] */ | ||
3065 | #define WM8915_ADCL_DAC2_VOL_SHIFT 0 /* ADCL_DAC2_VOL - [4:0] */ | ||
3066 | #define WM8915_ADCL_DAC2_VOL_WIDTH 5 /* ADCL_DAC2_VOL - [4:0] */ | ||
3067 | |||
3068 | /* | ||
3069 | * R1540 (0x604) - DAC2 Left Mixer Routing | ||
3070 | */ | ||
3071 | #define WM8915_ADCR_TO_DAC2L 0x0020 /* ADCR_TO_DAC2L */ | ||
3072 | #define WM8915_ADCR_TO_DAC2L_MASK 0x0020 /* ADCR_TO_DAC2L */ | ||
3073 | #define WM8915_ADCR_TO_DAC2L_SHIFT 5 /* ADCR_TO_DAC2L */ | ||
3074 | #define WM8915_ADCR_TO_DAC2L_WIDTH 1 /* ADCR_TO_DAC2L */ | ||
3075 | #define WM8915_ADCL_TO_DAC2L 0x0010 /* ADCL_TO_DAC2L */ | ||
3076 | #define WM8915_ADCL_TO_DAC2L_MASK 0x0010 /* ADCL_TO_DAC2L */ | ||
3077 | #define WM8915_ADCL_TO_DAC2L_SHIFT 4 /* ADCL_TO_DAC2L */ | ||
3078 | #define WM8915_ADCL_TO_DAC2L_WIDTH 1 /* ADCL_TO_DAC2L */ | ||
3079 | #define WM8915_DSP2RXL_TO_DAC2L 0x0002 /* DSP2RXL_TO_DAC2L */ | ||
3080 | #define WM8915_DSP2RXL_TO_DAC2L_MASK 0x0002 /* DSP2RXL_TO_DAC2L */ | ||
3081 | #define WM8915_DSP2RXL_TO_DAC2L_SHIFT 1 /* DSP2RXL_TO_DAC2L */ | ||
3082 | #define WM8915_DSP2RXL_TO_DAC2L_WIDTH 1 /* DSP2RXL_TO_DAC2L */ | ||
3083 | #define WM8915_DSP1RXL_TO_DAC2L 0x0001 /* DSP1RXL_TO_DAC2L */ | ||
3084 | #define WM8915_DSP1RXL_TO_DAC2L_MASK 0x0001 /* DSP1RXL_TO_DAC2L */ | ||
3085 | #define WM8915_DSP1RXL_TO_DAC2L_SHIFT 0 /* DSP1RXL_TO_DAC2L */ | ||
3086 | #define WM8915_DSP1RXL_TO_DAC2L_WIDTH 1 /* DSP1RXL_TO_DAC2L */ | ||
3087 | |||
3088 | /* | ||
3089 | * R1541 (0x605) - DAC2 Right Mixer Routing | ||
3090 | */ | ||
3091 | #define WM8915_ADCR_TO_DAC2R 0x0020 /* ADCR_TO_DAC2R */ | ||
3092 | #define WM8915_ADCR_TO_DAC2R_MASK 0x0020 /* ADCR_TO_DAC2R */ | ||
3093 | #define WM8915_ADCR_TO_DAC2R_SHIFT 5 /* ADCR_TO_DAC2R */ | ||
3094 | #define WM8915_ADCR_TO_DAC2R_WIDTH 1 /* ADCR_TO_DAC2R */ | ||
3095 | #define WM8915_ADCL_TO_DAC2R 0x0010 /* ADCL_TO_DAC2R */ | ||
3096 | #define WM8915_ADCL_TO_DAC2R_MASK 0x0010 /* ADCL_TO_DAC2R */ | ||
3097 | #define WM8915_ADCL_TO_DAC2R_SHIFT 4 /* ADCL_TO_DAC2R */ | ||
3098 | #define WM8915_ADCL_TO_DAC2R_WIDTH 1 /* ADCL_TO_DAC2R */ | ||
3099 | #define WM8915_DSP2RXR_TO_DAC2R 0x0002 /* DSP2RXR_TO_DAC2R */ | ||
3100 | #define WM8915_DSP2RXR_TO_DAC2R_MASK 0x0002 /* DSP2RXR_TO_DAC2R */ | ||
3101 | #define WM8915_DSP2RXR_TO_DAC2R_SHIFT 1 /* DSP2RXR_TO_DAC2R */ | ||
3102 | #define WM8915_DSP2RXR_TO_DAC2R_WIDTH 1 /* DSP2RXR_TO_DAC2R */ | ||
3103 | #define WM8915_DSP1RXR_TO_DAC2R 0x0001 /* DSP1RXR_TO_DAC2R */ | ||
3104 | #define WM8915_DSP1RXR_TO_DAC2R_MASK 0x0001 /* DSP1RXR_TO_DAC2R */ | ||
3105 | #define WM8915_DSP1RXR_TO_DAC2R_SHIFT 0 /* DSP1RXR_TO_DAC2R */ | ||
3106 | #define WM8915_DSP1RXR_TO_DAC2R_WIDTH 1 /* DSP1RXR_TO_DAC2R */ | ||
3107 | |||
3108 | /* | ||
3109 | * R1542 (0x606) - DSP1 TX Left Mixer Routing | ||
3110 | */ | ||
3111 | #define WM8915_ADC1L_TO_DSP1TXL 0x0002 /* ADC1L_TO_DSP1TXL */ | ||
3112 | #define WM8915_ADC1L_TO_DSP1TXL_MASK 0x0002 /* ADC1L_TO_DSP1TXL */ | ||
3113 | #define WM8915_ADC1L_TO_DSP1TXL_SHIFT 1 /* ADC1L_TO_DSP1TXL */ | ||
3114 | #define WM8915_ADC1L_TO_DSP1TXL_WIDTH 1 /* ADC1L_TO_DSP1TXL */ | ||
3115 | #define WM8915_DACL_TO_DSP1TXL 0x0001 /* DACL_TO_DSP1TXL */ | ||
3116 | #define WM8915_DACL_TO_DSP1TXL_MASK 0x0001 /* DACL_TO_DSP1TXL */ | ||
3117 | #define WM8915_DACL_TO_DSP1TXL_SHIFT 0 /* DACL_TO_DSP1TXL */ | ||
3118 | #define WM8915_DACL_TO_DSP1TXL_WIDTH 1 /* DACL_TO_DSP1TXL */ | ||
3119 | |||
3120 | /* | ||
3121 | * R1543 (0x607) - DSP1 TX Right Mixer Routing | ||
3122 | */ | ||
3123 | #define WM8915_ADC1R_TO_DSP1TXR 0x0002 /* ADC1R_TO_DSP1TXR */ | ||
3124 | #define WM8915_ADC1R_TO_DSP1TXR_MASK 0x0002 /* ADC1R_TO_DSP1TXR */ | ||
3125 | #define WM8915_ADC1R_TO_DSP1TXR_SHIFT 1 /* ADC1R_TO_DSP1TXR */ | ||
3126 | #define WM8915_ADC1R_TO_DSP1TXR_WIDTH 1 /* ADC1R_TO_DSP1TXR */ | ||
3127 | #define WM8915_DACR_TO_DSP1TXR 0x0001 /* DACR_TO_DSP1TXR */ | ||
3128 | #define WM8915_DACR_TO_DSP1TXR_MASK 0x0001 /* DACR_TO_DSP1TXR */ | ||
3129 | #define WM8915_DACR_TO_DSP1TXR_SHIFT 0 /* DACR_TO_DSP1TXR */ | ||
3130 | #define WM8915_DACR_TO_DSP1TXR_WIDTH 1 /* DACR_TO_DSP1TXR */ | ||
3131 | |||
3132 | /* | ||
3133 | * R1544 (0x608) - DSP2 TX Left Mixer Routing | ||
3134 | */ | ||
3135 | #define WM8915_ADC2L_TO_DSP2TXL 0x0002 /* ADC2L_TO_DSP2TXL */ | ||
3136 | #define WM8915_ADC2L_TO_DSP2TXL_MASK 0x0002 /* ADC2L_TO_DSP2TXL */ | ||
3137 | #define WM8915_ADC2L_TO_DSP2TXL_SHIFT 1 /* ADC2L_TO_DSP2TXL */ | ||
3138 | #define WM8915_ADC2L_TO_DSP2TXL_WIDTH 1 /* ADC2L_TO_DSP2TXL */ | ||
3139 | #define WM8915_DACL_TO_DSP2TXL 0x0001 /* DACL_TO_DSP2TXL */ | ||
3140 | #define WM8915_DACL_TO_DSP2TXL_MASK 0x0001 /* DACL_TO_DSP2TXL */ | ||
3141 | #define WM8915_DACL_TO_DSP2TXL_SHIFT 0 /* DACL_TO_DSP2TXL */ | ||
3142 | #define WM8915_DACL_TO_DSP2TXL_WIDTH 1 /* DACL_TO_DSP2TXL */ | ||
3143 | |||
3144 | /* | ||
3145 | * R1545 (0x609) - DSP2 TX Right Mixer Routing | ||
3146 | */ | ||
3147 | #define WM8915_ADC2R_TO_DSP2TXR 0x0002 /* ADC2R_TO_DSP2TXR */ | ||
3148 | #define WM8915_ADC2R_TO_DSP2TXR_MASK 0x0002 /* ADC2R_TO_DSP2TXR */ | ||
3149 | #define WM8915_ADC2R_TO_DSP2TXR_SHIFT 1 /* ADC2R_TO_DSP2TXR */ | ||
3150 | #define WM8915_ADC2R_TO_DSP2TXR_WIDTH 1 /* ADC2R_TO_DSP2TXR */ | ||
3151 | #define WM8915_DACR_TO_DSP2TXR 0x0001 /* DACR_TO_DSP2TXR */ | ||
3152 | #define WM8915_DACR_TO_DSP2TXR_MASK 0x0001 /* DACR_TO_DSP2TXR */ | ||
3153 | #define WM8915_DACR_TO_DSP2TXR_SHIFT 0 /* DACR_TO_DSP2TXR */ | ||
3154 | #define WM8915_DACR_TO_DSP2TXR_WIDTH 1 /* DACR_TO_DSP2TXR */ | ||
3155 | |||
3156 | /* | ||
3157 | * R1546 (0x60A) - DSP TX Mixer Select | ||
3158 | */ | ||
3159 | #define WM8915_DAC_TO_DSPTX_SRC 0x0001 /* DAC_TO_DSPTX_SRC */ | ||
3160 | #define WM8915_DAC_TO_DSPTX_SRC_MASK 0x0001 /* DAC_TO_DSPTX_SRC */ | ||
3161 | #define WM8915_DAC_TO_DSPTX_SRC_SHIFT 0 /* DAC_TO_DSPTX_SRC */ | ||
3162 | #define WM8915_DAC_TO_DSPTX_SRC_WIDTH 1 /* DAC_TO_DSPTX_SRC */ | ||
3163 | |||
3164 | /* | ||
3165 | * R1552 (0x610) - DAC Softmute | ||
3166 | */ | ||
3167 | #define WM8915_DAC_SOFTMUTEMODE 0x0002 /* DAC_SOFTMUTEMODE */ | ||
3168 | #define WM8915_DAC_SOFTMUTEMODE_MASK 0x0002 /* DAC_SOFTMUTEMODE */ | ||
3169 | #define WM8915_DAC_SOFTMUTEMODE_SHIFT 1 /* DAC_SOFTMUTEMODE */ | ||
3170 | #define WM8915_DAC_SOFTMUTEMODE_WIDTH 1 /* DAC_SOFTMUTEMODE */ | ||
3171 | #define WM8915_DAC_MUTERATE 0x0001 /* DAC_MUTERATE */ | ||
3172 | #define WM8915_DAC_MUTERATE_MASK 0x0001 /* DAC_MUTERATE */ | ||
3173 | #define WM8915_DAC_MUTERATE_SHIFT 0 /* DAC_MUTERATE */ | ||
3174 | #define WM8915_DAC_MUTERATE_WIDTH 1 /* DAC_MUTERATE */ | ||
3175 | |||
3176 | /* | ||
3177 | * R1568 (0x620) - Oversampling | ||
3178 | */ | ||
3179 | #define WM8915_SPK_OSR128 0x0008 /* SPK_OSR128 */ | ||
3180 | #define WM8915_SPK_OSR128_MASK 0x0008 /* SPK_OSR128 */ | ||
3181 | #define WM8915_SPK_OSR128_SHIFT 3 /* SPK_OSR128 */ | ||
3182 | #define WM8915_SPK_OSR128_WIDTH 1 /* SPK_OSR128 */ | ||
3183 | #define WM8915_DMIC_OSR64 0x0004 /* DMIC_OSR64 */ | ||
3184 | #define WM8915_DMIC_OSR64_MASK 0x0004 /* DMIC_OSR64 */ | ||
3185 | #define WM8915_DMIC_OSR64_SHIFT 2 /* DMIC_OSR64 */ | ||
3186 | #define WM8915_DMIC_OSR64_WIDTH 1 /* DMIC_OSR64 */ | ||
3187 | #define WM8915_ADC_OSR128 0x0002 /* ADC_OSR128 */ | ||
3188 | #define WM8915_ADC_OSR128_MASK 0x0002 /* ADC_OSR128 */ | ||
3189 | #define WM8915_ADC_OSR128_SHIFT 1 /* ADC_OSR128 */ | ||
3190 | #define WM8915_ADC_OSR128_WIDTH 1 /* ADC_OSR128 */ | ||
3191 | #define WM8915_DAC_OSR128 0x0001 /* DAC_OSR128 */ | ||
3192 | #define WM8915_DAC_OSR128_MASK 0x0001 /* DAC_OSR128 */ | ||
3193 | #define WM8915_DAC_OSR128_SHIFT 0 /* DAC_OSR128 */ | ||
3194 | #define WM8915_DAC_OSR128_WIDTH 1 /* DAC_OSR128 */ | ||
3195 | |||
3196 | /* | ||
3197 | * R1569 (0x621) - Sidetone | ||
3198 | */ | ||
3199 | #define WM8915_ST_LPF 0x1000 /* ST_LPF */ | ||
3200 | #define WM8915_ST_LPF_MASK 0x1000 /* ST_LPF */ | ||
3201 | #define WM8915_ST_LPF_SHIFT 12 /* ST_LPF */ | ||
3202 | #define WM8915_ST_LPF_WIDTH 1 /* ST_LPF */ | ||
3203 | #define WM8915_ST_HPF_CUT_MASK 0x0380 /* ST_HPF_CUT - [9:7] */ | ||
3204 | #define WM8915_ST_HPF_CUT_SHIFT 7 /* ST_HPF_CUT - [9:7] */ | ||
3205 | #define WM8915_ST_HPF_CUT_WIDTH 3 /* ST_HPF_CUT - [9:7] */ | ||
3206 | #define WM8915_ST_HPF 0x0040 /* ST_HPF */ | ||
3207 | #define WM8915_ST_HPF_MASK 0x0040 /* ST_HPF */ | ||
3208 | #define WM8915_ST_HPF_SHIFT 6 /* ST_HPF */ | ||
3209 | #define WM8915_ST_HPF_WIDTH 1 /* ST_HPF */ | ||
3210 | #define WM8915_STR_SEL 0x0002 /* STR_SEL */ | ||
3211 | #define WM8915_STR_SEL_MASK 0x0002 /* STR_SEL */ | ||
3212 | #define WM8915_STR_SEL_SHIFT 1 /* STR_SEL */ | ||
3213 | #define WM8915_STR_SEL_WIDTH 1 /* STR_SEL */ | ||
3214 | #define WM8915_STL_SEL 0x0001 /* STL_SEL */ | ||
3215 | #define WM8915_STL_SEL_MASK 0x0001 /* STL_SEL */ | ||
3216 | #define WM8915_STL_SEL_SHIFT 0 /* STL_SEL */ | ||
3217 | #define WM8915_STL_SEL_WIDTH 1 /* STL_SEL */ | ||
3218 | |||
3219 | /* | ||
3220 | * R1792 (0x700) - GPIO 1 | ||
3221 | */ | ||
3222 | #define WM8915_GP1_DIR 0x8000 /* GP1_DIR */ | ||
3223 | #define WM8915_GP1_DIR_MASK 0x8000 /* GP1_DIR */ | ||
3224 | #define WM8915_GP1_DIR_SHIFT 15 /* GP1_DIR */ | ||
3225 | #define WM8915_GP1_DIR_WIDTH 1 /* GP1_DIR */ | ||
3226 | #define WM8915_GP1_PU 0x4000 /* GP1_PU */ | ||
3227 | #define WM8915_GP1_PU_MASK 0x4000 /* GP1_PU */ | ||
3228 | #define WM8915_GP1_PU_SHIFT 14 /* GP1_PU */ | ||
3229 | #define WM8915_GP1_PU_WIDTH 1 /* GP1_PU */ | ||
3230 | #define WM8915_GP1_PD 0x2000 /* GP1_PD */ | ||
3231 | #define WM8915_GP1_PD_MASK 0x2000 /* GP1_PD */ | ||
3232 | #define WM8915_GP1_PD_SHIFT 13 /* GP1_PD */ | ||
3233 | #define WM8915_GP1_PD_WIDTH 1 /* GP1_PD */ | ||
3234 | #define WM8915_GP1_POL 0x0400 /* GP1_POL */ | ||
3235 | #define WM8915_GP1_POL_MASK 0x0400 /* GP1_POL */ | ||
3236 | #define WM8915_GP1_POL_SHIFT 10 /* GP1_POL */ | ||
3237 | #define WM8915_GP1_POL_WIDTH 1 /* GP1_POL */ | ||
3238 | #define WM8915_GP1_OP_CFG 0x0200 /* GP1_OP_CFG */ | ||
3239 | #define WM8915_GP1_OP_CFG_MASK 0x0200 /* GP1_OP_CFG */ | ||
3240 | #define WM8915_GP1_OP_CFG_SHIFT 9 /* GP1_OP_CFG */ | ||
3241 | #define WM8915_GP1_OP_CFG_WIDTH 1 /* GP1_OP_CFG */ | ||
3242 | #define WM8915_GP1_DB 0x0100 /* GP1_DB */ | ||
3243 | #define WM8915_GP1_DB_MASK 0x0100 /* GP1_DB */ | ||
3244 | #define WM8915_GP1_DB_SHIFT 8 /* GP1_DB */ | ||
3245 | #define WM8915_GP1_DB_WIDTH 1 /* GP1_DB */ | ||
3246 | #define WM8915_GP1_LVL 0x0040 /* GP1_LVL */ | ||
3247 | #define WM8915_GP1_LVL_MASK 0x0040 /* GP1_LVL */ | ||
3248 | #define WM8915_GP1_LVL_SHIFT 6 /* GP1_LVL */ | ||
3249 | #define WM8915_GP1_LVL_WIDTH 1 /* GP1_LVL */ | ||
3250 | #define WM8915_GP1_FN_MASK 0x000F /* GP1_FN - [3:0] */ | ||
3251 | #define WM8915_GP1_FN_SHIFT 0 /* GP1_FN - [3:0] */ | ||
3252 | #define WM8915_GP1_FN_WIDTH 4 /* GP1_FN - [3:0] */ | ||
3253 | |||
3254 | /* | ||
3255 | * R1793 (0x701) - GPIO 2 | ||
3256 | */ | ||
3257 | #define WM8915_GP2_DIR 0x8000 /* GP2_DIR */ | ||
3258 | #define WM8915_GP2_DIR_MASK 0x8000 /* GP2_DIR */ | ||
3259 | #define WM8915_GP2_DIR_SHIFT 15 /* GP2_DIR */ | ||
3260 | #define WM8915_GP2_DIR_WIDTH 1 /* GP2_DIR */ | ||
3261 | #define WM8915_GP2_PU 0x4000 /* GP2_PU */ | ||
3262 | #define WM8915_GP2_PU_MASK 0x4000 /* GP2_PU */ | ||
3263 | #define WM8915_GP2_PU_SHIFT 14 /* GP2_PU */ | ||
3264 | #define WM8915_GP2_PU_WIDTH 1 /* GP2_PU */ | ||
3265 | #define WM8915_GP2_PD 0x2000 /* GP2_PD */ | ||
3266 | #define WM8915_GP2_PD_MASK 0x2000 /* GP2_PD */ | ||
3267 | #define WM8915_GP2_PD_SHIFT 13 /* GP2_PD */ | ||
3268 | #define WM8915_GP2_PD_WIDTH 1 /* GP2_PD */ | ||
3269 | #define WM8915_GP2_POL 0x0400 /* GP2_POL */ | ||
3270 | #define WM8915_GP2_POL_MASK 0x0400 /* GP2_POL */ | ||
3271 | #define WM8915_GP2_POL_SHIFT 10 /* GP2_POL */ | ||
3272 | #define WM8915_GP2_POL_WIDTH 1 /* GP2_POL */ | ||
3273 | #define WM8915_GP2_OP_CFG 0x0200 /* GP2_OP_CFG */ | ||
3274 | #define WM8915_GP2_OP_CFG_MASK 0x0200 /* GP2_OP_CFG */ | ||
3275 | #define WM8915_GP2_OP_CFG_SHIFT 9 /* GP2_OP_CFG */ | ||
3276 | #define WM8915_GP2_OP_CFG_WIDTH 1 /* GP2_OP_CFG */ | ||
3277 | #define WM8915_GP2_DB 0x0100 /* GP2_DB */ | ||
3278 | #define WM8915_GP2_DB_MASK 0x0100 /* GP2_DB */ | ||
3279 | #define WM8915_GP2_DB_SHIFT 8 /* GP2_DB */ | ||
3280 | #define WM8915_GP2_DB_WIDTH 1 /* GP2_DB */ | ||
3281 | #define WM8915_GP2_LVL 0x0040 /* GP2_LVL */ | ||
3282 | #define WM8915_GP2_LVL_MASK 0x0040 /* GP2_LVL */ | ||
3283 | #define WM8915_GP2_LVL_SHIFT 6 /* GP2_LVL */ | ||
3284 | #define WM8915_GP2_LVL_WIDTH 1 /* GP2_LVL */ | ||
3285 | #define WM8915_GP2_FN_MASK 0x000F /* GP2_FN - [3:0] */ | ||
3286 | #define WM8915_GP2_FN_SHIFT 0 /* GP2_FN - [3:0] */ | ||
3287 | #define WM8915_GP2_FN_WIDTH 4 /* GP2_FN - [3:0] */ | ||
3288 | |||
3289 | /* | ||
3290 | * R1794 (0x702) - GPIO 3 | ||
3291 | */ | ||
3292 | #define WM8915_GP3_DIR 0x8000 /* GP3_DIR */ | ||
3293 | #define WM8915_GP3_DIR_MASK 0x8000 /* GP3_DIR */ | ||
3294 | #define WM8915_GP3_DIR_SHIFT 15 /* GP3_DIR */ | ||
3295 | #define WM8915_GP3_DIR_WIDTH 1 /* GP3_DIR */ | ||
3296 | #define WM8915_GP3_PU 0x4000 /* GP3_PU */ | ||
3297 | #define WM8915_GP3_PU_MASK 0x4000 /* GP3_PU */ | ||
3298 | #define WM8915_GP3_PU_SHIFT 14 /* GP3_PU */ | ||
3299 | #define WM8915_GP3_PU_WIDTH 1 /* GP3_PU */ | ||
3300 | #define WM8915_GP3_PD 0x2000 /* GP3_PD */ | ||
3301 | #define WM8915_GP3_PD_MASK 0x2000 /* GP3_PD */ | ||
3302 | #define WM8915_GP3_PD_SHIFT 13 /* GP3_PD */ | ||
3303 | #define WM8915_GP3_PD_WIDTH 1 /* GP3_PD */ | ||
3304 | #define WM8915_GP3_POL 0x0400 /* GP3_POL */ | ||
3305 | #define WM8915_GP3_POL_MASK 0x0400 /* GP3_POL */ | ||
3306 | #define WM8915_GP3_POL_SHIFT 10 /* GP3_POL */ | ||
3307 | #define WM8915_GP3_POL_WIDTH 1 /* GP3_POL */ | ||
3308 | #define WM8915_GP3_OP_CFG 0x0200 /* GP3_OP_CFG */ | ||
3309 | #define WM8915_GP3_OP_CFG_MASK 0x0200 /* GP3_OP_CFG */ | ||
3310 | #define WM8915_GP3_OP_CFG_SHIFT 9 /* GP3_OP_CFG */ | ||
3311 | #define WM8915_GP3_OP_CFG_WIDTH 1 /* GP3_OP_CFG */ | ||
3312 | #define WM8915_GP3_DB 0x0100 /* GP3_DB */ | ||
3313 | #define WM8915_GP3_DB_MASK 0x0100 /* GP3_DB */ | ||
3314 | #define WM8915_GP3_DB_SHIFT 8 /* GP3_DB */ | ||
3315 | #define WM8915_GP3_DB_WIDTH 1 /* GP3_DB */ | ||
3316 | #define WM8915_GP3_LVL 0x0040 /* GP3_LVL */ | ||
3317 | #define WM8915_GP3_LVL_MASK 0x0040 /* GP3_LVL */ | ||
3318 | #define WM8915_GP3_LVL_SHIFT 6 /* GP3_LVL */ | ||
3319 | #define WM8915_GP3_LVL_WIDTH 1 /* GP3_LVL */ | ||
3320 | #define WM8915_GP3_FN_MASK 0x000F /* GP3_FN - [3:0] */ | ||
3321 | #define WM8915_GP3_FN_SHIFT 0 /* GP3_FN - [3:0] */ | ||
3322 | #define WM8915_GP3_FN_WIDTH 4 /* GP3_FN - [3:0] */ | ||
3323 | |||
3324 | /* | ||
3325 | * R1795 (0x703) - GPIO 4 | ||
3326 | */ | ||
3327 | #define WM8915_GP4_DIR 0x8000 /* GP4_DIR */ | ||
3328 | #define WM8915_GP4_DIR_MASK 0x8000 /* GP4_DIR */ | ||
3329 | #define WM8915_GP4_DIR_SHIFT 15 /* GP4_DIR */ | ||
3330 | #define WM8915_GP4_DIR_WIDTH 1 /* GP4_DIR */ | ||
3331 | #define WM8915_GP4_PU 0x4000 /* GP4_PU */ | ||
3332 | #define WM8915_GP4_PU_MASK 0x4000 /* GP4_PU */ | ||
3333 | #define WM8915_GP4_PU_SHIFT 14 /* GP4_PU */ | ||
3334 | #define WM8915_GP4_PU_WIDTH 1 /* GP4_PU */ | ||
3335 | #define WM8915_GP4_PD 0x2000 /* GP4_PD */ | ||
3336 | #define WM8915_GP4_PD_MASK 0x2000 /* GP4_PD */ | ||
3337 | #define WM8915_GP4_PD_SHIFT 13 /* GP4_PD */ | ||
3338 | #define WM8915_GP4_PD_WIDTH 1 /* GP4_PD */ | ||
3339 | #define WM8915_GP4_POL 0x0400 /* GP4_POL */ | ||
3340 | #define WM8915_GP4_POL_MASK 0x0400 /* GP4_POL */ | ||
3341 | #define WM8915_GP4_POL_SHIFT 10 /* GP4_POL */ | ||
3342 | #define WM8915_GP4_POL_WIDTH 1 /* GP4_POL */ | ||
3343 | #define WM8915_GP4_OP_CFG 0x0200 /* GP4_OP_CFG */ | ||
3344 | #define WM8915_GP4_OP_CFG_MASK 0x0200 /* GP4_OP_CFG */ | ||
3345 | #define WM8915_GP4_OP_CFG_SHIFT 9 /* GP4_OP_CFG */ | ||
3346 | #define WM8915_GP4_OP_CFG_WIDTH 1 /* GP4_OP_CFG */ | ||
3347 | #define WM8915_GP4_DB 0x0100 /* GP4_DB */ | ||
3348 | #define WM8915_GP4_DB_MASK 0x0100 /* GP4_DB */ | ||
3349 | #define WM8915_GP4_DB_SHIFT 8 /* GP4_DB */ | ||
3350 | #define WM8915_GP4_DB_WIDTH 1 /* GP4_DB */ | ||
3351 | #define WM8915_GP4_LVL 0x0040 /* GP4_LVL */ | ||
3352 | #define WM8915_GP4_LVL_MASK 0x0040 /* GP4_LVL */ | ||
3353 | #define WM8915_GP4_LVL_SHIFT 6 /* GP4_LVL */ | ||
3354 | #define WM8915_GP4_LVL_WIDTH 1 /* GP4_LVL */ | ||
3355 | #define WM8915_GP4_FN_MASK 0x000F /* GP4_FN - [3:0] */ | ||
3356 | #define WM8915_GP4_FN_SHIFT 0 /* GP4_FN - [3:0] */ | ||
3357 | #define WM8915_GP4_FN_WIDTH 4 /* GP4_FN - [3:0] */ | ||
3358 | |||
3359 | /* | ||
3360 | * R1796 (0x704) - GPIO 5 | ||
3361 | */ | ||
3362 | #define WM8915_GP5_DIR 0x8000 /* GP5_DIR */ | ||
3363 | #define WM8915_GP5_DIR_MASK 0x8000 /* GP5_DIR */ | ||
3364 | #define WM8915_GP5_DIR_SHIFT 15 /* GP5_DIR */ | ||
3365 | #define WM8915_GP5_DIR_WIDTH 1 /* GP5_DIR */ | ||
3366 | #define WM8915_GP5_PU 0x4000 /* GP5_PU */ | ||
3367 | #define WM8915_GP5_PU_MASK 0x4000 /* GP5_PU */ | ||
3368 | #define WM8915_GP5_PU_SHIFT 14 /* GP5_PU */ | ||
3369 | #define WM8915_GP5_PU_WIDTH 1 /* GP5_PU */ | ||
3370 | #define WM8915_GP5_PD 0x2000 /* GP5_PD */ | ||
3371 | #define WM8915_GP5_PD_MASK 0x2000 /* GP5_PD */ | ||
3372 | #define WM8915_GP5_PD_SHIFT 13 /* GP5_PD */ | ||
3373 | #define WM8915_GP5_PD_WIDTH 1 /* GP5_PD */ | ||
3374 | #define WM8915_GP5_POL 0x0400 /* GP5_POL */ | ||
3375 | #define WM8915_GP5_POL_MASK 0x0400 /* GP5_POL */ | ||
3376 | #define WM8915_GP5_POL_SHIFT 10 /* GP5_POL */ | ||
3377 | #define WM8915_GP5_POL_WIDTH 1 /* GP5_POL */ | ||
3378 | #define WM8915_GP5_OP_CFG 0x0200 /* GP5_OP_CFG */ | ||
3379 | #define WM8915_GP5_OP_CFG_MASK 0x0200 /* GP5_OP_CFG */ | ||
3380 | #define WM8915_GP5_OP_CFG_SHIFT 9 /* GP5_OP_CFG */ | ||
3381 | #define WM8915_GP5_OP_CFG_WIDTH 1 /* GP5_OP_CFG */ | ||
3382 | #define WM8915_GP5_DB 0x0100 /* GP5_DB */ | ||
3383 | #define WM8915_GP5_DB_MASK 0x0100 /* GP5_DB */ | ||
3384 | #define WM8915_GP5_DB_SHIFT 8 /* GP5_DB */ | ||
3385 | #define WM8915_GP5_DB_WIDTH 1 /* GP5_DB */ | ||
3386 | #define WM8915_GP5_LVL 0x0040 /* GP5_LVL */ | ||
3387 | #define WM8915_GP5_LVL_MASK 0x0040 /* GP5_LVL */ | ||
3388 | #define WM8915_GP5_LVL_SHIFT 6 /* GP5_LVL */ | ||
3389 | #define WM8915_GP5_LVL_WIDTH 1 /* GP5_LVL */ | ||
3390 | #define WM8915_GP5_FN_MASK 0x000F /* GP5_FN - [3:0] */ | ||
3391 | #define WM8915_GP5_FN_SHIFT 0 /* GP5_FN - [3:0] */ | ||
3392 | #define WM8915_GP5_FN_WIDTH 4 /* GP5_FN - [3:0] */ | ||
3393 | |||
3394 | /* | ||
3395 | * R1824 (0x720) - Pull Control (1) | ||
3396 | */ | ||
3397 | #define WM8915_DMICDAT2_PD 0x1000 /* DMICDAT2_PD */ | ||
3398 | #define WM8915_DMICDAT2_PD_MASK 0x1000 /* DMICDAT2_PD */ | ||
3399 | #define WM8915_DMICDAT2_PD_SHIFT 12 /* DMICDAT2_PD */ | ||
3400 | #define WM8915_DMICDAT2_PD_WIDTH 1 /* DMICDAT2_PD */ | ||
3401 | #define WM8915_DMICDAT1_PD 0x0400 /* DMICDAT1_PD */ | ||
3402 | #define WM8915_DMICDAT1_PD_MASK 0x0400 /* DMICDAT1_PD */ | ||
3403 | #define WM8915_DMICDAT1_PD_SHIFT 10 /* DMICDAT1_PD */ | ||
3404 | #define WM8915_DMICDAT1_PD_WIDTH 1 /* DMICDAT1_PD */ | ||
3405 | #define WM8915_MCLK2_PU 0x0200 /* MCLK2_PU */ | ||
3406 | #define WM8915_MCLK2_PU_MASK 0x0200 /* MCLK2_PU */ | ||
3407 | #define WM8915_MCLK2_PU_SHIFT 9 /* MCLK2_PU */ | ||
3408 | #define WM8915_MCLK2_PU_WIDTH 1 /* MCLK2_PU */ | ||
3409 | #define WM8915_MCLK2_PD 0x0100 /* MCLK2_PD */ | ||
3410 | #define WM8915_MCLK2_PD_MASK 0x0100 /* MCLK2_PD */ | ||
3411 | #define WM8915_MCLK2_PD_SHIFT 8 /* MCLK2_PD */ | ||
3412 | #define WM8915_MCLK2_PD_WIDTH 1 /* MCLK2_PD */ | ||
3413 | #define WM8915_MCLK1_PU 0x0080 /* MCLK1_PU */ | ||
3414 | #define WM8915_MCLK1_PU_MASK 0x0080 /* MCLK1_PU */ | ||
3415 | #define WM8915_MCLK1_PU_SHIFT 7 /* MCLK1_PU */ | ||
3416 | #define WM8915_MCLK1_PU_WIDTH 1 /* MCLK1_PU */ | ||
3417 | #define WM8915_MCLK1_PD 0x0040 /* MCLK1_PD */ | ||
3418 | #define WM8915_MCLK1_PD_MASK 0x0040 /* MCLK1_PD */ | ||
3419 | #define WM8915_MCLK1_PD_SHIFT 6 /* MCLK1_PD */ | ||
3420 | #define WM8915_MCLK1_PD_WIDTH 1 /* MCLK1_PD */ | ||
3421 | #define WM8915_DACDAT1_PU 0x0020 /* DACDAT1_PU */ | ||
3422 | #define WM8915_DACDAT1_PU_MASK 0x0020 /* DACDAT1_PU */ | ||
3423 | #define WM8915_DACDAT1_PU_SHIFT 5 /* DACDAT1_PU */ | ||
3424 | #define WM8915_DACDAT1_PU_WIDTH 1 /* DACDAT1_PU */ | ||
3425 | #define WM8915_DACDAT1_PD 0x0010 /* DACDAT1_PD */ | ||
3426 | #define WM8915_DACDAT1_PD_MASK 0x0010 /* DACDAT1_PD */ | ||
3427 | #define WM8915_DACDAT1_PD_SHIFT 4 /* DACDAT1_PD */ | ||
3428 | #define WM8915_DACDAT1_PD_WIDTH 1 /* DACDAT1_PD */ | ||
3429 | #define WM8915_DACLRCLK1_PU 0x0008 /* DACLRCLK1_PU */ | ||
3430 | #define WM8915_DACLRCLK1_PU_MASK 0x0008 /* DACLRCLK1_PU */ | ||
3431 | #define WM8915_DACLRCLK1_PU_SHIFT 3 /* DACLRCLK1_PU */ | ||
3432 | #define WM8915_DACLRCLK1_PU_WIDTH 1 /* DACLRCLK1_PU */ | ||
3433 | #define WM8915_DACLRCLK1_PD 0x0004 /* DACLRCLK1_PD */ | ||
3434 | #define WM8915_DACLRCLK1_PD_MASK 0x0004 /* DACLRCLK1_PD */ | ||
3435 | #define WM8915_DACLRCLK1_PD_SHIFT 2 /* DACLRCLK1_PD */ | ||
3436 | #define WM8915_DACLRCLK1_PD_WIDTH 1 /* DACLRCLK1_PD */ | ||
3437 | #define WM8915_BCLK1_PU 0x0002 /* BCLK1_PU */ | ||
3438 | #define WM8915_BCLK1_PU_MASK 0x0002 /* BCLK1_PU */ | ||
3439 | #define WM8915_BCLK1_PU_SHIFT 1 /* BCLK1_PU */ | ||
3440 | #define WM8915_BCLK1_PU_WIDTH 1 /* BCLK1_PU */ | ||
3441 | #define WM8915_BCLK1_PD 0x0001 /* BCLK1_PD */ | ||
3442 | #define WM8915_BCLK1_PD_MASK 0x0001 /* BCLK1_PD */ | ||
3443 | #define WM8915_BCLK1_PD_SHIFT 0 /* BCLK1_PD */ | ||
3444 | #define WM8915_BCLK1_PD_WIDTH 1 /* BCLK1_PD */ | ||
3445 | |||
3446 | /* | ||
3447 | * R1825 (0x721) - Pull Control (2) | ||
3448 | */ | ||
3449 | #define WM8915_LDO1ENA_PD 0x0100 /* LDO1ENA_PD */ | ||
3450 | #define WM8915_LDO1ENA_PD_MASK 0x0100 /* LDO1ENA_PD */ | ||
3451 | #define WM8915_LDO1ENA_PD_SHIFT 8 /* LDO1ENA_PD */ | ||
3452 | #define WM8915_LDO1ENA_PD_WIDTH 1 /* LDO1ENA_PD */ | ||
3453 | #define WM8915_ADDR_PD 0x0040 /* ADDR_PD */ | ||
3454 | #define WM8915_ADDR_PD_MASK 0x0040 /* ADDR_PD */ | ||
3455 | #define WM8915_ADDR_PD_SHIFT 6 /* ADDR_PD */ | ||
3456 | #define WM8915_ADDR_PD_WIDTH 1 /* ADDR_PD */ | ||
3457 | #define WM8915_DACDAT2_PU 0x0020 /* DACDAT2_PU */ | ||
3458 | #define WM8915_DACDAT2_PU_MASK 0x0020 /* DACDAT2_PU */ | ||
3459 | #define WM8915_DACDAT2_PU_SHIFT 5 /* DACDAT2_PU */ | ||
3460 | #define WM8915_DACDAT2_PU_WIDTH 1 /* DACDAT2_PU */ | ||
3461 | #define WM8915_DACDAT2_PD 0x0010 /* DACDAT2_PD */ | ||
3462 | #define WM8915_DACDAT2_PD_MASK 0x0010 /* DACDAT2_PD */ | ||
3463 | #define WM8915_DACDAT2_PD_SHIFT 4 /* DACDAT2_PD */ | ||
3464 | #define WM8915_DACDAT2_PD_WIDTH 1 /* DACDAT2_PD */ | ||
3465 | #define WM8915_DACLRCLK2_PU 0x0008 /* DACLRCLK2_PU */ | ||
3466 | #define WM8915_DACLRCLK2_PU_MASK 0x0008 /* DACLRCLK2_PU */ | ||
3467 | #define WM8915_DACLRCLK2_PU_SHIFT 3 /* DACLRCLK2_PU */ | ||
3468 | #define WM8915_DACLRCLK2_PU_WIDTH 1 /* DACLRCLK2_PU */ | ||
3469 | #define WM8915_DACLRCLK2_PD 0x0004 /* DACLRCLK2_PD */ | ||
3470 | #define WM8915_DACLRCLK2_PD_MASK 0x0004 /* DACLRCLK2_PD */ | ||
3471 | #define WM8915_DACLRCLK2_PD_SHIFT 2 /* DACLRCLK2_PD */ | ||
3472 | #define WM8915_DACLRCLK2_PD_WIDTH 1 /* DACLRCLK2_PD */ | ||
3473 | #define WM8915_BCLK2_PU 0x0002 /* BCLK2_PU */ | ||
3474 | #define WM8915_BCLK2_PU_MASK 0x0002 /* BCLK2_PU */ | ||
3475 | #define WM8915_BCLK2_PU_SHIFT 1 /* BCLK2_PU */ | ||
3476 | #define WM8915_BCLK2_PU_WIDTH 1 /* BCLK2_PU */ | ||
3477 | #define WM8915_BCLK2_PD 0x0001 /* BCLK2_PD */ | ||
3478 | #define WM8915_BCLK2_PD_MASK 0x0001 /* BCLK2_PD */ | ||
3479 | #define WM8915_BCLK2_PD_SHIFT 0 /* BCLK2_PD */ | ||
3480 | #define WM8915_BCLK2_PD_WIDTH 1 /* BCLK2_PD */ | ||
3481 | |||
3482 | /* | ||
3483 | * R1840 (0x730) - Interrupt Status 1 | ||
3484 | */ | ||
3485 | #define WM8915_GP5_EINT 0x0010 /* GP5_EINT */ | ||
3486 | #define WM8915_GP5_EINT_MASK 0x0010 /* GP5_EINT */ | ||
3487 | #define WM8915_GP5_EINT_SHIFT 4 /* GP5_EINT */ | ||
3488 | #define WM8915_GP5_EINT_WIDTH 1 /* GP5_EINT */ | ||
3489 | #define WM8915_GP4_EINT 0x0008 /* GP4_EINT */ | ||
3490 | #define WM8915_GP4_EINT_MASK 0x0008 /* GP4_EINT */ | ||
3491 | #define WM8915_GP4_EINT_SHIFT 3 /* GP4_EINT */ | ||
3492 | #define WM8915_GP4_EINT_WIDTH 1 /* GP4_EINT */ | ||
3493 | #define WM8915_GP3_EINT 0x0004 /* GP3_EINT */ | ||
3494 | #define WM8915_GP3_EINT_MASK 0x0004 /* GP3_EINT */ | ||
3495 | #define WM8915_GP3_EINT_SHIFT 2 /* GP3_EINT */ | ||
3496 | #define WM8915_GP3_EINT_WIDTH 1 /* GP3_EINT */ | ||
3497 | #define WM8915_GP2_EINT 0x0002 /* GP2_EINT */ | ||
3498 | #define WM8915_GP2_EINT_MASK 0x0002 /* GP2_EINT */ | ||
3499 | #define WM8915_GP2_EINT_SHIFT 1 /* GP2_EINT */ | ||
3500 | #define WM8915_GP2_EINT_WIDTH 1 /* GP2_EINT */ | ||
3501 | #define WM8915_GP1_EINT 0x0001 /* GP1_EINT */ | ||
3502 | #define WM8915_GP1_EINT_MASK 0x0001 /* GP1_EINT */ | ||
3503 | #define WM8915_GP1_EINT_SHIFT 0 /* GP1_EINT */ | ||
3504 | #define WM8915_GP1_EINT_WIDTH 1 /* GP1_EINT */ | ||
3505 | |||
3506 | /* | ||
3507 | * R1841 (0x731) - Interrupt Status 2 | ||
3508 | */ | ||
3509 | #define WM8915_DCS_DONE_23_EINT 0x1000 /* DCS_DONE_23_EINT */ | ||
3510 | #define WM8915_DCS_DONE_23_EINT_MASK 0x1000 /* DCS_DONE_23_EINT */ | ||
3511 | #define WM8915_DCS_DONE_23_EINT_SHIFT 12 /* DCS_DONE_23_EINT */ | ||
3512 | #define WM8915_DCS_DONE_23_EINT_WIDTH 1 /* DCS_DONE_23_EINT */ | ||
3513 | #define WM8915_DCS_DONE_01_EINT 0x0800 /* DCS_DONE_01_EINT */ | ||
3514 | #define WM8915_DCS_DONE_01_EINT_MASK 0x0800 /* DCS_DONE_01_EINT */ | ||
3515 | #define WM8915_DCS_DONE_01_EINT_SHIFT 11 /* DCS_DONE_01_EINT */ | ||
3516 | #define WM8915_DCS_DONE_01_EINT_WIDTH 1 /* DCS_DONE_01_EINT */ | ||
3517 | #define WM8915_WSEQ_DONE_EINT 0x0400 /* WSEQ_DONE_EINT */ | ||
3518 | #define WM8915_WSEQ_DONE_EINT_MASK 0x0400 /* WSEQ_DONE_EINT */ | ||
3519 | #define WM8915_WSEQ_DONE_EINT_SHIFT 10 /* WSEQ_DONE_EINT */ | ||
3520 | #define WM8915_WSEQ_DONE_EINT_WIDTH 1 /* WSEQ_DONE_EINT */ | ||
3521 | #define WM8915_FIFOS_ERR_EINT 0x0200 /* FIFOS_ERR_EINT */ | ||
3522 | #define WM8915_FIFOS_ERR_EINT_MASK 0x0200 /* FIFOS_ERR_EINT */ | ||
3523 | #define WM8915_FIFOS_ERR_EINT_SHIFT 9 /* FIFOS_ERR_EINT */ | ||
3524 | #define WM8915_FIFOS_ERR_EINT_WIDTH 1 /* FIFOS_ERR_EINT */ | ||
3525 | #define WM8915_DSP2DRC_SIG_DET_EINT 0x0080 /* DSP2DRC_SIG_DET_EINT */ | ||
3526 | #define WM8915_DSP2DRC_SIG_DET_EINT_MASK 0x0080 /* DSP2DRC_SIG_DET_EINT */ | ||
3527 | #define WM8915_DSP2DRC_SIG_DET_EINT_SHIFT 7 /* DSP2DRC_SIG_DET_EINT */ | ||
3528 | #define WM8915_DSP2DRC_SIG_DET_EINT_WIDTH 1 /* DSP2DRC_SIG_DET_EINT */ | ||
3529 | #define WM8915_DSP1DRC_SIG_DET_EINT 0x0040 /* DSP1DRC_SIG_DET_EINT */ | ||
3530 | #define WM8915_DSP1DRC_SIG_DET_EINT_MASK 0x0040 /* DSP1DRC_SIG_DET_EINT */ | ||
3531 | #define WM8915_DSP1DRC_SIG_DET_EINT_SHIFT 6 /* DSP1DRC_SIG_DET_EINT */ | ||
3532 | #define WM8915_DSP1DRC_SIG_DET_EINT_WIDTH 1 /* DSP1DRC_SIG_DET_EINT */ | ||
3533 | #define WM8915_FLL_SW_CLK_DONE_EINT 0x0008 /* FLL_SW_CLK_DONE_EINT */ | ||
3534 | #define WM8915_FLL_SW_CLK_DONE_EINT_MASK 0x0008 /* FLL_SW_CLK_DONE_EINT */ | ||
3535 | #define WM8915_FLL_SW_CLK_DONE_EINT_SHIFT 3 /* FLL_SW_CLK_DONE_EINT */ | ||
3536 | #define WM8915_FLL_SW_CLK_DONE_EINT_WIDTH 1 /* FLL_SW_CLK_DONE_EINT */ | ||
3537 | #define WM8915_FLL_LOCK_EINT 0x0004 /* FLL_LOCK_EINT */ | ||
3538 | #define WM8915_FLL_LOCK_EINT_MASK 0x0004 /* FLL_LOCK_EINT */ | ||
3539 | #define WM8915_FLL_LOCK_EINT_SHIFT 2 /* FLL_LOCK_EINT */ | ||
3540 | #define WM8915_FLL_LOCK_EINT_WIDTH 1 /* FLL_LOCK_EINT */ | ||
3541 | #define WM8915_HP_DONE_EINT 0x0002 /* HP_DONE_EINT */ | ||
3542 | #define WM8915_HP_DONE_EINT_MASK 0x0002 /* HP_DONE_EINT */ | ||
3543 | #define WM8915_HP_DONE_EINT_SHIFT 1 /* HP_DONE_EINT */ | ||
3544 | #define WM8915_HP_DONE_EINT_WIDTH 1 /* HP_DONE_EINT */ | ||
3545 | #define WM8915_MICD_EINT 0x0001 /* MICD_EINT */ | ||
3546 | #define WM8915_MICD_EINT_MASK 0x0001 /* MICD_EINT */ | ||
3547 | #define WM8915_MICD_EINT_SHIFT 0 /* MICD_EINT */ | ||
3548 | #define WM8915_MICD_EINT_WIDTH 1 /* MICD_EINT */ | ||
3549 | |||
3550 | /* | ||
3551 | * R1842 (0x732) - Interrupt Raw Status 2 | ||
3552 | */ | ||
3553 | #define WM8915_DCS_DONE_23_STS 0x1000 /* DCS_DONE_23_STS */ | ||
3554 | #define WM8915_DCS_DONE_23_STS_MASK 0x1000 /* DCS_DONE_23_STS */ | ||
3555 | #define WM8915_DCS_DONE_23_STS_SHIFT 12 /* DCS_DONE_23_STS */ | ||
3556 | #define WM8915_DCS_DONE_23_STS_WIDTH 1 /* DCS_DONE_23_STS */ | ||
3557 | #define WM8915_DCS_DONE_01_STS 0x0800 /* DCS_DONE_01_STS */ | ||
3558 | #define WM8915_DCS_DONE_01_STS_MASK 0x0800 /* DCS_DONE_01_STS */ | ||
3559 | #define WM8915_DCS_DONE_01_STS_SHIFT 11 /* DCS_DONE_01_STS */ | ||
3560 | #define WM8915_DCS_DONE_01_STS_WIDTH 1 /* DCS_DONE_01_STS */ | ||
3561 | #define WM8915_WSEQ_DONE_STS 0x0400 /* WSEQ_DONE_STS */ | ||
3562 | #define WM8915_WSEQ_DONE_STS_MASK 0x0400 /* WSEQ_DONE_STS */ | ||
3563 | #define WM8915_WSEQ_DONE_STS_SHIFT 10 /* WSEQ_DONE_STS */ | ||
3564 | #define WM8915_WSEQ_DONE_STS_WIDTH 1 /* WSEQ_DONE_STS */ | ||
3565 | #define WM8915_FIFOS_ERR_STS 0x0200 /* FIFOS_ERR_STS */ | ||
3566 | #define WM8915_FIFOS_ERR_STS_MASK 0x0200 /* FIFOS_ERR_STS */ | ||
3567 | #define WM8915_FIFOS_ERR_STS_SHIFT 9 /* FIFOS_ERR_STS */ | ||
3568 | #define WM8915_FIFOS_ERR_STS_WIDTH 1 /* FIFOS_ERR_STS */ | ||
3569 | #define WM8915_DSP2DRC_SIG_DET_STS 0x0080 /* DSP2DRC_SIG_DET_STS */ | ||
3570 | #define WM8915_DSP2DRC_SIG_DET_STS_MASK 0x0080 /* DSP2DRC_SIG_DET_STS */ | ||
3571 | #define WM8915_DSP2DRC_SIG_DET_STS_SHIFT 7 /* DSP2DRC_SIG_DET_STS */ | ||
3572 | #define WM8915_DSP2DRC_SIG_DET_STS_WIDTH 1 /* DSP2DRC_SIG_DET_STS */ | ||
3573 | #define WM8915_DSP1DRC_SIG_DET_STS 0x0040 /* DSP1DRC_SIG_DET_STS */ | ||
3574 | #define WM8915_DSP1DRC_SIG_DET_STS_MASK 0x0040 /* DSP1DRC_SIG_DET_STS */ | ||
3575 | #define WM8915_DSP1DRC_SIG_DET_STS_SHIFT 6 /* DSP1DRC_SIG_DET_STS */ | ||
3576 | #define WM8915_DSP1DRC_SIG_DET_STS_WIDTH 1 /* DSP1DRC_SIG_DET_STS */ | ||
3577 | #define WM8915_FLL_LOCK_STS 0x0004 /* FLL_LOCK_STS */ | ||
3578 | #define WM8915_FLL_LOCK_STS_MASK 0x0004 /* FLL_LOCK_STS */ | ||
3579 | #define WM8915_FLL_LOCK_STS_SHIFT 2 /* FLL_LOCK_STS */ | ||
3580 | #define WM8915_FLL_LOCK_STS_WIDTH 1 /* FLL_LOCK_STS */ | ||
3581 | |||
3582 | /* | ||
3583 | * R1848 (0x738) - Interrupt Status 1 Mask | ||
3584 | */ | ||
3585 | #define WM8915_IM_GP5_EINT 0x0010 /* IM_GP5_EINT */ | ||
3586 | #define WM8915_IM_GP5_EINT_MASK 0x0010 /* IM_GP5_EINT */ | ||
3587 | #define WM8915_IM_GP5_EINT_SHIFT 4 /* IM_GP5_EINT */ | ||
3588 | #define WM8915_IM_GP5_EINT_WIDTH 1 /* IM_GP5_EINT */ | ||
3589 | #define WM8915_IM_GP4_EINT 0x0008 /* IM_GP4_EINT */ | ||
3590 | #define WM8915_IM_GP4_EINT_MASK 0x0008 /* IM_GP4_EINT */ | ||
3591 | #define WM8915_IM_GP4_EINT_SHIFT 3 /* IM_GP4_EINT */ | ||
3592 | #define WM8915_IM_GP4_EINT_WIDTH 1 /* IM_GP4_EINT */ | ||
3593 | #define WM8915_IM_GP3_EINT 0x0004 /* IM_GP3_EINT */ | ||
3594 | #define WM8915_IM_GP3_EINT_MASK 0x0004 /* IM_GP3_EINT */ | ||
3595 | #define WM8915_IM_GP3_EINT_SHIFT 2 /* IM_GP3_EINT */ | ||
3596 | #define WM8915_IM_GP3_EINT_WIDTH 1 /* IM_GP3_EINT */ | ||
3597 | #define WM8915_IM_GP2_EINT 0x0002 /* IM_GP2_EINT */ | ||
3598 | #define WM8915_IM_GP2_EINT_MASK 0x0002 /* IM_GP2_EINT */ | ||
3599 | #define WM8915_IM_GP2_EINT_SHIFT 1 /* IM_GP2_EINT */ | ||
3600 | #define WM8915_IM_GP2_EINT_WIDTH 1 /* IM_GP2_EINT */ | ||
3601 | #define WM8915_IM_GP1_EINT 0x0001 /* IM_GP1_EINT */ | ||
3602 | #define WM8915_IM_GP1_EINT_MASK 0x0001 /* IM_GP1_EINT */ | ||
3603 | #define WM8915_IM_GP1_EINT_SHIFT 0 /* IM_GP1_EINT */ | ||
3604 | #define WM8915_IM_GP1_EINT_WIDTH 1 /* IM_GP1_EINT */ | ||
3605 | |||
3606 | /* | ||
3607 | * R1849 (0x739) - Interrupt Status 2 Mask | ||
3608 | */ | ||
3609 | #define WM8915_IM_DCS_DONE_23_EINT 0x1000 /* IM_DCS_DONE_23_EINT */ | ||
3610 | #define WM8915_IM_DCS_DONE_23_EINT_MASK 0x1000 /* IM_DCS_DONE_23_EINT */ | ||
3611 | #define WM8915_IM_DCS_DONE_23_EINT_SHIFT 12 /* IM_DCS_DONE_23_EINT */ | ||
3612 | #define WM8915_IM_DCS_DONE_23_EINT_WIDTH 1 /* IM_DCS_DONE_23_EINT */ | ||
3613 | #define WM8915_IM_DCS_DONE_01_EINT 0x0800 /* IM_DCS_DONE_01_EINT */ | ||
3614 | #define WM8915_IM_DCS_DONE_01_EINT_MASK 0x0800 /* IM_DCS_DONE_01_EINT */ | ||
3615 | #define WM8915_IM_DCS_DONE_01_EINT_SHIFT 11 /* IM_DCS_DONE_01_EINT */ | ||
3616 | #define WM8915_IM_DCS_DONE_01_EINT_WIDTH 1 /* IM_DCS_DONE_01_EINT */ | ||
3617 | #define WM8915_IM_WSEQ_DONE_EINT 0x0400 /* IM_WSEQ_DONE_EINT */ | ||
3618 | #define WM8915_IM_WSEQ_DONE_EINT_MASK 0x0400 /* IM_WSEQ_DONE_EINT */ | ||
3619 | #define WM8915_IM_WSEQ_DONE_EINT_SHIFT 10 /* IM_WSEQ_DONE_EINT */ | ||
3620 | #define WM8915_IM_WSEQ_DONE_EINT_WIDTH 1 /* IM_WSEQ_DONE_EINT */ | ||
3621 | #define WM8915_IM_FIFOS_ERR_EINT 0x0200 /* IM_FIFOS_ERR_EINT */ | ||
3622 | #define WM8915_IM_FIFOS_ERR_EINT_MASK 0x0200 /* IM_FIFOS_ERR_EINT */ | ||
3623 | #define WM8915_IM_FIFOS_ERR_EINT_SHIFT 9 /* IM_FIFOS_ERR_EINT */ | ||
3624 | #define WM8915_IM_FIFOS_ERR_EINT_WIDTH 1 /* IM_FIFOS_ERR_EINT */ | ||
3625 | #define WM8915_IM_DSP2DRC_SIG_DET_EINT 0x0080 /* IM_DSP2DRC_SIG_DET_EINT */ | ||
3626 | #define WM8915_IM_DSP2DRC_SIG_DET_EINT_MASK 0x0080 /* IM_DSP2DRC_SIG_DET_EINT */ | ||
3627 | #define WM8915_IM_DSP2DRC_SIG_DET_EINT_SHIFT 7 /* IM_DSP2DRC_SIG_DET_EINT */ | ||
3628 | #define WM8915_IM_DSP2DRC_SIG_DET_EINT_WIDTH 1 /* IM_DSP2DRC_SIG_DET_EINT */ | ||
3629 | #define WM8915_IM_DSP1DRC_SIG_DET_EINT 0x0040 /* IM_DSP1DRC_SIG_DET_EINT */ | ||
3630 | #define WM8915_IM_DSP1DRC_SIG_DET_EINT_MASK 0x0040 /* IM_DSP1DRC_SIG_DET_EINT */ | ||
3631 | #define WM8915_IM_DSP1DRC_SIG_DET_EINT_SHIFT 6 /* IM_DSP1DRC_SIG_DET_EINT */ | ||
3632 | #define WM8915_IM_DSP1DRC_SIG_DET_EINT_WIDTH 1 /* IM_DSP1DRC_SIG_DET_EINT */ | ||
3633 | #define WM8915_IM_FLL_SW_CLK_DONE_EINT 0x0008 /* IM_FLL_SW_CLK_DONE_EINT */ | ||
3634 | #define WM8915_IM_FLL_SW_CLK_DONE_EINT_MASK 0x0008 /* IM_FLL_SW_CLK_DONE_EINT */ | ||
3635 | #define WM8915_IM_FLL_SW_CLK_DONE_EINT_SHIFT 3 /* IM_FLL_SW_CLK_DONE_EINT */ | ||
3636 | #define WM8915_IM_FLL_SW_CLK_DONE_EINT_WIDTH 1 /* IM_FLL_SW_CLK_DONE_EINT */ | ||
3637 | #define WM8915_IM_FLL_LOCK_EINT 0x0004 /* IM_FLL_LOCK_EINT */ | ||
3638 | #define WM8915_IM_FLL_LOCK_EINT_MASK 0x0004 /* IM_FLL_LOCK_EINT */ | ||
3639 | #define WM8915_IM_FLL_LOCK_EINT_SHIFT 2 /* IM_FLL_LOCK_EINT */ | ||
3640 | #define WM8915_IM_FLL_LOCK_EINT_WIDTH 1 /* IM_FLL_LOCK_EINT */ | ||
3641 | #define WM8915_IM_HP_DONE_EINT 0x0002 /* IM_HP_DONE_EINT */ | ||
3642 | #define WM8915_IM_HP_DONE_EINT_MASK 0x0002 /* IM_HP_DONE_EINT */ | ||
3643 | #define WM8915_IM_HP_DONE_EINT_SHIFT 1 /* IM_HP_DONE_EINT */ | ||
3644 | #define WM8915_IM_HP_DONE_EINT_WIDTH 1 /* IM_HP_DONE_EINT */ | ||
3645 | #define WM8915_IM_MICD_EINT 0x0001 /* IM_MICD_EINT */ | ||
3646 | #define WM8915_IM_MICD_EINT_MASK 0x0001 /* IM_MICD_EINT */ | ||
3647 | #define WM8915_IM_MICD_EINT_SHIFT 0 /* IM_MICD_EINT */ | ||
3648 | #define WM8915_IM_MICD_EINT_WIDTH 1 /* IM_MICD_EINT */ | ||
3649 | |||
3650 | /* | ||
3651 | * R1856 (0x740) - Interrupt Control | ||
3652 | */ | ||
3653 | #define WM8915_IM_IRQ 0x0001 /* IM_IRQ */ | ||
3654 | #define WM8915_IM_IRQ_MASK 0x0001 /* IM_IRQ */ | ||
3655 | #define WM8915_IM_IRQ_SHIFT 0 /* IM_IRQ */ | ||
3656 | #define WM8915_IM_IRQ_WIDTH 1 /* IM_IRQ */ | ||
3657 | |||
3658 | /* | ||
3659 | * R2048 (0x800) - Left PDM Speaker | ||
3660 | */ | ||
3661 | #define WM8915_SPKL_ENA 0x0010 /* SPKL_ENA */ | ||
3662 | #define WM8915_SPKL_ENA_MASK 0x0010 /* SPKL_ENA */ | ||
3663 | #define WM8915_SPKL_ENA_SHIFT 4 /* SPKL_ENA */ | ||
3664 | #define WM8915_SPKL_ENA_WIDTH 1 /* SPKL_ENA */ | ||
3665 | #define WM8915_SPKL_MUTE 0x0008 /* SPKL_MUTE */ | ||
3666 | #define WM8915_SPKL_MUTE_MASK 0x0008 /* SPKL_MUTE */ | ||
3667 | #define WM8915_SPKL_MUTE_SHIFT 3 /* SPKL_MUTE */ | ||
3668 | #define WM8915_SPKL_MUTE_WIDTH 1 /* SPKL_MUTE */ | ||
3669 | #define WM8915_SPKL_MUTE_ZC 0x0004 /* SPKL_MUTE_ZC */ | ||
3670 | #define WM8915_SPKL_MUTE_ZC_MASK 0x0004 /* SPKL_MUTE_ZC */ | ||
3671 | #define WM8915_SPKL_MUTE_ZC_SHIFT 2 /* SPKL_MUTE_ZC */ | ||
3672 | #define WM8915_SPKL_MUTE_ZC_WIDTH 1 /* SPKL_MUTE_ZC */ | ||
3673 | #define WM8915_SPKL_SRC_MASK 0x0003 /* SPKL_SRC - [1:0] */ | ||
3674 | #define WM8915_SPKL_SRC_SHIFT 0 /* SPKL_SRC - [1:0] */ | ||
3675 | #define WM8915_SPKL_SRC_WIDTH 2 /* SPKL_SRC - [1:0] */ | ||
3676 | |||
3677 | /* | ||
3678 | * R2049 (0x801) - Right PDM Speaker | ||
3679 | */ | ||
3680 | #define WM8915_SPKR_ENA 0x0010 /* SPKR_ENA */ | ||
3681 | #define WM8915_SPKR_ENA_MASK 0x0010 /* SPKR_ENA */ | ||
3682 | #define WM8915_SPKR_ENA_SHIFT 4 /* SPKR_ENA */ | ||
3683 | #define WM8915_SPKR_ENA_WIDTH 1 /* SPKR_ENA */ | ||
3684 | #define WM8915_SPKR_MUTE 0x0008 /* SPKR_MUTE */ | ||
3685 | #define WM8915_SPKR_MUTE_MASK 0x0008 /* SPKR_MUTE */ | ||
3686 | #define WM8915_SPKR_MUTE_SHIFT 3 /* SPKR_MUTE */ | ||
3687 | #define WM8915_SPKR_MUTE_WIDTH 1 /* SPKR_MUTE */ | ||
3688 | #define WM8915_SPKR_MUTE_ZC 0x0004 /* SPKR_MUTE_ZC */ | ||
3689 | #define WM8915_SPKR_MUTE_ZC_MASK 0x0004 /* SPKR_MUTE_ZC */ | ||
3690 | #define WM8915_SPKR_MUTE_ZC_SHIFT 2 /* SPKR_MUTE_ZC */ | ||
3691 | #define WM8915_SPKR_MUTE_ZC_WIDTH 1 /* SPKR_MUTE_ZC */ | ||
3692 | #define WM8915_SPKR_SRC_MASK 0x0003 /* SPKR_SRC - [1:0] */ | ||
3693 | #define WM8915_SPKR_SRC_SHIFT 0 /* SPKR_SRC - [1:0] */ | ||
3694 | #define WM8915_SPKR_SRC_WIDTH 2 /* SPKR_SRC - [1:0] */ | ||
3695 | |||
3696 | /* | ||
3697 | * R2050 (0x802) - PDM Speaker Mute Sequence | ||
3698 | */ | ||
3699 | #define WM8915_SPK_MUTE_ENDIAN 0x0100 /* SPK_MUTE_ENDIAN */ | ||
3700 | #define WM8915_SPK_MUTE_ENDIAN_MASK 0x0100 /* SPK_MUTE_ENDIAN */ | ||
3701 | #define WM8915_SPK_MUTE_ENDIAN_SHIFT 8 /* SPK_MUTE_ENDIAN */ | ||
3702 | #define WM8915_SPK_MUTE_ENDIAN_WIDTH 1 /* SPK_MUTE_ENDIAN */ | ||
3703 | #define WM8915_SPK_MUTE_SEQ1_MASK 0x00FF /* SPK_MUTE_SEQ1 - [7:0] */ | ||
3704 | #define WM8915_SPK_MUTE_SEQ1_SHIFT 0 /* SPK_MUTE_SEQ1 - [7:0] */ | ||
3705 | #define WM8915_SPK_MUTE_SEQ1_WIDTH 8 /* SPK_MUTE_SEQ1 - [7:0] */ | ||
3706 | |||
3707 | /* | ||
3708 | * R2051 (0x803) - PDM Speaker Volume | ||
3709 | */ | ||
3710 | #define WM8915_SPKR_VOL_MASK 0x00F0 /* SPKR_VOL - [7:4] */ | ||
3711 | #define WM8915_SPKR_VOL_SHIFT 4 /* SPKR_VOL - [7:4] */ | ||
3712 | #define WM8915_SPKR_VOL_WIDTH 4 /* SPKR_VOL - [7:4] */ | ||
3713 | #define WM8915_SPKL_VOL_MASK 0x000F /* SPKL_VOL - [3:0] */ | ||
3714 | #define WM8915_SPKL_VOL_SHIFT 0 /* SPKL_VOL - [3:0] */ | ||
3715 | #define WM8915_SPKL_VOL_WIDTH 4 /* SPKL_VOL - [3:0] */ | ||
3716 | |||
3717 | #endif | ||
diff --git a/sound/soc/codecs/wm8996.c b/sound/soc/codecs/wm8996.c new file mode 100644 index 000000000000..ab8e9d1aaff0 --- /dev/null +++ b/sound/soc/codecs/wm8996.c | |||
@@ -0,0 +1,2994 @@ | |||
1 | /* | ||
2 | * wm8996.c - WM8996 audio codec interface | ||
3 | * | ||
4 | * Copyright 2011 Wolfson Microelectronics PLC. | ||
5 | * Author: Mark Brown <broonie@opensource.wolfsonmicro.com> | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify it | ||
8 | * under the terms of the GNU General Public License as published by the | ||
9 | * Free Software Foundation; either version 2 of the License, or (at your | ||
10 | * option) any later version. | ||
11 | */ | ||
12 | |||
13 | #include <linux/module.h> | ||
14 | #include <linux/moduleparam.h> | ||
15 | #include <linux/init.h> | ||
16 | #include <linux/completion.h> | ||
17 | #include <linux/delay.h> | ||
18 | #include <linux/pm.h> | ||
19 | #include <linux/gcd.h> | ||
20 | #include <linux/gpio.h> | ||
21 | #include <linux/i2c.h> | ||
22 | #include <linux/regulator/consumer.h> | ||
23 | #include <linux/slab.h> | ||
24 | #include <linux/workqueue.h> | ||
25 | #include <sound/core.h> | ||
26 | #include <sound/jack.h> | ||
27 | #include <sound/pcm.h> | ||
28 | #include <sound/pcm_params.h> | ||
29 | #include <sound/soc.h> | ||
30 | #include <sound/initval.h> | ||
31 | #include <sound/tlv.h> | ||
32 | #include <trace/events/asoc.h> | ||
33 | |||
34 | #include <sound/wm8996.h> | ||
35 | #include "wm8996.h" | ||
36 | |||
37 | #define WM8996_AIFS 2 | ||
38 | |||
39 | #define HPOUT1L 1 | ||
40 | #define HPOUT1R 2 | ||
41 | #define HPOUT2L 4 | ||
42 | #define HPOUT2R 8 | ||
43 | |||
44 | #define WM8996_NUM_SUPPLIES 4 | ||
45 | static const char *wm8996_supply_names[WM8996_NUM_SUPPLIES] = { | ||
46 | "DBVDD", | ||
47 | "AVDD1", | ||
48 | "AVDD2", | ||
49 | "CPVDD", | ||
50 | }; | ||
51 | |||
52 | struct wm8996_priv { | ||
53 | struct snd_soc_codec *codec; | ||
54 | |||
55 | int ldo1ena; | ||
56 | |||
57 | int sysclk; | ||
58 | int sysclk_src; | ||
59 | |||
60 | int fll_src; | ||
61 | int fll_fref; | ||
62 | int fll_fout; | ||
63 | |||
64 | struct completion fll_lock; | ||
65 | |||
66 | u16 dcs_pending; | ||
67 | struct completion dcs_done; | ||
68 | |||
69 | u16 hpout_ena; | ||
70 | u16 hpout_pending; | ||
71 | |||
72 | struct regulator_bulk_data supplies[WM8996_NUM_SUPPLIES]; | ||
73 | struct notifier_block disable_nb[WM8996_NUM_SUPPLIES]; | ||
74 | |||
75 | struct wm8996_pdata pdata; | ||
76 | |||
77 | int rx_rate[WM8996_AIFS]; | ||
78 | int bclk_rate[WM8996_AIFS]; | ||
79 | |||
80 | /* Platform dependant ReTune mobile configuration */ | ||
81 | int num_retune_mobile_texts; | ||
82 | const char **retune_mobile_texts; | ||
83 | int retune_mobile_cfg[2]; | ||
84 | struct soc_enum retune_mobile_enum; | ||
85 | |||
86 | struct snd_soc_jack *jack; | ||
87 | bool detecting; | ||
88 | bool jack_mic; | ||
89 | wm8996_polarity_fn polarity_cb; | ||
90 | |||
91 | #ifdef CONFIG_GPIOLIB | ||
92 | struct gpio_chip gpio_chip; | ||
93 | #endif | ||
94 | }; | ||
95 | |||
96 | /* We can't use the same notifier block for more than one supply and | ||
97 | * there's no way I can see to get from a callback to the caller | ||
98 | * except container_of(). | ||
99 | */ | ||
100 | #define WM8996_REGULATOR_EVENT(n) \ | ||
101 | static int wm8996_regulator_event_##n(struct notifier_block *nb, \ | ||
102 | unsigned long event, void *data) \ | ||
103 | { \ | ||
104 | struct wm8996_priv *wm8996 = container_of(nb, struct wm8996_priv, \ | ||
105 | disable_nb[n]); \ | ||
106 | if (event & REGULATOR_EVENT_DISABLE) { \ | ||
107 | wm8996->codec->cache_sync = 1; \ | ||
108 | } \ | ||
109 | return 0; \ | ||
110 | } | ||
111 | |||
112 | WM8996_REGULATOR_EVENT(0) | ||
113 | WM8996_REGULATOR_EVENT(1) | ||
114 | WM8996_REGULATOR_EVENT(2) | ||
115 | WM8996_REGULATOR_EVENT(3) | ||
116 | |||
117 | static const u16 wm8996_reg[WM8996_MAX_REGISTER] = { | ||
118 | [WM8996_SOFTWARE_RESET] = 0x8996, | ||
119 | [WM8996_POWER_MANAGEMENT_7] = 0x10, | ||
120 | [WM8996_DAC1_HPOUT1_VOLUME] = 0x88, | ||
121 | [WM8996_DAC2_HPOUT2_VOLUME] = 0x88, | ||
122 | [WM8996_DAC1_LEFT_VOLUME] = 0x2c0, | ||
123 | [WM8996_DAC1_RIGHT_VOLUME] = 0x2c0, | ||
124 | [WM8996_DAC2_LEFT_VOLUME] = 0x2c0, | ||
125 | [WM8996_DAC2_RIGHT_VOLUME] = 0x2c0, | ||
126 | [WM8996_OUTPUT1_LEFT_VOLUME] = 0x80, | ||
127 | [WM8996_OUTPUT1_RIGHT_VOLUME] = 0x80, | ||
128 | [WM8996_OUTPUT2_LEFT_VOLUME] = 0x80, | ||
129 | [WM8996_OUTPUT2_RIGHT_VOLUME] = 0x80, | ||
130 | [WM8996_MICBIAS_1] = 0x39, | ||
131 | [WM8996_MICBIAS_2] = 0x39, | ||
132 | [WM8996_LDO_1] = 0x3, | ||
133 | [WM8996_LDO_2] = 0x13, | ||
134 | [WM8996_ACCESSORY_DETECT_MODE_1] = 0x4, | ||
135 | [WM8996_HEADPHONE_DETECT_1] = 0x20, | ||
136 | [WM8996_MIC_DETECT_1] = 0x7600, | ||
137 | [WM8996_MIC_DETECT_2] = 0xbf, | ||
138 | [WM8996_CHARGE_PUMP_1] = 0x1f25, | ||
139 | [WM8996_CHARGE_PUMP_2] = 0xab19, | ||
140 | [WM8996_DC_SERVO_5] = 0x2a2a, | ||
141 | [WM8996_CONTROL_INTERFACE_1] = 0x8004, | ||
142 | [WM8996_CLOCKING_1] = 0x10, | ||
143 | [WM8996_AIF_RATE] = 0x83, | ||
144 | [WM8996_FLL_CONTROL_4] = 0x5dc0, | ||
145 | [WM8996_FLL_CONTROL_5] = 0xc84, | ||
146 | [WM8996_FLL_EFS_2] = 0x2, | ||
147 | [WM8996_AIF1_TX_LRCLK_1] = 0x80, | ||
148 | [WM8996_AIF1_TX_LRCLK_2] = 0x8, | ||
149 | [WM8996_AIF1_RX_LRCLK_1] = 0x80, | ||
150 | [WM8996_AIF1TX_DATA_CONFIGURATION_1] = 0x1818, | ||
151 | [WM8996_AIF1RX_DATA_CONFIGURATION] = 0x1818, | ||
152 | [WM8996_AIF1TX_TEST] = 0x7, | ||
153 | [WM8996_AIF2_TX_LRCLK_1] = 0x80, | ||
154 | [WM8996_AIF2_TX_LRCLK_2] = 0x8, | ||
155 | [WM8996_AIF2_RX_LRCLK_1] = 0x80, | ||
156 | [WM8996_AIF2TX_DATA_CONFIGURATION_1] = 0x1818, | ||
157 | [WM8996_AIF2RX_DATA_CONFIGURATION] = 0x1818, | ||
158 | [WM8996_AIF2TX_TEST] = 0x1, | ||
159 | [WM8996_DSP1_TX_LEFT_VOLUME] = 0xc0, | ||
160 | [WM8996_DSP1_TX_RIGHT_VOLUME] = 0xc0, | ||
161 | [WM8996_DSP1_RX_LEFT_VOLUME] = 0xc0, | ||
162 | [WM8996_DSP1_RX_RIGHT_VOLUME] = 0xc0, | ||
163 | [WM8996_DSP1_TX_FILTERS] = 0x2000, | ||
164 | [WM8996_DSP1_RX_FILTERS_1] = 0x200, | ||
165 | [WM8996_DSP1_RX_FILTERS_2] = 0x10, | ||
166 | [WM8996_DSP1_DRC_1] = 0x98, | ||
167 | [WM8996_DSP1_DRC_2] = 0x845, | ||
168 | [WM8996_DSP1_RX_EQ_GAINS_1] = 0x6318, | ||
169 | [WM8996_DSP1_RX_EQ_GAINS_2] = 0x6300, | ||
170 | [WM8996_DSP1_RX_EQ_BAND_1_A] = 0xfca, | ||
171 | [WM8996_DSP1_RX_EQ_BAND_1_B] = 0x400, | ||
172 | [WM8996_DSP1_RX_EQ_BAND_1_PG] = 0xd8, | ||
173 | [WM8996_DSP1_RX_EQ_BAND_2_A] = 0x1eb5, | ||
174 | [WM8996_DSP1_RX_EQ_BAND_2_B] = 0xf145, | ||
175 | [WM8996_DSP1_RX_EQ_BAND_2_C] = 0xb75, | ||
176 | [WM8996_DSP1_RX_EQ_BAND_2_PG] = 0x1c5, | ||
177 | [WM8996_DSP1_RX_EQ_BAND_3_A] = 0x1c58, | ||
178 | [WM8996_DSP1_RX_EQ_BAND_3_B] = 0xf373, | ||
179 | [WM8996_DSP1_RX_EQ_BAND_3_C] = 0xa54, | ||
180 | [WM8996_DSP1_RX_EQ_BAND_3_PG] = 0x558, | ||
181 | [WM8996_DSP1_RX_EQ_BAND_4_A] = 0x168e, | ||
182 | [WM8996_DSP1_RX_EQ_BAND_4_B] = 0xf829, | ||
183 | [WM8996_DSP1_RX_EQ_BAND_4_C] = 0x7ad, | ||
184 | [WM8996_DSP1_RX_EQ_BAND_4_PG] = 0x1103, | ||
185 | [WM8996_DSP1_RX_EQ_BAND_5_A] = 0x564, | ||
186 | [WM8996_DSP1_RX_EQ_BAND_5_B] = 0x559, | ||
187 | [WM8996_DSP1_RX_EQ_BAND_5_PG] = 0x4000, | ||
188 | [WM8996_DSP2_TX_LEFT_VOLUME] = 0xc0, | ||
189 | [WM8996_DSP2_TX_RIGHT_VOLUME] = 0xc0, | ||
190 | [WM8996_DSP2_RX_LEFT_VOLUME] = 0xc0, | ||
191 | [WM8996_DSP2_RX_RIGHT_VOLUME] = 0xc0, | ||
192 | [WM8996_DSP2_TX_FILTERS] = 0x2000, | ||
193 | [WM8996_DSP2_RX_FILTERS_1] = 0x200, | ||
194 | [WM8996_DSP2_RX_FILTERS_2] = 0x10, | ||
195 | [WM8996_DSP2_DRC_1] = 0x98, | ||
196 | [WM8996_DSP2_DRC_2] = 0x845, | ||
197 | [WM8996_DSP2_RX_EQ_GAINS_1] = 0x6318, | ||
198 | [WM8996_DSP2_RX_EQ_GAINS_2] = 0x6300, | ||
199 | [WM8996_DSP2_RX_EQ_BAND_1_A] = 0xfca, | ||
200 | [WM8996_DSP2_RX_EQ_BAND_1_B] = 0x400, | ||
201 | [WM8996_DSP2_RX_EQ_BAND_1_PG] = 0xd8, | ||
202 | [WM8996_DSP2_RX_EQ_BAND_2_A] = 0x1eb5, | ||
203 | [WM8996_DSP2_RX_EQ_BAND_2_B] = 0xf145, | ||
204 | [WM8996_DSP2_RX_EQ_BAND_2_C] = 0xb75, | ||
205 | [WM8996_DSP2_RX_EQ_BAND_2_PG] = 0x1c5, | ||
206 | [WM8996_DSP2_RX_EQ_BAND_3_A] = 0x1c58, | ||
207 | [WM8996_DSP2_RX_EQ_BAND_3_B] = 0xf373, | ||
208 | [WM8996_DSP2_RX_EQ_BAND_3_C] = 0xa54, | ||
209 | [WM8996_DSP2_RX_EQ_BAND_3_PG] = 0x558, | ||
210 | [WM8996_DSP2_RX_EQ_BAND_4_A] = 0x168e, | ||
211 | [WM8996_DSP2_RX_EQ_BAND_4_B] = 0xf829, | ||
212 | [WM8996_DSP2_RX_EQ_BAND_4_C] = 0x7ad, | ||
213 | [WM8996_DSP2_RX_EQ_BAND_4_PG] = 0x1103, | ||
214 | [WM8996_DSP2_RX_EQ_BAND_5_A] = 0x564, | ||
215 | [WM8996_DSP2_RX_EQ_BAND_5_B] = 0x559, | ||
216 | [WM8996_DSP2_RX_EQ_BAND_5_PG] = 0x4000, | ||
217 | [WM8996_OVERSAMPLING] = 0xd, | ||
218 | [WM8996_SIDETONE] = 0x1040, | ||
219 | [WM8996_GPIO_1] = 0xa101, | ||
220 | [WM8996_GPIO_2] = 0xa101, | ||
221 | [WM8996_GPIO_3] = 0xa101, | ||
222 | [WM8996_GPIO_4] = 0xa101, | ||
223 | [WM8996_GPIO_5] = 0xa101, | ||
224 | [WM8996_PULL_CONTROL_2] = 0x140, | ||
225 | [WM8996_INTERRUPT_STATUS_1_MASK] = 0x1f, | ||
226 | [WM8996_INTERRUPT_STATUS_2_MASK] = 0x1ecf, | ||
227 | [WM8996_RIGHT_PDM_SPEAKER] = 0x1, | ||
228 | [WM8996_PDM_SPEAKER_MUTE_SEQUENCE] = 0x69, | ||
229 | [WM8996_PDM_SPEAKER_VOLUME] = 0x66, | ||
230 | [WM8996_WRITE_SEQUENCER_0] = 0x1, | ||
231 | [WM8996_WRITE_SEQUENCER_1] = 0x1, | ||
232 | [WM8996_WRITE_SEQUENCER_3] = 0x6, | ||
233 | [WM8996_WRITE_SEQUENCER_4] = 0x40, | ||
234 | [WM8996_WRITE_SEQUENCER_5] = 0x1, | ||
235 | [WM8996_WRITE_SEQUENCER_6] = 0xf, | ||
236 | [WM8996_WRITE_SEQUENCER_7] = 0x6, | ||
237 | [WM8996_WRITE_SEQUENCER_8] = 0x1, | ||
238 | [WM8996_WRITE_SEQUENCER_9] = 0x3, | ||
239 | [WM8996_WRITE_SEQUENCER_10] = 0x104, | ||
240 | [WM8996_WRITE_SEQUENCER_12] = 0x60, | ||
241 | [WM8996_WRITE_SEQUENCER_13] = 0x11, | ||
242 | [WM8996_WRITE_SEQUENCER_14] = 0x401, | ||
243 | [WM8996_WRITE_SEQUENCER_16] = 0x50, | ||
244 | [WM8996_WRITE_SEQUENCER_17] = 0x3, | ||
245 | [WM8996_WRITE_SEQUENCER_18] = 0x100, | ||
246 | [WM8996_WRITE_SEQUENCER_20] = 0x51, | ||
247 | [WM8996_WRITE_SEQUENCER_21] = 0x3, | ||
248 | [WM8996_WRITE_SEQUENCER_22] = 0x104, | ||
249 | [WM8996_WRITE_SEQUENCER_23] = 0xa, | ||
250 | [WM8996_WRITE_SEQUENCER_24] = 0x60, | ||
251 | [WM8996_WRITE_SEQUENCER_25] = 0x3b, | ||
252 | [WM8996_WRITE_SEQUENCER_26] = 0x502, | ||
253 | [WM8996_WRITE_SEQUENCER_27] = 0x100, | ||
254 | [WM8996_WRITE_SEQUENCER_28] = 0x2fff, | ||
255 | [WM8996_WRITE_SEQUENCER_32] = 0x2fff, | ||
256 | [WM8996_WRITE_SEQUENCER_36] = 0x2fff, | ||
257 | [WM8996_WRITE_SEQUENCER_40] = 0x2fff, | ||
258 | [WM8996_WRITE_SEQUENCER_44] = 0x2fff, | ||
259 | [WM8996_WRITE_SEQUENCER_48] = 0x2fff, | ||
260 | [WM8996_WRITE_SEQUENCER_52] = 0x2fff, | ||
261 | [WM8996_WRITE_SEQUENCER_56] = 0x2fff, | ||
262 | [WM8996_WRITE_SEQUENCER_60] = 0x2fff, | ||
263 | [WM8996_WRITE_SEQUENCER_64] = 0x1, | ||
264 | [WM8996_WRITE_SEQUENCER_65] = 0x1, | ||
265 | [WM8996_WRITE_SEQUENCER_67] = 0x6, | ||
266 | [WM8996_WRITE_SEQUENCER_68] = 0x40, | ||
267 | [WM8996_WRITE_SEQUENCER_69] = 0x1, | ||
268 | [WM8996_WRITE_SEQUENCER_70] = 0xf, | ||
269 | [WM8996_WRITE_SEQUENCER_71] = 0x6, | ||
270 | [WM8996_WRITE_SEQUENCER_72] = 0x1, | ||
271 | [WM8996_WRITE_SEQUENCER_73] = 0x3, | ||
272 | [WM8996_WRITE_SEQUENCER_74] = 0x104, | ||
273 | [WM8996_WRITE_SEQUENCER_76] = 0x60, | ||
274 | [WM8996_WRITE_SEQUENCER_77] = 0x11, | ||
275 | [WM8996_WRITE_SEQUENCER_78] = 0x401, | ||
276 | [WM8996_WRITE_SEQUENCER_80] = 0x50, | ||
277 | [WM8996_WRITE_SEQUENCER_81] = 0x3, | ||
278 | [WM8996_WRITE_SEQUENCER_82] = 0x100, | ||
279 | [WM8996_WRITE_SEQUENCER_84] = 0x60, | ||
280 | [WM8996_WRITE_SEQUENCER_85] = 0x3b, | ||
281 | [WM8996_WRITE_SEQUENCER_86] = 0x502, | ||
282 | [WM8996_WRITE_SEQUENCER_87] = 0x100, | ||
283 | [WM8996_WRITE_SEQUENCER_88] = 0x2fff, | ||
284 | [WM8996_WRITE_SEQUENCER_92] = 0x2fff, | ||
285 | [WM8996_WRITE_SEQUENCER_96] = 0x2fff, | ||
286 | [WM8996_WRITE_SEQUENCER_100] = 0x2fff, | ||
287 | [WM8996_WRITE_SEQUENCER_104] = 0x2fff, | ||
288 | [WM8996_WRITE_SEQUENCER_108] = 0x2fff, | ||
289 | [WM8996_WRITE_SEQUENCER_112] = 0x2fff, | ||
290 | [WM8996_WRITE_SEQUENCER_116] = 0x2fff, | ||
291 | [WM8996_WRITE_SEQUENCER_120] = 0x2fff, | ||
292 | [WM8996_WRITE_SEQUENCER_124] = 0x2fff, | ||
293 | [WM8996_WRITE_SEQUENCER_128] = 0x1, | ||
294 | [WM8996_WRITE_SEQUENCER_129] = 0x1, | ||
295 | [WM8996_WRITE_SEQUENCER_131] = 0x6, | ||
296 | [WM8996_WRITE_SEQUENCER_132] = 0x40, | ||
297 | [WM8996_WRITE_SEQUENCER_133] = 0x1, | ||
298 | [WM8996_WRITE_SEQUENCER_134] = 0xf, | ||
299 | [WM8996_WRITE_SEQUENCER_135] = 0x6, | ||
300 | [WM8996_WRITE_SEQUENCER_136] = 0x1, | ||
301 | [WM8996_WRITE_SEQUENCER_137] = 0x3, | ||
302 | [WM8996_WRITE_SEQUENCER_138] = 0x106, | ||
303 | [WM8996_WRITE_SEQUENCER_140] = 0x61, | ||
304 | [WM8996_WRITE_SEQUENCER_141] = 0x11, | ||
305 | [WM8996_WRITE_SEQUENCER_142] = 0x401, | ||
306 | [WM8996_WRITE_SEQUENCER_144] = 0x50, | ||
307 | [WM8996_WRITE_SEQUENCER_145] = 0x3, | ||
308 | [WM8996_WRITE_SEQUENCER_146] = 0x102, | ||
309 | [WM8996_WRITE_SEQUENCER_148] = 0x51, | ||
310 | [WM8996_WRITE_SEQUENCER_149] = 0x3, | ||
311 | [WM8996_WRITE_SEQUENCER_150] = 0x106, | ||
312 | [WM8996_WRITE_SEQUENCER_151] = 0xa, | ||
313 | [WM8996_WRITE_SEQUENCER_152] = 0x61, | ||
314 | [WM8996_WRITE_SEQUENCER_153] = 0x3b, | ||
315 | [WM8996_WRITE_SEQUENCER_154] = 0x502, | ||
316 | [WM8996_WRITE_SEQUENCER_155] = 0x100, | ||
317 | [WM8996_WRITE_SEQUENCER_156] = 0x2fff, | ||
318 | [WM8996_WRITE_SEQUENCER_160] = 0x2fff, | ||
319 | [WM8996_WRITE_SEQUENCER_164] = 0x2fff, | ||
320 | [WM8996_WRITE_SEQUENCER_168] = 0x2fff, | ||
321 | [WM8996_WRITE_SEQUENCER_172] = 0x2fff, | ||
322 | [WM8996_WRITE_SEQUENCER_176] = 0x2fff, | ||
323 | [WM8996_WRITE_SEQUENCER_180] = 0x2fff, | ||
324 | [WM8996_WRITE_SEQUENCER_184] = 0x2fff, | ||
325 | [WM8996_WRITE_SEQUENCER_188] = 0x2fff, | ||
326 | [WM8996_WRITE_SEQUENCER_192] = 0x1, | ||
327 | [WM8996_WRITE_SEQUENCER_193] = 0x1, | ||
328 | [WM8996_WRITE_SEQUENCER_195] = 0x6, | ||
329 | [WM8996_WRITE_SEQUENCER_196] = 0x40, | ||
330 | [WM8996_WRITE_SEQUENCER_197] = 0x1, | ||
331 | [WM8996_WRITE_SEQUENCER_198] = 0xf, | ||
332 | [WM8996_WRITE_SEQUENCER_199] = 0x6, | ||
333 | [WM8996_WRITE_SEQUENCER_200] = 0x1, | ||
334 | [WM8996_WRITE_SEQUENCER_201] = 0x3, | ||
335 | [WM8996_WRITE_SEQUENCER_202] = 0x106, | ||
336 | [WM8996_WRITE_SEQUENCER_204] = 0x61, | ||
337 | [WM8996_WRITE_SEQUENCER_205] = 0x11, | ||
338 | [WM8996_WRITE_SEQUENCER_206] = 0x401, | ||
339 | [WM8996_WRITE_SEQUENCER_208] = 0x50, | ||
340 | [WM8996_WRITE_SEQUENCER_209] = 0x3, | ||
341 | [WM8996_WRITE_SEQUENCER_210] = 0x102, | ||
342 | [WM8996_WRITE_SEQUENCER_212] = 0x61, | ||
343 | [WM8996_WRITE_SEQUENCER_213] = 0x3b, | ||
344 | [WM8996_WRITE_SEQUENCER_214] = 0x502, | ||
345 | [WM8996_WRITE_SEQUENCER_215] = 0x100, | ||
346 | [WM8996_WRITE_SEQUENCER_216] = 0x2fff, | ||
347 | [WM8996_WRITE_SEQUENCER_220] = 0x2fff, | ||
348 | [WM8996_WRITE_SEQUENCER_224] = 0x2fff, | ||
349 | [WM8996_WRITE_SEQUENCER_228] = 0x2fff, | ||
350 | [WM8996_WRITE_SEQUENCER_232] = 0x2fff, | ||
351 | [WM8996_WRITE_SEQUENCER_236] = 0x2fff, | ||
352 | [WM8996_WRITE_SEQUENCER_240] = 0x2fff, | ||
353 | [WM8996_WRITE_SEQUENCER_244] = 0x2fff, | ||
354 | [WM8996_WRITE_SEQUENCER_248] = 0x2fff, | ||
355 | [WM8996_WRITE_SEQUENCER_252] = 0x2fff, | ||
356 | [WM8996_WRITE_SEQUENCER_256] = 0x60, | ||
357 | [WM8996_WRITE_SEQUENCER_258] = 0x601, | ||
358 | [WM8996_WRITE_SEQUENCER_260] = 0x50, | ||
359 | [WM8996_WRITE_SEQUENCER_262] = 0x100, | ||
360 | [WM8996_WRITE_SEQUENCER_264] = 0x1, | ||
361 | [WM8996_WRITE_SEQUENCER_266] = 0x104, | ||
362 | [WM8996_WRITE_SEQUENCER_267] = 0x100, | ||
363 | [WM8996_WRITE_SEQUENCER_268] = 0x2fff, | ||
364 | [WM8996_WRITE_SEQUENCER_272] = 0x2fff, | ||
365 | [WM8996_WRITE_SEQUENCER_276] = 0x2fff, | ||
366 | [WM8996_WRITE_SEQUENCER_280] = 0x2fff, | ||
367 | [WM8996_WRITE_SEQUENCER_284] = 0x2fff, | ||
368 | [WM8996_WRITE_SEQUENCER_288] = 0x2fff, | ||
369 | [WM8996_WRITE_SEQUENCER_292] = 0x2fff, | ||
370 | [WM8996_WRITE_SEQUENCER_296] = 0x2fff, | ||
371 | [WM8996_WRITE_SEQUENCER_300] = 0x2fff, | ||
372 | [WM8996_WRITE_SEQUENCER_304] = 0x2fff, | ||
373 | [WM8996_WRITE_SEQUENCER_308] = 0x2fff, | ||
374 | [WM8996_WRITE_SEQUENCER_312] = 0x2fff, | ||
375 | [WM8996_WRITE_SEQUENCER_316] = 0x2fff, | ||
376 | [WM8996_WRITE_SEQUENCER_320] = 0x61, | ||
377 | [WM8996_WRITE_SEQUENCER_322] = 0x601, | ||
378 | [WM8996_WRITE_SEQUENCER_324] = 0x50, | ||
379 | [WM8996_WRITE_SEQUENCER_326] = 0x102, | ||
380 | [WM8996_WRITE_SEQUENCER_328] = 0x1, | ||
381 | [WM8996_WRITE_SEQUENCER_330] = 0x106, | ||
382 | [WM8996_WRITE_SEQUENCER_331] = 0x100, | ||
383 | [WM8996_WRITE_SEQUENCER_332] = 0x2fff, | ||
384 | [WM8996_WRITE_SEQUENCER_336] = 0x2fff, | ||
385 | [WM8996_WRITE_SEQUENCER_340] = 0x2fff, | ||
386 | [WM8996_WRITE_SEQUENCER_344] = 0x2fff, | ||
387 | [WM8996_WRITE_SEQUENCER_348] = 0x2fff, | ||
388 | [WM8996_WRITE_SEQUENCER_352] = 0x2fff, | ||
389 | [WM8996_WRITE_SEQUENCER_356] = 0x2fff, | ||
390 | [WM8996_WRITE_SEQUENCER_360] = 0x2fff, | ||
391 | [WM8996_WRITE_SEQUENCER_364] = 0x2fff, | ||
392 | [WM8996_WRITE_SEQUENCER_368] = 0x2fff, | ||
393 | [WM8996_WRITE_SEQUENCER_372] = 0x2fff, | ||
394 | [WM8996_WRITE_SEQUENCER_376] = 0x2fff, | ||
395 | [WM8996_WRITE_SEQUENCER_380] = 0x2fff, | ||
396 | [WM8996_WRITE_SEQUENCER_384] = 0x60, | ||
397 | [WM8996_WRITE_SEQUENCER_386] = 0x601, | ||
398 | [WM8996_WRITE_SEQUENCER_388] = 0x61, | ||
399 | [WM8996_WRITE_SEQUENCER_390] = 0x601, | ||
400 | [WM8996_WRITE_SEQUENCER_392] = 0x50, | ||
401 | [WM8996_WRITE_SEQUENCER_394] = 0x300, | ||
402 | [WM8996_WRITE_SEQUENCER_396] = 0x1, | ||
403 | [WM8996_WRITE_SEQUENCER_398] = 0x304, | ||
404 | [WM8996_WRITE_SEQUENCER_400] = 0x40, | ||
405 | [WM8996_WRITE_SEQUENCER_402] = 0xf, | ||
406 | [WM8996_WRITE_SEQUENCER_404] = 0x1, | ||
407 | [WM8996_WRITE_SEQUENCER_407] = 0x100, | ||
408 | }; | ||
409 | |||
410 | static const DECLARE_TLV_DB_SCALE(inpga_tlv, 0, 100, 0); | ||
411 | static const DECLARE_TLV_DB_SCALE(sidetone_tlv, -3600, 150, 0); | ||
412 | static const DECLARE_TLV_DB_SCALE(digital_tlv, -7200, 75, 1); | ||
413 | static const DECLARE_TLV_DB_SCALE(out_digital_tlv, -1200, 150, 0); | ||
414 | static const DECLARE_TLV_DB_SCALE(out_tlv, -900, 75, 0); | ||
415 | static const DECLARE_TLV_DB_SCALE(spk_tlv, -900, 150, 0); | ||
416 | static const DECLARE_TLV_DB_SCALE(eq_tlv, -1200, 100, 0); | ||
417 | |||
418 | static const char *sidetone_hpf_text[] = { | ||
419 | "2.9kHz", "1.5kHz", "735Hz", "403Hz", "196Hz", "98Hz", "49Hz" | ||
420 | }; | ||
421 | |||
422 | static const struct soc_enum sidetone_hpf = | ||
423 | SOC_ENUM_SINGLE(WM8996_SIDETONE, 7, 6, sidetone_hpf_text); | ||
424 | |||
425 | static const char *hpf_mode_text[] = { | ||
426 | "HiFi", "Custom", "Voice" | ||
427 | }; | ||
428 | |||
429 | static const struct soc_enum dsp1tx_hpf_mode = | ||
430 | SOC_ENUM_SINGLE(WM8996_DSP1_TX_FILTERS, 3, 3, hpf_mode_text); | ||
431 | |||
432 | static const struct soc_enum dsp2tx_hpf_mode = | ||
433 | SOC_ENUM_SINGLE(WM8996_DSP2_TX_FILTERS, 3, 3, hpf_mode_text); | ||
434 | |||
435 | static const char *hpf_cutoff_text[] = { | ||
436 | "50Hz", "75Hz", "100Hz", "150Hz", "200Hz", "300Hz", "400Hz" | ||
437 | }; | ||
438 | |||
439 | static const struct soc_enum dsp1tx_hpf_cutoff = | ||
440 | SOC_ENUM_SINGLE(WM8996_DSP1_TX_FILTERS, 0, 7, hpf_cutoff_text); | ||
441 | |||
442 | static const struct soc_enum dsp2tx_hpf_cutoff = | ||
443 | SOC_ENUM_SINGLE(WM8996_DSP2_TX_FILTERS, 0, 7, hpf_cutoff_text); | ||
444 | |||
445 | static void wm8996_set_retune_mobile(struct snd_soc_codec *codec, int block) | ||
446 | { | ||
447 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
448 | struct wm8996_pdata *pdata = &wm8996->pdata; | ||
449 | int base, best, best_val, save, i, cfg, iface; | ||
450 | |||
451 | if (!wm8996->num_retune_mobile_texts) | ||
452 | return; | ||
453 | |||
454 | switch (block) { | ||
455 | case 0: | ||
456 | base = WM8996_DSP1_RX_EQ_GAINS_1; | ||
457 | if (snd_soc_read(codec, WM8996_POWER_MANAGEMENT_8) & | ||
458 | WM8996_DSP1RX_SRC) | ||
459 | iface = 1; | ||
460 | else | ||
461 | iface = 0; | ||
462 | break; | ||
463 | case 1: | ||
464 | base = WM8996_DSP1_RX_EQ_GAINS_2; | ||
465 | if (snd_soc_read(codec, WM8996_POWER_MANAGEMENT_8) & | ||
466 | WM8996_DSP2RX_SRC) | ||
467 | iface = 1; | ||
468 | else | ||
469 | iface = 0; | ||
470 | break; | ||
471 | default: | ||
472 | return; | ||
473 | } | ||
474 | |||
475 | /* Find the version of the currently selected configuration | ||
476 | * with the nearest sample rate. */ | ||
477 | cfg = wm8996->retune_mobile_cfg[block]; | ||
478 | best = 0; | ||
479 | best_val = INT_MAX; | ||
480 | for (i = 0; i < pdata->num_retune_mobile_cfgs; i++) { | ||
481 | if (strcmp(pdata->retune_mobile_cfgs[i].name, | ||
482 | wm8996->retune_mobile_texts[cfg]) == 0 && | ||
483 | abs(pdata->retune_mobile_cfgs[i].rate | ||
484 | - wm8996->rx_rate[iface]) < best_val) { | ||
485 | best = i; | ||
486 | best_val = abs(pdata->retune_mobile_cfgs[i].rate | ||
487 | - wm8996->rx_rate[iface]); | ||
488 | } | ||
489 | } | ||
490 | |||
491 | dev_dbg(codec->dev, "ReTune Mobile %d %s/%dHz for %dHz sample rate\n", | ||
492 | block, | ||
493 | pdata->retune_mobile_cfgs[best].name, | ||
494 | pdata->retune_mobile_cfgs[best].rate, | ||
495 | wm8996->rx_rate[iface]); | ||
496 | |||
497 | /* The EQ will be disabled while reconfiguring it, remember the | ||
498 | * current configuration. | ||
499 | */ | ||
500 | save = snd_soc_read(codec, base); | ||
501 | save &= WM8996_DSP1RX_EQ_ENA; | ||
502 | |||
503 | for (i = 0; i < ARRAY_SIZE(pdata->retune_mobile_cfgs[best].regs); i++) | ||
504 | snd_soc_update_bits(codec, base + i, 0xffff, | ||
505 | pdata->retune_mobile_cfgs[best].regs[i]); | ||
506 | |||
507 | snd_soc_update_bits(codec, base, WM8996_DSP1RX_EQ_ENA, save); | ||
508 | } | ||
509 | |||
510 | /* Icky as hell but saves code duplication */ | ||
511 | static int wm8996_get_retune_mobile_block(const char *name) | ||
512 | { | ||
513 | if (strcmp(name, "DSP1 EQ Mode") == 0) | ||
514 | return 0; | ||
515 | if (strcmp(name, "DSP2 EQ Mode") == 0) | ||
516 | return 1; | ||
517 | return -EINVAL; | ||
518 | } | ||
519 | |||
520 | static int wm8996_put_retune_mobile_enum(struct snd_kcontrol *kcontrol, | ||
521 | struct snd_ctl_elem_value *ucontrol) | ||
522 | { | ||
523 | struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol); | ||
524 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
525 | struct wm8996_pdata *pdata = &wm8996->pdata; | ||
526 | int block = wm8996_get_retune_mobile_block(kcontrol->id.name); | ||
527 | int value = ucontrol->value.integer.value[0]; | ||
528 | |||
529 | if (block < 0) | ||
530 | return block; | ||
531 | |||
532 | if (value >= pdata->num_retune_mobile_cfgs) | ||
533 | return -EINVAL; | ||
534 | |||
535 | wm8996->retune_mobile_cfg[block] = value; | ||
536 | |||
537 | wm8996_set_retune_mobile(codec, block); | ||
538 | |||
539 | return 0; | ||
540 | } | ||
541 | |||
542 | static int wm8996_get_retune_mobile_enum(struct snd_kcontrol *kcontrol, | ||
543 | struct snd_ctl_elem_value *ucontrol) | ||
544 | { | ||
545 | struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol); | ||
546 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
547 | int block = wm8996_get_retune_mobile_block(kcontrol->id.name); | ||
548 | |||
549 | ucontrol->value.enumerated.item[0] = wm8996->retune_mobile_cfg[block]; | ||
550 | |||
551 | return 0; | ||
552 | } | ||
553 | |||
554 | static const struct snd_kcontrol_new wm8996_snd_controls[] = { | ||
555 | SOC_DOUBLE_R_TLV("Capture Volume", WM8996_LEFT_LINE_INPUT_VOLUME, | ||
556 | WM8996_RIGHT_LINE_INPUT_VOLUME, 0, 31, 0, inpga_tlv), | ||
557 | SOC_DOUBLE_R("Capture ZC Switch", WM8996_LEFT_LINE_INPUT_VOLUME, | ||
558 | WM8996_RIGHT_LINE_INPUT_VOLUME, 5, 1, 0), | ||
559 | |||
560 | SOC_DOUBLE_TLV("DAC1 Sidetone Volume", WM8996_DAC1_MIXER_VOLUMES, | ||
561 | 0, 5, 24, 0, sidetone_tlv), | ||
562 | SOC_DOUBLE_TLV("DAC2 Sidetone Volume", WM8996_DAC2_MIXER_VOLUMES, | ||
563 | 0, 5, 24, 0, sidetone_tlv), | ||
564 | SOC_SINGLE("Sidetone LPF Switch", WM8996_SIDETONE, 12, 1, 0), | ||
565 | SOC_ENUM("Sidetone HPF Cut-off", sidetone_hpf), | ||
566 | SOC_SINGLE("Sidetone HPF Switch", WM8996_SIDETONE, 6, 1, 0), | ||
567 | |||
568 | SOC_DOUBLE_R_TLV("DSP1 Capture Volume", WM8996_DSP1_TX_LEFT_VOLUME, | ||
569 | WM8996_DSP1_TX_RIGHT_VOLUME, 1, 96, 0, digital_tlv), | ||
570 | SOC_DOUBLE_R_TLV("DSP2 Capture Volume", WM8996_DSP2_TX_LEFT_VOLUME, | ||
571 | WM8996_DSP2_TX_RIGHT_VOLUME, 1, 96, 0, digital_tlv), | ||
572 | |||
573 | SOC_SINGLE("DSP1 Capture Notch Filter Switch", WM8996_DSP1_TX_FILTERS, | ||
574 | 13, 1, 0), | ||
575 | SOC_DOUBLE("DSP1 Capture HPF Switch", WM8996_DSP1_TX_FILTERS, 12, 11, 1, 0), | ||
576 | SOC_ENUM("DSP1 Capture HPF Mode", dsp1tx_hpf_mode), | ||
577 | SOC_ENUM("DSP1 Capture HPF Cutoff", dsp1tx_hpf_cutoff), | ||
578 | |||
579 | SOC_SINGLE("DSP2 Capture Notch Filter Switch", WM8996_DSP2_TX_FILTERS, | ||
580 | 13, 1, 0), | ||
581 | SOC_DOUBLE("DSP2 Capture HPF Switch", WM8996_DSP2_TX_FILTERS, 12, 11, 1, 0), | ||
582 | SOC_ENUM("DSP2 Capture HPF Mode", dsp2tx_hpf_mode), | ||
583 | SOC_ENUM("DSP2 Capture HPF Cutoff", dsp2tx_hpf_cutoff), | ||
584 | |||
585 | SOC_DOUBLE_R_TLV("DSP1 Playback Volume", WM8996_DSP1_RX_LEFT_VOLUME, | ||
586 | WM8996_DSP1_RX_RIGHT_VOLUME, 1, 112, 0, digital_tlv), | ||
587 | SOC_SINGLE("DSP1 Playback Switch", WM8996_DSP1_RX_FILTERS_1, 9, 1, 1), | ||
588 | |||
589 | SOC_DOUBLE_R_TLV("DSP2 Playback Volume", WM8996_DSP2_RX_LEFT_VOLUME, | ||
590 | WM8996_DSP2_RX_RIGHT_VOLUME, 1, 112, 0, digital_tlv), | ||
591 | SOC_SINGLE("DSP2 Playback Switch", WM8996_DSP2_RX_FILTERS_1, 9, 1, 1), | ||
592 | |||
593 | SOC_DOUBLE_R_TLV("DAC1 Volume", WM8996_DAC1_LEFT_VOLUME, | ||
594 | WM8996_DAC1_RIGHT_VOLUME, 1, 112, 0, digital_tlv), | ||
595 | SOC_DOUBLE_R("DAC1 Switch", WM8996_DAC1_LEFT_VOLUME, | ||
596 | WM8996_DAC1_RIGHT_VOLUME, 9, 1, 1), | ||
597 | |||
598 | SOC_DOUBLE_R_TLV("DAC2 Volume", WM8996_DAC2_LEFT_VOLUME, | ||
599 | WM8996_DAC2_RIGHT_VOLUME, 1, 112, 0, digital_tlv), | ||
600 | SOC_DOUBLE_R("DAC2 Switch", WM8996_DAC2_LEFT_VOLUME, | ||
601 | WM8996_DAC2_RIGHT_VOLUME, 9, 1, 1), | ||
602 | |||
603 | SOC_SINGLE("Speaker High Performance Switch", WM8996_OVERSAMPLING, 3, 1, 0), | ||
604 | SOC_SINGLE("DMIC High Performance Switch", WM8996_OVERSAMPLING, 2, 1, 0), | ||
605 | SOC_SINGLE("ADC High Performance Switch", WM8996_OVERSAMPLING, 1, 1, 0), | ||
606 | SOC_SINGLE("DAC High Performance Switch", WM8996_OVERSAMPLING, 0, 1, 0), | ||
607 | |||
608 | SOC_SINGLE("DAC Soft Mute Switch", WM8996_DAC_SOFTMUTE, 1, 1, 0), | ||
609 | SOC_SINGLE("DAC Slow Soft Mute Switch", WM8996_DAC_SOFTMUTE, 0, 1, 0), | ||
610 | |||
611 | SOC_DOUBLE_TLV("Digital Output 1 Volume", WM8996_DAC1_HPOUT1_VOLUME, 0, 4, | ||
612 | 8, 0, out_digital_tlv), | ||
613 | SOC_DOUBLE_TLV("Digital Output 2 Volume", WM8996_DAC2_HPOUT2_VOLUME, 0, 4, | ||
614 | 8, 0, out_digital_tlv), | ||
615 | |||
616 | SOC_DOUBLE_R_TLV("Output 1 Volume", WM8996_OUTPUT1_LEFT_VOLUME, | ||
617 | WM8996_OUTPUT1_RIGHT_VOLUME, 0, 12, 0, out_tlv), | ||
618 | SOC_DOUBLE_R("Output 1 ZC Switch", WM8996_OUTPUT1_LEFT_VOLUME, | ||
619 | WM8996_OUTPUT1_RIGHT_VOLUME, 7, 1, 0), | ||
620 | |||
621 | SOC_DOUBLE_R_TLV("Output 2 Volume", WM8996_OUTPUT2_LEFT_VOLUME, | ||
622 | WM8996_OUTPUT2_RIGHT_VOLUME, 0, 12, 0, out_tlv), | ||
623 | SOC_DOUBLE_R("Output 2 ZC Switch", WM8996_OUTPUT2_LEFT_VOLUME, | ||
624 | WM8996_OUTPUT2_RIGHT_VOLUME, 7, 1, 0), | ||
625 | |||
626 | SOC_DOUBLE_TLV("Speaker Volume", WM8996_PDM_SPEAKER_VOLUME, 0, 4, 8, 0, | ||
627 | spk_tlv), | ||
628 | SOC_DOUBLE_R("Speaker Switch", WM8996_LEFT_PDM_SPEAKER, | ||
629 | WM8996_RIGHT_PDM_SPEAKER, 3, 1, 1), | ||
630 | SOC_DOUBLE_R("Speaker ZC Switch", WM8996_LEFT_PDM_SPEAKER, | ||
631 | WM8996_RIGHT_PDM_SPEAKER, 2, 1, 0), | ||
632 | |||
633 | SOC_SINGLE("DSP1 EQ Switch", WM8996_DSP1_RX_EQ_GAINS_1, 0, 1, 0), | ||
634 | SOC_SINGLE("DSP2 EQ Switch", WM8996_DSP2_RX_EQ_GAINS_1, 0, 1, 0), | ||
635 | }; | ||
636 | |||
637 | static const struct snd_kcontrol_new wm8996_eq_controls[] = { | ||
638 | SOC_SINGLE_TLV("DSP1 EQ B1 Volume", WM8996_DSP1_RX_EQ_GAINS_1, 11, 31, 0, | ||
639 | eq_tlv), | ||
640 | SOC_SINGLE_TLV("DSP1 EQ B2 Volume", WM8996_DSP1_RX_EQ_GAINS_1, 6, 31, 0, | ||
641 | eq_tlv), | ||
642 | SOC_SINGLE_TLV("DSP1 EQ B3 Volume", WM8996_DSP1_RX_EQ_GAINS_1, 1, 31, 0, | ||
643 | eq_tlv), | ||
644 | SOC_SINGLE_TLV("DSP1 EQ B4 Volume", WM8996_DSP1_RX_EQ_GAINS_2, 11, 31, 0, | ||
645 | eq_tlv), | ||
646 | SOC_SINGLE_TLV("DSP1 EQ B5 Volume", WM8996_DSP1_RX_EQ_GAINS_2, 6, 31, 0, | ||
647 | eq_tlv), | ||
648 | |||
649 | SOC_SINGLE_TLV("DSP2 EQ B1 Volume", WM8996_DSP2_RX_EQ_GAINS_1, 11, 31, 0, | ||
650 | eq_tlv), | ||
651 | SOC_SINGLE_TLV("DSP2 EQ B2 Volume", WM8996_DSP2_RX_EQ_GAINS_1, 6, 31, 0, | ||
652 | eq_tlv), | ||
653 | SOC_SINGLE_TLV("DSP2 EQ B3 Volume", WM8996_DSP2_RX_EQ_GAINS_1, 1, 31, 0, | ||
654 | eq_tlv), | ||
655 | SOC_SINGLE_TLV("DSP2 EQ B4 Volume", WM8996_DSP2_RX_EQ_GAINS_2, 11, 31, 0, | ||
656 | eq_tlv), | ||
657 | SOC_SINGLE_TLV("DSP2 EQ B5 Volume", WM8996_DSP2_RX_EQ_GAINS_2, 6, 31, 0, | ||
658 | eq_tlv), | ||
659 | }; | ||
660 | |||
661 | static int cp_event(struct snd_soc_dapm_widget *w, | ||
662 | struct snd_kcontrol *kcontrol, int event) | ||
663 | { | ||
664 | switch (event) { | ||
665 | case SND_SOC_DAPM_POST_PMU: | ||
666 | msleep(5); | ||
667 | break; | ||
668 | default: | ||
669 | BUG(); | ||
670 | return -EINVAL; | ||
671 | } | ||
672 | |||
673 | return 0; | ||
674 | } | ||
675 | |||
676 | static int rmv_short_event(struct snd_soc_dapm_widget *w, | ||
677 | struct snd_kcontrol *kcontrol, int event) | ||
678 | { | ||
679 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(w->codec); | ||
680 | |||
681 | /* Record which outputs we enabled */ | ||
682 | switch (event) { | ||
683 | case SND_SOC_DAPM_PRE_PMD: | ||
684 | wm8996->hpout_pending &= ~w->shift; | ||
685 | break; | ||
686 | case SND_SOC_DAPM_PRE_PMU: | ||
687 | wm8996->hpout_pending |= w->shift; | ||
688 | break; | ||
689 | default: | ||
690 | BUG(); | ||
691 | return -EINVAL; | ||
692 | } | ||
693 | |||
694 | return 0; | ||
695 | } | ||
696 | |||
697 | static void wait_for_dc_servo(struct snd_soc_codec *codec, u16 mask) | ||
698 | { | ||
699 | struct i2c_client *i2c = to_i2c_client(codec->dev); | ||
700 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
701 | int i, ret; | ||
702 | unsigned long timeout = 200; | ||
703 | |||
704 | snd_soc_write(codec, WM8996_DC_SERVO_2, mask); | ||
705 | |||
706 | /* Use the interrupt if possible */ | ||
707 | do { | ||
708 | if (i2c->irq) { | ||
709 | timeout = wait_for_completion_timeout(&wm8996->dcs_done, | ||
710 | msecs_to_jiffies(200)); | ||
711 | if (timeout == 0) | ||
712 | dev_err(codec->dev, "DC servo timed out\n"); | ||
713 | |||
714 | } else { | ||
715 | msleep(1); | ||
716 | if (--i) { | ||
717 | timeout = 0; | ||
718 | break; | ||
719 | } | ||
720 | } | ||
721 | |||
722 | ret = snd_soc_read(codec, WM8996_DC_SERVO_2); | ||
723 | dev_dbg(codec->dev, "DC servo state: %x\n", ret); | ||
724 | } while (ret & mask); | ||
725 | |||
726 | if (timeout == 0) | ||
727 | dev_err(codec->dev, "DC servo timed out for %x\n", mask); | ||
728 | else | ||
729 | dev_dbg(codec->dev, "DC servo complete for %x\n", mask); | ||
730 | } | ||
731 | |||
732 | static void wm8996_seq_notifier(struct snd_soc_dapm_context *dapm, | ||
733 | enum snd_soc_dapm_type event, int subseq) | ||
734 | { | ||
735 | struct snd_soc_codec *codec = container_of(dapm, | ||
736 | struct snd_soc_codec, dapm); | ||
737 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
738 | u16 val, mask; | ||
739 | |||
740 | /* Complete any pending DC servo starts */ | ||
741 | if (wm8996->dcs_pending) { | ||
742 | dev_dbg(codec->dev, "Starting DC servo for %x\n", | ||
743 | wm8996->dcs_pending); | ||
744 | |||
745 | /* Trigger a startup sequence */ | ||
746 | wait_for_dc_servo(codec, wm8996->dcs_pending | ||
747 | << WM8996_DCS_TRIG_STARTUP_0_SHIFT); | ||
748 | |||
749 | wm8996->dcs_pending = 0; | ||
750 | } | ||
751 | |||
752 | if (wm8996->hpout_pending != wm8996->hpout_ena) { | ||
753 | dev_dbg(codec->dev, "Applying RMV_SHORTs %x->%x\n", | ||
754 | wm8996->hpout_ena, wm8996->hpout_pending); | ||
755 | |||
756 | val = 0; | ||
757 | mask = 0; | ||
758 | if (wm8996->hpout_pending & HPOUT1L) { | ||
759 | val |= WM8996_HPOUT1L_RMV_SHORT; | ||
760 | mask |= WM8996_HPOUT1L_RMV_SHORT; | ||
761 | } else { | ||
762 | mask |= WM8996_HPOUT1L_RMV_SHORT | | ||
763 | WM8996_HPOUT1L_OUTP | | ||
764 | WM8996_HPOUT1L_DLY; | ||
765 | } | ||
766 | |||
767 | if (wm8996->hpout_pending & HPOUT1R) { | ||
768 | val |= WM8996_HPOUT1R_RMV_SHORT; | ||
769 | mask |= WM8996_HPOUT1R_RMV_SHORT; | ||
770 | } else { | ||
771 | mask |= WM8996_HPOUT1R_RMV_SHORT | | ||
772 | WM8996_HPOUT1R_OUTP | | ||
773 | WM8996_HPOUT1R_DLY; | ||
774 | } | ||
775 | |||
776 | snd_soc_update_bits(codec, WM8996_ANALOGUE_HP_1, mask, val); | ||
777 | |||
778 | val = 0; | ||
779 | mask = 0; | ||
780 | if (wm8996->hpout_pending & HPOUT2L) { | ||
781 | val |= WM8996_HPOUT2L_RMV_SHORT; | ||
782 | mask |= WM8996_HPOUT2L_RMV_SHORT; | ||
783 | } else { | ||
784 | mask |= WM8996_HPOUT2L_RMV_SHORT | | ||
785 | WM8996_HPOUT2L_OUTP | | ||
786 | WM8996_HPOUT2L_DLY; | ||
787 | } | ||
788 | |||
789 | if (wm8996->hpout_pending & HPOUT2R) { | ||
790 | val |= WM8996_HPOUT2R_RMV_SHORT; | ||
791 | mask |= WM8996_HPOUT2R_RMV_SHORT; | ||
792 | } else { | ||
793 | mask |= WM8996_HPOUT2R_RMV_SHORT | | ||
794 | WM8996_HPOUT2R_OUTP | | ||
795 | WM8996_HPOUT2R_DLY; | ||
796 | } | ||
797 | |||
798 | snd_soc_update_bits(codec, WM8996_ANALOGUE_HP_2, mask, val); | ||
799 | |||
800 | wm8996->hpout_ena = wm8996->hpout_pending; | ||
801 | } | ||
802 | } | ||
803 | |||
804 | static int dcs_start(struct snd_soc_dapm_widget *w, | ||
805 | struct snd_kcontrol *kcontrol, int event) | ||
806 | { | ||
807 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(w->codec); | ||
808 | |||
809 | switch (event) { | ||
810 | case SND_SOC_DAPM_POST_PMU: | ||
811 | wm8996->dcs_pending |= 1 << w->shift; | ||
812 | break; | ||
813 | default: | ||
814 | BUG(); | ||
815 | return -EINVAL; | ||
816 | } | ||
817 | |||
818 | return 0; | ||
819 | } | ||
820 | |||
821 | static const char *sidetone_text[] = { | ||
822 | "IN1", "IN2", | ||
823 | }; | ||
824 | |||
825 | static const struct soc_enum left_sidetone_enum = | ||
826 | SOC_ENUM_SINGLE(WM8996_SIDETONE, 0, 2, sidetone_text); | ||
827 | |||
828 | static const struct snd_kcontrol_new left_sidetone = | ||
829 | SOC_DAPM_ENUM("Left Sidetone", left_sidetone_enum); | ||
830 | |||
831 | static const struct soc_enum right_sidetone_enum = | ||
832 | SOC_ENUM_SINGLE(WM8996_SIDETONE, 1, 2, sidetone_text); | ||
833 | |||
834 | static const struct snd_kcontrol_new right_sidetone = | ||
835 | SOC_DAPM_ENUM("Right Sidetone", right_sidetone_enum); | ||
836 | |||
837 | static const char *spk_text[] = { | ||
838 | "DAC1L", "DAC1R", "DAC2L", "DAC2R" | ||
839 | }; | ||
840 | |||
841 | static const struct soc_enum spkl_enum = | ||
842 | SOC_ENUM_SINGLE(WM8996_LEFT_PDM_SPEAKER, 0, 4, spk_text); | ||
843 | |||
844 | static const struct snd_kcontrol_new spkl_mux = | ||
845 | SOC_DAPM_ENUM("SPKL", spkl_enum); | ||
846 | |||
847 | static const struct soc_enum spkr_enum = | ||
848 | SOC_ENUM_SINGLE(WM8996_RIGHT_PDM_SPEAKER, 0, 4, spk_text); | ||
849 | |||
850 | static const struct snd_kcontrol_new spkr_mux = | ||
851 | SOC_DAPM_ENUM("SPKR", spkr_enum); | ||
852 | |||
853 | static const char *dsp1rx_text[] = { | ||
854 | "AIF1", "AIF2" | ||
855 | }; | ||
856 | |||
857 | static const struct soc_enum dsp1rx_enum = | ||
858 | SOC_ENUM_SINGLE(WM8996_POWER_MANAGEMENT_8, 0, 2, dsp1rx_text); | ||
859 | |||
860 | static const struct snd_kcontrol_new dsp1rx = | ||
861 | SOC_DAPM_ENUM("DSP1RX", dsp1rx_enum); | ||
862 | |||
863 | static const char *dsp2rx_text[] = { | ||
864 | "AIF2", "AIF1" | ||
865 | }; | ||
866 | |||
867 | static const struct soc_enum dsp2rx_enum = | ||
868 | SOC_ENUM_SINGLE(WM8996_POWER_MANAGEMENT_8, 4, 2, dsp2rx_text); | ||
869 | |||
870 | static const struct snd_kcontrol_new dsp2rx = | ||
871 | SOC_DAPM_ENUM("DSP2RX", dsp2rx_enum); | ||
872 | |||
873 | static const char *aif2tx_text[] = { | ||
874 | "DSP2", "DSP1", "AIF1" | ||
875 | }; | ||
876 | |||
877 | static const struct soc_enum aif2tx_enum = | ||
878 | SOC_ENUM_SINGLE(WM8996_POWER_MANAGEMENT_8, 6, 3, aif2tx_text); | ||
879 | |||
880 | static const struct snd_kcontrol_new aif2tx = | ||
881 | SOC_DAPM_ENUM("AIF2TX", aif2tx_enum); | ||
882 | |||
883 | static const char *inmux_text[] = { | ||
884 | "ADC", "DMIC1", "DMIC2" | ||
885 | }; | ||
886 | |||
887 | static const struct soc_enum in1_enum = | ||
888 | SOC_ENUM_SINGLE(WM8996_POWER_MANAGEMENT_7, 0, 3, inmux_text); | ||
889 | |||
890 | static const struct snd_kcontrol_new in1_mux = | ||
891 | SOC_DAPM_ENUM("IN1 Mux", in1_enum); | ||
892 | |||
893 | static const struct soc_enum in2_enum = | ||
894 | SOC_ENUM_SINGLE(WM8996_POWER_MANAGEMENT_7, 4, 3, inmux_text); | ||
895 | |||
896 | static const struct snd_kcontrol_new in2_mux = | ||
897 | SOC_DAPM_ENUM("IN2 Mux", in2_enum); | ||
898 | |||
899 | static const struct snd_kcontrol_new dac2r_mix[] = { | ||
900 | SOC_DAPM_SINGLE("Right Sidetone Switch", WM8996_DAC2_RIGHT_MIXER_ROUTING, | ||
901 | 5, 1, 0), | ||
902 | SOC_DAPM_SINGLE("Left Sidetone Switch", WM8996_DAC2_RIGHT_MIXER_ROUTING, | ||
903 | 4, 1, 0), | ||
904 | SOC_DAPM_SINGLE("DSP2 Switch", WM8996_DAC2_RIGHT_MIXER_ROUTING, 1, 1, 0), | ||
905 | SOC_DAPM_SINGLE("DSP1 Switch", WM8996_DAC2_RIGHT_MIXER_ROUTING, 0, 1, 0), | ||
906 | }; | ||
907 | |||
908 | static const struct snd_kcontrol_new dac2l_mix[] = { | ||
909 | SOC_DAPM_SINGLE("Right Sidetone Switch", WM8996_DAC2_LEFT_MIXER_ROUTING, | ||
910 | 5, 1, 0), | ||
911 | SOC_DAPM_SINGLE("Left Sidetone Switch", WM8996_DAC2_LEFT_MIXER_ROUTING, | ||
912 | 4, 1, 0), | ||
913 | SOC_DAPM_SINGLE("DSP2 Switch", WM8996_DAC2_LEFT_MIXER_ROUTING, 1, 1, 0), | ||
914 | SOC_DAPM_SINGLE("DSP1 Switch", WM8996_DAC2_LEFT_MIXER_ROUTING, 0, 1, 0), | ||
915 | }; | ||
916 | |||
917 | static const struct snd_kcontrol_new dac1r_mix[] = { | ||
918 | SOC_DAPM_SINGLE("Right Sidetone Switch", WM8996_DAC1_RIGHT_MIXER_ROUTING, | ||
919 | 5, 1, 0), | ||
920 | SOC_DAPM_SINGLE("Left Sidetone Switch", WM8996_DAC1_RIGHT_MIXER_ROUTING, | ||
921 | 4, 1, 0), | ||
922 | SOC_DAPM_SINGLE("DSP2 Switch", WM8996_DAC1_RIGHT_MIXER_ROUTING, 1, 1, 0), | ||
923 | SOC_DAPM_SINGLE("DSP1 Switch", WM8996_DAC1_RIGHT_MIXER_ROUTING, 0, 1, 0), | ||
924 | }; | ||
925 | |||
926 | static const struct snd_kcontrol_new dac1l_mix[] = { | ||
927 | SOC_DAPM_SINGLE("Right Sidetone Switch", WM8996_DAC1_LEFT_MIXER_ROUTING, | ||
928 | 5, 1, 0), | ||
929 | SOC_DAPM_SINGLE("Left Sidetone Switch", WM8996_DAC1_LEFT_MIXER_ROUTING, | ||
930 | 4, 1, 0), | ||
931 | SOC_DAPM_SINGLE("DSP2 Switch", WM8996_DAC1_LEFT_MIXER_ROUTING, 1, 1, 0), | ||
932 | SOC_DAPM_SINGLE("DSP1 Switch", WM8996_DAC1_LEFT_MIXER_ROUTING, 0, 1, 0), | ||
933 | }; | ||
934 | |||
935 | static const struct snd_kcontrol_new dsp1txl[] = { | ||
936 | SOC_DAPM_SINGLE("IN1 Switch", WM8996_DSP1_TX_LEFT_MIXER_ROUTING, | ||
937 | 1, 1, 0), | ||
938 | SOC_DAPM_SINGLE("DAC Switch", WM8996_DSP1_TX_LEFT_MIXER_ROUTING, | ||
939 | 0, 1, 0), | ||
940 | }; | ||
941 | |||
942 | static const struct snd_kcontrol_new dsp1txr[] = { | ||
943 | SOC_DAPM_SINGLE("IN1 Switch", WM8996_DSP1_TX_RIGHT_MIXER_ROUTING, | ||
944 | 1, 1, 0), | ||
945 | SOC_DAPM_SINGLE("DAC Switch", WM8996_DSP1_TX_RIGHT_MIXER_ROUTING, | ||
946 | 0, 1, 0), | ||
947 | }; | ||
948 | |||
949 | static const struct snd_kcontrol_new dsp2txl[] = { | ||
950 | SOC_DAPM_SINGLE("IN1 Switch", WM8996_DSP2_TX_LEFT_MIXER_ROUTING, | ||
951 | 1, 1, 0), | ||
952 | SOC_DAPM_SINGLE("DAC Switch", WM8996_DSP2_TX_LEFT_MIXER_ROUTING, | ||
953 | 0, 1, 0), | ||
954 | }; | ||
955 | |||
956 | static const struct snd_kcontrol_new dsp2txr[] = { | ||
957 | SOC_DAPM_SINGLE("IN1 Switch", WM8996_DSP2_TX_RIGHT_MIXER_ROUTING, | ||
958 | 1, 1, 0), | ||
959 | SOC_DAPM_SINGLE("DAC Switch", WM8996_DSP2_TX_RIGHT_MIXER_ROUTING, | ||
960 | 0, 1, 0), | ||
961 | }; | ||
962 | |||
963 | |||
964 | static const struct snd_soc_dapm_widget wm8996_dapm_widgets[] = { | ||
965 | SND_SOC_DAPM_INPUT("IN1LN"), | ||
966 | SND_SOC_DAPM_INPUT("IN1LP"), | ||
967 | SND_SOC_DAPM_INPUT("IN1RN"), | ||
968 | SND_SOC_DAPM_INPUT("IN1RP"), | ||
969 | |||
970 | SND_SOC_DAPM_INPUT("IN2LN"), | ||
971 | SND_SOC_DAPM_INPUT("IN2LP"), | ||
972 | SND_SOC_DAPM_INPUT("IN2RN"), | ||
973 | SND_SOC_DAPM_INPUT("IN2RP"), | ||
974 | |||
975 | SND_SOC_DAPM_INPUT("DMIC1DAT"), | ||
976 | SND_SOC_DAPM_INPUT("DMIC2DAT"), | ||
977 | |||
978 | SND_SOC_DAPM_SUPPLY_S("SYSCLK", 1, WM8996_AIF_CLOCKING_1, 0, 0, NULL, 0), | ||
979 | SND_SOC_DAPM_SUPPLY_S("SYSDSPCLK", 2, WM8996_CLOCKING_1, 1, 0, NULL, 0), | ||
980 | SND_SOC_DAPM_SUPPLY_S("AIFCLK", 2, WM8996_CLOCKING_1, 2, 0, NULL, 0), | ||
981 | SND_SOC_DAPM_SUPPLY_S("Charge Pump", 2, WM8996_CHARGE_PUMP_1, 15, 0, cp_event, | ||
982 | SND_SOC_DAPM_POST_PMU), | ||
983 | |||
984 | SND_SOC_DAPM_SUPPLY("LDO2", WM8996_POWER_MANAGEMENT_2, 1, 0, NULL, 0), | ||
985 | SND_SOC_DAPM_MICBIAS("MICB2", WM8996_POWER_MANAGEMENT_1, 9, 0), | ||
986 | SND_SOC_DAPM_MICBIAS("MICB1", WM8996_POWER_MANAGEMENT_1, 8, 0), | ||
987 | |||
988 | SND_SOC_DAPM_PGA("IN1L PGA", WM8996_POWER_MANAGEMENT_2, 5, 0, NULL, 0), | ||
989 | SND_SOC_DAPM_PGA("IN1R PGA", WM8996_POWER_MANAGEMENT_2, 4, 0, NULL, 0), | ||
990 | |||
991 | SND_SOC_DAPM_MUX("IN1L Mux", SND_SOC_NOPM, 0, 0, &in1_mux), | ||
992 | SND_SOC_DAPM_MUX("IN1R Mux", SND_SOC_NOPM, 0, 0, &in1_mux), | ||
993 | SND_SOC_DAPM_MUX("IN2L Mux", SND_SOC_NOPM, 0, 0, &in2_mux), | ||
994 | SND_SOC_DAPM_MUX("IN2R Mux", SND_SOC_NOPM, 0, 0, &in2_mux), | ||
995 | |||
996 | SND_SOC_DAPM_PGA("IN1L", WM8996_POWER_MANAGEMENT_7, 2, 0, NULL, 0), | ||
997 | SND_SOC_DAPM_PGA("IN1R", WM8996_POWER_MANAGEMENT_7, 3, 0, NULL, 0), | ||
998 | SND_SOC_DAPM_PGA("IN2L", WM8996_POWER_MANAGEMENT_7, 6, 0, NULL, 0), | ||
999 | SND_SOC_DAPM_PGA("IN2R", WM8996_POWER_MANAGEMENT_7, 7, 0, NULL, 0), | ||
1000 | |||
1001 | SND_SOC_DAPM_SUPPLY("DMIC2", WM8996_POWER_MANAGEMENT_7, 9, 0, NULL, 0), | ||
1002 | SND_SOC_DAPM_SUPPLY("DMIC1", WM8996_POWER_MANAGEMENT_7, 8, 0, NULL, 0), | ||
1003 | |||
1004 | SND_SOC_DAPM_ADC("DMIC2L", NULL, WM8996_POWER_MANAGEMENT_3, 5, 0), | ||
1005 | SND_SOC_DAPM_ADC("DMIC2R", NULL, WM8996_POWER_MANAGEMENT_3, 4, 0), | ||
1006 | SND_SOC_DAPM_ADC("DMIC1L", NULL, WM8996_POWER_MANAGEMENT_3, 3, 0), | ||
1007 | SND_SOC_DAPM_ADC("DMIC1R", NULL, WM8996_POWER_MANAGEMENT_3, 2, 0), | ||
1008 | |||
1009 | SND_SOC_DAPM_ADC("ADCL", NULL, WM8996_POWER_MANAGEMENT_3, 1, 0), | ||
1010 | SND_SOC_DAPM_ADC("ADCR", NULL, WM8996_POWER_MANAGEMENT_3, 0, 0), | ||
1011 | |||
1012 | SND_SOC_DAPM_MUX("Left Sidetone", SND_SOC_NOPM, 0, 0, &left_sidetone), | ||
1013 | SND_SOC_DAPM_MUX("Right Sidetone", SND_SOC_NOPM, 0, 0, &right_sidetone), | ||
1014 | |||
1015 | SND_SOC_DAPM_AIF_IN("DSP2RXL", NULL, 0, WM8996_POWER_MANAGEMENT_3, 11, 0), | ||
1016 | SND_SOC_DAPM_AIF_IN("DSP2RXR", NULL, 1, WM8996_POWER_MANAGEMENT_3, 10, 0), | ||
1017 | SND_SOC_DAPM_AIF_IN("DSP1RXL", NULL, 0, WM8996_POWER_MANAGEMENT_3, 9, 0), | ||
1018 | SND_SOC_DAPM_AIF_IN("DSP1RXR", NULL, 1, WM8996_POWER_MANAGEMENT_3, 8, 0), | ||
1019 | |||
1020 | SND_SOC_DAPM_MIXER("DSP2TXL", WM8996_POWER_MANAGEMENT_5, 11, 0, | ||
1021 | dsp2txl, ARRAY_SIZE(dsp2txl)), | ||
1022 | SND_SOC_DAPM_MIXER("DSP2TXR", WM8996_POWER_MANAGEMENT_5, 10, 0, | ||
1023 | dsp2txr, ARRAY_SIZE(dsp2txr)), | ||
1024 | SND_SOC_DAPM_MIXER("DSP1TXL", WM8996_POWER_MANAGEMENT_5, 9, 0, | ||
1025 | dsp1txl, ARRAY_SIZE(dsp1txl)), | ||
1026 | SND_SOC_DAPM_MIXER("DSP1TXR", WM8996_POWER_MANAGEMENT_5, 8, 0, | ||
1027 | dsp1txr, ARRAY_SIZE(dsp1txr)), | ||
1028 | |||
1029 | SND_SOC_DAPM_MIXER("DAC2L Mixer", SND_SOC_NOPM, 0, 0, | ||
1030 | dac2l_mix, ARRAY_SIZE(dac2l_mix)), | ||
1031 | SND_SOC_DAPM_MIXER("DAC2R Mixer", SND_SOC_NOPM, 0, 0, | ||
1032 | dac2r_mix, ARRAY_SIZE(dac2r_mix)), | ||
1033 | SND_SOC_DAPM_MIXER("DAC1L Mixer", SND_SOC_NOPM, 0, 0, | ||
1034 | dac1l_mix, ARRAY_SIZE(dac1l_mix)), | ||
1035 | SND_SOC_DAPM_MIXER("DAC1R Mixer", SND_SOC_NOPM, 0, 0, | ||
1036 | dac1r_mix, ARRAY_SIZE(dac1r_mix)), | ||
1037 | |||
1038 | SND_SOC_DAPM_DAC("DAC2L", NULL, WM8996_POWER_MANAGEMENT_5, 3, 0), | ||
1039 | SND_SOC_DAPM_DAC("DAC2R", NULL, WM8996_POWER_MANAGEMENT_5, 2, 0), | ||
1040 | SND_SOC_DAPM_DAC("DAC1L", NULL, WM8996_POWER_MANAGEMENT_5, 1, 0), | ||
1041 | SND_SOC_DAPM_DAC("DAC1R", NULL, WM8996_POWER_MANAGEMENT_5, 0, 0), | ||
1042 | |||
1043 | SND_SOC_DAPM_AIF_IN("AIF2RX1", "AIF2 Playback", 1, | ||
1044 | WM8996_POWER_MANAGEMENT_4, 9, 0), | ||
1045 | SND_SOC_DAPM_AIF_IN("AIF2RX0", "AIF2 Playback", 2, | ||
1046 | WM8996_POWER_MANAGEMENT_4, 8, 0), | ||
1047 | |||
1048 | SND_SOC_DAPM_AIF_IN("AIF2TX1", "AIF2 Capture", 1, | ||
1049 | WM8996_POWER_MANAGEMENT_6, 9, 0), | ||
1050 | SND_SOC_DAPM_AIF_IN("AIF2TX0", "AIF2 Capture", 2, | ||
1051 | WM8996_POWER_MANAGEMENT_6, 8, 0), | ||
1052 | |||
1053 | SND_SOC_DAPM_AIF_IN("AIF1RX5", "AIF1 Playback", 5, | ||
1054 | WM8996_POWER_MANAGEMENT_4, 5, 0), | ||
1055 | SND_SOC_DAPM_AIF_IN("AIF1RX4", "AIF1 Playback", 4, | ||
1056 | WM8996_POWER_MANAGEMENT_4, 4, 0), | ||
1057 | SND_SOC_DAPM_AIF_IN("AIF1RX3", "AIF1 Playback", 3, | ||
1058 | WM8996_POWER_MANAGEMENT_4, 3, 0), | ||
1059 | SND_SOC_DAPM_AIF_IN("AIF1RX2", "AIF1 Playback", 2, | ||
1060 | WM8996_POWER_MANAGEMENT_4, 2, 0), | ||
1061 | SND_SOC_DAPM_AIF_IN("AIF1RX1", "AIF1 Playback", 1, | ||
1062 | WM8996_POWER_MANAGEMENT_4, 1, 0), | ||
1063 | SND_SOC_DAPM_AIF_IN("AIF1RX0", "AIF1 Playback", 0, | ||
1064 | WM8996_POWER_MANAGEMENT_4, 0, 0), | ||
1065 | |||
1066 | SND_SOC_DAPM_AIF_OUT("AIF1TX5", "AIF1 Capture", 5, | ||
1067 | WM8996_POWER_MANAGEMENT_6, 5, 0), | ||
1068 | SND_SOC_DAPM_AIF_OUT("AIF1TX4", "AIF1 Capture", 4, | ||
1069 | WM8996_POWER_MANAGEMENT_6, 4, 0), | ||
1070 | SND_SOC_DAPM_AIF_OUT("AIF1TX3", "AIF1 Capture", 3, | ||
1071 | WM8996_POWER_MANAGEMENT_6, 3, 0), | ||
1072 | SND_SOC_DAPM_AIF_OUT("AIF1TX2", "AIF1 Capture", 2, | ||
1073 | WM8996_POWER_MANAGEMENT_6, 2, 0), | ||
1074 | SND_SOC_DAPM_AIF_OUT("AIF1TX1", "AIF1 Capture", 1, | ||
1075 | WM8996_POWER_MANAGEMENT_6, 1, 0), | ||
1076 | SND_SOC_DAPM_AIF_OUT("AIF1TX0", "AIF1 Capture", 0, | ||
1077 | WM8996_POWER_MANAGEMENT_6, 0, 0), | ||
1078 | |||
1079 | /* We route as stereo pairs so define some dummy widgets to squash | ||
1080 | * things down for now. RXA = 0,1, RXB = 2,3 and so on */ | ||
1081 | SND_SOC_DAPM_PGA("AIF1RXA", SND_SOC_NOPM, 0, 0, NULL, 0), | ||
1082 | SND_SOC_DAPM_PGA("AIF1RXB", SND_SOC_NOPM, 0, 0, NULL, 0), | ||
1083 | SND_SOC_DAPM_PGA("AIF1RXC", SND_SOC_NOPM, 0, 0, NULL, 0), | ||
1084 | SND_SOC_DAPM_PGA("AIF2RX", SND_SOC_NOPM, 0, 0, NULL, 0), | ||
1085 | SND_SOC_DAPM_PGA("DSP2TX", SND_SOC_NOPM, 0, 0, NULL, 0), | ||
1086 | |||
1087 | SND_SOC_DAPM_MUX("DSP1RX", SND_SOC_NOPM, 0, 0, &dsp1rx), | ||
1088 | SND_SOC_DAPM_MUX("DSP2RX", SND_SOC_NOPM, 0, 0, &dsp2rx), | ||
1089 | SND_SOC_DAPM_MUX("AIF2TX", SND_SOC_NOPM, 0, 0, &aif2tx), | ||
1090 | |||
1091 | SND_SOC_DAPM_MUX("SPKL", SND_SOC_NOPM, 0, 0, &spkl_mux), | ||
1092 | SND_SOC_DAPM_MUX("SPKR", SND_SOC_NOPM, 0, 0, &spkr_mux), | ||
1093 | SND_SOC_DAPM_PGA("SPKL PGA", WM8996_LEFT_PDM_SPEAKER, 4, 0, NULL, 0), | ||
1094 | SND_SOC_DAPM_PGA("SPKR PGA", WM8996_RIGHT_PDM_SPEAKER, 4, 0, NULL, 0), | ||
1095 | |||
1096 | SND_SOC_DAPM_PGA_S("HPOUT2L PGA", 0, WM8996_POWER_MANAGEMENT_1, 7, 0, NULL, 0), | ||
1097 | SND_SOC_DAPM_PGA_S("HPOUT2L_DLY", 1, WM8996_ANALOGUE_HP_2, 5, 0, NULL, 0), | ||
1098 | SND_SOC_DAPM_PGA_S("HPOUT2L_DCS", 2, WM8996_DC_SERVO_1, 2, 0, dcs_start, | ||
1099 | SND_SOC_DAPM_POST_PMU), | ||
1100 | SND_SOC_DAPM_PGA_S("HPOUT2L_OUTP", 3, WM8996_ANALOGUE_HP_2, 6, 0, NULL, 0), | ||
1101 | SND_SOC_DAPM_PGA_S("HPOUT2L_RMV_SHORT", 3, SND_SOC_NOPM, HPOUT2L, 0, | ||
1102 | rmv_short_event, | ||
1103 | SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_PRE_PMD), | ||
1104 | |||
1105 | SND_SOC_DAPM_PGA_S("HPOUT2R PGA", 0, WM8996_POWER_MANAGEMENT_1, 6, 0,NULL, 0), | ||
1106 | SND_SOC_DAPM_PGA_S("HPOUT2R_DLY", 1, WM8996_ANALOGUE_HP_2, 1, 0, NULL, 0), | ||
1107 | SND_SOC_DAPM_PGA_S("HPOUT2R_DCS", 2, WM8996_DC_SERVO_1, 3, 0, dcs_start, | ||
1108 | SND_SOC_DAPM_POST_PMU), | ||
1109 | SND_SOC_DAPM_PGA_S("HPOUT2R_OUTP", 3, WM8996_ANALOGUE_HP_2, 2, 0, NULL, 0), | ||
1110 | SND_SOC_DAPM_PGA_S("HPOUT2R_RMV_SHORT", 3, SND_SOC_NOPM, HPOUT2R, 0, | ||
1111 | rmv_short_event, | ||
1112 | SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_PRE_PMD), | ||
1113 | |||
1114 | SND_SOC_DAPM_PGA_S("HPOUT1L PGA", 0, WM8996_POWER_MANAGEMENT_1, 5, 0, NULL, 0), | ||
1115 | SND_SOC_DAPM_PGA_S("HPOUT1L_DLY", 1, WM8996_ANALOGUE_HP_1, 5, 0, NULL, 0), | ||
1116 | SND_SOC_DAPM_PGA_S("HPOUT1L_DCS", 2, WM8996_DC_SERVO_1, 0, 0, dcs_start, | ||
1117 | SND_SOC_DAPM_POST_PMU), | ||
1118 | SND_SOC_DAPM_PGA_S("HPOUT1L_OUTP", 3, WM8996_ANALOGUE_HP_1, 6, 0, NULL, 0), | ||
1119 | SND_SOC_DAPM_PGA_S("HPOUT1L_RMV_SHORT", 3, SND_SOC_NOPM, HPOUT1L, 0, | ||
1120 | rmv_short_event, | ||
1121 | SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_PRE_PMD), | ||
1122 | |||
1123 | SND_SOC_DAPM_PGA_S("HPOUT1R PGA", 0, WM8996_POWER_MANAGEMENT_1, 4, 0, NULL, 0), | ||
1124 | SND_SOC_DAPM_PGA_S("HPOUT1R_DLY", 1, WM8996_ANALOGUE_HP_1, 1, 0, NULL, 0), | ||
1125 | SND_SOC_DAPM_PGA_S("HPOUT1R_DCS", 2, WM8996_DC_SERVO_1, 1, 0, dcs_start, | ||
1126 | SND_SOC_DAPM_POST_PMU), | ||
1127 | SND_SOC_DAPM_PGA_S("HPOUT1R_OUTP", 3, WM8996_ANALOGUE_HP_1, 2, 0, NULL, 0), | ||
1128 | SND_SOC_DAPM_PGA_S("HPOUT1R_RMV_SHORT", 3, SND_SOC_NOPM, HPOUT1R, 0, | ||
1129 | rmv_short_event, | ||
1130 | SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_PRE_PMD), | ||
1131 | |||
1132 | SND_SOC_DAPM_OUTPUT("HPOUT1L"), | ||
1133 | SND_SOC_DAPM_OUTPUT("HPOUT1R"), | ||
1134 | SND_SOC_DAPM_OUTPUT("HPOUT2L"), | ||
1135 | SND_SOC_DAPM_OUTPUT("HPOUT2R"), | ||
1136 | SND_SOC_DAPM_OUTPUT("SPKDAT"), | ||
1137 | }; | ||
1138 | |||
1139 | static const struct snd_soc_dapm_route wm8996_dapm_routes[] = { | ||
1140 | { "AIFCLK", NULL, "SYSCLK" }, | ||
1141 | { "SYSDSPCLK", NULL, "SYSCLK" }, | ||
1142 | { "Charge Pump", NULL, "SYSCLK" }, | ||
1143 | |||
1144 | { "MICB1", NULL, "LDO2" }, | ||
1145 | { "MICB2", NULL, "LDO2" }, | ||
1146 | |||
1147 | { "IN1L PGA", NULL, "IN2LN" }, | ||
1148 | { "IN1L PGA", NULL, "IN2LP" }, | ||
1149 | { "IN1L PGA", NULL, "IN1LN" }, | ||
1150 | { "IN1L PGA", NULL, "IN1LP" }, | ||
1151 | |||
1152 | { "IN1R PGA", NULL, "IN2RN" }, | ||
1153 | { "IN1R PGA", NULL, "IN2RP" }, | ||
1154 | { "IN1R PGA", NULL, "IN1RN" }, | ||
1155 | { "IN1R PGA", NULL, "IN1RP" }, | ||
1156 | |||
1157 | { "ADCL", NULL, "IN1L PGA" }, | ||
1158 | |||
1159 | { "ADCR", NULL, "IN1R PGA" }, | ||
1160 | |||
1161 | { "DMIC1L", NULL, "DMIC1DAT" }, | ||
1162 | { "DMIC1R", NULL, "DMIC1DAT" }, | ||
1163 | { "DMIC2L", NULL, "DMIC2DAT" }, | ||
1164 | { "DMIC2R", NULL, "DMIC2DAT" }, | ||
1165 | |||
1166 | { "DMIC2L", NULL, "DMIC2" }, | ||
1167 | { "DMIC2R", NULL, "DMIC2" }, | ||
1168 | { "DMIC1L", NULL, "DMIC1" }, | ||
1169 | { "DMIC1R", NULL, "DMIC1" }, | ||
1170 | |||
1171 | { "IN1L Mux", "ADC", "ADCL" }, | ||
1172 | { "IN1L Mux", "DMIC1", "DMIC1L" }, | ||
1173 | { "IN1L Mux", "DMIC2", "DMIC2L" }, | ||
1174 | |||
1175 | { "IN1R Mux", "ADC", "ADCR" }, | ||
1176 | { "IN1R Mux", "DMIC1", "DMIC1R" }, | ||
1177 | { "IN1R Mux", "DMIC2", "DMIC2R" }, | ||
1178 | |||
1179 | { "IN2L Mux", "ADC", "ADCL" }, | ||
1180 | { "IN2L Mux", "DMIC1", "DMIC1L" }, | ||
1181 | { "IN2L Mux", "DMIC2", "DMIC2L" }, | ||
1182 | |||
1183 | { "IN2R Mux", "ADC", "ADCR" }, | ||
1184 | { "IN2R Mux", "DMIC1", "DMIC1R" }, | ||
1185 | { "IN2R Mux", "DMIC2", "DMIC2R" }, | ||
1186 | |||
1187 | { "Left Sidetone", "IN1", "IN1L Mux" }, | ||
1188 | { "Left Sidetone", "IN2", "IN2L Mux" }, | ||
1189 | |||
1190 | { "Right Sidetone", "IN1", "IN1R Mux" }, | ||
1191 | { "Right Sidetone", "IN2", "IN2R Mux" }, | ||
1192 | |||
1193 | { "DSP1TXL", "IN1 Switch", "IN1L Mux" }, | ||
1194 | { "DSP1TXR", "IN1 Switch", "IN1R Mux" }, | ||
1195 | |||
1196 | { "DSP2TXL", "IN1 Switch", "IN2L Mux" }, | ||
1197 | { "DSP2TXR", "IN1 Switch", "IN2R Mux" }, | ||
1198 | |||
1199 | { "AIF1TX0", NULL, "DSP1TXL" }, | ||
1200 | { "AIF1TX1", NULL, "DSP1TXR" }, | ||
1201 | { "AIF1TX2", NULL, "DSP2TXL" }, | ||
1202 | { "AIF1TX3", NULL, "DSP2TXR" }, | ||
1203 | { "AIF1TX4", NULL, "AIF2RX0" }, | ||
1204 | { "AIF1TX5", NULL, "AIF2RX1" }, | ||
1205 | |||
1206 | { "AIF1RX0", NULL, "AIFCLK" }, | ||
1207 | { "AIF1RX1", NULL, "AIFCLK" }, | ||
1208 | { "AIF1RX2", NULL, "AIFCLK" }, | ||
1209 | { "AIF1RX3", NULL, "AIFCLK" }, | ||
1210 | { "AIF1RX4", NULL, "AIFCLK" }, | ||
1211 | { "AIF1RX5", NULL, "AIFCLK" }, | ||
1212 | |||
1213 | { "AIF2RX0", NULL, "AIFCLK" }, | ||
1214 | { "AIF2RX1", NULL, "AIFCLK" }, | ||
1215 | |||
1216 | { "DSP1RXL", NULL, "SYSDSPCLK" }, | ||
1217 | { "DSP1RXR", NULL, "SYSDSPCLK" }, | ||
1218 | { "DSP2RXL", NULL, "SYSDSPCLK" }, | ||
1219 | { "DSP2RXR", NULL, "SYSDSPCLK" }, | ||
1220 | { "DSP1TXL", NULL, "SYSDSPCLK" }, | ||
1221 | { "DSP1TXR", NULL, "SYSDSPCLK" }, | ||
1222 | { "DSP2TXL", NULL, "SYSDSPCLK" }, | ||
1223 | { "DSP2TXR", NULL, "SYSDSPCLK" }, | ||
1224 | |||
1225 | { "AIF1RXA", NULL, "AIF1RX0" }, | ||
1226 | { "AIF1RXA", NULL, "AIF1RX1" }, | ||
1227 | { "AIF1RXB", NULL, "AIF1RX2" }, | ||
1228 | { "AIF1RXB", NULL, "AIF1RX3" }, | ||
1229 | { "AIF1RXC", NULL, "AIF1RX4" }, | ||
1230 | { "AIF1RXC", NULL, "AIF1RX5" }, | ||
1231 | |||
1232 | { "AIF2RX", NULL, "AIF2RX0" }, | ||
1233 | { "AIF2RX", NULL, "AIF2RX1" }, | ||
1234 | |||
1235 | { "AIF2TX", "DSP2", "DSP2TX" }, | ||
1236 | { "AIF2TX", "DSP1", "DSP1RX" }, | ||
1237 | { "AIF2TX", "AIF1", "AIF1RXC" }, | ||
1238 | |||
1239 | { "DSP1RXL", NULL, "DSP1RX" }, | ||
1240 | { "DSP1RXR", NULL, "DSP1RX" }, | ||
1241 | { "DSP2RXL", NULL, "DSP2RX" }, | ||
1242 | { "DSP2RXR", NULL, "DSP2RX" }, | ||
1243 | |||
1244 | { "DSP2TX", NULL, "DSP2TXL" }, | ||
1245 | { "DSP2TX", NULL, "DSP2TXR" }, | ||
1246 | |||
1247 | { "DSP1RX", "AIF1", "AIF1RXA" }, | ||
1248 | { "DSP1RX", "AIF2", "AIF2RX" }, | ||
1249 | |||
1250 | { "DSP2RX", "AIF1", "AIF1RXB" }, | ||
1251 | { "DSP2RX", "AIF2", "AIF2RX" }, | ||
1252 | |||
1253 | { "DAC2L Mixer", "DSP2 Switch", "DSP2RXL" }, | ||
1254 | { "DAC2L Mixer", "DSP1 Switch", "DSP1RXL" }, | ||
1255 | { "DAC2L Mixer", "Right Sidetone Switch", "Right Sidetone" }, | ||
1256 | { "DAC2L Mixer", "Left Sidetone Switch", "Left Sidetone" }, | ||
1257 | |||
1258 | { "DAC2R Mixer", "DSP2 Switch", "DSP2RXR" }, | ||
1259 | { "DAC2R Mixer", "DSP1 Switch", "DSP1RXR" }, | ||
1260 | { "DAC2R Mixer", "Right Sidetone Switch", "Right Sidetone" }, | ||
1261 | { "DAC2R Mixer", "Left Sidetone Switch", "Left Sidetone" }, | ||
1262 | |||
1263 | { "DAC1L Mixer", "DSP2 Switch", "DSP2RXL" }, | ||
1264 | { "DAC1L Mixer", "DSP1 Switch", "DSP1RXL" }, | ||
1265 | { "DAC1L Mixer", "Right Sidetone Switch", "Right Sidetone" }, | ||
1266 | { "DAC1L Mixer", "Left Sidetone Switch", "Left Sidetone" }, | ||
1267 | |||
1268 | { "DAC1R Mixer", "DSP2 Switch", "DSP2RXR" }, | ||
1269 | { "DAC1R Mixer", "DSP1 Switch", "DSP1RXR" }, | ||
1270 | { "DAC1R Mixer", "Right Sidetone Switch", "Right Sidetone" }, | ||
1271 | { "DAC1R Mixer", "Left Sidetone Switch", "Left Sidetone" }, | ||
1272 | |||
1273 | { "DAC1L", NULL, "DAC1L Mixer" }, | ||
1274 | { "DAC1R", NULL, "DAC1R Mixer" }, | ||
1275 | { "DAC2L", NULL, "DAC2L Mixer" }, | ||
1276 | { "DAC2R", NULL, "DAC2R Mixer" }, | ||
1277 | |||
1278 | { "HPOUT2L PGA", NULL, "Charge Pump" }, | ||
1279 | { "HPOUT2L PGA", NULL, "DAC2L" }, | ||
1280 | { "HPOUT2L_DLY", NULL, "HPOUT2L PGA" }, | ||
1281 | { "HPOUT2L_DCS", NULL, "HPOUT2L_DLY" }, | ||
1282 | { "HPOUT2L_OUTP", NULL, "HPOUT2L_DCS" }, | ||
1283 | { "HPOUT2L_RMV_SHORT", NULL, "HPOUT2L_OUTP" }, | ||
1284 | |||
1285 | { "HPOUT2R PGA", NULL, "Charge Pump" }, | ||
1286 | { "HPOUT2R PGA", NULL, "DAC2R" }, | ||
1287 | { "HPOUT2R_DLY", NULL, "HPOUT2R PGA" }, | ||
1288 | { "HPOUT2R_DCS", NULL, "HPOUT2R_DLY" }, | ||
1289 | { "HPOUT2R_OUTP", NULL, "HPOUT2R_DCS" }, | ||
1290 | { "HPOUT2R_RMV_SHORT", NULL, "HPOUT2R_OUTP" }, | ||
1291 | |||
1292 | { "HPOUT1L PGA", NULL, "Charge Pump" }, | ||
1293 | { "HPOUT1L PGA", NULL, "DAC1L" }, | ||
1294 | { "HPOUT1L_DLY", NULL, "HPOUT1L PGA" }, | ||
1295 | { "HPOUT1L_DCS", NULL, "HPOUT1L_DLY" }, | ||
1296 | { "HPOUT1L_OUTP", NULL, "HPOUT1L_DCS" }, | ||
1297 | { "HPOUT1L_RMV_SHORT", NULL, "HPOUT1L_OUTP" }, | ||
1298 | |||
1299 | { "HPOUT1R PGA", NULL, "Charge Pump" }, | ||
1300 | { "HPOUT1R PGA", NULL, "DAC1R" }, | ||
1301 | { "HPOUT1R_DLY", NULL, "HPOUT1R PGA" }, | ||
1302 | { "HPOUT1R_DCS", NULL, "HPOUT1R_DLY" }, | ||
1303 | { "HPOUT1R_OUTP", NULL, "HPOUT1R_DCS" }, | ||
1304 | { "HPOUT1R_RMV_SHORT", NULL, "HPOUT1R_OUTP" }, | ||
1305 | |||
1306 | { "HPOUT2L", NULL, "HPOUT2L_RMV_SHORT" }, | ||
1307 | { "HPOUT2R", NULL, "HPOUT2R_RMV_SHORT" }, | ||
1308 | { "HPOUT1L", NULL, "HPOUT1L_RMV_SHORT" }, | ||
1309 | { "HPOUT1R", NULL, "HPOUT1R_RMV_SHORT" }, | ||
1310 | |||
1311 | { "SPKL", "DAC1L", "DAC1L" }, | ||
1312 | { "SPKL", "DAC1R", "DAC1R" }, | ||
1313 | { "SPKL", "DAC2L", "DAC2L" }, | ||
1314 | { "SPKL", "DAC2R", "DAC2R" }, | ||
1315 | |||
1316 | { "SPKR", "DAC1L", "DAC1L" }, | ||
1317 | { "SPKR", "DAC1R", "DAC1R" }, | ||
1318 | { "SPKR", "DAC2L", "DAC2L" }, | ||
1319 | { "SPKR", "DAC2R", "DAC2R" }, | ||
1320 | |||
1321 | { "SPKL PGA", NULL, "SPKL" }, | ||
1322 | { "SPKR PGA", NULL, "SPKR" }, | ||
1323 | |||
1324 | { "SPKDAT", NULL, "SPKL PGA" }, | ||
1325 | { "SPKDAT", NULL, "SPKR PGA" }, | ||
1326 | }; | ||
1327 | |||
1328 | static int wm8996_readable_register(struct snd_soc_codec *codec, | ||
1329 | unsigned int reg) | ||
1330 | { | ||
1331 | /* Due to the sparseness of the register map the compiler | ||
1332 | * output from an explicit switch statement ends up being much | ||
1333 | * more efficient than a table. | ||
1334 | */ | ||
1335 | switch (reg) { | ||
1336 | case WM8996_SOFTWARE_RESET: | ||
1337 | case WM8996_POWER_MANAGEMENT_1: | ||
1338 | case WM8996_POWER_MANAGEMENT_2: | ||
1339 | case WM8996_POWER_MANAGEMENT_3: | ||
1340 | case WM8996_POWER_MANAGEMENT_4: | ||
1341 | case WM8996_POWER_MANAGEMENT_5: | ||
1342 | case WM8996_POWER_MANAGEMENT_6: | ||
1343 | case WM8996_POWER_MANAGEMENT_7: | ||
1344 | case WM8996_POWER_MANAGEMENT_8: | ||
1345 | case WM8996_LEFT_LINE_INPUT_VOLUME: | ||
1346 | case WM8996_RIGHT_LINE_INPUT_VOLUME: | ||
1347 | case WM8996_LINE_INPUT_CONTROL: | ||
1348 | case WM8996_DAC1_HPOUT1_VOLUME: | ||
1349 | case WM8996_DAC2_HPOUT2_VOLUME: | ||
1350 | case WM8996_DAC1_LEFT_VOLUME: | ||
1351 | case WM8996_DAC1_RIGHT_VOLUME: | ||
1352 | case WM8996_DAC2_LEFT_VOLUME: | ||
1353 | case WM8996_DAC2_RIGHT_VOLUME: | ||
1354 | case WM8996_OUTPUT1_LEFT_VOLUME: | ||
1355 | case WM8996_OUTPUT1_RIGHT_VOLUME: | ||
1356 | case WM8996_OUTPUT2_LEFT_VOLUME: | ||
1357 | case WM8996_OUTPUT2_RIGHT_VOLUME: | ||
1358 | case WM8996_MICBIAS_1: | ||
1359 | case WM8996_MICBIAS_2: | ||
1360 | case WM8996_LDO_1: | ||
1361 | case WM8996_LDO_2: | ||
1362 | case WM8996_ACCESSORY_DETECT_MODE_1: | ||
1363 | case WM8996_ACCESSORY_DETECT_MODE_2: | ||
1364 | case WM8996_HEADPHONE_DETECT_1: | ||
1365 | case WM8996_HEADPHONE_DETECT_2: | ||
1366 | case WM8996_MIC_DETECT_1: | ||
1367 | case WM8996_MIC_DETECT_2: | ||
1368 | case WM8996_MIC_DETECT_3: | ||
1369 | case WM8996_CHARGE_PUMP_1: | ||
1370 | case WM8996_CHARGE_PUMP_2: | ||
1371 | case WM8996_DC_SERVO_1: | ||
1372 | case WM8996_DC_SERVO_2: | ||
1373 | case WM8996_DC_SERVO_3: | ||
1374 | case WM8996_DC_SERVO_5: | ||
1375 | case WM8996_DC_SERVO_6: | ||
1376 | case WM8996_DC_SERVO_7: | ||
1377 | case WM8996_DC_SERVO_READBACK_0: | ||
1378 | case WM8996_ANALOGUE_HP_1: | ||
1379 | case WM8996_ANALOGUE_HP_2: | ||
1380 | case WM8996_CHIP_REVISION: | ||
1381 | case WM8996_CONTROL_INTERFACE_1: | ||
1382 | case WM8996_WRITE_SEQUENCER_CTRL_1: | ||
1383 | case WM8996_WRITE_SEQUENCER_CTRL_2: | ||
1384 | case WM8996_AIF_CLOCKING_1: | ||
1385 | case WM8996_AIF_CLOCKING_2: | ||
1386 | case WM8996_CLOCKING_1: | ||
1387 | case WM8996_CLOCKING_2: | ||
1388 | case WM8996_AIF_RATE: | ||
1389 | case WM8996_FLL_CONTROL_1: | ||
1390 | case WM8996_FLL_CONTROL_2: | ||
1391 | case WM8996_FLL_CONTROL_3: | ||
1392 | case WM8996_FLL_CONTROL_4: | ||
1393 | case WM8996_FLL_CONTROL_5: | ||
1394 | case WM8996_FLL_CONTROL_6: | ||
1395 | case WM8996_FLL_EFS_1: | ||
1396 | case WM8996_FLL_EFS_2: | ||
1397 | case WM8996_AIF1_CONTROL: | ||
1398 | case WM8996_AIF1_BCLK: | ||
1399 | case WM8996_AIF1_TX_LRCLK_1: | ||
1400 | case WM8996_AIF1_TX_LRCLK_2: | ||
1401 | case WM8996_AIF1_RX_LRCLK_1: | ||
1402 | case WM8996_AIF1_RX_LRCLK_2: | ||
1403 | case WM8996_AIF1TX_DATA_CONFIGURATION_1: | ||
1404 | case WM8996_AIF1TX_DATA_CONFIGURATION_2: | ||
1405 | case WM8996_AIF1RX_DATA_CONFIGURATION: | ||
1406 | case WM8996_AIF1TX_CHANNEL_0_CONFIGURATION: | ||
1407 | case WM8996_AIF1TX_CHANNEL_1_CONFIGURATION: | ||
1408 | case WM8996_AIF1TX_CHANNEL_2_CONFIGURATION: | ||
1409 | case WM8996_AIF1TX_CHANNEL_3_CONFIGURATION: | ||
1410 | case WM8996_AIF1TX_CHANNEL_4_CONFIGURATION: | ||
1411 | case WM8996_AIF1TX_CHANNEL_5_CONFIGURATION: | ||
1412 | case WM8996_AIF1RX_CHANNEL_0_CONFIGURATION: | ||
1413 | case WM8996_AIF1RX_CHANNEL_1_CONFIGURATION: | ||
1414 | case WM8996_AIF1RX_CHANNEL_2_CONFIGURATION: | ||
1415 | case WM8996_AIF1RX_CHANNEL_3_CONFIGURATION: | ||
1416 | case WM8996_AIF1RX_CHANNEL_4_CONFIGURATION: | ||
1417 | case WM8996_AIF1RX_CHANNEL_5_CONFIGURATION: | ||
1418 | case WM8996_AIF1RX_MONO_CONFIGURATION: | ||
1419 | case WM8996_AIF1TX_TEST: | ||
1420 | case WM8996_AIF2_CONTROL: | ||
1421 | case WM8996_AIF2_BCLK: | ||
1422 | case WM8996_AIF2_TX_LRCLK_1: | ||
1423 | case WM8996_AIF2_TX_LRCLK_2: | ||
1424 | case WM8996_AIF2_RX_LRCLK_1: | ||
1425 | case WM8996_AIF2_RX_LRCLK_2: | ||
1426 | case WM8996_AIF2TX_DATA_CONFIGURATION_1: | ||
1427 | case WM8996_AIF2TX_DATA_CONFIGURATION_2: | ||
1428 | case WM8996_AIF2RX_DATA_CONFIGURATION: | ||
1429 | case WM8996_AIF2TX_CHANNEL_0_CONFIGURATION: | ||
1430 | case WM8996_AIF2TX_CHANNEL_1_CONFIGURATION: | ||
1431 | case WM8996_AIF2RX_CHANNEL_0_CONFIGURATION: | ||
1432 | case WM8996_AIF2RX_CHANNEL_1_CONFIGURATION: | ||
1433 | case WM8996_AIF2RX_MONO_CONFIGURATION: | ||
1434 | case WM8996_AIF2TX_TEST: | ||
1435 | case WM8996_DSP1_TX_LEFT_VOLUME: | ||
1436 | case WM8996_DSP1_TX_RIGHT_VOLUME: | ||
1437 | case WM8996_DSP1_RX_LEFT_VOLUME: | ||
1438 | case WM8996_DSP1_RX_RIGHT_VOLUME: | ||
1439 | case WM8996_DSP1_TX_FILTERS: | ||
1440 | case WM8996_DSP1_RX_FILTERS_1: | ||
1441 | case WM8996_DSP1_RX_FILTERS_2: | ||
1442 | case WM8996_DSP1_DRC_1: | ||
1443 | case WM8996_DSP1_DRC_2: | ||
1444 | case WM8996_DSP1_DRC_3: | ||
1445 | case WM8996_DSP1_DRC_4: | ||
1446 | case WM8996_DSP1_DRC_5: | ||
1447 | case WM8996_DSP1_RX_EQ_GAINS_1: | ||
1448 | case WM8996_DSP1_RX_EQ_GAINS_2: | ||
1449 | case WM8996_DSP1_RX_EQ_BAND_1_A: | ||
1450 | case WM8996_DSP1_RX_EQ_BAND_1_B: | ||
1451 | case WM8996_DSP1_RX_EQ_BAND_1_PG: | ||
1452 | case WM8996_DSP1_RX_EQ_BAND_2_A: | ||
1453 | case WM8996_DSP1_RX_EQ_BAND_2_B: | ||
1454 | case WM8996_DSP1_RX_EQ_BAND_2_C: | ||
1455 | case WM8996_DSP1_RX_EQ_BAND_2_PG: | ||
1456 | case WM8996_DSP1_RX_EQ_BAND_3_A: | ||
1457 | case WM8996_DSP1_RX_EQ_BAND_3_B: | ||
1458 | case WM8996_DSP1_RX_EQ_BAND_3_C: | ||
1459 | case WM8996_DSP1_RX_EQ_BAND_3_PG: | ||
1460 | case WM8996_DSP1_RX_EQ_BAND_4_A: | ||
1461 | case WM8996_DSP1_RX_EQ_BAND_4_B: | ||
1462 | case WM8996_DSP1_RX_EQ_BAND_4_C: | ||
1463 | case WM8996_DSP1_RX_EQ_BAND_4_PG: | ||
1464 | case WM8996_DSP1_RX_EQ_BAND_5_A: | ||
1465 | case WM8996_DSP1_RX_EQ_BAND_5_B: | ||
1466 | case WM8996_DSP1_RX_EQ_BAND_5_PG: | ||
1467 | case WM8996_DSP2_TX_LEFT_VOLUME: | ||
1468 | case WM8996_DSP2_TX_RIGHT_VOLUME: | ||
1469 | case WM8996_DSP2_RX_LEFT_VOLUME: | ||
1470 | case WM8996_DSP2_RX_RIGHT_VOLUME: | ||
1471 | case WM8996_DSP2_TX_FILTERS: | ||
1472 | case WM8996_DSP2_RX_FILTERS_1: | ||
1473 | case WM8996_DSP2_RX_FILTERS_2: | ||
1474 | case WM8996_DSP2_DRC_1: | ||
1475 | case WM8996_DSP2_DRC_2: | ||
1476 | case WM8996_DSP2_DRC_3: | ||
1477 | case WM8996_DSP2_DRC_4: | ||
1478 | case WM8996_DSP2_DRC_5: | ||
1479 | case WM8996_DSP2_RX_EQ_GAINS_1: | ||
1480 | case WM8996_DSP2_RX_EQ_GAINS_2: | ||
1481 | case WM8996_DSP2_RX_EQ_BAND_1_A: | ||
1482 | case WM8996_DSP2_RX_EQ_BAND_1_B: | ||
1483 | case WM8996_DSP2_RX_EQ_BAND_1_PG: | ||
1484 | case WM8996_DSP2_RX_EQ_BAND_2_A: | ||
1485 | case WM8996_DSP2_RX_EQ_BAND_2_B: | ||
1486 | case WM8996_DSP2_RX_EQ_BAND_2_C: | ||
1487 | case WM8996_DSP2_RX_EQ_BAND_2_PG: | ||
1488 | case WM8996_DSP2_RX_EQ_BAND_3_A: | ||
1489 | case WM8996_DSP2_RX_EQ_BAND_3_B: | ||
1490 | case WM8996_DSP2_RX_EQ_BAND_3_C: | ||
1491 | case WM8996_DSP2_RX_EQ_BAND_3_PG: | ||
1492 | case WM8996_DSP2_RX_EQ_BAND_4_A: | ||
1493 | case WM8996_DSP2_RX_EQ_BAND_4_B: | ||
1494 | case WM8996_DSP2_RX_EQ_BAND_4_C: | ||
1495 | case WM8996_DSP2_RX_EQ_BAND_4_PG: | ||
1496 | case WM8996_DSP2_RX_EQ_BAND_5_A: | ||
1497 | case WM8996_DSP2_RX_EQ_BAND_5_B: | ||
1498 | case WM8996_DSP2_RX_EQ_BAND_5_PG: | ||
1499 | case WM8996_DAC1_MIXER_VOLUMES: | ||
1500 | case WM8996_DAC1_LEFT_MIXER_ROUTING: | ||
1501 | case WM8996_DAC1_RIGHT_MIXER_ROUTING: | ||
1502 | case WM8996_DAC2_MIXER_VOLUMES: | ||
1503 | case WM8996_DAC2_LEFT_MIXER_ROUTING: | ||
1504 | case WM8996_DAC2_RIGHT_MIXER_ROUTING: | ||
1505 | case WM8996_DSP1_TX_LEFT_MIXER_ROUTING: | ||
1506 | case WM8996_DSP1_TX_RIGHT_MIXER_ROUTING: | ||
1507 | case WM8996_DSP2_TX_LEFT_MIXER_ROUTING: | ||
1508 | case WM8996_DSP2_TX_RIGHT_MIXER_ROUTING: | ||
1509 | case WM8996_DSP_TX_MIXER_SELECT: | ||
1510 | case WM8996_DAC_SOFTMUTE: | ||
1511 | case WM8996_OVERSAMPLING: | ||
1512 | case WM8996_SIDETONE: | ||
1513 | case WM8996_GPIO_1: | ||
1514 | case WM8996_GPIO_2: | ||
1515 | case WM8996_GPIO_3: | ||
1516 | case WM8996_GPIO_4: | ||
1517 | case WM8996_GPIO_5: | ||
1518 | case WM8996_PULL_CONTROL_1: | ||
1519 | case WM8996_PULL_CONTROL_2: | ||
1520 | case WM8996_INTERRUPT_STATUS_1: | ||
1521 | case WM8996_INTERRUPT_STATUS_2: | ||
1522 | case WM8996_INTERRUPT_RAW_STATUS_2: | ||
1523 | case WM8996_INTERRUPT_STATUS_1_MASK: | ||
1524 | case WM8996_INTERRUPT_STATUS_2_MASK: | ||
1525 | case WM8996_INTERRUPT_CONTROL: | ||
1526 | case WM8996_LEFT_PDM_SPEAKER: | ||
1527 | case WM8996_RIGHT_PDM_SPEAKER: | ||
1528 | case WM8996_PDM_SPEAKER_MUTE_SEQUENCE: | ||
1529 | case WM8996_PDM_SPEAKER_VOLUME: | ||
1530 | return 1; | ||
1531 | default: | ||
1532 | return 0; | ||
1533 | } | ||
1534 | } | ||
1535 | |||
1536 | static int wm8996_volatile_register(struct snd_soc_codec *codec, | ||
1537 | unsigned int reg) | ||
1538 | { | ||
1539 | switch (reg) { | ||
1540 | case WM8996_SOFTWARE_RESET: | ||
1541 | case WM8996_CHIP_REVISION: | ||
1542 | case WM8996_LDO_1: | ||
1543 | case WM8996_LDO_2: | ||
1544 | case WM8996_INTERRUPT_STATUS_1: | ||
1545 | case WM8996_INTERRUPT_STATUS_2: | ||
1546 | case WM8996_INTERRUPT_RAW_STATUS_2: | ||
1547 | case WM8996_DC_SERVO_READBACK_0: | ||
1548 | case WM8996_DC_SERVO_2: | ||
1549 | case WM8996_DC_SERVO_6: | ||
1550 | case WM8996_DC_SERVO_7: | ||
1551 | case WM8996_FLL_CONTROL_6: | ||
1552 | case WM8996_MIC_DETECT_3: | ||
1553 | case WM8996_HEADPHONE_DETECT_1: | ||
1554 | case WM8996_HEADPHONE_DETECT_2: | ||
1555 | return 1; | ||
1556 | default: | ||
1557 | return 0; | ||
1558 | } | ||
1559 | } | ||
1560 | |||
1561 | static int wm8996_reset(struct snd_soc_codec *codec) | ||
1562 | { | ||
1563 | return snd_soc_write(codec, WM8996_SOFTWARE_RESET, 0x8915); | ||
1564 | } | ||
1565 | |||
1566 | static const int bclk_divs[] = { | ||
1567 | 1, 2, 3, 4, 6, 8, 12, 16, 24, 32, 48, 64, 96 | ||
1568 | }; | ||
1569 | |||
1570 | static void wm8996_update_bclk(struct snd_soc_codec *codec) | ||
1571 | { | ||
1572 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
1573 | int aif, best, cur_val, bclk_rate, bclk_reg, i; | ||
1574 | |||
1575 | /* Don't bother if we're in a low frequency idle mode that | ||
1576 | * can't support audio. | ||
1577 | */ | ||
1578 | if (wm8996->sysclk < 64000) | ||
1579 | return; | ||
1580 | |||
1581 | for (aif = 0; aif < WM8996_AIFS; aif++) { | ||
1582 | switch (aif) { | ||
1583 | case 0: | ||
1584 | bclk_reg = WM8996_AIF1_BCLK; | ||
1585 | break; | ||
1586 | case 1: | ||
1587 | bclk_reg = WM8996_AIF2_BCLK; | ||
1588 | break; | ||
1589 | } | ||
1590 | |||
1591 | bclk_rate = wm8996->bclk_rate[aif]; | ||
1592 | |||
1593 | /* Pick a divisor for BCLK as close as we can get to ideal */ | ||
1594 | best = 0; | ||
1595 | for (i = 0; i < ARRAY_SIZE(bclk_divs); i++) { | ||
1596 | cur_val = (wm8996->sysclk / bclk_divs[i]) - bclk_rate; | ||
1597 | if (cur_val < 0) /* BCLK table is sorted */ | ||
1598 | break; | ||
1599 | best = i; | ||
1600 | } | ||
1601 | bclk_rate = wm8996->sysclk / bclk_divs[best]; | ||
1602 | dev_dbg(codec->dev, "Using BCLK_DIV %d for actual BCLK %dHz\n", | ||
1603 | bclk_divs[best], bclk_rate); | ||
1604 | |||
1605 | snd_soc_update_bits(codec, bclk_reg, | ||
1606 | WM8996_AIF1_BCLK_DIV_MASK, best); | ||
1607 | } | ||
1608 | } | ||
1609 | |||
1610 | static int wm8996_set_bias_level(struct snd_soc_codec *codec, | ||
1611 | enum snd_soc_bias_level level) | ||
1612 | { | ||
1613 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
1614 | int ret; | ||
1615 | |||
1616 | switch (level) { | ||
1617 | case SND_SOC_BIAS_ON: | ||
1618 | break; | ||
1619 | |||
1620 | case SND_SOC_BIAS_PREPARE: | ||
1621 | if (codec->dapm.bias_level == SND_SOC_BIAS_STANDBY) { | ||
1622 | snd_soc_update_bits(codec, WM8996_POWER_MANAGEMENT_1, | ||
1623 | WM8996_BG_ENA, WM8996_BG_ENA); | ||
1624 | msleep(2); | ||
1625 | } | ||
1626 | break; | ||
1627 | |||
1628 | case SND_SOC_BIAS_STANDBY: | ||
1629 | if (codec->dapm.bias_level == SND_SOC_BIAS_OFF) { | ||
1630 | ret = regulator_bulk_enable(ARRAY_SIZE(wm8996->supplies), | ||
1631 | wm8996->supplies); | ||
1632 | if (ret != 0) { | ||
1633 | dev_err(codec->dev, | ||
1634 | "Failed to enable supplies: %d\n", | ||
1635 | ret); | ||
1636 | return ret; | ||
1637 | } | ||
1638 | |||
1639 | if (wm8996->pdata.ldo_ena >= 0) { | ||
1640 | gpio_set_value_cansleep(wm8996->pdata.ldo_ena, | ||
1641 | 1); | ||
1642 | msleep(5); | ||
1643 | } | ||
1644 | |||
1645 | codec->cache_only = false; | ||
1646 | snd_soc_cache_sync(codec); | ||
1647 | } | ||
1648 | |||
1649 | snd_soc_update_bits(codec, WM8996_POWER_MANAGEMENT_1, | ||
1650 | WM8996_BG_ENA, 0); | ||
1651 | break; | ||
1652 | |||
1653 | case SND_SOC_BIAS_OFF: | ||
1654 | codec->cache_only = true; | ||
1655 | if (wm8996->pdata.ldo_ena >= 0) | ||
1656 | gpio_set_value_cansleep(wm8996->pdata.ldo_ena, 0); | ||
1657 | regulator_bulk_disable(ARRAY_SIZE(wm8996->supplies), | ||
1658 | wm8996->supplies); | ||
1659 | break; | ||
1660 | } | ||
1661 | |||
1662 | codec->dapm.bias_level = level; | ||
1663 | |||
1664 | return 0; | ||
1665 | } | ||
1666 | |||
1667 | static int wm8996_set_fmt(struct snd_soc_dai *dai, unsigned int fmt) | ||
1668 | { | ||
1669 | struct snd_soc_codec *codec = dai->codec; | ||
1670 | int aifctrl = 0; | ||
1671 | int bclk = 0; | ||
1672 | int lrclk_tx = 0; | ||
1673 | int lrclk_rx = 0; | ||
1674 | int aifctrl_reg, bclk_reg, lrclk_tx_reg, lrclk_rx_reg; | ||
1675 | |||
1676 | switch (dai->id) { | ||
1677 | case 0: | ||
1678 | aifctrl_reg = WM8996_AIF1_CONTROL; | ||
1679 | bclk_reg = WM8996_AIF1_BCLK; | ||
1680 | lrclk_tx_reg = WM8996_AIF1_TX_LRCLK_2; | ||
1681 | lrclk_rx_reg = WM8996_AIF1_RX_LRCLK_2; | ||
1682 | break; | ||
1683 | case 1: | ||
1684 | aifctrl_reg = WM8996_AIF2_CONTROL; | ||
1685 | bclk_reg = WM8996_AIF2_BCLK; | ||
1686 | lrclk_tx_reg = WM8996_AIF2_TX_LRCLK_2; | ||
1687 | lrclk_rx_reg = WM8996_AIF2_RX_LRCLK_2; | ||
1688 | break; | ||
1689 | default: | ||
1690 | BUG(); | ||
1691 | return -EINVAL; | ||
1692 | } | ||
1693 | |||
1694 | switch (fmt & SND_SOC_DAIFMT_INV_MASK) { | ||
1695 | case SND_SOC_DAIFMT_NB_NF: | ||
1696 | break; | ||
1697 | case SND_SOC_DAIFMT_IB_NF: | ||
1698 | bclk |= WM8996_AIF1_BCLK_INV; | ||
1699 | break; | ||
1700 | case SND_SOC_DAIFMT_NB_IF: | ||
1701 | lrclk_tx |= WM8996_AIF1TX_LRCLK_INV; | ||
1702 | lrclk_rx |= WM8996_AIF1RX_LRCLK_INV; | ||
1703 | break; | ||
1704 | case SND_SOC_DAIFMT_IB_IF: | ||
1705 | bclk |= WM8996_AIF1_BCLK_INV; | ||
1706 | lrclk_tx |= WM8996_AIF1TX_LRCLK_INV; | ||
1707 | lrclk_rx |= WM8996_AIF1RX_LRCLK_INV; | ||
1708 | break; | ||
1709 | } | ||
1710 | |||
1711 | switch (fmt & SND_SOC_DAIFMT_MASTER_MASK) { | ||
1712 | case SND_SOC_DAIFMT_CBS_CFS: | ||
1713 | break; | ||
1714 | case SND_SOC_DAIFMT_CBS_CFM: | ||
1715 | lrclk_tx |= WM8996_AIF1TX_LRCLK_MSTR; | ||
1716 | lrclk_rx |= WM8996_AIF1RX_LRCLK_MSTR; | ||
1717 | break; | ||
1718 | case SND_SOC_DAIFMT_CBM_CFS: | ||
1719 | bclk |= WM8996_AIF1_BCLK_MSTR; | ||
1720 | break; | ||
1721 | case SND_SOC_DAIFMT_CBM_CFM: | ||
1722 | bclk |= WM8996_AIF1_BCLK_MSTR; | ||
1723 | lrclk_tx |= WM8996_AIF1TX_LRCLK_MSTR; | ||
1724 | lrclk_rx |= WM8996_AIF1RX_LRCLK_MSTR; | ||
1725 | break; | ||
1726 | default: | ||
1727 | return -EINVAL; | ||
1728 | } | ||
1729 | |||
1730 | switch (fmt & SND_SOC_DAIFMT_FORMAT_MASK) { | ||
1731 | case SND_SOC_DAIFMT_DSP_A: | ||
1732 | break; | ||
1733 | case SND_SOC_DAIFMT_DSP_B: | ||
1734 | aifctrl |= 1; | ||
1735 | break; | ||
1736 | case SND_SOC_DAIFMT_I2S: | ||
1737 | aifctrl |= 2; | ||
1738 | break; | ||
1739 | case SND_SOC_DAIFMT_LEFT_J: | ||
1740 | aifctrl |= 3; | ||
1741 | break; | ||
1742 | default: | ||
1743 | return -EINVAL; | ||
1744 | } | ||
1745 | |||
1746 | snd_soc_update_bits(codec, aifctrl_reg, WM8996_AIF1_FMT_MASK, aifctrl); | ||
1747 | snd_soc_update_bits(codec, bclk_reg, | ||
1748 | WM8996_AIF1_BCLK_INV | WM8996_AIF1_BCLK_MSTR, | ||
1749 | bclk); | ||
1750 | snd_soc_update_bits(codec, lrclk_tx_reg, | ||
1751 | WM8996_AIF1TX_LRCLK_INV | | ||
1752 | WM8996_AIF1TX_LRCLK_MSTR, | ||
1753 | lrclk_tx); | ||
1754 | snd_soc_update_bits(codec, lrclk_rx_reg, | ||
1755 | WM8996_AIF1RX_LRCLK_INV | | ||
1756 | WM8996_AIF1RX_LRCLK_MSTR, | ||
1757 | lrclk_rx); | ||
1758 | |||
1759 | return 0; | ||
1760 | } | ||
1761 | |||
1762 | static const int dsp_divs[] = { | ||
1763 | 48000, 32000, 16000, 8000 | ||
1764 | }; | ||
1765 | |||
1766 | static int wm8996_hw_params(struct snd_pcm_substream *substream, | ||
1767 | struct snd_pcm_hw_params *params, | ||
1768 | struct snd_soc_dai *dai) | ||
1769 | { | ||
1770 | struct snd_soc_codec *codec = dai->codec; | ||
1771 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
1772 | int bits, i, bclk_rate; | ||
1773 | int aifdata = 0; | ||
1774 | int lrclk = 0; | ||
1775 | int dsp = 0; | ||
1776 | int aifdata_reg, lrclk_reg, dsp_shift; | ||
1777 | |||
1778 | switch (dai->id) { | ||
1779 | case 0: | ||
1780 | if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK || | ||
1781 | (snd_soc_read(codec, WM8996_GPIO_1)) & WM8996_GP1_FN_MASK) { | ||
1782 | aifdata_reg = WM8996_AIF1RX_DATA_CONFIGURATION; | ||
1783 | lrclk_reg = WM8996_AIF1_RX_LRCLK_1; | ||
1784 | } else { | ||
1785 | aifdata_reg = WM8996_AIF1TX_DATA_CONFIGURATION_1; | ||
1786 | lrclk_reg = WM8996_AIF1_TX_LRCLK_1; | ||
1787 | } | ||
1788 | dsp_shift = 0; | ||
1789 | break; | ||
1790 | case 1: | ||
1791 | if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK || | ||
1792 | (snd_soc_read(codec, WM8996_GPIO_2)) & WM8996_GP2_FN_MASK) { | ||
1793 | aifdata_reg = WM8996_AIF2RX_DATA_CONFIGURATION; | ||
1794 | lrclk_reg = WM8996_AIF2_RX_LRCLK_1; | ||
1795 | } else { | ||
1796 | aifdata_reg = WM8996_AIF2TX_DATA_CONFIGURATION_1; | ||
1797 | lrclk_reg = WM8996_AIF2_TX_LRCLK_1; | ||
1798 | } | ||
1799 | dsp_shift = WM8996_DSP2_DIV_SHIFT; | ||
1800 | break; | ||
1801 | default: | ||
1802 | BUG(); | ||
1803 | return -EINVAL; | ||
1804 | } | ||
1805 | |||
1806 | bclk_rate = snd_soc_params_to_bclk(params); | ||
1807 | if (bclk_rate < 0) { | ||
1808 | dev_err(codec->dev, "Unsupported BCLK rate: %d\n", bclk_rate); | ||
1809 | return bclk_rate; | ||
1810 | } | ||
1811 | |||
1812 | wm8996->bclk_rate[dai->id] = bclk_rate; | ||
1813 | wm8996->rx_rate[dai->id] = params_rate(params); | ||
1814 | |||
1815 | /* Needs looking at for TDM */ | ||
1816 | bits = snd_pcm_format_width(params_format(params)); | ||
1817 | if (bits < 0) | ||
1818 | return bits; | ||
1819 | aifdata |= (bits << WM8996_AIF1TX_WL_SHIFT) | bits; | ||
1820 | |||
1821 | for (i = 0; i < ARRAY_SIZE(dsp_divs); i++) { | ||
1822 | if (dsp_divs[i] == params_rate(params)) | ||
1823 | break; | ||
1824 | } | ||
1825 | if (i == ARRAY_SIZE(dsp_divs)) { | ||
1826 | dev_err(codec->dev, "Unsupported sample rate %dHz\n", | ||
1827 | params_rate(params)); | ||
1828 | return -EINVAL; | ||
1829 | } | ||
1830 | dsp |= i << dsp_shift; | ||
1831 | |||
1832 | wm8996_update_bclk(codec); | ||
1833 | |||
1834 | lrclk = bclk_rate / params_rate(params); | ||
1835 | dev_dbg(dai->dev, "Using LRCLK rate %d for actual LRCLK %dHz\n", | ||
1836 | lrclk, bclk_rate / lrclk); | ||
1837 | |||
1838 | snd_soc_update_bits(codec, aifdata_reg, | ||
1839 | WM8996_AIF1TX_WL_MASK | | ||
1840 | WM8996_AIF1TX_SLOT_LEN_MASK, | ||
1841 | aifdata); | ||
1842 | snd_soc_update_bits(codec, lrclk_reg, WM8996_AIF1RX_RATE_MASK, | ||
1843 | lrclk); | ||
1844 | snd_soc_update_bits(codec, WM8996_AIF_CLOCKING_2, | ||
1845 | WM8996_DSP1_DIV_SHIFT << dsp_shift, dsp); | ||
1846 | |||
1847 | return 0; | ||
1848 | } | ||
1849 | |||
1850 | static int wm8996_set_sysclk(struct snd_soc_dai *dai, | ||
1851 | int clk_id, unsigned int freq, int dir) | ||
1852 | { | ||
1853 | struct snd_soc_codec *codec = dai->codec; | ||
1854 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
1855 | int lfclk = 0; | ||
1856 | int ratediv = 0; | ||
1857 | int src; | ||
1858 | int old; | ||
1859 | |||
1860 | if (freq == wm8996->sysclk && clk_id == wm8996->sysclk_src) | ||
1861 | return 0; | ||
1862 | |||
1863 | /* Disable SYSCLK while we reconfigure */ | ||
1864 | old = snd_soc_read(codec, WM8996_AIF_CLOCKING_1) & WM8996_SYSCLK_ENA; | ||
1865 | snd_soc_update_bits(codec, WM8996_AIF_CLOCKING_1, | ||
1866 | WM8996_SYSCLK_ENA, 0); | ||
1867 | |||
1868 | switch (clk_id) { | ||
1869 | case WM8996_SYSCLK_MCLK1: | ||
1870 | wm8996->sysclk = freq; | ||
1871 | src = 0; | ||
1872 | break; | ||
1873 | case WM8996_SYSCLK_MCLK2: | ||
1874 | wm8996->sysclk = freq; | ||
1875 | src = 1; | ||
1876 | break; | ||
1877 | case WM8996_SYSCLK_FLL: | ||
1878 | wm8996->sysclk = freq; | ||
1879 | src = 2; | ||
1880 | break; | ||
1881 | default: | ||
1882 | dev_err(codec->dev, "Unsupported clock source %d\n", clk_id); | ||
1883 | return -EINVAL; | ||
1884 | } | ||
1885 | |||
1886 | switch (wm8996->sysclk) { | ||
1887 | case 6144000: | ||
1888 | snd_soc_update_bits(codec, WM8996_AIF_RATE, | ||
1889 | WM8996_SYSCLK_RATE, 0); | ||
1890 | break; | ||
1891 | case 24576000: | ||
1892 | ratediv = WM8996_SYSCLK_DIV; | ||
1893 | case 12288000: | ||
1894 | snd_soc_update_bits(codec, WM8996_AIF_RATE, | ||
1895 | WM8996_SYSCLK_RATE, WM8996_SYSCLK_RATE); | ||
1896 | break; | ||
1897 | case 32000: | ||
1898 | case 32768: | ||
1899 | lfclk = WM8996_LFCLK_ENA; | ||
1900 | break; | ||
1901 | default: | ||
1902 | dev_warn(codec->dev, "Unsupported clock rate %dHz\n", | ||
1903 | wm8996->sysclk); | ||
1904 | return -EINVAL; | ||
1905 | } | ||
1906 | |||
1907 | wm8996_update_bclk(codec); | ||
1908 | |||
1909 | snd_soc_update_bits(codec, WM8996_AIF_CLOCKING_1, | ||
1910 | WM8996_SYSCLK_SRC_MASK | WM8996_SYSCLK_DIV_MASK, | ||
1911 | src << WM8996_SYSCLK_SRC_SHIFT | ratediv); | ||
1912 | snd_soc_update_bits(codec, WM8996_CLOCKING_1, WM8996_LFCLK_ENA, lfclk); | ||
1913 | snd_soc_update_bits(codec, WM8996_AIF_CLOCKING_1, | ||
1914 | WM8996_SYSCLK_ENA, old); | ||
1915 | |||
1916 | wm8996->sysclk_src = clk_id; | ||
1917 | |||
1918 | return 0; | ||
1919 | } | ||
1920 | |||
1921 | struct _fll_div { | ||
1922 | u16 fll_fratio; | ||
1923 | u16 fll_outdiv; | ||
1924 | u16 fll_refclk_div; | ||
1925 | u16 fll_loop_gain; | ||
1926 | u16 fll_ref_freq; | ||
1927 | u16 n; | ||
1928 | u16 theta; | ||
1929 | u16 lambda; | ||
1930 | }; | ||
1931 | |||
1932 | static struct { | ||
1933 | unsigned int min; | ||
1934 | unsigned int max; | ||
1935 | u16 fll_fratio; | ||
1936 | int ratio; | ||
1937 | } fll_fratios[] = { | ||
1938 | { 0, 64000, 4, 16 }, | ||
1939 | { 64000, 128000, 3, 8 }, | ||
1940 | { 128000, 256000, 2, 4 }, | ||
1941 | { 256000, 1000000, 1, 2 }, | ||
1942 | { 1000000, 13500000, 0, 1 }, | ||
1943 | }; | ||
1944 | |||
1945 | static int fll_factors(struct _fll_div *fll_div, unsigned int Fref, | ||
1946 | unsigned int Fout) | ||
1947 | { | ||
1948 | unsigned int target; | ||
1949 | unsigned int div; | ||
1950 | unsigned int fratio, gcd_fll; | ||
1951 | int i; | ||
1952 | |||
1953 | /* Fref must be <=13.5MHz */ | ||
1954 | div = 1; | ||
1955 | fll_div->fll_refclk_div = 0; | ||
1956 | while ((Fref / div) > 13500000) { | ||
1957 | div *= 2; | ||
1958 | fll_div->fll_refclk_div++; | ||
1959 | |||
1960 | if (div > 8) { | ||
1961 | pr_err("Can't scale %dMHz input down to <=13.5MHz\n", | ||
1962 | Fref); | ||
1963 | return -EINVAL; | ||
1964 | } | ||
1965 | } | ||
1966 | |||
1967 | pr_debug("FLL Fref=%u Fout=%u\n", Fref, Fout); | ||
1968 | |||
1969 | /* Apply the division for our remaining calculations */ | ||
1970 | Fref /= div; | ||
1971 | |||
1972 | if (Fref >= 3000000) | ||
1973 | fll_div->fll_loop_gain = 5; | ||
1974 | else | ||
1975 | fll_div->fll_loop_gain = 0; | ||
1976 | |||
1977 | if (Fref >= 48000) | ||
1978 | fll_div->fll_ref_freq = 0; | ||
1979 | else | ||
1980 | fll_div->fll_ref_freq = 1; | ||
1981 | |||
1982 | /* Fvco should be 90-100MHz; don't check the upper bound */ | ||
1983 | div = 2; | ||
1984 | while (Fout * div < 90000000) { | ||
1985 | div++; | ||
1986 | if (div > 64) { | ||
1987 | pr_err("Unable to find FLL_OUTDIV for Fout=%uHz\n", | ||
1988 | Fout); | ||
1989 | return -EINVAL; | ||
1990 | } | ||
1991 | } | ||
1992 | target = Fout * div; | ||
1993 | fll_div->fll_outdiv = div - 1; | ||
1994 | |||
1995 | pr_debug("FLL Fvco=%dHz\n", target); | ||
1996 | |||
1997 | /* Find an appropraite FLL_FRATIO and factor it out of the target */ | ||
1998 | for (i = 0; i < ARRAY_SIZE(fll_fratios); i++) { | ||
1999 | if (fll_fratios[i].min <= Fref && Fref <= fll_fratios[i].max) { | ||
2000 | fll_div->fll_fratio = fll_fratios[i].fll_fratio; | ||
2001 | fratio = fll_fratios[i].ratio; | ||
2002 | break; | ||
2003 | } | ||
2004 | } | ||
2005 | if (i == ARRAY_SIZE(fll_fratios)) { | ||
2006 | pr_err("Unable to find FLL_FRATIO for Fref=%uHz\n", Fref); | ||
2007 | return -EINVAL; | ||
2008 | } | ||
2009 | |||
2010 | fll_div->n = target / (fratio * Fref); | ||
2011 | |||
2012 | if (target % Fref == 0) { | ||
2013 | fll_div->theta = 0; | ||
2014 | fll_div->lambda = 0; | ||
2015 | } else { | ||
2016 | gcd_fll = gcd(target, fratio * Fref); | ||
2017 | |||
2018 | fll_div->theta = (target - (fll_div->n * fratio * Fref)) | ||
2019 | / gcd_fll; | ||
2020 | fll_div->lambda = (fratio * Fref) / gcd_fll; | ||
2021 | } | ||
2022 | |||
2023 | pr_debug("FLL N=%x THETA=%x LAMBDA=%x\n", | ||
2024 | fll_div->n, fll_div->theta, fll_div->lambda); | ||
2025 | pr_debug("FLL_FRATIO=%x FLL_OUTDIV=%x FLL_REFCLK_DIV=%x\n", | ||
2026 | fll_div->fll_fratio, fll_div->fll_outdiv, | ||
2027 | fll_div->fll_refclk_div); | ||
2028 | |||
2029 | return 0; | ||
2030 | } | ||
2031 | |||
2032 | static int wm8996_set_fll(struct snd_soc_codec *codec, int fll_id, int source, | ||
2033 | unsigned int Fref, unsigned int Fout) | ||
2034 | { | ||
2035 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
2036 | struct i2c_client *i2c = to_i2c_client(codec->dev); | ||
2037 | struct _fll_div fll_div; | ||
2038 | unsigned long timeout; | ||
2039 | int ret, reg; | ||
2040 | |||
2041 | /* Any change? */ | ||
2042 | if (source == wm8996->fll_src && Fref == wm8996->fll_fref && | ||
2043 | Fout == wm8996->fll_fout) | ||
2044 | return 0; | ||
2045 | |||
2046 | if (Fout == 0) { | ||
2047 | dev_dbg(codec->dev, "FLL disabled\n"); | ||
2048 | |||
2049 | wm8996->fll_fref = 0; | ||
2050 | wm8996->fll_fout = 0; | ||
2051 | |||
2052 | snd_soc_update_bits(codec, WM8996_FLL_CONTROL_1, | ||
2053 | WM8996_FLL_ENA, 0); | ||
2054 | |||
2055 | return 0; | ||
2056 | } | ||
2057 | |||
2058 | ret = fll_factors(&fll_div, Fref, Fout); | ||
2059 | if (ret != 0) | ||
2060 | return ret; | ||
2061 | |||
2062 | switch (source) { | ||
2063 | case WM8996_FLL_MCLK1: | ||
2064 | reg = 0; | ||
2065 | break; | ||
2066 | case WM8996_FLL_MCLK2: | ||
2067 | reg = 1; | ||
2068 | break; | ||
2069 | case WM8996_FLL_DACLRCLK1: | ||
2070 | reg = 2; | ||
2071 | break; | ||
2072 | case WM8996_FLL_BCLK1: | ||
2073 | reg = 3; | ||
2074 | break; | ||
2075 | default: | ||
2076 | dev_err(codec->dev, "Unknown FLL source %d\n", ret); | ||
2077 | return -EINVAL; | ||
2078 | } | ||
2079 | |||
2080 | reg |= fll_div.fll_refclk_div << WM8996_FLL_REFCLK_DIV_SHIFT; | ||
2081 | reg |= fll_div.fll_ref_freq << WM8996_FLL_REF_FREQ_SHIFT; | ||
2082 | |||
2083 | snd_soc_update_bits(codec, WM8996_FLL_CONTROL_5, | ||
2084 | WM8996_FLL_REFCLK_DIV_MASK | WM8996_FLL_REF_FREQ | | ||
2085 | WM8996_FLL_REFCLK_SRC_MASK, reg); | ||
2086 | |||
2087 | reg = 0; | ||
2088 | if (fll_div.theta || fll_div.lambda) | ||
2089 | reg |= WM8996_FLL_EFS_ENA | (3 << WM8996_FLL_LFSR_SEL_SHIFT); | ||
2090 | else | ||
2091 | reg |= 1 << WM8996_FLL_LFSR_SEL_SHIFT; | ||
2092 | snd_soc_write(codec, WM8996_FLL_EFS_2, reg); | ||
2093 | |||
2094 | snd_soc_update_bits(codec, WM8996_FLL_CONTROL_2, | ||
2095 | WM8996_FLL_OUTDIV_MASK | | ||
2096 | WM8996_FLL_FRATIO_MASK, | ||
2097 | (fll_div.fll_outdiv << WM8996_FLL_OUTDIV_SHIFT) | | ||
2098 | (fll_div.fll_fratio)); | ||
2099 | |||
2100 | snd_soc_write(codec, WM8996_FLL_CONTROL_3, fll_div.theta); | ||
2101 | |||
2102 | snd_soc_update_bits(codec, WM8996_FLL_CONTROL_4, | ||
2103 | WM8996_FLL_N_MASK | WM8996_FLL_LOOP_GAIN_MASK, | ||
2104 | (fll_div.n << WM8996_FLL_N_SHIFT) | | ||
2105 | fll_div.fll_loop_gain); | ||
2106 | |||
2107 | snd_soc_write(codec, WM8996_FLL_EFS_1, fll_div.lambda); | ||
2108 | |||
2109 | snd_soc_update_bits(codec, WM8996_FLL_CONTROL_1, | ||
2110 | WM8996_FLL_ENA, WM8996_FLL_ENA); | ||
2111 | |||
2112 | /* The FLL supports live reconfiguration - kick that in case we were | ||
2113 | * already enabled. | ||
2114 | */ | ||
2115 | snd_soc_write(codec, WM8996_FLL_CONTROL_6, WM8996_FLL_SWITCH_CLK); | ||
2116 | |||
2117 | /* Wait for the FLL to lock, using the interrupt if possible */ | ||
2118 | if (Fref > 1000000) | ||
2119 | timeout = usecs_to_jiffies(300); | ||
2120 | else | ||
2121 | timeout = msecs_to_jiffies(2); | ||
2122 | |||
2123 | /* Allow substantially longer if we've actually got the IRQ */ | ||
2124 | if (i2c->irq) | ||
2125 | timeout *= 1000; | ||
2126 | |||
2127 | ret = wait_for_completion_timeout(&wm8996->fll_lock, timeout); | ||
2128 | |||
2129 | if (ret == 0 && i2c->irq) { | ||
2130 | dev_err(codec->dev, "Timed out waiting for FLL\n"); | ||
2131 | ret = -ETIMEDOUT; | ||
2132 | } else { | ||
2133 | ret = 0; | ||
2134 | } | ||
2135 | |||
2136 | dev_dbg(codec->dev, "FLL configured for %dHz->%dHz\n", Fref, Fout); | ||
2137 | |||
2138 | wm8996->fll_fref = Fref; | ||
2139 | wm8996->fll_fout = Fout; | ||
2140 | wm8996->fll_src = source; | ||
2141 | |||
2142 | return ret; | ||
2143 | } | ||
2144 | |||
2145 | #ifdef CONFIG_GPIOLIB | ||
2146 | static inline struct wm8996_priv *gpio_to_wm8996(struct gpio_chip *chip) | ||
2147 | { | ||
2148 | return container_of(chip, struct wm8996_priv, gpio_chip); | ||
2149 | } | ||
2150 | |||
2151 | static void wm8996_gpio_set(struct gpio_chip *chip, unsigned offset, int value) | ||
2152 | { | ||
2153 | struct wm8996_priv *wm8996 = gpio_to_wm8996(chip); | ||
2154 | struct snd_soc_codec *codec = wm8996->codec; | ||
2155 | |||
2156 | snd_soc_update_bits(codec, WM8996_GPIO_1 + offset, | ||
2157 | WM8996_GP1_LVL, !!value << WM8996_GP1_LVL_SHIFT); | ||
2158 | } | ||
2159 | |||
2160 | static int wm8996_gpio_direction_out(struct gpio_chip *chip, | ||
2161 | unsigned offset, int value) | ||
2162 | { | ||
2163 | struct wm8996_priv *wm8996 = gpio_to_wm8996(chip); | ||
2164 | struct snd_soc_codec *codec = wm8996->codec; | ||
2165 | int val; | ||
2166 | |||
2167 | val = (1 << WM8996_GP1_FN_SHIFT) | (!!value << WM8996_GP1_LVL_SHIFT); | ||
2168 | |||
2169 | return snd_soc_update_bits(codec, WM8996_GPIO_1 + offset, | ||
2170 | WM8996_GP1_FN_MASK | WM8996_GP1_DIR | | ||
2171 | WM8996_GP1_LVL, val); | ||
2172 | } | ||
2173 | |||
2174 | static int wm8996_gpio_get(struct gpio_chip *chip, unsigned offset) | ||
2175 | { | ||
2176 | struct wm8996_priv *wm8996 = gpio_to_wm8996(chip); | ||
2177 | struct snd_soc_codec *codec = wm8996->codec; | ||
2178 | int ret; | ||
2179 | |||
2180 | ret = snd_soc_read(codec, WM8996_GPIO_1 + offset); | ||
2181 | if (ret < 0) | ||
2182 | return ret; | ||
2183 | |||
2184 | return (ret & WM8996_GP1_LVL) != 0; | ||
2185 | } | ||
2186 | |||
2187 | static int wm8996_gpio_direction_in(struct gpio_chip *chip, unsigned offset) | ||
2188 | { | ||
2189 | struct wm8996_priv *wm8996 = gpio_to_wm8996(chip); | ||
2190 | struct snd_soc_codec *codec = wm8996->codec; | ||
2191 | |||
2192 | return snd_soc_update_bits(codec, WM8996_GPIO_1 + offset, | ||
2193 | WM8996_GP1_FN_MASK | WM8996_GP1_DIR, | ||
2194 | (1 << WM8996_GP1_FN_SHIFT) | | ||
2195 | (1 << WM8996_GP1_DIR_SHIFT)); | ||
2196 | } | ||
2197 | |||
2198 | static struct gpio_chip wm8996_template_chip = { | ||
2199 | .label = "wm8996", | ||
2200 | .owner = THIS_MODULE, | ||
2201 | .direction_output = wm8996_gpio_direction_out, | ||
2202 | .set = wm8996_gpio_set, | ||
2203 | .direction_input = wm8996_gpio_direction_in, | ||
2204 | .get = wm8996_gpio_get, | ||
2205 | .can_sleep = 1, | ||
2206 | }; | ||
2207 | |||
2208 | static void wm8996_init_gpio(struct snd_soc_codec *codec) | ||
2209 | { | ||
2210 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
2211 | int ret; | ||
2212 | |||
2213 | wm8996->gpio_chip = wm8996_template_chip; | ||
2214 | wm8996->gpio_chip.ngpio = 5; | ||
2215 | wm8996->gpio_chip.dev = codec->dev; | ||
2216 | |||
2217 | if (wm8996->pdata.gpio_base) | ||
2218 | wm8996->gpio_chip.base = wm8996->pdata.gpio_base; | ||
2219 | else | ||
2220 | wm8996->gpio_chip.base = -1; | ||
2221 | |||
2222 | ret = gpiochip_add(&wm8996->gpio_chip); | ||
2223 | if (ret != 0) | ||
2224 | dev_err(codec->dev, "Failed to add GPIOs: %d\n", ret); | ||
2225 | } | ||
2226 | |||
2227 | static void wm8996_free_gpio(struct snd_soc_codec *codec) | ||
2228 | { | ||
2229 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
2230 | int ret; | ||
2231 | |||
2232 | ret = gpiochip_remove(&wm8996->gpio_chip); | ||
2233 | if (ret != 0) | ||
2234 | dev_err(codec->dev, "Failed to remove GPIOs: %d\n", ret); | ||
2235 | } | ||
2236 | #else | ||
2237 | static void wm8996_init_gpio(struct snd_soc_codec *codec) | ||
2238 | { | ||
2239 | } | ||
2240 | |||
2241 | static void wm8996_free_gpio(struct snd_soc_codec *codec) | ||
2242 | { | ||
2243 | } | ||
2244 | #endif | ||
2245 | |||
2246 | /** | ||
2247 | * wm8996_detect - Enable default WM8996 jack detection | ||
2248 | * | ||
2249 | * The WM8996 has advanced accessory detection support for headsets. | ||
2250 | * This function provides a default implementation which integrates | ||
2251 | * the majority of this functionality with minimal user configuration. | ||
2252 | * | ||
2253 | * This will detect headset, headphone and short circuit button and | ||
2254 | * will also detect inverted microphone ground connections and update | ||
2255 | * the polarity of the connections. | ||
2256 | */ | ||
2257 | int wm8996_detect(struct snd_soc_codec *codec, struct snd_soc_jack *jack, | ||
2258 | wm8996_polarity_fn polarity_cb) | ||
2259 | { | ||
2260 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
2261 | |||
2262 | wm8996->jack = jack; | ||
2263 | wm8996->detecting = true; | ||
2264 | wm8996->polarity_cb = polarity_cb; | ||
2265 | |||
2266 | if (wm8996->polarity_cb) | ||
2267 | wm8996->polarity_cb(codec, 0); | ||
2268 | |||
2269 | /* Clear discarge to avoid noise during detection */ | ||
2270 | snd_soc_update_bits(codec, WM8996_MICBIAS_1, | ||
2271 | WM8996_MICB1_DISCH, 0); | ||
2272 | snd_soc_update_bits(codec, WM8996_MICBIAS_2, | ||
2273 | WM8996_MICB2_DISCH, 0); | ||
2274 | |||
2275 | /* LDO2 powers the microphones, SYSCLK clocks detection */ | ||
2276 | snd_soc_dapm_force_enable_pin(&codec->dapm, "LDO2"); | ||
2277 | snd_soc_dapm_force_enable_pin(&codec->dapm, "SYSCLK"); | ||
2278 | |||
2279 | /* We start off just enabling microphone detection - even a | ||
2280 | * plain headphone will trigger detection. | ||
2281 | */ | ||
2282 | snd_soc_update_bits(codec, WM8996_MIC_DETECT_1, | ||
2283 | WM8996_MICD_ENA, WM8996_MICD_ENA); | ||
2284 | |||
2285 | /* Slowest detection rate, gives debounce for initial detection */ | ||
2286 | snd_soc_update_bits(codec, WM8996_MIC_DETECT_1, | ||
2287 | WM8996_MICD_RATE_MASK, | ||
2288 | WM8996_MICD_RATE_MASK); | ||
2289 | |||
2290 | /* Enable interrupts and we're off */ | ||
2291 | snd_soc_update_bits(codec, WM8996_INTERRUPT_STATUS_2_MASK, | ||
2292 | WM8996_IM_MICD_EINT, 0); | ||
2293 | |||
2294 | return 0; | ||
2295 | } | ||
2296 | EXPORT_SYMBOL_GPL(wm8996_detect); | ||
2297 | |||
2298 | static void wm8996_micd(struct snd_soc_codec *codec) | ||
2299 | { | ||
2300 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
2301 | int val, reg; | ||
2302 | |||
2303 | val = snd_soc_read(codec, WM8996_MIC_DETECT_3); | ||
2304 | |||
2305 | dev_dbg(codec->dev, "Microphone event: %x\n", val); | ||
2306 | |||
2307 | if (!(val & WM8996_MICD_VALID)) { | ||
2308 | dev_warn(codec->dev, "Microphone detection state invalid\n"); | ||
2309 | return; | ||
2310 | } | ||
2311 | |||
2312 | /* No accessory, reset everything and report removal */ | ||
2313 | if (!(val & WM8996_MICD_STS)) { | ||
2314 | dev_dbg(codec->dev, "Jack removal detected\n"); | ||
2315 | wm8996->jack_mic = false; | ||
2316 | wm8996->detecting = true; | ||
2317 | snd_soc_jack_report(wm8996->jack, 0, | ||
2318 | SND_JACK_HEADSET | SND_JACK_BTN_0); | ||
2319 | snd_soc_update_bits(codec, WM8996_MIC_DETECT_1, | ||
2320 | WM8996_MICD_RATE_MASK, | ||
2321 | WM8996_MICD_RATE_MASK); | ||
2322 | return; | ||
2323 | } | ||
2324 | |||
2325 | /* If the measurement is very high we've got a microphone but | ||
2326 | * do a little debounce to account for mechanical issues. | ||
2327 | */ | ||
2328 | if (val & 0x400) { | ||
2329 | dev_dbg(codec->dev, "Microphone detected\n"); | ||
2330 | snd_soc_jack_report(wm8996->jack, SND_JACK_HEADSET, | ||
2331 | SND_JACK_HEADSET | SND_JACK_BTN_0); | ||
2332 | wm8996->jack_mic = true; | ||
2333 | wm8996->detecting = false; | ||
2334 | |||
2335 | /* Increase poll rate to give better responsiveness | ||
2336 | * for buttons */ | ||
2337 | snd_soc_update_bits(codec, WM8996_MIC_DETECT_1, | ||
2338 | WM8996_MICD_RATE_MASK, | ||
2339 | 5 << WM8996_MICD_RATE_SHIFT); | ||
2340 | } | ||
2341 | |||
2342 | /* If we detected a lower impedence during initial startup | ||
2343 | * then we probably have the wrong polarity, flip it. Don't | ||
2344 | * do this for the lowest impedences to speed up detection of | ||
2345 | * plain headphones. | ||
2346 | */ | ||
2347 | if (wm8996->detecting && (val & 0x3f0)) { | ||
2348 | reg = snd_soc_read(codec, WM8996_ACCESSORY_DETECT_MODE_2); | ||
2349 | reg ^= WM8996_HPOUT1FB_SRC | WM8996_MICD_SRC | | ||
2350 | WM8996_MICD_BIAS_SRC; | ||
2351 | snd_soc_update_bits(codec, WM8996_ACCESSORY_DETECT_MODE_2, | ||
2352 | WM8996_HPOUT1FB_SRC | WM8996_MICD_SRC | | ||
2353 | WM8996_MICD_BIAS_SRC, reg); | ||
2354 | |||
2355 | if (wm8996->polarity_cb) | ||
2356 | wm8996->polarity_cb(codec, | ||
2357 | (reg & WM8996_MICD_SRC) != 0); | ||
2358 | |||
2359 | dev_dbg(codec->dev, "Set microphone polarity to %d\n", | ||
2360 | (reg & WM8996_MICD_SRC) != 0); | ||
2361 | |||
2362 | return; | ||
2363 | } | ||
2364 | |||
2365 | /* Don't distinguish between buttons, just report any low | ||
2366 | * impedence as BTN_0. | ||
2367 | */ | ||
2368 | if (val & 0x3fc) { | ||
2369 | if (wm8996->jack_mic) { | ||
2370 | dev_dbg(codec->dev, "Mic button detected\n"); | ||
2371 | snd_soc_jack_report(wm8996->jack, | ||
2372 | SND_JACK_HEADSET | SND_JACK_BTN_0, | ||
2373 | SND_JACK_HEADSET | SND_JACK_BTN_0); | ||
2374 | } else { | ||
2375 | dev_dbg(codec->dev, "Headphone detected\n"); | ||
2376 | snd_soc_jack_report(wm8996->jack, | ||
2377 | SND_JACK_HEADPHONE, | ||
2378 | SND_JACK_HEADSET | | ||
2379 | SND_JACK_BTN_0); | ||
2380 | |||
2381 | /* Increase the detection rate a bit for | ||
2382 | * responsiveness. | ||
2383 | */ | ||
2384 | snd_soc_update_bits(codec, WM8996_MIC_DETECT_1, | ||
2385 | WM8996_MICD_RATE_MASK, | ||
2386 | 7 << WM8996_MICD_RATE_SHIFT); | ||
2387 | |||
2388 | wm8996->detecting = false; | ||
2389 | } | ||
2390 | } | ||
2391 | } | ||
2392 | |||
2393 | static irqreturn_t wm8996_irq(int irq, void *data) | ||
2394 | { | ||
2395 | struct snd_soc_codec *codec = data; | ||
2396 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
2397 | int irq_val; | ||
2398 | |||
2399 | irq_val = snd_soc_read(codec, WM8996_INTERRUPT_STATUS_2); | ||
2400 | if (irq_val < 0) { | ||
2401 | dev_err(codec->dev, "Failed to read IRQ status: %d\n", | ||
2402 | irq_val); | ||
2403 | return IRQ_NONE; | ||
2404 | } | ||
2405 | irq_val &= ~snd_soc_read(codec, WM8996_INTERRUPT_STATUS_2_MASK); | ||
2406 | |||
2407 | snd_soc_write(codec, WM8996_INTERRUPT_STATUS_2, irq_val); | ||
2408 | |||
2409 | if (irq_val & (WM8996_DCS_DONE_01_EINT | WM8996_DCS_DONE_23_EINT)) { | ||
2410 | dev_dbg(codec->dev, "DC servo IRQ\n"); | ||
2411 | complete(&wm8996->dcs_done); | ||
2412 | } | ||
2413 | |||
2414 | if (irq_val & WM8996_FIFOS_ERR_EINT) | ||
2415 | dev_err(codec->dev, "Digital core FIFO error\n"); | ||
2416 | |||
2417 | if (irq_val & WM8996_FLL_LOCK_EINT) { | ||
2418 | dev_dbg(codec->dev, "FLL locked\n"); | ||
2419 | complete(&wm8996->fll_lock); | ||
2420 | } | ||
2421 | |||
2422 | if (irq_val & WM8996_MICD_EINT) | ||
2423 | wm8996_micd(codec); | ||
2424 | |||
2425 | if (irq_val) | ||
2426 | return IRQ_HANDLED; | ||
2427 | else | ||
2428 | return IRQ_NONE; | ||
2429 | } | ||
2430 | |||
2431 | static irqreturn_t wm8996_edge_irq(int irq, void *data) | ||
2432 | { | ||
2433 | irqreturn_t ret = IRQ_NONE; | ||
2434 | irqreturn_t val; | ||
2435 | |||
2436 | do { | ||
2437 | val = wm8996_irq(irq, data); | ||
2438 | if (val != IRQ_NONE) | ||
2439 | ret = val; | ||
2440 | } while (val != IRQ_NONE); | ||
2441 | |||
2442 | return ret; | ||
2443 | } | ||
2444 | |||
2445 | static void wm8996_retune_mobile_pdata(struct snd_soc_codec *codec) | ||
2446 | { | ||
2447 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
2448 | struct wm8996_pdata *pdata = &wm8996->pdata; | ||
2449 | |||
2450 | struct snd_kcontrol_new controls[] = { | ||
2451 | SOC_ENUM_EXT("DSP1 EQ Mode", | ||
2452 | wm8996->retune_mobile_enum, | ||
2453 | wm8996_get_retune_mobile_enum, | ||
2454 | wm8996_put_retune_mobile_enum), | ||
2455 | SOC_ENUM_EXT("DSP2 EQ Mode", | ||
2456 | wm8996->retune_mobile_enum, | ||
2457 | wm8996_get_retune_mobile_enum, | ||
2458 | wm8996_put_retune_mobile_enum), | ||
2459 | }; | ||
2460 | int ret, i, j; | ||
2461 | const char **t; | ||
2462 | |||
2463 | /* We need an array of texts for the enum API but the number | ||
2464 | * of texts is likely to be less than the number of | ||
2465 | * configurations due to the sample rate dependency of the | ||
2466 | * configurations. */ | ||
2467 | wm8996->num_retune_mobile_texts = 0; | ||
2468 | wm8996->retune_mobile_texts = NULL; | ||
2469 | for (i = 0; i < pdata->num_retune_mobile_cfgs; i++) { | ||
2470 | for (j = 0; j < wm8996->num_retune_mobile_texts; j++) { | ||
2471 | if (strcmp(pdata->retune_mobile_cfgs[i].name, | ||
2472 | wm8996->retune_mobile_texts[j]) == 0) | ||
2473 | break; | ||
2474 | } | ||
2475 | |||
2476 | if (j != wm8996->num_retune_mobile_texts) | ||
2477 | continue; | ||
2478 | |||
2479 | /* Expand the array... */ | ||
2480 | t = krealloc(wm8996->retune_mobile_texts, | ||
2481 | sizeof(char *) * | ||
2482 | (wm8996->num_retune_mobile_texts + 1), | ||
2483 | GFP_KERNEL); | ||
2484 | if (t == NULL) | ||
2485 | continue; | ||
2486 | |||
2487 | /* ...store the new entry... */ | ||
2488 | t[wm8996->num_retune_mobile_texts] = | ||
2489 | pdata->retune_mobile_cfgs[i].name; | ||
2490 | |||
2491 | /* ...and remember the new version. */ | ||
2492 | wm8996->num_retune_mobile_texts++; | ||
2493 | wm8996->retune_mobile_texts = t; | ||
2494 | } | ||
2495 | |||
2496 | dev_dbg(codec->dev, "Allocated %d unique ReTune Mobile names\n", | ||
2497 | wm8996->num_retune_mobile_texts); | ||
2498 | |||
2499 | wm8996->retune_mobile_enum.max = wm8996->num_retune_mobile_texts; | ||
2500 | wm8996->retune_mobile_enum.texts = wm8996->retune_mobile_texts; | ||
2501 | |||
2502 | ret = snd_soc_add_controls(codec, controls, ARRAY_SIZE(controls)); | ||
2503 | if (ret != 0) | ||
2504 | dev_err(codec->dev, | ||
2505 | "Failed to add ReTune Mobile controls: %d\n", ret); | ||
2506 | } | ||
2507 | |||
2508 | static int wm8996_probe(struct snd_soc_codec *codec) | ||
2509 | { | ||
2510 | int ret; | ||
2511 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
2512 | struct i2c_client *i2c = to_i2c_client(codec->dev); | ||
2513 | struct snd_soc_dapm_context *dapm = &codec->dapm; | ||
2514 | int i, irq_flags; | ||
2515 | |||
2516 | wm8996->codec = codec; | ||
2517 | |||
2518 | init_completion(&wm8996->dcs_done); | ||
2519 | init_completion(&wm8996->fll_lock); | ||
2520 | |||
2521 | dapm->idle_bias_off = true; | ||
2522 | dapm->bias_level = SND_SOC_BIAS_OFF; | ||
2523 | |||
2524 | ret = snd_soc_codec_set_cache_io(codec, 16, 16, SND_SOC_I2C); | ||
2525 | if (ret != 0) { | ||
2526 | dev_err(codec->dev, "Failed to set cache I/O: %d\n", ret); | ||
2527 | goto err; | ||
2528 | } | ||
2529 | |||
2530 | for (i = 0; i < ARRAY_SIZE(wm8996->supplies); i++) | ||
2531 | wm8996->supplies[i].supply = wm8996_supply_names[i]; | ||
2532 | |||
2533 | ret = regulator_bulk_get(codec->dev, ARRAY_SIZE(wm8996->supplies), | ||
2534 | wm8996->supplies); | ||
2535 | if (ret != 0) { | ||
2536 | dev_err(codec->dev, "Failed to request supplies: %d\n", ret); | ||
2537 | goto err; | ||
2538 | } | ||
2539 | |||
2540 | wm8996->disable_nb[0].notifier_call = wm8996_regulator_event_0; | ||
2541 | wm8996->disable_nb[1].notifier_call = wm8996_regulator_event_1; | ||
2542 | wm8996->disable_nb[2].notifier_call = wm8996_regulator_event_2; | ||
2543 | wm8996->disable_nb[3].notifier_call = wm8996_regulator_event_3; | ||
2544 | |||
2545 | /* This should really be moved into the regulator core */ | ||
2546 | for (i = 0; i < ARRAY_SIZE(wm8996->supplies); i++) { | ||
2547 | ret = regulator_register_notifier(wm8996->supplies[i].consumer, | ||
2548 | &wm8996->disable_nb[i]); | ||
2549 | if (ret != 0) { | ||
2550 | dev_err(codec->dev, | ||
2551 | "Failed to register regulator notifier: %d\n", | ||
2552 | ret); | ||
2553 | } | ||
2554 | } | ||
2555 | |||
2556 | ret = regulator_bulk_enable(ARRAY_SIZE(wm8996->supplies), | ||
2557 | wm8996->supplies); | ||
2558 | if (ret != 0) { | ||
2559 | dev_err(codec->dev, "Failed to enable supplies: %d\n", ret); | ||
2560 | goto err_get; | ||
2561 | } | ||
2562 | |||
2563 | if (wm8996->pdata.ldo_ena >= 0) { | ||
2564 | gpio_set_value_cansleep(wm8996->pdata.ldo_ena, 1); | ||
2565 | msleep(5); | ||
2566 | } | ||
2567 | |||
2568 | ret = snd_soc_read(codec, WM8996_SOFTWARE_RESET); | ||
2569 | if (ret < 0) { | ||
2570 | dev_err(codec->dev, "Failed to read ID register: %d\n", ret); | ||
2571 | goto err_enable; | ||
2572 | } | ||
2573 | if (ret != 0x8915) { | ||
2574 | dev_err(codec->dev, "Device is not a WM8996, ID %x\n", ret); | ||
2575 | ret = -EINVAL; | ||
2576 | goto err_enable; | ||
2577 | } | ||
2578 | |||
2579 | ret = snd_soc_read(codec, WM8996_CHIP_REVISION); | ||
2580 | if (ret < 0) { | ||
2581 | dev_err(codec->dev, "Failed to read device revision: %d\n", | ||
2582 | ret); | ||
2583 | goto err_enable; | ||
2584 | } | ||
2585 | |||
2586 | dev_info(codec->dev, "revision %c\n", | ||
2587 | (ret & WM8996_CHIP_REV_MASK) + 'A'); | ||
2588 | |||
2589 | if (wm8996->pdata.ldo_ena >= 0) { | ||
2590 | gpio_set_value_cansleep(wm8996->pdata.ldo_ena, 0); | ||
2591 | } else { | ||
2592 | ret = wm8996_reset(codec); | ||
2593 | if (ret < 0) { | ||
2594 | dev_err(codec->dev, "Failed to issue reset\n"); | ||
2595 | goto err_enable; | ||
2596 | } | ||
2597 | } | ||
2598 | |||
2599 | codec->cache_only = true; | ||
2600 | |||
2601 | /* Apply platform data settings */ | ||
2602 | snd_soc_update_bits(codec, WM8996_LINE_INPUT_CONTROL, | ||
2603 | WM8996_INL_MODE_MASK | WM8996_INR_MODE_MASK, | ||
2604 | wm8996->pdata.inl_mode << WM8996_INL_MODE_SHIFT | | ||
2605 | wm8996->pdata.inr_mode); | ||
2606 | |||
2607 | for (i = 0; i < ARRAY_SIZE(wm8996->pdata.gpio_default); i++) { | ||
2608 | if (!wm8996->pdata.gpio_default[i]) | ||
2609 | continue; | ||
2610 | |||
2611 | snd_soc_write(codec, WM8996_GPIO_1 + i, | ||
2612 | wm8996->pdata.gpio_default[i] & 0xffff); | ||
2613 | } | ||
2614 | |||
2615 | if (wm8996->pdata.spkmute_seq) | ||
2616 | snd_soc_update_bits(codec, WM8996_PDM_SPEAKER_MUTE_SEQUENCE, | ||
2617 | WM8996_SPK_MUTE_ENDIAN | | ||
2618 | WM8996_SPK_MUTE_SEQ1_MASK, | ||
2619 | wm8996->pdata.spkmute_seq); | ||
2620 | |||
2621 | snd_soc_update_bits(codec, WM8996_ACCESSORY_DETECT_MODE_2, | ||
2622 | WM8996_MICD_BIAS_SRC | WM8996_HPOUT1FB_SRC | | ||
2623 | WM8996_MICD_SRC, wm8996->pdata.micdet_def); | ||
2624 | |||
2625 | /* Latch volume update bits */ | ||
2626 | snd_soc_update_bits(codec, WM8996_LEFT_LINE_INPUT_VOLUME, | ||
2627 | WM8996_IN1_VU, WM8996_IN1_VU); | ||
2628 | snd_soc_update_bits(codec, WM8996_RIGHT_LINE_INPUT_VOLUME, | ||
2629 | WM8996_IN1_VU, WM8996_IN1_VU); | ||
2630 | |||
2631 | snd_soc_update_bits(codec, WM8996_DAC1_LEFT_VOLUME, | ||
2632 | WM8996_DAC1_VU, WM8996_DAC1_VU); | ||
2633 | snd_soc_update_bits(codec, WM8996_DAC1_RIGHT_VOLUME, | ||
2634 | WM8996_DAC1_VU, WM8996_DAC1_VU); | ||
2635 | snd_soc_update_bits(codec, WM8996_DAC2_LEFT_VOLUME, | ||
2636 | WM8996_DAC2_VU, WM8996_DAC2_VU); | ||
2637 | snd_soc_update_bits(codec, WM8996_DAC2_RIGHT_VOLUME, | ||
2638 | WM8996_DAC2_VU, WM8996_DAC2_VU); | ||
2639 | |||
2640 | snd_soc_update_bits(codec, WM8996_OUTPUT1_LEFT_VOLUME, | ||
2641 | WM8996_DAC1_VU, WM8996_DAC1_VU); | ||
2642 | snd_soc_update_bits(codec, WM8996_OUTPUT1_RIGHT_VOLUME, | ||
2643 | WM8996_DAC1_VU, WM8996_DAC1_VU); | ||
2644 | snd_soc_update_bits(codec, WM8996_OUTPUT2_LEFT_VOLUME, | ||
2645 | WM8996_DAC2_VU, WM8996_DAC2_VU); | ||
2646 | snd_soc_update_bits(codec, WM8996_OUTPUT2_RIGHT_VOLUME, | ||
2647 | WM8996_DAC2_VU, WM8996_DAC2_VU); | ||
2648 | |||
2649 | snd_soc_update_bits(codec, WM8996_DSP1_TX_LEFT_VOLUME, | ||
2650 | WM8996_DSP1TX_VU, WM8996_DSP1TX_VU); | ||
2651 | snd_soc_update_bits(codec, WM8996_DSP1_TX_RIGHT_VOLUME, | ||
2652 | WM8996_DSP1TX_VU, WM8996_DSP1TX_VU); | ||
2653 | snd_soc_update_bits(codec, WM8996_DSP2_TX_LEFT_VOLUME, | ||
2654 | WM8996_DSP2TX_VU, WM8996_DSP2TX_VU); | ||
2655 | snd_soc_update_bits(codec, WM8996_DSP2_TX_RIGHT_VOLUME, | ||
2656 | WM8996_DSP2TX_VU, WM8996_DSP2TX_VU); | ||
2657 | |||
2658 | snd_soc_update_bits(codec, WM8996_DSP1_RX_LEFT_VOLUME, | ||
2659 | WM8996_DSP1RX_VU, WM8996_DSP1RX_VU); | ||
2660 | snd_soc_update_bits(codec, WM8996_DSP1_RX_RIGHT_VOLUME, | ||
2661 | WM8996_DSP1RX_VU, WM8996_DSP1RX_VU); | ||
2662 | snd_soc_update_bits(codec, WM8996_DSP2_RX_LEFT_VOLUME, | ||
2663 | WM8996_DSP2RX_VU, WM8996_DSP2RX_VU); | ||
2664 | snd_soc_update_bits(codec, WM8996_DSP2_RX_RIGHT_VOLUME, | ||
2665 | WM8996_DSP2RX_VU, WM8996_DSP2RX_VU); | ||
2666 | |||
2667 | /* No support currently for the underclocked TDM modes and | ||
2668 | * pick a default TDM layout with each channel pair working with | ||
2669 | * slots 0 and 1. */ | ||
2670 | snd_soc_update_bits(codec, WM8996_AIF1RX_CHANNEL_0_CONFIGURATION, | ||
2671 | WM8996_AIF1RX_CHAN0_SLOTS_MASK | | ||
2672 | WM8996_AIF1RX_CHAN0_START_SLOT_MASK, | ||
2673 | 1 << WM8996_AIF1RX_CHAN0_SLOTS_SHIFT | 0); | ||
2674 | snd_soc_update_bits(codec, WM8996_AIF1RX_CHANNEL_1_CONFIGURATION, | ||
2675 | WM8996_AIF1RX_CHAN1_SLOTS_MASK | | ||
2676 | WM8996_AIF1RX_CHAN1_START_SLOT_MASK, | ||
2677 | 1 << WM8996_AIF1RX_CHAN1_SLOTS_SHIFT | 1); | ||
2678 | snd_soc_update_bits(codec, WM8996_AIF1RX_CHANNEL_2_CONFIGURATION, | ||
2679 | WM8996_AIF1RX_CHAN2_SLOTS_MASK | | ||
2680 | WM8996_AIF1RX_CHAN2_START_SLOT_MASK, | ||
2681 | 1 << WM8996_AIF1RX_CHAN2_SLOTS_SHIFT | 0); | ||
2682 | snd_soc_update_bits(codec, WM8996_AIF1RX_CHANNEL_3_CONFIGURATION, | ||
2683 | WM8996_AIF1RX_CHAN3_SLOTS_MASK | | ||
2684 | WM8996_AIF1RX_CHAN0_START_SLOT_MASK, | ||
2685 | 1 << WM8996_AIF1RX_CHAN3_SLOTS_SHIFT | 1); | ||
2686 | snd_soc_update_bits(codec, WM8996_AIF1RX_CHANNEL_4_CONFIGURATION, | ||
2687 | WM8996_AIF1RX_CHAN4_SLOTS_MASK | | ||
2688 | WM8996_AIF1RX_CHAN0_START_SLOT_MASK, | ||
2689 | 1 << WM8996_AIF1RX_CHAN4_SLOTS_SHIFT | 0); | ||
2690 | snd_soc_update_bits(codec, WM8996_AIF1RX_CHANNEL_5_CONFIGURATION, | ||
2691 | WM8996_AIF1RX_CHAN5_SLOTS_MASK | | ||
2692 | WM8996_AIF1RX_CHAN0_START_SLOT_MASK, | ||
2693 | 1 << WM8996_AIF1RX_CHAN5_SLOTS_SHIFT | 1); | ||
2694 | |||
2695 | snd_soc_update_bits(codec, WM8996_AIF2RX_CHANNEL_0_CONFIGURATION, | ||
2696 | WM8996_AIF2RX_CHAN0_SLOTS_MASK | | ||
2697 | WM8996_AIF2RX_CHAN0_START_SLOT_MASK, | ||
2698 | 1 << WM8996_AIF2RX_CHAN0_SLOTS_SHIFT | 0); | ||
2699 | snd_soc_update_bits(codec, WM8996_AIF2RX_CHANNEL_1_CONFIGURATION, | ||
2700 | WM8996_AIF2RX_CHAN1_SLOTS_MASK | | ||
2701 | WM8996_AIF2RX_CHAN1_START_SLOT_MASK, | ||
2702 | 1 << WM8996_AIF2RX_CHAN1_SLOTS_SHIFT | 1); | ||
2703 | |||
2704 | snd_soc_update_bits(codec, WM8996_AIF1TX_CHANNEL_0_CONFIGURATION, | ||
2705 | WM8996_AIF1TX_CHAN0_SLOTS_MASK | | ||
2706 | WM8996_AIF1TX_CHAN0_START_SLOT_MASK, | ||
2707 | 1 << WM8996_AIF1TX_CHAN0_SLOTS_SHIFT | 0); | ||
2708 | snd_soc_update_bits(codec, WM8996_AIF1TX_CHANNEL_1_CONFIGURATION, | ||
2709 | WM8996_AIF1TX_CHAN1_SLOTS_MASK | | ||
2710 | WM8996_AIF1TX_CHAN0_START_SLOT_MASK, | ||
2711 | 1 << WM8996_AIF1TX_CHAN1_SLOTS_SHIFT | 1); | ||
2712 | snd_soc_update_bits(codec, WM8996_AIF1TX_CHANNEL_2_CONFIGURATION, | ||
2713 | WM8996_AIF1TX_CHAN2_SLOTS_MASK | | ||
2714 | WM8996_AIF1TX_CHAN0_START_SLOT_MASK, | ||
2715 | 1 << WM8996_AIF1TX_CHAN2_SLOTS_SHIFT | 0); | ||
2716 | snd_soc_update_bits(codec, WM8996_AIF1TX_CHANNEL_3_CONFIGURATION, | ||
2717 | WM8996_AIF1TX_CHAN3_SLOTS_MASK | | ||
2718 | WM8996_AIF1TX_CHAN0_START_SLOT_MASK, | ||
2719 | 1 << WM8996_AIF1TX_CHAN3_SLOTS_SHIFT | 1); | ||
2720 | snd_soc_update_bits(codec, WM8996_AIF1TX_CHANNEL_4_CONFIGURATION, | ||
2721 | WM8996_AIF1TX_CHAN4_SLOTS_MASK | | ||
2722 | WM8996_AIF1TX_CHAN0_START_SLOT_MASK, | ||
2723 | 1 << WM8996_AIF1TX_CHAN4_SLOTS_SHIFT | 0); | ||
2724 | snd_soc_update_bits(codec, WM8996_AIF1TX_CHANNEL_5_CONFIGURATION, | ||
2725 | WM8996_AIF1TX_CHAN5_SLOTS_MASK | | ||
2726 | WM8996_AIF1TX_CHAN0_START_SLOT_MASK, | ||
2727 | 1 << WM8996_AIF1TX_CHAN5_SLOTS_SHIFT | 1); | ||
2728 | |||
2729 | snd_soc_update_bits(codec, WM8996_AIF2TX_CHANNEL_0_CONFIGURATION, | ||
2730 | WM8996_AIF2TX_CHAN0_SLOTS_MASK | | ||
2731 | WM8996_AIF2TX_CHAN0_START_SLOT_MASK, | ||
2732 | 1 << WM8996_AIF2TX_CHAN0_SLOTS_SHIFT | 0); | ||
2733 | snd_soc_update_bits(codec, WM8996_AIF1TX_CHANNEL_1_CONFIGURATION, | ||
2734 | WM8996_AIF2TX_CHAN1_SLOTS_MASK | | ||
2735 | WM8996_AIF2TX_CHAN1_START_SLOT_MASK, | ||
2736 | 1 << WM8996_AIF1TX_CHAN1_SLOTS_SHIFT | 1); | ||
2737 | |||
2738 | if (wm8996->pdata.num_retune_mobile_cfgs) | ||
2739 | wm8996_retune_mobile_pdata(codec); | ||
2740 | else | ||
2741 | snd_soc_add_controls(codec, wm8996_eq_controls, | ||
2742 | ARRAY_SIZE(wm8996_eq_controls)); | ||
2743 | |||
2744 | /* If the TX LRCLK pins are not in LRCLK mode configure the | ||
2745 | * AIFs to source their clocks from the RX LRCLKs. | ||
2746 | */ | ||
2747 | if ((snd_soc_read(codec, WM8996_GPIO_1))) | ||
2748 | snd_soc_update_bits(codec, WM8996_AIF1_TX_LRCLK_2, | ||
2749 | WM8996_AIF1TX_LRCLK_MODE, | ||
2750 | WM8996_AIF1TX_LRCLK_MODE); | ||
2751 | |||
2752 | if ((snd_soc_read(codec, WM8996_GPIO_2))) | ||
2753 | snd_soc_update_bits(codec, WM8996_AIF2_TX_LRCLK_2, | ||
2754 | WM8996_AIF2TX_LRCLK_MODE, | ||
2755 | WM8996_AIF2TX_LRCLK_MODE); | ||
2756 | |||
2757 | regulator_bulk_disable(ARRAY_SIZE(wm8996->supplies), wm8996->supplies); | ||
2758 | |||
2759 | wm8996_init_gpio(codec); | ||
2760 | |||
2761 | if (i2c->irq) { | ||
2762 | if (wm8996->pdata.irq_flags) | ||
2763 | irq_flags = wm8996->pdata.irq_flags; | ||
2764 | else | ||
2765 | irq_flags = IRQF_TRIGGER_LOW; | ||
2766 | |||
2767 | irq_flags |= IRQF_ONESHOT; | ||
2768 | |||
2769 | if (irq_flags & (IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING)) | ||
2770 | ret = request_threaded_irq(i2c->irq, NULL, | ||
2771 | wm8996_edge_irq, | ||
2772 | irq_flags, "wm8996", codec); | ||
2773 | else | ||
2774 | ret = request_threaded_irq(i2c->irq, NULL, wm8996_irq, | ||
2775 | irq_flags, "wm8996", codec); | ||
2776 | |||
2777 | if (ret == 0) { | ||
2778 | /* Unmask the interrupt */ | ||
2779 | snd_soc_update_bits(codec, WM8996_INTERRUPT_CONTROL, | ||
2780 | WM8996_IM_IRQ, 0); | ||
2781 | |||
2782 | /* Enable error reporting and DC servo status */ | ||
2783 | snd_soc_update_bits(codec, | ||
2784 | WM8996_INTERRUPT_STATUS_2_MASK, | ||
2785 | WM8996_IM_DCS_DONE_23_EINT | | ||
2786 | WM8996_IM_DCS_DONE_01_EINT | | ||
2787 | WM8996_IM_FLL_LOCK_EINT | | ||
2788 | WM8996_IM_FIFOS_ERR_EINT, | ||
2789 | 0); | ||
2790 | } else { | ||
2791 | dev_err(codec->dev, "Failed to request IRQ: %d\n", | ||
2792 | ret); | ||
2793 | } | ||
2794 | } | ||
2795 | |||
2796 | return 0; | ||
2797 | |||
2798 | err_enable: | ||
2799 | if (wm8996->pdata.ldo_ena >= 0) | ||
2800 | gpio_set_value_cansleep(wm8996->pdata.ldo_ena, 0); | ||
2801 | |||
2802 | regulator_bulk_disable(ARRAY_SIZE(wm8996->supplies), wm8996->supplies); | ||
2803 | err_get: | ||
2804 | regulator_bulk_free(ARRAY_SIZE(wm8996->supplies), wm8996->supplies); | ||
2805 | err: | ||
2806 | return ret; | ||
2807 | } | ||
2808 | |||
2809 | static int wm8996_remove(struct snd_soc_codec *codec) | ||
2810 | { | ||
2811 | struct wm8996_priv *wm8996 = snd_soc_codec_get_drvdata(codec); | ||
2812 | struct i2c_client *i2c = to_i2c_client(codec->dev); | ||
2813 | int i; | ||
2814 | |||
2815 | snd_soc_update_bits(codec, WM8996_INTERRUPT_CONTROL, | ||
2816 | WM8996_IM_IRQ, WM8996_IM_IRQ); | ||
2817 | |||
2818 | if (i2c->irq) | ||
2819 | free_irq(i2c->irq, codec); | ||
2820 | |||
2821 | wm8996_free_gpio(codec); | ||
2822 | |||
2823 | for (i = 0; i < ARRAY_SIZE(wm8996->supplies); i++) | ||
2824 | regulator_unregister_notifier(wm8996->supplies[i].consumer, | ||
2825 | &wm8996->disable_nb[i]); | ||
2826 | regulator_bulk_free(ARRAY_SIZE(wm8996->supplies), wm8996->supplies); | ||
2827 | |||
2828 | return 0; | ||
2829 | } | ||
2830 | |||
2831 | static struct snd_soc_codec_driver soc_codec_dev_wm8996 = { | ||
2832 | .probe = wm8996_probe, | ||
2833 | .remove = wm8996_remove, | ||
2834 | .set_bias_level = wm8996_set_bias_level, | ||
2835 | .seq_notifier = wm8996_seq_notifier, | ||
2836 | .reg_cache_size = WM8996_MAX_REGISTER + 1, | ||
2837 | .reg_word_size = sizeof(u16), | ||
2838 | .reg_cache_default = wm8996_reg, | ||
2839 | .volatile_register = wm8996_volatile_register, | ||
2840 | .readable_register = wm8996_readable_register, | ||
2841 | .compress_type = SND_SOC_RBTREE_COMPRESSION, | ||
2842 | .controls = wm8996_snd_controls, | ||
2843 | .num_controls = ARRAY_SIZE(wm8996_snd_controls), | ||
2844 | .dapm_widgets = wm8996_dapm_widgets, | ||
2845 | .num_dapm_widgets = ARRAY_SIZE(wm8996_dapm_widgets), | ||
2846 | .dapm_routes = wm8996_dapm_routes, | ||
2847 | .num_dapm_routes = ARRAY_SIZE(wm8996_dapm_routes), | ||
2848 | .set_pll = wm8996_set_fll, | ||
2849 | }; | ||
2850 | |||
2851 | #define WM8996_RATES (SNDRV_PCM_RATE_8000 | SNDRV_PCM_RATE_16000 |\ | ||
2852 | SNDRV_PCM_RATE_32000 | SNDRV_PCM_RATE_48000) | ||
2853 | #define WM8996_FORMATS (SNDRV_PCM_FMTBIT_S8 | SNDRV_PCM_FMTBIT_S16_LE |\ | ||
2854 | SNDRV_PCM_FMTBIT_S20_3LE | SNDRV_PCM_FMTBIT_S24_LE |\ | ||
2855 | SNDRV_PCM_FMTBIT_S32_LE) | ||
2856 | |||
2857 | static struct snd_soc_dai_ops wm8996_dai_ops = { | ||
2858 | .set_fmt = wm8996_set_fmt, | ||
2859 | .hw_params = wm8996_hw_params, | ||
2860 | .set_sysclk = wm8996_set_sysclk, | ||
2861 | }; | ||
2862 | |||
2863 | static struct snd_soc_dai_driver wm8996_dai[] = { | ||
2864 | { | ||
2865 | .name = "wm8996-aif1", | ||
2866 | .playback = { | ||
2867 | .stream_name = "AIF1 Playback", | ||
2868 | .channels_min = 1, | ||
2869 | .channels_max = 6, | ||
2870 | .rates = WM8996_RATES, | ||
2871 | .formats = WM8996_FORMATS, | ||
2872 | }, | ||
2873 | .capture = { | ||
2874 | .stream_name = "AIF1 Capture", | ||
2875 | .channels_min = 1, | ||
2876 | .channels_max = 6, | ||
2877 | .rates = WM8996_RATES, | ||
2878 | .formats = WM8996_FORMATS, | ||
2879 | }, | ||
2880 | .ops = &wm8996_dai_ops, | ||
2881 | }, | ||
2882 | { | ||
2883 | .name = "wm8996-aif2", | ||
2884 | .playback = { | ||
2885 | .stream_name = "AIF2 Playback", | ||
2886 | .channels_min = 1, | ||
2887 | .channels_max = 2, | ||
2888 | .rates = WM8996_RATES, | ||
2889 | .formats = WM8996_FORMATS, | ||
2890 | }, | ||
2891 | .capture = { | ||
2892 | .stream_name = "AIF2 Capture", | ||
2893 | .channels_min = 1, | ||
2894 | .channels_max = 2, | ||
2895 | .rates = WM8996_RATES, | ||
2896 | .formats = WM8996_FORMATS, | ||
2897 | }, | ||
2898 | .ops = &wm8996_dai_ops, | ||
2899 | }, | ||
2900 | }; | ||
2901 | |||
2902 | static __devinit int wm8996_i2c_probe(struct i2c_client *i2c, | ||
2903 | const struct i2c_device_id *id) | ||
2904 | { | ||
2905 | struct wm8996_priv *wm8996; | ||
2906 | int ret; | ||
2907 | |||
2908 | wm8996 = kzalloc(sizeof(struct wm8996_priv), GFP_KERNEL); | ||
2909 | if (wm8996 == NULL) | ||
2910 | return -ENOMEM; | ||
2911 | |||
2912 | i2c_set_clientdata(i2c, wm8996); | ||
2913 | |||
2914 | if (dev_get_platdata(&i2c->dev)) | ||
2915 | memcpy(&wm8996->pdata, dev_get_platdata(&i2c->dev), | ||
2916 | sizeof(wm8996->pdata)); | ||
2917 | |||
2918 | if (wm8996->pdata.ldo_ena > 0) { | ||
2919 | ret = gpio_request_one(wm8996->pdata.ldo_ena, | ||
2920 | GPIOF_OUT_INIT_LOW, "WM8996 ENA"); | ||
2921 | if (ret < 0) { | ||
2922 | dev_err(&i2c->dev, "Failed to request GPIO %d: %d\n", | ||
2923 | wm8996->pdata.ldo_ena, ret); | ||
2924 | goto err; | ||
2925 | } | ||
2926 | } | ||
2927 | |||
2928 | ret = snd_soc_register_codec(&i2c->dev, | ||
2929 | &soc_codec_dev_wm8996, wm8996_dai, | ||
2930 | ARRAY_SIZE(wm8996_dai)); | ||
2931 | if (ret < 0) | ||
2932 | goto err_gpio; | ||
2933 | |||
2934 | return ret; | ||
2935 | |||
2936 | err_gpio: | ||
2937 | if (wm8996->pdata.ldo_ena > 0) | ||
2938 | gpio_free(wm8996->pdata.ldo_ena); | ||
2939 | err: | ||
2940 | kfree(wm8996); | ||
2941 | |||
2942 | return ret; | ||
2943 | } | ||
2944 | |||
2945 | static __devexit int wm8996_i2c_remove(struct i2c_client *client) | ||
2946 | { | ||
2947 | struct wm8996_priv *wm8996 = i2c_get_clientdata(client); | ||
2948 | |||
2949 | snd_soc_unregister_codec(&client->dev); | ||
2950 | if (wm8996->pdata.ldo_ena > 0) | ||
2951 | gpio_free(wm8996->pdata.ldo_ena); | ||
2952 | kfree(i2c_get_clientdata(client)); | ||
2953 | return 0; | ||
2954 | } | ||
2955 | |||
2956 | static const struct i2c_device_id wm8996_i2c_id[] = { | ||
2957 | { "wm8996", 0 }, | ||
2958 | { } | ||
2959 | }; | ||
2960 | MODULE_DEVICE_TABLE(i2c, wm8996_i2c_id); | ||
2961 | |||
2962 | static struct i2c_driver wm8996_i2c_driver = { | ||
2963 | .driver = { | ||
2964 | .name = "wm8996", | ||
2965 | .owner = THIS_MODULE, | ||
2966 | }, | ||
2967 | .probe = wm8996_i2c_probe, | ||
2968 | .remove = __devexit_p(wm8996_i2c_remove), | ||
2969 | .id_table = wm8996_i2c_id, | ||
2970 | }; | ||
2971 | |||
2972 | static int __init wm8996_modinit(void) | ||
2973 | { | ||
2974 | int ret; | ||
2975 | |||
2976 | ret = i2c_add_driver(&wm8996_i2c_driver); | ||
2977 | if (ret != 0) { | ||
2978 | printk(KERN_ERR "Failed to register WM8996 I2C driver: %d\n", | ||
2979 | ret); | ||
2980 | } | ||
2981 | |||
2982 | return ret; | ||
2983 | } | ||
2984 | module_init(wm8996_modinit); | ||
2985 | |||
2986 | static void __exit wm8996_exit(void) | ||
2987 | { | ||
2988 | i2c_del_driver(&wm8996_i2c_driver); | ||
2989 | } | ||
2990 | module_exit(wm8996_exit); | ||
2991 | |||
2992 | MODULE_DESCRIPTION("ASoC WM8996 driver"); | ||
2993 | MODULE_AUTHOR("Mark Brown <broonie@opensource.wolfsonmicro.com>"); | ||
2994 | MODULE_LICENSE("GPL"); | ||
diff --git a/sound/soc/codecs/wm8996.h b/sound/soc/codecs/wm8996.h new file mode 100644 index 000000000000..0fde643194ce --- /dev/null +++ b/sound/soc/codecs/wm8996.h | |||
@@ -0,0 +1,3717 @@ | |||
1 | /* | ||
2 | * wm8996.h - WM8996 audio codec interface | ||
3 | * | ||
4 | * Copyright 2011 Wolfson Microelectronics PLC. | ||
5 | * Author: Mark Brown <broonie@opensource.wolfsonmicro.com> | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify it | ||
8 | * under the terms of the GNU General Public License as published by the | ||
9 | * Free Software Foundation; either version 2 of the License, or (at your | ||
10 | * option) any later version. | ||
11 | */ | ||
12 | |||
13 | #ifndef _WM8996_H | ||
14 | #define _WM8996_H | ||
15 | |||
16 | #define WM8996_SYSCLK_MCLK1 1 | ||
17 | #define WM8996_SYSCLK_MCLK2 2 | ||
18 | #define WM8996_SYSCLK_FLL 3 | ||
19 | |||
20 | #define WM8996_FLL_MCLK1 1 | ||
21 | #define WM8996_FLL_MCLK2 2 | ||
22 | #define WM8996_FLL_DACLRCLK1 3 | ||
23 | #define WM8996_FLL_BCLK1 4 | ||
24 | |||
25 | typedef void (*wm8996_polarity_fn)(struct snd_soc_codec *codec, int polarity); | ||
26 | |||
27 | int wm8996_detect(struct snd_soc_codec *codec, struct snd_soc_jack *jack, | ||
28 | wm8996_polarity_fn polarity_cb); | ||
29 | |||
30 | /* | ||
31 | * Register values. | ||
32 | */ | ||
33 | #define WM8996_SOFTWARE_RESET 0x00 | ||
34 | #define WM8996_POWER_MANAGEMENT_1 0x01 | ||
35 | #define WM8996_POWER_MANAGEMENT_2 0x02 | ||
36 | #define WM8996_POWER_MANAGEMENT_3 0x03 | ||
37 | #define WM8996_POWER_MANAGEMENT_4 0x04 | ||
38 | #define WM8996_POWER_MANAGEMENT_5 0x05 | ||
39 | #define WM8996_POWER_MANAGEMENT_6 0x06 | ||
40 | #define WM8996_POWER_MANAGEMENT_7 0x07 | ||
41 | #define WM8996_POWER_MANAGEMENT_8 0x08 | ||
42 | #define WM8996_LEFT_LINE_INPUT_VOLUME 0x10 | ||
43 | #define WM8996_RIGHT_LINE_INPUT_VOLUME 0x11 | ||
44 | #define WM8996_LINE_INPUT_CONTROL 0x12 | ||
45 | #define WM8996_DAC1_HPOUT1_VOLUME 0x15 | ||
46 | #define WM8996_DAC2_HPOUT2_VOLUME 0x16 | ||
47 | #define WM8996_DAC1_LEFT_VOLUME 0x18 | ||
48 | #define WM8996_DAC1_RIGHT_VOLUME 0x19 | ||
49 | #define WM8996_DAC2_LEFT_VOLUME 0x1A | ||
50 | #define WM8996_DAC2_RIGHT_VOLUME 0x1B | ||
51 | #define WM8996_OUTPUT1_LEFT_VOLUME 0x1C | ||
52 | #define WM8996_OUTPUT1_RIGHT_VOLUME 0x1D | ||
53 | #define WM8996_OUTPUT2_LEFT_VOLUME 0x1E | ||
54 | #define WM8996_OUTPUT2_RIGHT_VOLUME 0x1F | ||
55 | #define WM8996_MICBIAS_1 0x20 | ||
56 | #define WM8996_MICBIAS_2 0x21 | ||
57 | #define WM8996_LDO_1 0x28 | ||
58 | #define WM8996_LDO_2 0x29 | ||
59 | #define WM8996_ACCESSORY_DETECT_MODE_1 0x30 | ||
60 | #define WM8996_ACCESSORY_DETECT_MODE_2 0x31 | ||
61 | #define WM8996_HEADPHONE_DETECT_1 0x34 | ||
62 | #define WM8996_HEADPHONE_DETECT_2 0x35 | ||
63 | #define WM8996_MIC_DETECT_1 0x38 | ||
64 | #define WM8996_MIC_DETECT_2 0x39 | ||
65 | #define WM8996_MIC_DETECT_3 0x3A | ||
66 | #define WM8996_CHARGE_PUMP_1 0x40 | ||
67 | #define WM8996_CHARGE_PUMP_2 0x41 | ||
68 | #define WM8996_DC_SERVO_1 0x50 | ||
69 | #define WM8996_DC_SERVO_2 0x51 | ||
70 | #define WM8996_DC_SERVO_3 0x52 | ||
71 | #define WM8996_DC_SERVO_5 0x54 | ||
72 | #define WM8996_DC_SERVO_6 0x55 | ||
73 | #define WM8996_DC_SERVO_7 0x56 | ||
74 | #define WM8996_DC_SERVO_READBACK_0 0x57 | ||
75 | #define WM8996_ANALOGUE_HP_1 0x60 | ||
76 | #define WM8996_ANALOGUE_HP_2 0x61 | ||
77 | #define WM8996_CHIP_REVISION 0x100 | ||
78 | #define WM8996_CONTROL_INTERFACE_1 0x101 | ||
79 | #define WM8996_WRITE_SEQUENCER_CTRL_1 0x110 | ||
80 | #define WM8996_WRITE_SEQUENCER_CTRL_2 0x111 | ||
81 | #define WM8996_AIF_CLOCKING_1 0x200 | ||
82 | #define WM8996_AIF_CLOCKING_2 0x201 | ||
83 | #define WM8996_CLOCKING_1 0x208 | ||
84 | #define WM8996_CLOCKING_2 0x209 | ||
85 | #define WM8996_AIF_RATE 0x210 | ||
86 | #define WM8996_FLL_CONTROL_1 0x220 | ||
87 | #define WM8996_FLL_CONTROL_2 0x221 | ||
88 | #define WM8996_FLL_CONTROL_3 0x222 | ||
89 | #define WM8996_FLL_CONTROL_4 0x223 | ||
90 | #define WM8996_FLL_CONTROL_5 0x224 | ||
91 | #define WM8996_FLL_CONTROL_6 0x225 | ||
92 | #define WM8996_FLL_EFS_1 0x226 | ||
93 | #define WM8996_FLL_EFS_2 0x227 | ||
94 | #define WM8996_AIF1_CONTROL 0x300 | ||
95 | #define WM8996_AIF1_BCLK 0x301 | ||
96 | #define WM8996_AIF1_TX_LRCLK_1 0x302 | ||
97 | #define WM8996_AIF1_TX_LRCLK_2 0x303 | ||
98 | #define WM8996_AIF1_RX_LRCLK_1 0x304 | ||
99 | #define WM8996_AIF1_RX_LRCLK_2 0x305 | ||
100 | #define WM8996_AIF1TX_DATA_CONFIGURATION_1 0x306 | ||
101 | #define WM8996_AIF1TX_DATA_CONFIGURATION_2 0x307 | ||
102 | #define WM8996_AIF1RX_DATA_CONFIGURATION 0x308 | ||
103 | #define WM8996_AIF1TX_CHANNEL_0_CONFIGURATION 0x309 | ||
104 | #define WM8996_AIF1TX_CHANNEL_1_CONFIGURATION 0x30A | ||
105 | #define WM8996_AIF1TX_CHANNEL_2_CONFIGURATION 0x30B | ||
106 | #define WM8996_AIF1TX_CHANNEL_3_CONFIGURATION 0x30C | ||
107 | #define WM8996_AIF1TX_CHANNEL_4_CONFIGURATION 0x30D | ||
108 | #define WM8996_AIF1TX_CHANNEL_5_CONFIGURATION 0x30E | ||
109 | #define WM8996_AIF1RX_CHANNEL_0_CONFIGURATION 0x30F | ||
110 | #define WM8996_AIF1RX_CHANNEL_1_CONFIGURATION 0x310 | ||
111 | #define WM8996_AIF1RX_CHANNEL_2_CONFIGURATION 0x311 | ||
112 | #define WM8996_AIF1RX_CHANNEL_3_CONFIGURATION 0x312 | ||
113 | #define WM8996_AIF1RX_CHANNEL_4_CONFIGURATION 0x313 | ||
114 | #define WM8996_AIF1RX_CHANNEL_5_CONFIGURATION 0x314 | ||
115 | #define WM8996_AIF1RX_MONO_CONFIGURATION 0x315 | ||
116 | #define WM8996_AIF1TX_TEST 0x31A | ||
117 | #define WM8996_AIF2_CONTROL 0x320 | ||
118 | #define WM8996_AIF2_BCLK 0x321 | ||
119 | #define WM8996_AIF2_TX_LRCLK_1 0x322 | ||
120 | #define WM8996_AIF2_TX_LRCLK_2 0x323 | ||
121 | #define WM8996_AIF2_RX_LRCLK_1 0x324 | ||
122 | #define WM8996_AIF2_RX_LRCLK_2 0x325 | ||
123 | #define WM8996_AIF2TX_DATA_CONFIGURATION_1 0x326 | ||
124 | #define WM8996_AIF2TX_DATA_CONFIGURATION_2 0x327 | ||
125 | #define WM8996_AIF2RX_DATA_CONFIGURATION 0x328 | ||
126 | #define WM8996_AIF2TX_CHANNEL_0_CONFIGURATION 0x329 | ||
127 | #define WM8996_AIF2TX_CHANNEL_1_CONFIGURATION 0x32A | ||
128 | #define WM8996_AIF2RX_CHANNEL_0_CONFIGURATION 0x32B | ||
129 | #define WM8996_AIF2RX_CHANNEL_1_CONFIGURATION 0x32C | ||
130 | #define WM8996_AIF2RX_MONO_CONFIGURATION 0x32D | ||
131 | #define WM8996_AIF2TX_TEST 0x32F | ||
132 | #define WM8996_DSP1_TX_LEFT_VOLUME 0x400 | ||
133 | #define WM8996_DSP1_TX_RIGHT_VOLUME 0x401 | ||
134 | #define WM8996_DSP1_RX_LEFT_VOLUME 0x402 | ||
135 | #define WM8996_DSP1_RX_RIGHT_VOLUME 0x403 | ||
136 | #define WM8996_DSP1_TX_FILTERS 0x410 | ||
137 | #define WM8996_DSP1_RX_FILTERS_1 0x420 | ||
138 | #define WM8996_DSP1_RX_FILTERS_2 0x421 | ||
139 | #define WM8996_DSP1_DRC_1 0x440 | ||
140 | #define WM8996_DSP1_DRC_2 0x441 | ||
141 | #define WM8996_DSP1_DRC_3 0x442 | ||
142 | #define WM8996_DSP1_DRC_4 0x443 | ||
143 | #define WM8996_DSP1_DRC_5 0x444 | ||
144 | #define WM8996_DSP1_RX_EQ_GAINS_1 0x480 | ||
145 | #define WM8996_DSP1_RX_EQ_GAINS_2 0x481 | ||
146 | #define WM8996_DSP1_RX_EQ_BAND_1_A 0x482 | ||
147 | #define WM8996_DSP1_RX_EQ_BAND_1_B 0x483 | ||
148 | #define WM8996_DSP1_RX_EQ_BAND_1_PG 0x484 | ||
149 | #define WM8996_DSP1_RX_EQ_BAND_2_A 0x485 | ||
150 | #define WM8996_DSP1_RX_EQ_BAND_2_B 0x486 | ||
151 | #define WM8996_DSP1_RX_EQ_BAND_2_C 0x487 | ||
152 | #define WM8996_DSP1_RX_EQ_BAND_2_PG 0x488 | ||
153 | #define WM8996_DSP1_RX_EQ_BAND_3_A 0x489 | ||
154 | #define WM8996_DSP1_RX_EQ_BAND_3_B 0x48A | ||
155 | #define WM8996_DSP1_RX_EQ_BAND_3_C 0x48B | ||
156 | #define WM8996_DSP1_RX_EQ_BAND_3_PG 0x48C | ||
157 | #define WM8996_DSP1_RX_EQ_BAND_4_A 0x48D | ||
158 | #define WM8996_DSP1_RX_EQ_BAND_4_B 0x48E | ||
159 | #define WM8996_DSP1_RX_EQ_BAND_4_C 0x48F | ||
160 | #define WM8996_DSP1_RX_EQ_BAND_4_PG 0x490 | ||
161 | #define WM8996_DSP1_RX_EQ_BAND_5_A 0x491 | ||
162 | #define WM8996_DSP1_RX_EQ_BAND_5_B 0x492 | ||
163 | #define WM8996_DSP1_RX_EQ_BAND_5_PG 0x493 | ||
164 | #define WM8996_DSP2_TX_LEFT_VOLUME 0x500 | ||
165 | #define WM8996_DSP2_TX_RIGHT_VOLUME 0x501 | ||
166 | #define WM8996_DSP2_RX_LEFT_VOLUME 0x502 | ||
167 | #define WM8996_DSP2_RX_RIGHT_VOLUME 0x503 | ||
168 | #define WM8996_DSP2_TX_FILTERS 0x510 | ||
169 | #define WM8996_DSP2_RX_FILTERS_1 0x520 | ||
170 | #define WM8996_DSP2_RX_FILTERS_2 0x521 | ||
171 | #define WM8996_DSP2_DRC_1 0x540 | ||
172 | #define WM8996_DSP2_DRC_2 0x541 | ||
173 | #define WM8996_DSP2_DRC_3 0x542 | ||
174 | #define WM8996_DSP2_DRC_4 0x543 | ||
175 | #define WM8996_DSP2_DRC_5 0x544 | ||
176 | #define WM8996_DSP2_RX_EQ_GAINS_1 0x580 | ||
177 | #define WM8996_DSP2_RX_EQ_GAINS_2 0x581 | ||
178 | #define WM8996_DSP2_RX_EQ_BAND_1_A 0x582 | ||
179 | #define WM8996_DSP2_RX_EQ_BAND_1_B 0x583 | ||
180 | #define WM8996_DSP2_RX_EQ_BAND_1_PG 0x584 | ||
181 | #define WM8996_DSP2_RX_EQ_BAND_2_A 0x585 | ||
182 | #define WM8996_DSP2_RX_EQ_BAND_2_B 0x586 | ||
183 | #define WM8996_DSP2_RX_EQ_BAND_2_C 0x587 | ||
184 | #define WM8996_DSP2_RX_EQ_BAND_2_PG 0x588 | ||
185 | #define WM8996_DSP2_RX_EQ_BAND_3_A 0x589 | ||
186 | #define WM8996_DSP2_RX_EQ_BAND_3_B 0x58A | ||
187 | #define WM8996_DSP2_RX_EQ_BAND_3_C 0x58B | ||
188 | #define WM8996_DSP2_RX_EQ_BAND_3_PG 0x58C | ||
189 | #define WM8996_DSP2_RX_EQ_BAND_4_A 0x58D | ||
190 | #define WM8996_DSP2_RX_EQ_BAND_4_B 0x58E | ||
191 | #define WM8996_DSP2_RX_EQ_BAND_4_C 0x58F | ||
192 | #define WM8996_DSP2_RX_EQ_BAND_4_PG 0x590 | ||
193 | #define WM8996_DSP2_RX_EQ_BAND_5_A 0x591 | ||
194 | #define WM8996_DSP2_RX_EQ_BAND_5_B 0x592 | ||
195 | #define WM8996_DSP2_RX_EQ_BAND_5_PG 0x593 | ||
196 | #define WM8996_DAC1_MIXER_VOLUMES 0x600 | ||
197 | #define WM8996_DAC1_LEFT_MIXER_ROUTING 0x601 | ||
198 | #define WM8996_DAC1_RIGHT_MIXER_ROUTING 0x602 | ||
199 | #define WM8996_DAC2_MIXER_VOLUMES 0x603 | ||
200 | #define WM8996_DAC2_LEFT_MIXER_ROUTING 0x604 | ||
201 | #define WM8996_DAC2_RIGHT_MIXER_ROUTING 0x605 | ||
202 | #define WM8996_DSP1_TX_LEFT_MIXER_ROUTING 0x606 | ||
203 | #define WM8996_DSP1_TX_RIGHT_MIXER_ROUTING 0x607 | ||
204 | #define WM8996_DSP2_TX_LEFT_MIXER_ROUTING 0x608 | ||
205 | #define WM8996_DSP2_TX_RIGHT_MIXER_ROUTING 0x609 | ||
206 | #define WM8996_DSP_TX_MIXER_SELECT 0x60A | ||
207 | #define WM8996_DAC_SOFTMUTE 0x610 | ||
208 | #define WM8996_OVERSAMPLING 0x620 | ||
209 | #define WM8996_SIDETONE 0x621 | ||
210 | #define WM8996_GPIO_1 0x700 | ||
211 | #define WM8996_GPIO_2 0x701 | ||
212 | #define WM8996_GPIO_3 0x702 | ||
213 | #define WM8996_GPIO_4 0x703 | ||
214 | #define WM8996_GPIO_5 0x704 | ||
215 | #define WM8996_PULL_CONTROL_1 0x720 | ||
216 | #define WM8996_PULL_CONTROL_2 0x721 | ||
217 | #define WM8996_INTERRUPT_STATUS_1 0x730 | ||
218 | #define WM8996_INTERRUPT_STATUS_2 0x731 | ||
219 | #define WM8996_INTERRUPT_RAW_STATUS_2 0x732 | ||
220 | #define WM8996_INTERRUPT_STATUS_1_MASK 0x738 | ||
221 | #define WM8996_INTERRUPT_STATUS_2_MASK 0x739 | ||
222 | #define WM8996_INTERRUPT_CONTROL 0x740 | ||
223 | #define WM8996_LEFT_PDM_SPEAKER 0x800 | ||
224 | #define WM8996_RIGHT_PDM_SPEAKER 0x801 | ||
225 | #define WM8996_PDM_SPEAKER_MUTE_SEQUENCE 0x802 | ||
226 | #define WM8996_PDM_SPEAKER_VOLUME 0x803 | ||
227 | #define WM8996_WRITE_SEQUENCER_0 0x3000 | ||
228 | #define WM8996_WRITE_SEQUENCER_1 0x3001 | ||
229 | #define WM8996_WRITE_SEQUENCER_2 0x3002 | ||
230 | #define WM8996_WRITE_SEQUENCER_3 0x3003 | ||
231 | #define WM8996_WRITE_SEQUENCER_4 0x3004 | ||
232 | #define WM8996_WRITE_SEQUENCER_5 0x3005 | ||
233 | #define WM8996_WRITE_SEQUENCER_6 0x3006 | ||
234 | #define WM8996_WRITE_SEQUENCER_7 0x3007 | ||
235 | #define WM8996_WRITE_SEQUENCER_8 0x3008 | ||
236 | #define WM8996_WRITE_SEQUENCER_9 0x3009 | ||
237 | #define WM8996_WRITE_SEQUENCER_10 0x300A | ||
238 | #define WM8996_WRITE_SEQUENCER_11 0x300B | ||
239 | #define WM8996_WRITE_SEQUENCER_12 0x300C | ||
240 | #define WM8996_WRITE_SEQUENCER_13 0x300D | ||
241 | #define WM8996_WRITE_SEQUENCER_14 0x300E | ||
242 | #define WM8996_WRITE_SEQUENCER_15 0x300F | ||
243 | #define WM8996_WRITE_SEQUENCER_16 0x3010 | ||
244 | #define WM8996_WRITE_SEQUENCER_17 0x3011 | ||
245 | #define WM8996_WRITE_SEQUENCER_18 0x3012 | ||
246 | #define WM8996_WRITE_SEQUENCER_19 0x3013 | ||
247 | #define WM8996_WRITE_SEQUENCER_20 0x3014 | ||
248 | #define WM8996_WRITE_SEQUENCER_21 0x3015 | ||
249 | #define WM8996_WRITE_SEQUENCER_22 0x3016 | ||
250 | #define WM8996_WRITE_SEQUENCER_23 0x3017 | ||
251 | #define WM8996_WRITE_SEQUENCER_24 0x3018 | ||
252 | #define WM8996_WRITE_SEQUENCER_25 0x3019 | ||
253 | #define WM8996_WRITE_SEQUENCER_26 0x301A | ||
254 | #define WM8996_WRITE_SEQUENCER_27 0x301B | ||
255 | #define WM8996_WRITE_SEQUENCER_28 0x301C | ||
256 | #define WM8996_WRITE_SEQUENCER_29 0x301D | ||
257 | #define WM8996_WRITE_SEQUENCER_30 0x301E | ||
258 | #define WM8996_WRITE_SEQUENCER_31 0x301F | ||
259 | #define WM8996_WRITE_SEQUENCER_32 0x3020 | ||
260 | #define WM8996_WRITE_SEQUENCER_33 0x3021 | ||
261 | #define WM8996_WRITE_SEQUENCER_34 0x3022 | ||
262 | #define WM8996_WRITE_SEQUENCER_35 0x3023 | ||
263 | #define WM8996_WRITE_SEQUENCER_36 0x3024 | ||
264 | #define WM8996_WRITE_SEQUENCER_37 0x3025 | ||
265 | #define WM8996_WRITE_SEQUENCER_38 0x3026 | ||
266 | #define WM8996_WRITE_SEQUENCER_39 0x3027 | ||
267 | #define WM8996_WRITE_SEQUENCER_40 0x3028 | ||
268 | #define WM8996_WRITE_SEQUENCER_41 0x3029 | ||
269 | #define WM8996_WRITE_SEQUENCER_42 0x302A | ||
270 | #define WM8996_WRITE_SEQUENCER_43 0x302B | ||
271 | #define WM8996_WRITE_SEQUENCER_44 0x302C | ||
272 | #define WM8996_WRITE_SEQUENCER_45 0x302D | ||
273 | #define WM8996_WRITE_SEQUENCER_46 0x302E | ||
274 | #define WM8996_WRITE_SEQUENCER_47 0x302F | ||
275 | #define WM8996_WRITE_SEQUENCER_48 0x3030 | ||
276 | #define WM8996_WRITE_SEQUENCER_49 0x3031 | ||
277 | #define WM8996_WRITE_SEQUENCER_50 0x3032 | ||
278 | #define WM8996_WRITE_SEQUENCER_51 0x3033 | ||
279 | #define WM8996_WRITE_SEQUENCER_52 0x3034 | ||
280 | #define WM8996_WRITE_SEQUENCER_53 0x3035 | ||
281 | #define WM8996_WRITE_SEQUENCER_54 0x3036 | ||
282 | #define WM8996_WRITE_SEQUENCER_55 0x3037 | ||
283 | #define WM8996_WRITE_SEQUENCER_56 0x3038 | ||
284 | #define WM8996_WRITE_SEQUENCER_57 0x3039 | ||
285 | #define WM8996_WRITE_SEQUENCER_58 0x303A | ||
286 | #define WM8996_WRITE_SEQUENCER_59 0x303B | ||
287 | #define WM8996_WRITE_SEQUENCER_60 0x303C | ||
288 | #define WM8996_WRITE_SEQUENCER_61 0x303D | ||
289 | #define WM8996_WRITE_SEQUENCER_62 0x303E | ||
290 | #define WM8996_WRITE_SEQUENCER_63 0x303F | ||
291 | #define WM8996_WRITE_SEQUENCER_64 0x3040 | ||
292 | #define WM8996_WRITE_SEQUENCER_65 0x3041 | ||
293 | #define WM8996_WRITE_SEQUENCER_66 0x3042 | ||
294 | #define WM8996_WRITE_SEQUENCER_67 0x3043 | ||
295 | #define WM8996_WRITE_SEQUENCER_68 0x3044 | ||
296 | #define WM8996_WRITE_SEQUENCER_69 0x3045 | ||
297 | #define WM8996_WRITE_SEQUENCER_70 0x3046 | ||
298 | #define WM8996_WRITE_SEQUENCER_71 0x3047 | ||
299 | #define WM8996_WRITE_SEQUENCER_72 0x3048 | ||
300 | #define WM8996_WRITE_SEQUENCER_73 0x3049 | ||
301 | #define WM8996_WRITE_SEQUENCER_74 0x304A | ||
302 | #define WM8996_WRITE_SEQUENCER_75 0x304B | ||
303 | #define WM8996_WRITE_SEQUENCER_76 0x304C | ||
304 | #define WM8996_WRITE_SEQUENCER_77 0x304D | ||
305 | #define WM8996_WRITE_SEQUENCER_78 0x304E | ||
306 | #define WM8996_WRITE_SEQUENCER_79 0x304F | ||
307 | #define WM8996_WRITE_SEQUENCER_80 0x3050 | ||
308 | #define WM8996_WRITE_SEQUENCER_81 0x3051 | ||
309 | #define WM8996_WRITE_SEQUENCER_82 0x3052 | ||
310 | #define WM8996_WRITE_SEQUENCER_83 0x3053 | ||
311 | #define WM8996_WRITE_SEQUENCER_84 0x3054 | ||
312 | #define WM8996_WRITE_SEQUENCER_85 0x3055 | ||
313 | #define WM8996_WRITE_SEQUENCER_86 0x3056 | ||
314 | #define WM8996_WRITE_SEQUENCER_87 0x3057 | ||
315 | #define WM8996_WRITE_SEQUENCER_88 0x3058 | ||
316 | #define WM8996_WRITE_SEQUENCER_89 0x3059 | ||
317 | #define WM8996_WRITE_SEQUENCER_90 0x305A | ||
318 | #define WM8996_WRITE_SEQUENCER_91 0x305B | ||
319 | #define WM8996_WRITE_SEQUENCER_92 0x305C | ||
320 | #define WM8996_WRITE_SEQUENCER_93 0x305D | ||
321 | #define WM8996_WRITE_SEQUENCER_94 0x305E | ||
322 | #define WM8996_WRITE_SEQUENCER_95 0x305F | ||
323 | #define WM8996_WRITE_SEQUENCER_96 0x3060 | ||
324 | #define WM8996_WRITE_SEQUENCER_97 0x3061 | ||
325 | #define WM8996_WRITE_SEQUENCER_98 0x3062 | ||
326 | #define WM8996_WRITE_SEQUENCER_99 0x3063 | ||
327 | #define WM8996_WRITE_SEQUENCER_100 0x3064 | ||
328 | #define WM8996_WRITE_SEQUENCER_101 0x3065 | ||
329 | #define WM8996_WRITE_SEQUENCER_102 0x3066 | ||
330 | #define WM8996_WRITE_SEQUENCER_103 0x3067 | ||
331 | #define WM8996_WRITE_SEQUENCER_104 0x3068 | ||
332 | #define WM8996_WRITE_SEQUENCER_105 0x3069 | ||
333 | #define WM8996_WRITE_SEQUENCER_106 0x306A | ||
334 | #define WM8996_WRITE_SEQUENCER_107 0x306B | ||
335 | #define WM8996_WRITE_SEQUENCER_108 0x306C | ||
336 | #define WM8996_WRITE_SEQUENCER_109 0x306D | ||
337 | #define WM8996_WRITE_SEQUENCER_110 0x306E | ||
338 | #define WM8996_WRITE_SEQUENCER_111 0x306F | ||
339 | #define WM8996_WRITE_SEQUENCER_112 0x3070 | ||
340 | #define WM8996_WRITE_SEQUENCER_113 0x3071 | ||
341 | #define WM8996_WRITE_SEQUENCER_114 0x3072 | ||
342 | #define WM8996_WRITE_SEQUENCER_115 0x3073 | ||
343 | #define WM8996_WRITE_SEQUENCER_116 0x3074 | ||
344 | #define WM8996_WRITE_SEQUENCER_117 0x3075 | ||
345 | #define WM8996_WRITE_SEQUENCER_118 0x3076 | ||
346 | #define WM8996_WRITE_SEQUENCER_119 0x3077 | ||
347 | #define WM8996_WRITE_SEQUENCER_120 0x3078 | ||
348 | #define WM8996_WRITE_SEQUENCER_121 0x3079 | ||
349 | #define WM8996_WRITE_SEQUENCER_122 0x307A | ||
350 | #define WM8996_WRITE_SEQUENCER_123 0x307B | ||
351 | #define WM8996_WRITE_SEQUENCER_124 0x307C | ||
352 | #define WM8996_WRITE_SEQUENCER_125 0x307D | ||
353 | #define WM8996_WRITE_SEQUENCER_126 0x307E | ||
354 | #define WM8996_WRITE_SEQUENCER_127 0x307F | ||
355 | #define WM8996_WRITE_SEQUENCER_128 0x3080 | ||
356 | #define WM8996_WRITE_SEQUENCER_129 0x3081 | ||
357 | #define WM8996_WRITE_SEQUENCER_130 0x3082 | ||
358 | #define WM8996_WRITE_SEQUENCER_131 0x3083 | ||
359 | #define WM8996_WRITE_SEQUENCER_132 0x3084 | ||
360 | #define WM8996_WRITE_SEQUENCER_133 0x3085 | ||
361 | #define WM8996_WRITE_SEQUENCER_134 0x3086 | ||
362 | #define WM8996_WRITE_SEQUENCER_135 0x3087 | ||
363 | #define WM8996_WRITE_SEQUENCER_136 0x3088 | ||
364 | #define WM8996_WRITE_SEQUENCER_137 0x3089 | ||
365 | #define WM8996_WRITE_SEQUENCER_138 0x308A | ||
366 | #define WM8996_WRITE_SEQUENCER_139 0x308B | ||
367 | #define WM8996_WRITE_SEQUENCER_140 0x308C | ||
368 | #define WM8996_WRITE_SEQUENCER_141 0x308D | ||
369 | #define WM8996_WRITE_SEQUENCER_142 0x308E | ||
370 | #define WM8996_WRITE_SEQUENCER_143 0x308F | ||
371 | #define WM8996_WRITE_SEQUENCER_144 0x3090 | ||
372 | #define WM8996_WRITE_SEQUENCER_145 0x3091 | ||
373 | #define WM8996_WRITE_SEQUENCER_146 0x3092 | ||
374 | #define WM8996_WRITE_SEQUENCER_147 0x3093 | ||
375 | #define WM8996_WRITE_SEQUENCER_148 0x3094 | ||
376 | #define WM8996_WRITE_SEQUENCER_149 0x3095 | ||
377 | #define WM8996_WRITE_SEQUENCER_150 0x3096 | ||
378 | #define WM8996_WRITE_SEQUENCER_151 0x3097 | ||
379 | #define WM8996_WRITE_SEQUENCER_152 0x3098 | ||
380 | #define WM8996_WRITE_SEQUENCER_153 0x3099 | ||
381 | #define WM8996_WRITE_SEQUENCER_154 0x309A | ||
382 | #define WM8996_WRITE_SEQUENCER_155 0x309B | ||
383 | #define WM8996_WRITE_SEQUENCER_156 0x309C | ||
384 | #define WM8996_WRITE_SEQUENCER_157 0x309D | ||
385 | #define WM8996_WRITE_SEQUENCER_158 0x309E | ||
386 | #define WM8996_WRITE_SEQUENCER_159 0x309F | ||
387 | #define WM8996_WRITE_SEQUENCER_160 0x30A0 | ||
388 | #define WM8996_WRITE_SEQUENCER_161 0x30A1 | ||
389 | #define WM8996_WRITE_SEQUENCER_162 0x30A2 | ||
390 | #define WM8996_WRITE_SEQUENCER_163 0x30A3 | ||
391 | #define WM8996_WRITE_SEQUENCER_164 0x30A4 | ||
392 | #define WM8996_WRITE_SEQUENCER_165 0x30A5 | ||
393 | #define WM8996_WRITE_SEQUENCER_166 0x30A6 | ||
394 | #define WM8996_WRITE_SEQUENCER_167 0x30A7 | ||
395 | #define WM8996_WRITE_SEQUENCER_168 0x30A8 | ||
396 | #define WM8996_WRITE_SEQUENCER_169 0x30A9 | ||
397 | #define WM8996_WRITE_SEQUENCER_170 0x30AA | ||
398 | #define WM8996_WRITE_SEQUENCER_171 0x30AB | ||
399 | #define WM8996_WRITE_SEQUENCER_172 0x30AC | ||
400 | #define WM8996_WRITE_SEQUENCER_173 0x30AD | ||
401 | #define WM8996_WRITE_SEQUENCER_174 0x30AE | ||
402 | #define WM8996_WRITE_SEQUENCER_175 0x30AF | ||
403 | #define WM8996_WRITE_SEQUENCER_176 0x30B0 | ||
404 | #define WM8996_WRITE_SEQUENCER_177 0x30B1 | ||
405 | #define WM8996_WRITE_SEQUENCER_178 0x30B2 | ||
406 | #define WM8996_WRITE_SEQUENCER_179 0x30B3 | ||
407 | #define WM8996_WRITE_SEQUENCER_180 0x30B4 | ||
408 | #define WM8996_WRITE_SEQUENCER_181 0x30B5 | ||
409 | #define WM8996_WRITE_SEQUENCER_182 0x30B6 | ||
410 | #define WM8996_WRITE_SEQUENCER_183 0x30B7 | ||
411 | #define WM8996_WRITE_SEQUENCER_184 0x30B8 | ||
412 | #define WM8996_WRITE_SEQUENCER_185 0x30B9 | ||
413 | #define WM8996_WRITE_SEQUENCER_186 0x30BA | ||
414 | #define WM8996_WRITE_SEQUENCER_187 0x30BB | ||
415 | #define WM8996_WRITE_SEQUENCER_188 0x30BC | ||
416 | #define WM8996_WRITE_SEQUENCER_189 0x30BD | ||
417 | #define WM8996_WRITE_SEQUENCER_190 0x30BE | ||
418 | #define WM8996_WRITE_SEQUENCER_191 0x30BF | ||
419 | #define WM8996_WRITE_SEQUENCER_192 0x30C0 | ||
420 | #define WM8996_WRITE_SEQUENCER_193 0x30C1 | ||
421 | #define WM8996_WRITE_SEQUENCER_194 0x30C2 | ||
422 | #define WM8996_WRITE_SEQUENCER_195 0x30C3 | ||
423 | #define WM8996_WRITE_SEQUENCER_196 0x30C4 | ||
424 | #define WM8996_WRITE_SEQUENCER_197 0x30C5 | ||
425 | #define WM8996_WRITE_SEQUENCER_198 0x30C6 | ||
426 | #define WM8996_WRITE_SEQUENCER_199 0x30C7 | ||
427 | #define WM8996_WRITE_SEQUENCER_200 0x30C8 | ||
428 | #define WM8996_WRITE_SEQUENCER_201 0x30C9 | ||
429 | #define WM8996_WRITE_SEQUENCER_202 0x30CA | ||
430 | #define WM8996_WRITE_SEQUENCER_203 0x30CB | ||
431 | #define WM8996_WRITE_SEQUENCER_204 0x30CC | ||
432 | #define WM8996_WRITE_SEQUENCER_205 0x30CD | ||
433 | #define WM8996_WRITE_SEQUENCER_206 0x30CE | ||
434 | #define WM8996_WRITE_SEQUENCER_207 0x30CF | ||
435 | #define WM8996_WRITE_SEQUENCER_208 0x30D0 | ||
436 | #define WM8996_WRITE_SEQUENCER_209 0x30D1 | ||
437 | #define WM8996_WRITE_SEQUENCER_210 0x30D2 | ||
438 | #define WM8996_WRITE_SEQUENCER_211 0x30D3 | ||
439 | #define WM8996_WRITE_SEQUENCER_212 0x30D4 | ||
440 | #define WM8996_WRITE_SEQUENCER_213 0x30D5 | ||
441 | #define WM8996_WRITE_SEQUENCER_214 0x30D6 | ||
442 | #define WM8996_WRITE_SEQUENCER_215 0x30D7 | ||
443 | #define WM8996_WRITE_SEQUENCER_216 0x30D8 | ||
444 | #define WM8996_WRITE_SEQUENCER_217 0x30D9 | ||
445 | #define WM8996_WRITE_SEQUENCER_218 0x30DA | ||
446 | #define WM8996_WRITE_SEQUENCER_219 0x30DB | ||
447 | #define WM8996_WRITE_SEQUENCER_220 0x30DC | ||
448 | #define WM8996_WRITE_SEQUENCER_221 0x30DD | ||
449 | #define WM8996_WRITE_SEQUENCER_222 0x30DE | ||
450 | #define WM8996_WRITE_SEQUENCER_223 0x30DF | ||
451 | #define WM8996_WRITE_SEQUENCER_224 0x30E0 | ||
452 | #define WM8996_WRITE_SEQUENCER_225 0x30E1 | ||
453 | #define WM8996_WRITE_SEQUENCER_226 0x30E2 | ||
454 | #define WM8996_WRITE_SEQUENCER_227 0x30E3 | ||
455 | #define WM8996_WRITE_SEQUENCER_228 0x30E4 | ||
456 | #define WM8996_WRITE_SEQUENCER_229 0x30E5 | ||
457 | #define WM8996_WRITE_SEQUENCER_230 0x30E6 | ||
458 | #define WM8996_WRITE_SEQUENCER_231 0x30E7 | ||
459 | #define WM8996_WRITE_SEQUENCER_232 0x30E8 | ||
460 | #define WM8996_WRITE_SEQUENCER_233 0x30E9 | ||
461 | #define WM8996_WRITE_SEQUENCER_234 0x30EA | ||
462 | #define WM8996_WRITE_SEQUENCER_235 0x30EB | ||
463 | #define WM8996_WRITE_SEQUENCER_236 0x30EC | ||
464 | #define WM8996_WRITE_SEQUENCER_237 0x30ED | ||
465 | #define WM8996_WRITE_SEQUENCER_238 0x30EE | ||
466 | #define WM8996_WRITE_SEQUENCER_239 0x30EF | ||
467 | #define WM8996_WRITE_SEQUENCER_240 0x30F0 | ||
468 | #define WM8996_WRITE_SEQUENCER_241 0x30F1 | ||
469 | #define WM8996_WRITE_SEQUENCER_242 0x30F2 | ||
470 | #define WM8996_WRITE_SEQUENCER_243 0x30F3 | ||
471 | #define WM8996_WRITE_SEQUENCER_244 0x30F4 | ||
472 | #define WM8996_WRITE_SEQUENCER_245 0x30F5 | ||
473 | #define WM8996_WRITE_SEQUENCER_246 0x30F6 | ||
474 | #define WM8996_WRITE_SEQUENCER_247 0x30F7 | ||
475 | #define WM8996_WRITE_SEQUENCER_248 0x30F8 | ||
476 | #define WM8996_WRITE_SEQUENCER_249 0x30F9 | ||
477 | #define WM8996_WRITE_SEQUENCER_250 0x30FA | ||
478 | #define WM8996_WRITE_SEQUENCER_251 0x30FB | ||
479 | #define WM8996_WRITE_SEQUENCER_252 0x30FC | ||
480 | #define WM8996_WRITE_SEQUENCER_253 0x30FD | ||
481 | #define WM8996_WRITE_SEQUENCER_254 0x30FE | ||
482 | #define WM8996_WRITE_SEQUENCER_255 0x30FF | ||
483 | #define WM8996_WRITE_SEQUENCER_256 0x3100 | ||
484 | #define WM8996_WRITE_SEQUENCER_257 0x3101 | ||
485 | #define WM8996_WRITE_SEQUENCER_258 0x3102 | ||
486 | #define WM8996_WRITE_SEQUENCER_259 0x3103 | ||
487 | #define WM8996_WRITE_SEQUENCER_260 0x3104 | ||
488 | #define WM8996_WRITE_SEQUENCER_261 0x3105 | ||
489 | #define WM8996_WRITE_SEQUENCER_262 0x3106 | ||
490 | #define WM8996_WRITE_SEQUENCER_263 0x3107 | ||
491 | #define WM8996_WRITE_SEQUENCER_264 0x3108 | ||
492 | #define WM8996_WRITE_SEQUENCER_265 0x3109 | ||
493 | #define WM8996_WRITE_SEQUENCER_266 0x310A | ||
494 | #define WM8996_WRITE_SEQUENCER_267 0x310B | ||
495 | #define WM8996_WRITE_SEQUENCER_268 0x310C | ||
496 | #define WM8996_WRITE_SEQUENCER_269 0x310D | ||
497 | #define WM8996_WRITE_SEQUENCER_270 0x310E | ||
498 | #define WM8996_WRITE_SEQUENCER_271 0x310F | ||
499 | #define WM8996_WRITE_SEQUENCER_272 0x3110 | ||
500 | #define WM8996_WRITE_SEQUENCER_273 0x3111 | ||
501 | #define WM8996_WRITE_SEQUENCER_274 0x3112 | ||
502 | #define WM8996_WRITE_SEQUENCER_275 0x3113 | ||
503 | #define WM8996_WRITE_SEQUENCER_276 0x3114 | ||
504 | #define WM8996_WRITE_SEQUENCER_277 0x3115 | ||
505 | #define WM8996_WRITE_SEQUENCER_278 0x3116 | ||
506 | #define WM8996_WRITE_SEQUENCER_279 0x3117 | ||
507 | #define WM8996_WRITE_SEQUENCER_280 0x3118 | ||
508 | #define WM8996_WRITE_SEQUENCER_281 0x3119 | ||
509 | #define WM8996_WRITE_SEQUENCER_282 0x311A | ||
510 | #define WM8996_WRITE_SEQUENCER_283 0x311B | ||
511 | #define WM8996_WRITE_SEQUENCER_284 0x311C | ||
512 | #define WM8996_WRITE_SEQUENCER_285 0x311D | ||
513 | #define WM8996_WRITE_SEQUENCER_286 0x311E | ||
514 | #define WM8996_WRITE_SEQUENCER_287 0x311F | ||
515 | #define WM8996_WRITE_SEQUENCER_288 0x3120 | ||
516 | #define WM8996_WRITE_SEQUENCER_289 0x3121 | ||
517 | #define WM8996_WRITE_SEQUENCER_290 0x3122 | ||
518 | #define WM8996_WRITE_SEQUENCER_291 0x3123 | ||
519 | #define WM8996_WRITE_SEQUENCER_292 0x3124 | ||
520 | #define WM8996_WRITE_SEQUENCER_293 0x3125 | ||
521 | #define WM8996_WRITE_SEQUENCER_294 0x3126 | ||
522 | #define WM8996_WRITE_SEQUENCER_295 0x3127 | ||
523 | #define WM8996_WRITE_SEQUENCER_296 0x3128 | ||
524 | #define WM8996_WRITE_SEQUENCER_297 0x3129 | ||
525 | #define WM8996_WRITE_SEQUENCER_298 0x312A | ||
526 | #define WM8996_WRITE_SEQUENCER_299 0x312B | ||
527 | #define WM8996_WRITE_SEQUENCER_300 0x312C | ||
528 | #define WM8996_WRITE_SEQUENCER_301 0x312D | ||
529 | #define WM8996_WRITE_SEQUENCER_302 0x312E | ||
530 | #define WM8996_WRITE_SEQUENCER_303 0x312F | ||
531 | #define WM8996_WRITE_SEQUENCER_304 0x3130 | ||
532 | #define WM8996_WRITE_SEQUENCER_305 0x3131 | ||
533 | #define WM8996_WRITE_SEQUENCER_306 0x3132 | ||
534 | #define WM8996_WRITE_SEQUENCER_307 0x3133 | ||
535 | #define WM8996_WRITE_SEQUENCER_308 0x3134 | ||
536 | #define WM8996_WRITE_SEQUENCER_309 0x3135 | ||
537 | #define WM8996_WRITE_SEQUENCER_310 0x3136 | ||
538 | #define WM8996_WRITE_SEQUENCER_311 0x3137 | ||
539 | #define WM8996_WRITE_SEQUENCER_312 0x3138 | ||
540 | #define WM8996_WRITE_SEQUENCER_313 0x3139 | ||
541 | #define WM8996_WRITE_SEQUENCER_314 0x313A | ||
542 | #define WM8996_WRITE_SEQUENCER_315 0x313B | ||
543 | #define WM8996_WRITE_SEQUENCER_316 0x313C | ||
544 | #define WM8996_WRITE_SEQUENCER_317 0x313D | ||
545 | #define WM8996_WRITE_SEQUENCER_318 0x313E | ||
546 | #define WM8996_WRITE_SEQUENCER_319 0x313F | ||
547 | #define WM8996_WRITE_SEQUENCER_320 0x3140 | ||
548 | #define WM8996_WRITE_SEQUENCER_321 0x3141 | ||
549 | #define WM8996_WRITE_SEQUENCER_322 0x3142 | ||
550 | #define WM8996_WRITE_SEQUENCER_323 0x3143 | ||
551 | #define WM8996_WRITE_SEQUENCER_324 0x3144 | ||
552 | #define WM8996_WRITE_SEQUENCER_325 0x3145 | ||
553 | #define WM8996_WRITE_SEQUENCER_326 0x3146 | ||
554 | #define WM8996_WRITE_SEQUENCER_327 0x3147 | ||
555 | #define WM8996_WRITE_SEQUENCER_328 0x3148 | ||
556 | #define WM8996_WRITE_SEQUENCER_329 0x3149 | ||
557 | #define WM8996_WRITE_SEQUENCER_330 0x314A | ||
558 | #define WM8996_WRITE_SEQUENCER_331 0x314B | ||
559 | #define WM8996_WRITE_SEQUENCER_332 0x314C | ||
560 | #define WM8996_WRITE_SEQUENCER_333 0x314D | ||
561 | #define WM8996_WRITE_SEQUENCER_334 0x314E | ||
562 | #define WM8996_WRITE_SEQUENCER_335 0x314F | ||
563 | #define WM8996_WRITE_SEQUENCER_336 0x3150 | ||
564 | #define WM8996_WRITE_SEQUENCER_337 0x3151 | ||
565 | #define WM8996_WRITE_SEQUENCER_338 0x3152 | ||
566 | #define WM8996_WRITE_SEQUENCER_339 0x3153 | ||
567 | #define WM8996_WRITE_SEQUENCER_340 0x3154 | ||
568 | #define WM8996_WRITE_SEQUENCER_341 0x3155 | ||
569 | #define WM8996_WRITE_SEQUENCER_342 0x3156 | ||
570 | #define WM8996_WRITE_SEQUENCER_343 0x3157 | ||
571 | #define WM8996_WRITE_SEQUENCER_344 0x3158 | ||
572 | #define WM8996_WRITE_SEQUENCER_345 0x3159 | ||
573 | #define WM8996_WRITE_SEQUENCER_346 0x315A | ||
574 | #define WM8996_WRITE_SEQUENCER_347 0x315B | ||
575 | #define WM8996_WRITE_SEQUENCER_348 0x315C | ||
576 | #define WM8996_WRITE_SEQUENCER_349 0x315D | ||
577 | #define WM8996_WRITE_SEQUENCER_350 0x315E | ||
578 | #define WM8996_WRITE_SEQUENCER_351 0x315F | ||
579 | #define WM8996_WRITE_SEQUENCER_352 0x3160 | ||
580 | #define WM8996_WRITE_SEQUENCER_353 0x3161 | ||
581 | #define WM8996_WRITE_SEQUENCER_354 0x3162 | ||
582 | #define WM8996_WRITE_SEQUENCER_355 0x3163 | ||
583 | #define WM8996_WRITE_SEQUENCER_356 0x3164 | ||
584 | #define WM8996_WRITE_SEQUENCER_357 0x3165 | ||
585 | #define WM8996_WRITE_SEQUENCER_358 0x3166 | ||
586 | #define WM8996_WRITE_SEQUENCER_359 0x3167 | ||
587 | #define WM8996_WRITE_SEQUENCER_360 0x3168 | ||
588 | #define WM8996_WRITE_SEQUENCER_361 0x3169 | ||
589 | #define WM8996_WRITE_SEQUENCER_362 0x316A | ||
590 | #define WM8996_WRITE_SEQUENCER_363 0x316B | ||
591 | #define WM8996_WRITE_SEQUENCER_364 0x316C | ||
592 | #define WM8996_WRITE_SEQUENCER_365 0x316D | ||
593 | #define WM8996_WRITE_SEQUENCER_366 0x316E | ||
594 | #define WM8996_WRITE_SEQUENCER_367 0x316F | ||
595 | #define WM8996_WRITE_SEQUENCER_368 0x3170 | ||
596 | #define WM8996_WRITE_SEQUENCER_369 0x3171 | ||
597 | #define WM8996_WRITE_SEQUENCER_370 0x3172 | ||
598 | #define WM8996_WRITE_SEQUENCER_371 0x3173 | ||
599 | #define WM8996_WRITE_SEQUENCER_372 0x3174 | ||
600 | #define WM8996_WRITE_SEQUENCER_373 0x3175 | ||
601 | #define WM8996_WRITE_SEQUENCER_374 0x3176 | ||
602 | #define WM8996_WRITE_SEQUENCER_375 0x3177 | ||
603 | #define WM8996_WRITE_SEQUENCER_376 0x3178 | ||
604 | #define WM8996_WRITE_SEQUENCER_377 0x3179 | ||
605 | #define WM8996_WRITE_SEQUENCER_378 0x317A | ||
606 | #define WM8996_WRITE_SEQUENCER_379 0x317B | ||
607 | #define WM8996_WRITE_SEQUENCER_380 0x317C | ||
608 | #define WM8996_WRITE_SEQUENCER_381 0x317D | ||
609 | #define WM8996_WRITE_SEQUENCER_382 0x317E | ||
610 | #define WM8996_WRITE_SEQUENCER_383 0x317F | ||
611 | #define WM8996_WRITE_SEQUENCER_384 0x3180 | ||
612 | #define WM8996_WRITE_SEQUENCER_385 0x3181 | ||
613 | #define WM8996_WRITE_SEQUENCER_386 0x3182 | ||
614 | #define WM8996_WRITE_SEQUENCER_387 0x3183 | ||
615 | #define WM8996_WRITE_SEQUENCER_388 0x3184 | ||
616 | #define WM8996_WRITE_SEQUENCER_389 0x3185 | ||
617 | #define WM8996_WRITE_SEQUENCER_390 0x3186 | ||
618 | #define WM8996_WRITE_SEQUENCER_391 0x3187 | ||
619 | #define WM8996_WRITE_SEQUENCER_392 0x3188 | ||
620 | #define WM8996_WRITE_SEQUENCER_393 0x3189 | ||
621 | #define WM8996_WRITE_SEQUENCER_394 0x318A | ||
622 | #define WM8996_WRITE_SEQUENCER_395 0x318B | ||
623 | #define WM8996_WRITE_SEQUENCER_396 0x318C | ||
624 | #define WM8996_WRITE_SEQUENCER_397 0x318D | ||
625 | #define WM8996_WRITE_SEQUENCER_398 0x318E | ||
626 | #define WM8996_WRITE_SEQUENCER_399 0x318F | ||
627 | #define WM8996_WRITE_SEQUENCER_400 0x3190 | ||
628 | #define WM8996_WRITE_SEQUENCER_401 0x3191 | ||
629 | #define WM8996_WRITE_SEQUENCER_402 0x3192 | ||
630 | #define WM8996_WRITE_SEQUENCER_403 0x3193 | ||
631 | #define WM8996_WRITE_SEQUENCER_404 0x3194 | ||
632 | #define WM8996_WRITE_SEQUENCER_405 0x3195 | ||
633 | #define WM8996_WRITE_SEQUENCER_406 0x3196 | ||
634 | #define WM8996_WRITE_SEQUENCER_407 0x3197 | ||
635 | #define WM8996_WRITE_SEQUENCER_408 0x3198 | ||
636 | #define WM8996_WRITE_SEQUENCER_409 0x3199 | ||
637 | #define WM8996_WRITE_SEQUENCER_410 0x319A | ||
638 | #define WM8996_WRITE_SEQUENCER_411 0x319B | ||
639 | #define WM8996_WRITE_SEQUENCER_412 0x319C | ||
640 | #define WM8996_WRITE_SEQUENCER_413 0x319D | ||
641 | #define WM8996_WRITE_SEQUENCER_414 0x319E | ||
642 | #define WM8996_WRITE_SEQUENCER_415 0x319F | ||
643 | #define WM8996_WRITE_SEQUENCER_416 0x31A0 | ||
644 | #define WM8996_WRITE_SEQUENCER_417 0x31A1 | ||
645 | #define WM8996_WRITE_SEQUENCER_418 0x31A2 | ||
646 | #define WM8996_WRITE_SEQUENCER_419 0x31A3 | ||
647 | #define WM8996_WRITE_SEQUENCER_420 0x31A4 | ||
648 | #define WM8996_WRITE_SEQUENCER_421 0x31A5 | ||
649 | #define WM8996_WRITE_SEQUENCER_422 0x31A6 | ||
650 | #define WM8996_WRITE_SEQUENCER_423 0x31A7 | ||
651 | #define WM8996_WRITE_SEQUENCER_424 0x31A8 | ||
652 | #define WM8996_WRITE_SEQUENCER_425 0x31A9 | ||
653 | #define WM8996_WRITE_SEQUENCER_426 0x31AA | ||
654 | #define WM8996_WRITE_SEQUENCER_427 0x31AB | ||
655 | #define WM8996_WRITE_SEQUENCER_428 0x31AC | ||
656 | #define WM8996_WRITE_SEQUENCER_429 0x31AD | ||
657 | #define WM8996_WRITE_SEQUENCER_430 0x31AE | ||
658 | #define WM8996_WRITE_SEQUENCER_431 0x31AF | ||
659 | #define WM8996_WRITE_SEQUENCER_432 0x31B0 | ||
660 | #define WM8996_WRITE_SEQUENCER_433 0x31B1 | ||
661 | #define WM8996_WRITE_SEQUENCER_434 0x31B2 | ||
662 | #define WM8996_WRITE_SEQUENCER_435 0x31B3 | ||
663 | #define WM8996_WRITE_SEQUENCER_436 0x31B4 | ||
664 | #define WM8996_WRITE_SEQUENCER_437 0x31B5 | ||
665 | #define WM8996_WRITE_SEQUENCER_438 0x31B6 | ||
666 | #define WM8996_WRITE_SEQUENCER_439 0x31B7 | ||
667 | #define WM8996_WRITE_SEQUENCER_440 0x31B8 | ||
668 | #define WM8996_WRITE_SEQUENCER_441 0x31B9 | ||
669 | #define WM8996_WRITE_SEQUENCER_442 0x31BA | ||
670 | #define WM8996_WRITE_SEQUENCER_443 0x31BB | ||
671 | #define WM8996_WRITE_SEQUENCER_444 0x31BC | ||
672 | #define WM8996_WRITE_SEQUENCER_445 0x31BD | ||
673 | #define WM8996_WRITE_SEQUENCER_446 0x31BE | ||
674 | #define WM8996_WRITE_SEQUENCER_447 0x31BF | ||
675 | #define WM8996_WRITE_SEQUENCER_448 0x31C0 | ||
676 | #define WM8996_WRITE_SEQUENCER_449 0x31C1 | ||
677 | #define WM8996_WRITE_SEQUENCER_450 0x31C2 | ||
678 | #define WM8996_WRITE_SEQUENCER_451 0x31C3 | ||
679 | #define WM8996_WRITE_SEQUENCER_452 0x31C4 | ||
680 | #define WM8996_WRITE_SEQUENCER_453 0x31C5 | ||
681 | #define WM8996_WRITE_SEQUENCER_454 0x31C6 | ||
682 | #define WM8996_WRITE_SEQUENCER_455 0x31C7 | ||
683 | #define WM8996_WRITE_SEQUENCER_456 0x31C8 | ||
684 | #define WM8996_WRITE_SEQUENCER_457 0x31C9 | ||
685 | #define WM8996_WRITE_SEQUENCER_458 0x31CA | ||
686 | #define WM8996_WRITE_SEQUENCER_459 0x31CB | ||
687 | #define WM8996_WRITE_SEQUENCER_460 0x31CC | ||
688 | #define WM8996_WRITE_SEQUENCER_461 0x31CD | ||
689 | #define WM8996_WRITE_SEQUENCER_462 0x31CE | ||
690 | #define WM8996_WRITE_SEQUENCER_463 0x31CF | ||
691 | #define WM8996_WRITE_SEQUENCER_464 0x31D0 | ||
692 | #define WM8996_WRITE_SEQUENCER_465 0x31D1 | ||
693 | #define WM8996_WRITE_SEQUENCER_466 0x31D2 | ||
694 | #define WM8996_WRITE_SEQUENCER_467 0x31D3 | ||
695 | #define WM8996_WRITE_SEQUENCER_468 0x31D4 | ||
696 | #define WM8996_WRITE_SEQUENCER_469 0x31D5 | ||
697 | #define WM8996_WRITE_SEQUENCER_470 0x31D6 | ||
698 | #define WM8996_WRITE_SEQUENCER_471 0x31D7 | ||
699 | #define WM8996_WRITE_SEQUENCER_472 0x31D8 | ||
700 | #define WM8996_WRITE_SEQUENCER_473 0x31D9 | ||
701 | #define WM8996_WRITE_SEQUENCER_474 0x31DA | ||
702 | #define WM8996_WRITE_SEQUENCER_475 0x31DB | ||
703 | #define WM8996_WRITE_SEQUENCER_476 0x31DC | ||
704 | #define WM8996_WRITE_SEQUENCER_477 0x31DD | ||
705 | #define WM8996_WRITE_SEQUENCER_478 0x31DE | ||
706 | #define WM8996_WRITE_SEQUENCER_479 0x31DF | ||
707 | #define WM8996_WRITE_SEQUENCER_480 0x31E0 | ||
708 | #define WM8996_WRITE_SEQUENCER_481 0x31E1 | ||
709 | #define WM8996_WRITE_SEQUENCER_482 0x31E2 | ||
710 | #define WM8996_WRITE_SEQUENCER_483 0x31E3 | ||
711 | #define WM8996_WRITE_SEQUENCER_484 0x31E4 | ||
712 | #define WM8996_WRITE_SEQUENCER_485 0x31E5 | ||
713 | #define WM8996_WRITE_SEQUENCER_486 0x31E6 | ||
714 | #define WM8996_WRITE_SEQUENCER_487 0x31E7 | ||
715 | #define WM8996_WRITE_SEQUENCER_488 0x31E8 | ||
716 | #define WM8996_WRITE_SEQUENCER_489 0x31E9 | ||
717 | #define WM8996_WRITE_SEQUENCER_490 0x31EA | ||
718 | #define WM8996_WRITE_SEQUENCER_491 0x31EB | ||
719 | #define WM8996_WRITE_SEQUENCER_492 0x31EC | ||
720 | #define WM8996_WRITE_SEQUENCER_493 0x31ED | ||
721 | #define WM8996_WRITE_SEQUENCER_494 0x31EE | ||
722 | #define WM8996_WRITE_SEQUENCER_495 0x31EF | ||
723 | #define WM8996_WRITE_SEQUENCER_496 0x31F0 | ||
724 | #define WM8996_WRITE_SEQUENCER_497 0x31F1 | ||
725 | #define WM8996_WRITE_SEQUENCER_498 0x31F2 | ||
726 | #define WM8996_WRITE_SEQUENCER_499 0x31F3 | ||
727 | #define WM8996_WRITE_SEQUENCER_500 0x31F4 | ||
728 | #define WM8996_WRITE_SEQUENCER_501 0x31F5 | ||
729 | #define WM8996_WRITE_SEQUENCER_502 0x31F6 | ||
730 | #define WM8996_WRITE_SEQUENCER_503 0x31F7 | ||
731 | #define WM8996_WRITE_SEQUENCER_504 0x31F8 | ||
732 | #define WM8996_WRITE_SEQUENCER_505 0x31F9 | ||
733 | #define WM8996_WRITE_SEQUENCER_506 0x31FA | ||
734 | #define WM8996_WRITE_SEQUENCER_507 0x31FB | ||
735 | #define WM8996_WRITE_SEQUENCER_508 0x31FC | ||
736 | #define WM8996_WRITE_SEQUENCER_509 0x31FD | ||
737 | #define WM8996_WRITE_SEQUENCER_510 0x31FE | ||
738 | #define WM8996_WRITE_SEQUENCER_511 0x31FF | ||
739 | |||
740 | #define WM8996_REGISTER_COUNT 706 | ||
741 | #define WM8996_MAX_REGISTER 0x31FF | ||
742 | |||
743 | /* | ||
744 | * Field Definitions. | ||
745 | */ | ||
746 | |||
747 | /* | ||
748 | * R0 (0x00) - Software Reset | ||
749 | */ | ||
750 | #define WM8996_SW_RESET_MASK 0xFFFF /* SW_RESET - [15:0] */ | ||
751 | #define WM8996_SW_RESET_SHIFT 0 /* SW_RESET - [15:0] */ | ||
752 | #define WM8996_SW_RESET_WIDTH 16 /* SW_RESET - [15:0] */ | ||
753 | |||
754 | /* | ||
755 | * R1 (0x01) - Power Management (1) | ||
756 | */ | ||
757 | #define WM8996_MICB2_ENA 0x0200 /* MICB2_ENA */ | ||
758 | #define WM8996_MICB2_ENA_MASK 0x0200 /* MICB2_ENA */ | ||
759 | #define WM8996_MICB2_ENA_SHIFT 9 /* MICB2_ENA */ | ||
760 | #define WM8996_MICB2_ENA_WIDTH 1 /* MICB2_ENA */ | ||
761 | #define WM8996_MICB1_ENA 0x0100 /* MICB1_ENA */ | ||
762 | #define WM8996_MICB1_ENA_MASK 0x0100 /* MICB1_ENA */ | ||
763 | #define WM8996_MICB1_ENA_SHIFT 8 /* MICB1_ENA */ | ||
764 | #define WM8996_MICB1_ENA_WIDTH 1 /* MICB1_ENA */ | ||
765 | #define WM8996_HPOUT2L_ENA 0x0080 /* HPOUT2L_ENA */ | ||
766 | #define WM8996_HPOUT2L_ENA_MASK 0x0080 /* HPOUT2L_ENA */ | ||
767 | #define WM8996_HPOUT2L_ENA_SHIFT 7 /* HPOUT2L_ENA */ | ||
768 | #define WM8996_HPOUT2L_ENA_WIDTH 1 /* HPOUT2L_ENA */ | ||
769 | #define WM8996_HPOUT2R_ENA 0x0040 /* HPOUT2R_ENA */ | ||
770 | #define WM8996_HPOUT2R_ENA_MASK 0x0040 /* HPOUT2R_ENA */ | ||
771 | #define WM8996_HPOUT2R_ENA_SHIFT 6 /* HPOUT2R_ENA */ | ||
772 | #define WM8996_HPOUT2R_ENA_WIDTH 1 /* HPOUT2R_ENA */ | ||
773 | #define WM8996_HPOUT1L_ENA 0x0020 /* HPOUT1L_ENA */ | ||
774 | #define WM8996_HPOUT1L_ENA_MASK 0x0020 /* HPOUT1L_ENA */ | ||
775 | #define WM8996_HPOUT1L_ENA_SHIFT 5 /* HPOUT1L_ENA */ | ||
776 | #define WM8996_HPOUT1L_ENA_WIDTH 1 /* HPOUT1L_ENA */ | ||
777 | #define WM8996_HPOUT1R_ENA 0x0010 /* HPOUT1R_ENA */ | ||
778 | #define WM8996_HPOUT1R_ENA_MASK 0x0010 /* HPOUT1R_ENA */ | ||
779 | #define WM8996_HPOUT1R_ENA_SHIFT 4 /* HPOUT1R_ENA */ | ||
780 | #define WM8996_HPOUT1R_ENA_WIDTH 1 /* HPOUT1R_ENA */ | ||
781 | #define WM8996_BG_ENA 0x0001 /* BG_ENA */ | ||
782 | #define WM8996_BG_ENA_MASK 0x0001 /* BG_ENA */ | ||
783 | #define WM8996_BG_ENA_SHIFT 0 /* BG_ENA */ | ||
784 | #define WM8996_BG_ENA_WIDTH 1 /* BG_ENA */ | ||
785 | |||
786 | /* | ||
787 | * R2 (0x02) - Power Management (2) | ||
788 | */ | ||
789 | #define WM8996_OPCLK_ENA 0x0800 /* OPCLK_ENA */ | ||
790 | #define WM8996_OPCLK_ENA_MASK 0x0800 /* OPCLK_ENA */ | ||
791 | #define WM8996_OPCLK_ENA_SHIFT 11 /* OPCLK_ENA */ | ||
792 | #define WM8996_OPCLK_ENA_WIDTH 1 /* OPCLK_ENA */ | ||
793 | #define WM8996_INL_ENA 0x0020 /* INL_ENA */ | ||
794 | #define WM8996_INL_ENA_MASK 0x0020 /* INL_ENA */ | ||
795 | #define WM8996_INL_ENA_SHIFT 5 /* INL_ENA */ | ||
796 | #define WM8996_INL_ENA_WIDTH 1 /* INL_ENA */ | ||
797 | #define WM8996_INR_ENA 0x0010 /* INR_ENA */ | ||
798 | #define WM8996_INR_ENA_MASK 0x0010 /* INR_ENA */ | ||
799 | #define WM8996_INR_ENA_SHIFT 4 /* INR_ENA */ | ||
800 | #define WM8996_INR_ENA_WIDTH 1 /* INR_ENA */ | ||
801 | #define WM8996_LDO2_ENA 0x0002 /* LDO2_ENA */ | ||
802 | #define WM8996_LDO2_ENA_MASK 0x0002 /* LDO2_ENA */ | ||
803 | #define WM8996_LDO2_ENA_SHIFT 1 /* LDO2_ENA */ | ||
804 | #define WM8996_LDO2_ENA_WIDTH 1 /* LDO2_ENA */ | ||
805 | |||
806 | /* | ||
807 | * R3 (0x03) - Power Management (3) | ||
808 | */ | ||
809 | #define WM8996_DSP2RXL_ENA 0x0800 /* DSP2RXL_ENA */ | ||
810 | #define WM8996_DSP2RXL_ENA_MASK 0x0800 /* DSP2RXL_ENA */ | ||
811 | #define WM8996_DSP2RXL_ENA_SHIFT 11 /* DSP2RXL_ENA */ | ||
812 | #define WM8996_DSP2RXL_ENA_WIDTH 1 /* DSP2RXL_ENA */ | ||
813 | #define WM8996_DSP2RXR_ENA 0x0400 /* DSP2RXR_ENA */ | ||
814 | #define WM8996_DSP2RXR_ENA_MASK 0x0400 /* DSP2RXR_ENA */ | ||
815 | #define WM8996_DSP2RXR_ENA_SHIFT 10 /* DSP2RXR_ENA */ | ||
816 | #define WM8996_DSP2RXR_ENA_WIDTH 1 /* DSP2RXR_ENA */ | ||
817 | #define WM8996_DSP1RXL_ENA 0x0200 /* DSP1RXL_ENA */ | ||
818 | #define WM8996_DSP1RXL_ENA_MASK 0x0200 /* DSP1RXL_ENA */ | ||
819 | #define WM8996_DSP1RXL_ENA_SHIFT 9 /* DSP1RXL_ENA */ | ||
820 | #define WM8996_DSP1RXL_ENA_WIDTH 1 /* DSP1RXL_ENA */ | ||
821 | #define WM8996_DSP1RXR_ENA 0x0100 /* DSP1RXR_ENA */ | ||
822 | #define WM8996_DSP1RXR_ENA_MASK 0x0100 /* DSP1RXR_ENA */ | ||
823 | #define WM8996_DSP1RXR_ENA_SHIFT 8 /* DSP1RXR_ENA */ | ||
824 | #define WM8996_DSP1RXR_ENA_WIDTH 1 /* DSP1RXR_ENA */ | ||
825 | #define WM8996_DMIC2L_ENA 0x0020 /* DMIC2L_ENA */ | ||
826 | #define WM8996_DMIC2L_ENA_MASK 0x0020 /* DMIC2L_ENA */ | ||
827 | #define WM8996_DMIC2L_ENA_SHIFT 5 /* DMIC2L_ENA */ | ||
828 | #define WM8996_DMIC2L_ENA_WIDTH 1 /* DMIC2L_ENA */ | ||
829 | #define WM8996_DMIC2R_ENA 0x0010 /* DMIC2R_ENA */ | ||
830 | #define WM8996_DMIC2R_ENA_MASK 0x0010 /* DMIC2R_ENA */ | ||
831 | #define WM8996_DMIC2R_ENA_SHIFT 4 /* DMIC2R_ENA */ | ||
832 | #define WM8996_DMIC2R_ENA_WIDTH 1 /* DMIC2R_ENA */ | ||
833 | #define WM8996_DMIC1L_ENA 0x0008 /* DMIC1L_ENA */ | ||
834 | #define WM8996_DMIC1L_ENA_MASK 0x0008 /* DMIC1L_ENA */ | ||
835 | #define WM8996_DMIC1L_ENA_SHIFT 3 /* DMIC1L_ENA */ | ||
836 | #define WM8996_DMIC1L_ENA_WIDTH 1 /* DMIC1L_ENA */ | ||
837 | #define WM8996_DMIC1R_ENA 0x0004 /* DMIC1R_ENA */ | ||
838 | #define WM8996_DMIC1R_ENA_MASK 0x0004 /* DMIC1R_ENA */ | ||
839 | #define WM8996_DMIC1R_ENA_SHIFT 2 /* DMIC1R_ENA */ | ||
840 | #define WM8996_DMIC1R_ENA_WIDTH 1 /* DMIC1R_ENA */ | ||
841 | #define WM8996_ADCL_ENA 0x0002 /* ADCL_ENA */ | ||
842 | #define WM8996_ADCL_ENA_MASK 0x0002 /* ADCL_ENA */ | ||
843 | #define WM8996_ADCL_ENA_SHIFT 1 /* ADCL_ENA */ | ||
844 | #define WM8996_ADCL_ENA_WIDTH 1 /* ADCL_ENA */ | ||
845 | #define WM8996_ADCR_ENA 0x0001 /* ADCR_ENA */ | ||
846 | #define WM8996_ADCR_ENA_MASK 0x0001 /* ADCR_ENA */ | ||
847 | #define WM8996_ADCR_ENA_SHIFT 0 /* ADCR_ENA */ | ||
848 | #define WM8996_ADCR_ENA_WIDTH 1 /* ADCR_ENA */ | ||
849 | |||
850 | /* | ||
851 | * R4 (0x04) - Power Management (4) | ||
852 | */ | ||
853 | #define WM8996_AIF2RX_CHAN1_ENA 0x0200 /* AIF2RX_CHAN1_ENA */ | ||
854 | #define WM8996_AIF2RX_CHAN1_ENA_MASK 0x0200 /* AIF2RX_CHAN1_ENA */ | ||
855 | #define WM8996_AIF2RX_CHAN1_ENA_SHIFT 9 /* AIF2RX_CHAN1_ENA */ | ||
856 | #define WM8996_AIF2RX_CHAN1_ENA_WIDTH 1 /* AIF2RX_CHAN1_ENA */ | ||
857 | #define WM8996_AIF2RX_CHAN0_ENA 0x0100 /* AIF2RX_CHAN0_ENA */ | ||
858 | #define WM8996_AIF2RX_CHAN0_ENA_MASK 0x0100 /* AIF2RX_CHAN0_ENA */ | ||
859 | #define WM8996_AIF2RX_CHAN0_ENA_SHIFT 8 /* AIF2RX_CHAN0_ENA */ | ||
860 | #define WM8996_AIF2RX_CHAN0_ENA_WIDTH 1 /* AIF2RX_CHAN0_ENA */ | ||
861 | #define WM8996_AIF1RX_CHAN5_ENA 0x0020 /* AIF1RX_CHAN5_ENA */ | ||
862 | #define WM8996_AIF1RX_CHAN5_ENA_MASK 0x0020 /* AIF1RX_CHAN5_ENA */ | ||
863 | #define WM8996_AIF1RX_CHAN5_ENA_SHIFT 5 /* AIF1RX_CHAN5_ENA */ | ||
864 | #define WM8996_AIF1RX_CHAN5_ENA_WIDTH 1 /* AIF1RX_CHAN5_ENA */ | ||
865 | #define WM8996_AIF1RX_CHAN4_ENA 0x0010 /* AIF1RX_CHAN4_ENA */ | ||
866 | #define WM8996_AIF1RX_CHAN4_ENA_MASK 0x0010 /* AIF1RX_CHAN4_ENA */ | ||
867 | #define WM8996_AIF1RX_CHAN4_ENA_SHIFT 4 /* AIF1RX_CHAN4_ENA */ | ||
868 | #define WM8996_AIF1RX_CHAN4_ENA_WIDTH 1 /* AIF1RX_CHAN4_ENA */ | ||
869 | #define WM8996_AIF1RX_CHAN3_ENA 0x0008 /* AIF1RX_CHAN3_ENA */ | ||
870 | #define WM8996_AIF1RX_CHAN3_ENA_MASK 0x0008 /* AIF1RX_CHAN3_ENA */ | ||
871 | #define WM8996_AIF1RX_CHAN3_ENA_SHIFT 3 /* AIF1RX_CHAN3_ENA */ | ||
872 | #define WM8996_AIF1RX_CHAN3_ENA_WIDTH 1 /* AIF1RX_CHAN3_ENA */ | ||
873 | #define WM8996_AIF1RX_CHAN2_ENA 0x0004 /* AIF1RX_CHAN2_ENA */ | ||
874 | #define WM8996_AIF1RX_CHAN2_ENA_MASK 0x0004 /* AIF1RX_CHAN2_ENA */ | ||
875 | #define WM8996_AIF1RX_CHAN2_ENA_SHIFT 2 /* AIF1RX_CHAN2_ENA */ | ||
876 | #define WM8996_AIF1RX_CHAN2_ENA_WIDTH 1 /* AIF1RX_CHAN2_ENA */ | ||
877 | #define WM8996_AIF1RX_CHAN1_ENA 0x0002 /* AIF1RX_CHAN1_ENA */ | ||
878 | #define WM8996_AIF1RX_CHAN1_ENA_MASK 0x0002 /* AIF1RX_CHAN1_ENA */ | ||
879 | #define WM8996_AIF1RX_CHAN1_ENA_SHIFT 1 /* AIF1RX_CHAN1_ENA */ | ||
880 | #define WM8996_AIF1RX_CHAN1_ENA_WIDTH 1 /* AIF1RX_CHAN1_ENA */ | ||
881 | #define WM8996_AIF1RX_CHAN0_ENA 0x0001 /* AIF1RX_CHAN0_ENA */ | ||
882 | #define WM8996_AIF1RX_CHAN0_ENA_MASK 0x0001 /* AIF1RX_CHAN0_ENA */ | ||
883 | #define WM8996_AIF1RX_CHAN0_ENA_SHIFT 0 /* AIF1RX_CHAN0_ENA */ | ||
884 | #define WM8996_AIF1RX_CHAN0_ENA_WIDTH 1 /* AIF1RX_CHAN0_ENA */ | ||
885 | |||
886 | /* | ||
887 | * R5 (0x05) - Power Management (5) | ||
888 | */ | ||
889 | #define WM8996_DSP2TXL_ENA 0x0800 /* DSP2TXL_ENA */ | ||
890 | #define WM8996_DSP2TXL_ENA_MASK 0x0800 /* DSP2TXL_ENA */ | ||
891 | #define WM8996_DSP2TXL_ENA_SHIFT 11 /* DSP2TXL_ENA */ | ||
892 | #define WM8996_DSP2TXL_ENA_WIDTH 1 /* DSP2TXL_ENA */ | ||
893 | #define WM8996_DSP2TXR_ENA 0x0400 /* DSP2TXR_ENA */ | ||
894 | #define WM8996_DSP2TXR_ENA_MASK 0x0400 /* DSP2TXR_ENA */ | ||
895 | #define WM8996_DSP2TXR_ENA_SHIFT 10 /* DSP2TXR_ENA */ | ||
896 | #define WM8996_DSP2TXR_ENA_WIDTH 1 /* DSP2TXR_ENA */ | ||
897 | #define WM8996_DSP1TXL_ENA 0x0200 /* DSP1TXL_ENA */ | ||
898 | #define WM8996_DSP1TXL_ENA_MASK 0x0200 /* DSP1TXL_ENA */ | ||
899 | #define WM8996_DSP1TXL_ENA_SHIFT 9 /* DSP1TXL_ENA */ | ||
900 | #define WM8996_DSP1TXL_ENA_WIDTH 1 /* DSP1TXL_ENA */ | ||
901 | #define WM8996_DSP1TXR_ENA 0x0100 /* DSP1TXR_ENA */ | ||
902 | #define WM8996_DSP1TXR_ENA_MASK 0x0100 /* DSP1TXR_ENA */ | ||
903 | #define WM8996_DSP1TXR_ENA_SHIFT 8 /* DSP1TXR_ENA */ | ||
904 | #define WM8996_DSP1TXR_ENA_WIDTH 1 /* DSP1TXR_ENA */ | ||
905 | #define WM8996_DAC2L_ENA 0x0008 /* DAC2L_ENA */ | ||
906 | #define WM8996_DAC2L_ENA_MASK 0x0008 /* DAC2L_ENA */ | ||
907 | #define WM8996_DAC2L_ENA_SHIFT 3 /* DAC2L_ENA */ | ||
908 | #define WM8996_DAC2L_ENA_WIDTH 1 /* DAC2L_ENA */ | ||
909 | #define WM8996_DAC2R_ENA 0x0004 /* DAC2R_ENA */ | ||
910 | #define WM8996_DAC2R_ENA_MASK 0x0004 /* DAC2R_ENA */ | ||
911 | #define WM8996_DAC2R_ENA_SHIFT 2 /* DAC2R_ENA */ | ||
912 | #define WM8996_DAC2R_ENA_WIDTH 1 /* DAC2R_ENA */ | ||
913 | #define WM8996_DAC1L_ENA 0x0002 /* DAC1L_ENA */ | ||
914 | #define WM8996_DAC1L_ENA_MASK 0x0002 /* DAC1L_ENA */ | ||
915 | #define WM8996_DAC1L_ENA_SHIFT 1 /* DAC1L_ENA */ | ||
916 | #define WM8996_DAC1L_ENA_WIDTH 1 /* DAC1L_ENA */ | ||
917 | #define WM8996_DAC1R_ENA 0x0001 /* DAC1R_ENA */ | ||
918 | #define WM8996_DAC1R_ENA_MASK 0x0001 /* DAC1R_ENA */ | ||
919 | #define WM8996_DAC1R_ENA_SHIFT 0 /* DAC1R_ENA */ | ||
920 | #define WM8996_DAC1R_ENA_WIDTH 1 /* DAC1R_ENA */ | ||
921 | |||
922 | /* | ||
923 | * R6 (0x06) - Power Management (6) | ||
924 | */ | ||
925 | #define WM8996_AIF2TX_CHAN1_ENA 0x0200 /* AIF2TX_CHAN1_ENA */ | ||
926 | #define WM8996_AIF2TX_CHAN1_ENA_MASK 0x0200 /* AIF2TX_CHAN1_ENA */ | ||
927 | #define WM8996_AIF2TX_CHAN1_ENA_SHIFT 9 /* AIF2TX_CHAN1_ENA */ | ||
928 | #define WM8996_AIF2TX_CHAN1_ENA_WIDTH 1 /* AIF2TX_CHAN1_ENA */ | ||
929 | #define WM8996_AIF2TX_CHAN0_ENA 0x0100 /* AIF2TX_CHAN0_ENA */ | ||
930 | #define WM8996_AIF2TX_CHAN0_ENA_MASK 0x0100 /* AIF2TX_CHAN0_ENA */ | ||
931 | #define WM8996_AIF2TX_CHAN0_ENA_SHIFT 8 /* AIF2TX_CHAN0_ENA */ | ||
932 | #define WM8996_AIF2TX_CHAN0_ENA_WIDTH 1 /* AIF2TX_CHAN0_ENA */ | ||
933 | #define WM8996_AIF1TX_CHAN5_ENA 0x0020 /* AIF1TX_CHAN5_ENA */ | ||
934 | #define WM8996_AIF1TX_CHAN5_ENA_MASK 0x0020 /* AIF1TX_CHAN5_ENA */ | ||
935 | #define WM8996_AIF1TX_CHAN5_ENA_SHIFT 5 /* AIF1TX_CHAN5_ENA */ | ||
936 | #define WM8996_AIF1TX_CHAN5_ENA_WIDTH 1 /* AIF1TX_CHAN5_ENA */ | ||
937 | #define WM8996_AIF1TX_CHAN4_ENA 0x0010 /* AIF1TX_CHAN4_ENA */ | ||
938 | #define WM8996_AIF1TX_CHAN4_ENA_MASK 0x0010 /* AIF1TX_CHAN4_ENA */ | ||
939 | #define WM8996_AIF1TX_CHAN4_ENA_SHIFT 4 /* AIF1TX_CHAN4_ENA */ | ||
940 | #define WM8996_AIF1TX_CHAN4_ENA_WIDTH 1 /* AIF1TX_CHAN4_ENA */ | ||
941 | #define WM8996_AIF1TX_CHAN3_ENA 0x0008 /* AIF1TX_CHAN3_ENA */ | ||
942 | #define WM8996_AIF1TX_CHAN3_ENA_MASK 0x0008 /* AIF1TX_CHAN3_ENA */ | ||
943 | #define WM8996_AIF1TX_CHAN3_ENA_SHIFT 3 /* AIF1TX_CHAN3_ENA */ | ||
944 | #define WM8996_AIF1TX_CHAN3_ENA_WIDTH 1 /* AIF1TX_CHAN3_ENA */ | ||
945 | #define WM8996_AIF1TX_CHAN2_ENA 0x0004 /* AIF1TX_CHAN2_ENA */ | ||
946 | #define WM8996_AIF1TX_CHAN2_ENA_MASK 0x0004 /* AIF1TX_CHAN2_ENA */ | ||
947 | #define WM8996_AIF1TX_CHAN2_ENA_SHIFT 2 /* AIF1TX_CHAN2_ENA */ | ||
948 | #define WM8996_AIF1TX_CHAN2_ENA_WIDTH 1 /* AIF1TX_CHAN2_ENA */ | ||
949 | #define WM8996_AIF1TX_CHAN1_ENA 0x0002 /* AIF1TX_CHAN1_ENA */ | ||
950 | #define WM8996_AIF1TX_CHAN1_ENA_MASK 0x0002 /* AIF1TX_CHAN1_ENA */ | ||
951 | #define WM8996_AIF1TX_CHAN1_ENA_SHIFT 1 /* AIF1TX_CHAN1_ENA */ | ||
952 | #define WM8996_AIF1TX_CHAN1_ENA_WIDTH 1 /* AIF1TX_CHAN1_ENA */ | ||
953 | #define WM8996_AIF1TX_CHAN0_ENA 0x0001 /* AIF1TX_CHAN0_ENA */ | ||
954 | #define WM8996_AIF1TX_CHAN0_ENA_MASK 0x0001 /* AIF1TX_CHAN0_ENA */ | ||
955 | #define WM8996_AIF1TX_CHAN0_ENA_SHIFT 0 /* AIF1TX_CHAN0_ENA */ | ||
956 | #define WM8996_AIF1TX_CHAN0_ENA_WIDTH 1 /* AIF1TX_CHAN0_ENA */ | ||
957 | |||
958 | /* | ||
959 | * R7 (0x07) - Power Management (7) | ||
960 | */ | ||
961 | #define WM8996_DMIC2_FN 0x0200 /* DMIC2_FN */ | ||
962 | #define WM8996_DMIC2_FN_MASK 0x0200 /* DMIC2_FN */ | ||
963 | #define WM8996_DMIC2_FN_SHIFT 9 /* DMIC2_FN */ | ||
964 | #define WM8996_DMIC2_FN_WIDTH 1 /* DMIC2_FN */ | ||
965 | #define WM8996_DMIC1_FN 0x0100 /* DMIC1_FN */ | ||
966 | #define WM8996_DMIC1_FN_MASK 0x0100 /* DMIC1_FN */ | ||
967 | #define WM8996_DMIC1_FN_SHIFT 8 /* DMIC1_FN */ | ||
968 | #define WM8996_DMIC1_FN_WIDTH 1 /* DMIC1_FN */ | ||
969 | #define WM8996_ADC_DMIC_DSP2R_ENA 0x0080 /* ADC_DMIC_DSP2R_ENA */ | ||
970 | #define WM8996_ADC_DMIC_DSP2R_ENA_MASK 0x0080 /* ADC_DMIC_DSP2R_ENA */ | ||
971 | #define WM8996_ADC_DMIC_DSP2R_ENA_SHIFT 7 /* ADC_DMIC_DSP2R_ENA */ | ||
972 | #define WM8996_ADC_DMIC_DSP2R_ENA_WIDTH 1 /* ADC_DMIC_DSP2R_ENA */ | ||
973 | #define WM8996_ADC_DMIC_DSP2L_ENA 0x0040 /* ADC_DMIC_DSP2L_ENA */ | ||
974 | #define WM8996_ADC_DMIC_DSP2L_ENA_MASK 0x0040 /* ADC_DMIC_DSP2L_ENA */ | ||
975 | #define WM8996_ADC_DMIC_DSP2L_ENA_SHIFT 6 /* ADC_DMIC_DSP2L_ENA */ | ||
976 | #define WM8996_ADC_DMIC_DSP2L_ENA_WIDTH 1 /* ADC_DMIC_DSP2L_ENA */ | ||
977 | #define WM8996_ADC_DMIC_SRC2_MASK 0x0030 /* ADC_DMIC_SRC2 - [5:4] */ | ||
978 | #define WM8996_ADC_DMIC_SRC2_SHIFT 4 /* ADC_DMIC_SRC2 - [5:4] */ | ||
979 | #define WM8996_ADC_DMIC_SRC2_WIDTH 2 /* ADC_DMIC_SRC2 - [5:4] */ | ||
980 | #define WM8996_ADC_DMIC_DSP1R_ENA 0x0008 /* ADC_DMIC_DSP1R_ENA */ | ||
981 | #define WM8996_ADC_DMIC_DSP1R_ENA_MASK 0x0008 /* ADC_DMIC_DSP1R_ENA */ | ||
982 | #define WM8996_ADC_DMIC_DSP1R_ENA_SHIFT 3 /* ADC_DMIC_DSP1R_ENA */ | ||
983 | #define WM8996_ADC_DMIC_DSP1R_ENA_WIDTH 1 /* ADC_DMIC_DSP1R_ENA */ | ||
984 | #define WM8996_ADC_DMIC_DSP1L_ENA 0x0004 /* ADC_DMIC_DSP1L_ENA */ | ||
985 | #define WM8996_ADC_DMIC_DSP1L_ENA_MASK 0x0004 /* ADC_DMIC_DSP1L_ENA */ | ||
986 | #define WM8996_ADC_DMIC_DSP1L_ENA_SHIFT 2 /* ADC_DMIC_DSP1L_ENA */ | ||
987 | #define WM8996_ADC_DMIC_DSP1L_ENA_WIDTH 1 /* ADC_DMIC_DSP1L_ENA */ | ||
988 | #define WM8996_ADC_DMIC_SRC1_MASK 0x0003 /* ADC_DMIC_SRC1 - [1:0] */ | ||
989 | #define WM8996_ADC_DMIC_SRC1_SHIFT 0 /* ADC_DMIC_SRC1 - [1:0] */ | ||
990 | #define WM8996_ADC_DMIC_SRC1_WIDTH 2 /* ADC_DMIC_SRC1 - [1:0] */ | ||
991 | |||
992 | /* | ||
993 | * R8 (0x08) - Power Management (8) | ||
994 | */ | ||
995 | #define WM8996_AIF2TX_SRC_MASK 0x00C0 /* AIF2TX_SRC - [7:6] */ | ||
996 | #define WM8996_AIF2TX_SRC_SHIFT 6 /* AIF2TX_SRC - [7:6] */ | ||
997 | #define WM8996_AIF2TX_SRC_WIDTH 2 /* AIF2TX_SRC - [7:6] */ | ||
998 | #define WM8996_DSP2RX_SRC 0x0010 /* DSP2RX_SRC */ | ||
999 | #define WM8996_DSP2RX_SRC_MASK 0x0010 /* DSP2RX_SRC */ | ||
1000 | #define WM8996_DSP2RX_SRC_SHIFT 4 /* DSP2RX_SRC */ | ||
1001 | #define WM8996_DSP2RX_SRC_WIDTH 1 /* DSP2RX_SRC */ | ||
1002 | #define WM8996_DSP1RX_SRC 0x0001 /* DSP1RX_SRC */ | ||
1003 | #define WM8996_DSP1RX_SRC_MASK 0x0001 /* DSP1RX_SRC */ | ||
1004 | #define WM8996_DSP1RX_SRC_SHIFT 0 /* DSP1RX_SRC */ | ||
1005 | #define WM8996_DSP1RX_SRC_WIDTH 1 /* DSP1RX_SRC */ | ||
1006 | |||
1007 | /* | ||
1008 | * R16 (0x10) - Left Line Input Volume | ||
1009 | */ | ||
1010 | #define WM8996_IN1_VU 0x0080 /* IN1_VU */ | ||
1011 | #define WM8996_IN1_VU_MASK 0x0080 /* IN1_VU */ | ||
1012 | #define WM8996_IN1_VU_SHIFT 7 /* IN1_VU */ | ||
1013 | #define WM8996_IN1_VU_WIDTH 1 /* IN1_VU */ | ||
1014 | #define WM8996_IN1L_ZC 0x0020 /* IN1L_ZC */ | ||
1015 | #define WM8996_IN1L_ZC_MASK 0x0020 /* IN1L_ZC */ | ||
1016 | #define WM8996_IN1L_ZC_SHIFT 5 /* IN1L_ZC */ | ||
1017 | #define WM8996_IN1L_ZC_WIDTH 1 /* IN1L_ZC */ | ||
1018 | #define WM8996_IN1L_VOL_MASK 0x001F /* IN1L_VOL - [4:0] */ | ||
1019 | #define WM8996_IN1L_VOL_SHIFT 0 /* IN1L_VOL - [4:0] */ | ||
1020 | #define WM8996_IN1L_VOL_WIDTH 5 /* IN1L_VOL - [4:0] */ | ||
1021 | |||
1022 | /* | ||
1023 | * R17 (0x11) - Right Line Input Volume | ||
1024 | */ | ||
1025 | #define WM8996_IN1_VU 0x0080 /* IN1_VU */ | ||
1026 | #define WM8996_IN1_VU_MASK 0x0080 /* IN1_VU */ | ||
1027 | #define WM8996_IN1_VU_SHIFT 7 /* IN1_VU */ | ||
1028 | #define WM8996_IN1_VU_WIDTH 1 /* IN1_VU */ | ||
1029 | #define WM8996_IN1R_ZC 0x0020 /* IN1R_ZC */ | ||
1030 | #define WM8996_IN1R_ZC_MASK 0x0020 /* IN1R_ZC */ | ||
1031 | #define WM8996_IN1R_ZC_SHIFT 5 /* IN1R_ZC */ | ||
1032 | #define WM8996_IN1R_ZC_WIDTH 1 /* IN1R_ZC */ | ||
1033 | #define WM8996_IN1R_VOL_MASK 0x001F /* IN1R_VOL - [4:0] */ | ||
1034 | #define WM8996_IN1R_VOL_SHIFT 0 /* IN1R_VOL - [4:0] */ | ||
1035 | #define WM8996_IN1R_VOL_WIDTH 5 /* IN1R_VOL - [4:0] */ | ||
1036 | |||
1037 | /* | ||
1038 | * R18 (0x12) - Line Input Control | ||
1039 | */ | ||
1040 | #define WM8996_INL_MODE_MASK 0x000C /* INL_MODE - [3:2] */ | ||
1041 | #define WM8996_INL_MODE_SHIFT 2 /* INL_MODE - [3:2] */ | ||
1042 | #define WM8996_INL_MODE_WIDTH 2 /* INL_MODE - [3:2] */ | ||
1043 | #define WM8996_INR_MODE_MASK 0x0003 /* INR_MODE - [1:0] */ | ||
1044 | #define WM8996_INR_MODE_SHIFT 0 /* INR_MODE - [1:0] */ | ||
1045 | #define WM8996_INR_MODE_WIDTH 2 /* INR_MODE - [1:0] */ | ||
1046 | |||
1047 | /* | ||
1048 | * R21 (0x15) - DAC1 HPOUT1 Volume | ||
1049 | */ | ||
1050 | #define WM8996_DAC1R_HPOUT1R_VOL_MASK 0x00F0 /* DAC1R_HPOUT1R_VOL - [7:4] */ | ||
1051 | #define WM8996_DAC1R_HPOUT1R_VOL_SHIFT 4 /* DAC1R_HPOUT1R_VOL - [7:4] */ | ||
1052 | #define WM8996_DAC1R_HPOUT1R_VOL_WIDTH 4 /* DAC1R_HPOUT1R_VOL - [7:4] */ | ||
1053 | #define WM8996_DAC1L_HPOUT1L_VOL_MASK 0x000F /* DAC1L_HPOUT1L_VOL - [3:0] */ | ||
1054 | #define WM8996_DAC1L_HPOUT1L_VOL_SHIFT 0 /* DAC1L_HPOUT1L_VOL - [3:0] */ | ||
1055 | #define WM8996_DAC1L_HPOUT1L_VOL_WIDTH 4 /* DAC1L_HPOUT1L_VOL - [3:0] */ | ||
1056 | |||
1057 | /* | ||
1058 | * R22 (0x16) - DAC2 HPOUT2 Volume | ||
1059 | */ | ||
1060 | #define WM8996_DAC2R_HPOUT2R_VOL_MASK 0x00F0 /* DAC2R_HPOUT2R_VOL - [7:4] */ | ||
1061 | #define WM8996_DAC2R_HPOUT2R_VOL_SHIFT 4 /* DAC2R_HPOUT2R_VOL - [7:4] */ | ||
1062 | #define WM8996_DAC2R_HPOUT2R_VOL_WIDTH 4 /* DAC2R_HPOUT2R_VOL - [7:4] */ | ||
1063 | #define WM8996_DAC2L_HPOUT2L_VOL_MASK 0x000F /* DAC2L_HPOUT2L_VOL - [3:0] */ | ||
1064 | #define WM8996_DAC2L_HPOUT2L_VOL_SHIFT 0 /* DAC2L_HPOUT2L_VOL - [3:0] */ | ||
1065 | #define WM8996_DAC2L_HPOUT2L_VOL_WIDTH 4 /* DAC2L_HPOUT2L_VOL - [3:0] */ | ||
1066 | |||
1067 | /* | ||
1068 | * R24 (0x18) - DAC1 Left Volume | ||
1069 | */ | ||
1070 | #define WM8996_DAC1L_MUTE 0x0200 /* DAC1L_MUTE */ | ||
1071 | #define WM8996_DAC1L_MUTE_MASK 0x0200 /* DAC1L_MUTE */ | ||
1072 | #define WM8996_DAC1L_MUTE_SHIFT 9 /* DAC1L_MUTE */ | ||
1073 | #define WM8996_DAC1L_MUTE_WIDTH 1 /* DAC1L_MUTE */ | ||
1074 | #define WM8996_DAC1_VU 0x0100 /* DAC1_VU */ | ||
1075 | #define WM8996_DAC1_VU_MASK 0x0100 /* DAC1_VU */ | ||
1076 | #define WM8996_DAC1_VU_SHIFT 8 /* DAC1_VU */ | ||
1077 | #define WM8996_DAC1_VU_WIDTH 1 /* DAC1_VU */ | ||
1078 | #define WM8996_DAC1L_VOL_MASK 0x00FF /* DAC1L_VOL - [7:0] */ | ||
1079 | #define WM8996_DAC1L_VOL_SHIFT 0 /* DAC1L_VOL - [7:0] */ | ||
1080 | #define WM8996_DAC1L_VOL_WIDTH 8 /* DAC1L_VOL - [7:0] */ | ||
1081 | |||
1082 | /* | ||
1083 | * R25 (0x19) - DAC1 Right Volume | ||
1084 | */ | ||
1085 | #define WM8996_DAC1R_MUTE 0x0200 /* DAC1R_MUTE */ | ||
1086 | #define WM8996_DAC1R_MUTE_MASK 0x0200 /* DAC1R_MUTE */ | ||
1087 | #define WM8996_DAC1R_MUTE_SHIFT 9 /* DAC1R_MUTE */ | ||
1088 | #define WM8996_DAC1R_MUTE_WIDTH 1 /* DAC1R_MUTE */ | ||
1089 | #define WM8996_DAC1_VU 0x0100 /* DAC1_VU */ | ||
1090 | #define WM8996_DAC1_VU_MASK 0x0100 /* DAC1_VU */ | ||
1091 | #define WM8996_DAC1_VU_SHIFT 8 /* DAC1_VU */ | ||
1092 | #define WM8996_DAC1_VU_WIDTH 1 /* DAC1_VU */ | ||
1093 | #define WM8996_DAC1R_VOL_MASK 0x00FF /* DAC1R_VOL - [7:0] */ | ||
1094 | #define WM8996_DAC1R_VOL_SHIFT 0 /* DAC1R_VOL - [7:0] */ | ||
1095 | #define WM8996_DAC1R_VOL_WIDTH 8 /* DAC1R_VOL - [7:0] */ | ||
1096 | |||
1097 | /* | ||
1098 | * R26 (0x1A) - DAC2 Left Volume | ||
1099 | */ | ||
1100 | #define WM8996_DAC2L_MUTE 0x0200 /* DAC2L_MUTE */ | ||
1101 | #define WM8996_DAC2L_MUTE_MASK 0x0200 /* DAC2L_MUTE */ | ||
1102 | #define WM8996_DAC2L_MUTE_SHIFT 9 /* DAC2L_MUTE */ | ||
1103 | #define WM8996_DAC2L_MUTE_WIDTH 1 /* DAC2L_MUTE */ | ||
1104 | #define WM8996_DAC2_VU 0x0100 /* DAC2_VU */ | ||
1105 | #define WM8996_DAC2_VU_MASK 0x0100 /* DAC2_VU */ | ||
1106 | #define WM8996_DAC2_VU_SHIFT 8 /* DAC2_VU */ | ||
1107 | #define WM8996_DAC2_VU_WIDTH 1 /* DAC2_VU */ | ||
1108 | #define WM8996_DAC2L_VOL_MASK 0x00FF /* DAC2L_VOL - [7:0] */ | ||
1109 | #define WM8996_DAC2L_VOL_SHIFT 0 /* DAC2L_VOL - [7:0] */ | ||
1110 | #define WM8996_DAC2L_VOL_WIDTH 8 /* DAC2L_VOL - [7:0] */ | ||
1111 | |||
1112 | /* | ||
1113 | * R27 (0x1B) - DAC2 Right Volume | ||
1114 | */ | ||
1115 | #define WM8996_DAC2R_MUTE 0x0200 /* DAC2R_MUTE */ | ||
1116 | #define WM8996_DAC2R_MUTE_MASK 0x0200 /* DAC2R_MUTE */ | ||
1117 | #define WM8996_DAC2R_MUTE_SHIFT 9 /* DAC2R_MUTE */ | ||
1118 | #define WM8996_DAC2R_MUTE_WIDTH 1 /* DAC2R_MUTE */ | ||
1119 | #define WM8996_DAC2_VU 0x0100 /* DAC2_VU */ | ||
1120 | #define WM8996_DAC2_VU_MASK 0x0100 /* DAC2_VU */ | ||
1121 | #define WM8996_DAC2_VU_SHIFT 8 /* DAC2_VU */ | ||
1122 | #define WM8996_DAC2_VU_WIDTH 1 /* DAC2_VU */ | ||
1123 | #define WM8996_DAC2R_VOL_MASK 0x00FF /* DAC2R_VOL - [7:0] */ | ||
1124 | #define WM8996_DAC2R_VOL_SHIFT 0 /* DAC2R_VOL - [7:0] */ | ||
1125 | #define WM8996_DAC2R_VOL_WIDTH 8 /* DAC2R_VOL - [7:0] */ | ||
1126 | |||
1127 | /* | ||
1128 | * R28 (0x1C) - Output1 Left Volume | ||
1129 | */ | ||
1130 | #define WM8996_DAC1_VU 0x0100 /* DAC1_VU */ | ||
1131 | #define WM8996_DAC1_VU_MASK 0x0100 /* DAC1_VU */ | ||
1132 | #define WM8996_DAC1_VU_SHIFT 8 /* DAC1_VU */ | ||
1133 | #define WM8996_DAC1_VU_WIDTH 1 /* DAC1_VU */ | ||
1134 | #define WM8996_HPOUT1L_ZC 0x0080 /* HPOUT1L_ZC */ | ||
1135 | #define WM8996_HPOUT1L_ZC_MASK 0x0080 /* HPOUT1L_ZC */ | ||
1136 | #define WM8996_HPOUT1L_ZC_SHIFT 7 /* HPOUT1L_ZC */ | ||
1137 | #define WM8996_HPOUT1L_ZC_WIDTH 1 /* HPOUT1L_ZC */ | ||
1138 | #define WM8996_HPOUT1L_VOL_MASK 0x000F /* HPOUT1L_VOL - [3:0] */ | ||
1139 | #define WM8996_HPOUT1L_VOL_SHIFT 0 /* HPOUT1L_VOL - [3:0] */ | ||
1140 | #define WM8996_HPOUT1L_VOL_WIDTH 4 /* HPOUT1L_VOL - [3:0] */ | ||
1141 | |||
1142 | /* | ||
1143 | * R29 (0x1D) - Output1 Right Volume | ||
1144 | */ | ||
1145 | #define WM8996_DAC1_VU 0x0100 /* DAC1_VU */ | ||
1146 | #define WM8996_DAC1_VU_MASK 0x0100 /* DAC1_VU */ | ||
1147 | #define WM8996_DAC1_VU_SHIFT 8 /* DAC1_VU */ | ||
1148 | #define WM8996_DAC1_VU_WIDTH 1 /* DAC1_VU */ | ||
1149 | #define WM8996_HPOUT1R_ZC 0x0080 /* HPOUT1R_ZC */ | ||
1150 | #define WM8996_HPOUT1R_ZC_MASK 0x0080 /* HPOUT1R_ZC */ | ||
1151 | #define WM8996_HPOUT1R_ZC_SHIFT 7 /* HPOUT1R_ZC */ | ||
1152 | #define WM8996_HPOUT1R_ZC_WIDTH 1 /* HPOUT1R_ZC */ | ||
1153 | #define WM8996_HPOUT1R_VOL_MASK 0x000F /* HPOUT1R_VOL - [3:0] */ | ||
1154 | #define WM8996_HPOUT1R_VOL_SHIFT 0 /* HPOUT1R_VOL - [3:0] */ | ||
1155 | #define WM8996_HPOUT1R_VOL_WIDTH 4 /* HPOUT1R_VOL - [3:0] */ | ||
1156 | |||
1157 | /* | ||
1158 | * R30 (0x1E) - Output2 Left Volume | ||
1159 | */ | ||
1160 | #define WM8996_DAC2_VU 0x0100 /* DAC2_VU */ | ||
1161 | #define WM8996_DAC2_VU_MASK 0x0100 /* DAC2_VU */ | ||
1162 | #define WM8996_DAC2_VU_SHIFT 8 /* DAC2_VU */ | ||
1163 | #define WM8996_DAC2_VU_WIDTH 1 /* DAC2_VU */ | ||
1164 | #define WM8996_HPOUT2L_ZC 0x0080 /* HPOUT2L_ZC */ | ||
1165 | #define WM8996_HPOUT2L_ZC_MASK 0x0080 /* HPOUT2L_ZC */ | ||
1166 | #define WM8996_HPOUT2L_ZC_SHIFT 7 /* HPOUT2L_ZC */ | ||
1167 | #define WM8996_HPOUT2L_ZC_WIDTH 1 /* HPOUT2L_ZC */ | ||
1168 | #define WM8996_HPOUT2L_VOL_MASK 0x000F /* HPOUT2L_VOL - [3:0] */ | ||
1169 | #define WM8996_HPOUT2L_VOL_SHIFT 0 /* HPOUT2L_VOL - [3:0] */ | ||
1170 | #define WM8996_HPOUT2L_VOL_WIDTH 4 /* HPOUT2L_VOL - [3:0] */ | ||
1171 | |||
1172 | /* | ||
1173 | * R31 (0x1F) - Output2 Right Volume | ||
1174 | */ | ||
1175 | #define WM8996_DAC2_VU 0x0100 /* DAC2_VU */ | ||
1176 | #define WM8996_DAC2_VU_MASK 0x0100 /* DAC2_VU */ | ||
1177 | #define WM8996_DAC2_VU_SHIFT 8 /* DAC2_VU */ | ||
1178 | #define WM8996_DAC2_VU_WIDTH 1 /* DAC2_VU */ | ||
1179 | #define WM8996_HPOUT2R_ZC 0x0080 /* HPOUT2R_ZC */ | ||
1180 | #define WM8996_HPOUT2R_ZC_MASK 0x0080 /* HPOUT2R_ZC */ | ||
1181 | #define WM8996_HPOUT2R_ZC_SHIFT 7 /* HPOUT2R_ZC */ | ||
1182 | #define WM8996_HPOUT2R_ZC_WIDTH 1 /* HPOUT2R_ZC */ | ||
1183 | #define WM8996_HPOUT2R_VOL_MASK 0x000F /* HPOUT2R_VOL - [3:0] */ | ||
1184 | #define WM8996_HPOUT2R_VOL_SHIFT 0 /* HPOUT2R_VOL - [3:0] */ | ||
1185 | #define WM8996_HPOUT2R_VOL_WIDTH 4 /* HPOUT2R_VOL - [3:0] */ | ||
1186 | |||
1187 | /* | ||
1188 | * R32 (0x20) - MICBIAS (1) | ||
1189 | */ | ||
1190 | #define WM8996_MICB1_RATE 0x0020 /* MICB1_RATE */ | ||
1191 | #define WM8996_MICB1_RATE_MASK 0x0020 /* MICB1_RATE */ | ||
1192 | #define WM8996_MICB1_RATE_SHIFT 5 /* MICB1_RATE */ | ||
1193 | #define WM8996_MICB1_RATE_WIDTH 1 /* MICB1_RATE */ | ||
1194 | #define WM8996_MICB1_MODE 0x0010 /* MICB1_MODE */ | ||
1195 | #define WM8996_MICB1_MODE_MASK 0x0010 /* MICB1_MODE */ | ||
1196 | #define WM8996_MICB1_MODE_SHIFT 4 /* MICB1_MODE */ | ||
1197 | #define WM8996_MICB1_MODE_WIDTH 1 /* MICB1_MODE */ | ||
1198 | #define WM8996_MICB1_LVL_MASK 0x000E /* MICB1_LVL - [3:1] */ | ||
1199 | #define WM8996_MICB1_LVL_SHIFT 1 /* MICB1_LVL - [3:1] */ | ||
1200 | #define WM8996_MICB1_LVL_WIDTH 3 /* MICB1_LVL - [3:1] */ | ||
1201 | #define WM8996_MICB1_DISCH 0x0001 /* MICB1_DISCH */ | ||
1202 | #define WM8996_MICB1_DISCH_MASK 0x0001 /* MICB1_DISCH */ | ||
1203 | #define WM8996_MICB1_DISCH_SHIFT 0 /* MICB1_DISCH */ | ||
1204 | #define WM8996_MICB1_DISCH_WIDTH 1 /* MICB1_DISCH */ | ||
1205 | |||
1206 | /* | ||
1207 | * R33 (0x21) - MICBIAS (2) | ||
1208 | */ | ||
1209 | #define WM8996_MICB2_RATE 0x0020 /* MICB2_RATE */ | ||
1210 | #define WM8996_MICB2_RATE_MASK 0x0020 /* MICB2_RATE */ | ||
1211 | #define WM8996_MICB2_RATE_SHIFT 5 /* MICB2_RATE */ | ||
1212 | #define WM8996_MICB2_RATE_WIDTH 1 /* MICB2_RATE */ | ||
1213 | #define WM8996_MICB2_MODE 0x0010 /* MICB2_MODE */ | ||
1214 | #define WM8996_MICB2_MODE_MASK 0x0010 /* MICB2_MODE */ | ||
1215 | #define WM8996_MICB2_MODE_SHIFT 4 /* MICB2_MODE */ | ||
1216 | #define WM8996_MICB2_MODE_WIDTH 1 /* MICB2_MODE */ | ||
1217 | #define WM8996_MICB2_LVL_MASK 0x000E /* MICB2_LVL - [3:1] */ | ||
1218 | #define WM8996_MICB2_LVL_SHIFT 1 /* MICB2_LVL - [3:1] */ | ||
1219 | #define WM8996_MICB2_LVL_WIDTH 3 /* MICB2_LVL - [3:1] */ | ||
1220 | #define WM8996_MICB2_DISCH 0x0001 /* MICB2_DISCH */ | ||
1221 | #define WM8996_MICB2_DISCH_MASK 0x0001 /* MICB2_DISCH */ | ||
1222 | #define WM8996_MICB2_DISCH_SHIFT 0 /* MICB2_DISCH */ | ||
1223 | #define WM8996_MICB2_DISCH_WIDTH 1 /* MICB2_DISCH */ | ||
1224 | |||
1225 | /* | ||
1226 | * R40 (0x28) - LDO 1 | ||
1227 | */ | ||
1228 | #define WM8996_LDO1_MODE 0x0020 /* LDO1_MODE */ | ||
1229 | #define WM8996_LDO1_MODE_MASK 0x0020 /* LDO1_MODE */ | ||
1230 | #define WM8996_LDO1_MODE_SHIFT 5 /* LDO1_MODE */ | ||
1231 | #define WM8996_LDO1_MODE_WIDTH 1 /* LDO1_MODE */ | ||
1232 | #define WM8996_LDO1_VSEL_MASK 0x0006 /* LDO1_VSEL - [2:1] */ | ||
1233 | #define WM8996_LDO1_VSEL_SHIFT 1 /* LDO1_VSEL - [2:1] */ | ||
1234 | #define WM8996_LDO1_VSEL_WIDTH 2 /* LDO1_VSEL - [2:1] */ | ||
1235 | #define WM8996_LDO1_DISCH 0x0001 /* LDO1_DISCH */ | ||
1236 | #define WM8996_LDO1_DISCH_MASK 0x0001 /* LDO1_DISCH */ | ||
1237 | #define WM8996_LDO1_DISCH_SHIFT 0 /* LDO1_DISCH */ | ||
1238 | #define WM8996_LDO1_DISCH_WIDTH 1 /* LDO1_DISCH */ | ||
1239 | |||
1240 | /* | ||
1241 | * R41 (0x29) - LDO 2 | ||
1242 | */ | ||
1243 | #define WM8996_LDO2_MODE 0x0020 /* LDO2_MODE */ | ||
1244 | #define WM8996_LDO2_MODE_MASK 0x0020 /* LDO2_MODE */ | ||
1245 | #define WM8996_LDO2_MODE_SHIFT 5 /* LDO2_MODE */ | ||
1246 | #define WM8996_LDO2_MODE_WIDTH 1 /* LDO2_MODE */ | ||
1247 | #define WM8996_LDO2_VSEL_MASK 0x001E /* LDO2_VSEL - [4:1] */ | ||
1248 | #define WM8996_LDO2_VSEL_SHIFT 1 /* LDO2_VSEL - [4:1] */ | ||
1249 | #define WM8996_LDO2_VSEL_WIDTH 4 /* LDO2_VSEL - [4:1] */ | ||
1250 | #define WM8996_LDO2_DISCH 0x0001 /* LDO2_DISCH */ | ||
1251 | #define WM8996_LDO2_DISCH_MASK 0x0001 /* LDO2_DISCH */ | ||
1252 | #define WM8996_LDO2_DISCH_SHIFT 0 /* LDO2_DISCH */ | ||
1253 | #define WM8996_LDO2_DISCH_WIDTH 1 /* LDO2_DISCH */ | ||
1254 | |||
1255 | /* | ||
1256 | * R48 (0x30) - Accessory Detect Mode 1 | ||
1257 | */ | ||
1258 | #define WM8996_JD_MODE_MASK 0x0003 /* JD_MODE - [1:0] */ | ||
1259 | #define WM8996_JD_MODE_SHIFT 0 /* JD_MODE - [1:0] */ | ||
1260 | #define WM8996_JD_MODE_WIDTH 2 /* JD_MODE - [1:0] */ | ||
1261 | |||
1262 | /* | ||
1263 | * R49 (0x31) - Accessory Detect Mode 2 | ||
1264 | */ | ||
1265 | #define WM8996_HPOUT1FB_SRC 0x0004 /* HPOUT1FB_SRC */ | ||
1266 | #define WM8996_HPOUT1FB_SRC_MASK 0x0004 /* HPOUT1FB_SRC */ | ||
1267 | #define WM8996_HPOUT1FB_SRC_SHIFT 2 /* HPOUT1FB_SRC */ | ||
1268 | #define WM8996_HPOUT1FB_SRC_WIDTH 1 /* HPOUT1FB_SRC */ | ||
1269 | #define WM8996_MICD_SRC 0x0002 /* MICD_SRC */ | ||
1270 | #define WM8996_MICD_SRC_MASK 0x0002 /* MICD_SRC */ | ||
1271 | #define WM8996_MICD_SRC_SHIFT 1 /* MICD_SRC */ | ||
1272 | #define WM8996_MICD_SRC_WIDTH 1 /* MICD_SRC */ | ||
1273 | #define WM8996_MICD_BIAS_SRC 0x0001 /* MICD_BIAS_SRC */ | ||
1274 | #define WM8996_MICD_BIAS_SRC_MASK 0x0001 /* MICD_BIAS_SRC */ | ||
1275 | #define WM8996_MICD_BIAS_SRC_SHIFT 0 /* MICD_BIAS_SRC */ | ||
1276 | #define WM8996_MICD_BIAS_SRC_WIDTH 1 /* MICD_BIAS_SRC */ | ||
1277 | |||
1278 | /* | ||
1279 | * R52 (0x34) - Headphone Detect 1 | ||
1280 | */ | ||
1281 | #define WM8996_HP_HOLDTIME_MASK 0x00E0 /* HP_HOLDTIME - [7:5] */ | ||
1282 | #define WM8996_HP_HOLDTIME_SHIFT 5 /* HP_HOLDTIME - [7:5] */ | ||
1283 | #define WM8996_HP_HOLDTIME_WIDTH 3 /* HP_HOLDTIME - [7:5] */ | ||
1284 | #define WM8996_HP_CLK_DIV_MASK 0x0018 /* HP_CLK_DIV - [4:3] */ | ||
1285 | #define WM8996_HP_CLK_DIV_SHIFT 3 /* HP_CLK_DIV - [4:3] */ | ||
1286 | #define WM8996_HP_CLK_DIV_WIDTH 2 /* HP_CLK_DIV - [4:3] */ | ||
1287 | #define WM8996_HP_STEP_SIZE 0x0002 /* HP_STEP_SIZE */ | ||
1288 | #define WM8996_HP_STEP_SIZE_MASK 0x0002 /* HP_STEP_SIZE */ | ||
1289 | #define WM8996_HP_STEP_SIZE_SHIFT 1 /* HP_STEP_SIZE */ | ||
1290 | #define WM8996_HP_STEP_SIZE_WIDTH 1 /* HP_STEP_SIZE */ | ||
1291 | #define WM8996_HP_POLL 0x0001 /* HP_POLL */ | ||
1292 | #define WM8996_HP_POLL_MASK 0x0001 /* HP_POLL */ | ||
1293 | #define WM8996_HP_POLL_SHIFT 0 /* HP_POLL */ | ||
1294 | #define WM8996_HP_POLL_WIDTH 1 /* HP_POLL */ | ||
1295 | |||
1296 | /* | ||
1297 | * R53 (0x35) - Headphone Detect 2 | ||
1298 | */ | ||
1299 | #define WM8996_HP_DONE 0x0080 /* HP_DONE */ | ||
1300 | #define WM8996_HP_DONE_MASK 0x0080 /* HP_DONE */ | ||
1301 | #define WM8996_HP_DONE_SHIFT 7 /* HP_DONE */ | ||
1302 | #define WM8996_HP_DONE_WIDTH 1 /* HP_DONE */ | ||
1303 | #define WM8996_HP_LVL_MASK 0x007F /* HP_LVL - [6:0] */ | ||
1304 | #define WM8996_HP_LVL_SHIFT 0 /* HP_LVL - [6:0] */ | ||
1305 | #define WM8996_HP_LVL_WIDTH 7 /* HP_LVL - [6:0] */ | ||
1306 | |||
1307 | /* | ||
1308 | * R56 (0x38) - Mic Detect 1 | ||
1309 | */ | ||
1310 | #define WM8996_MICD_BIAS_STARTTIME_MASK 0xF000 /* MICD_BIAS_STARTTIME - [15:12] */ | ||
1311 | #define WM8996_MICD_BIAS_STARTTIME_SHIFT 12 /* MICD_BIAS_STARTTIME - [15:12] */ | ||
1312 | #define WM8996_MICD_BIAS_STARTTIME_WIDTH 4 /* MICD_BIAS_STARTTIME - [15:12] */ | ||
1313 | #define WM8996_MICD_RATE_MASK 0x0F00 /* MICD_RATE - [11:8] */ | ||
1314 | #define WM8996_MICD_RATE_SHIFT 8 /* MICD_RATE - [11:8] */ | ||
1315 | #define WM8996_MICD_RATE_WIDTH 4 /* MICD_RATE - [11:8] */ | ||
1316 | #define WM8996_MICD_DBTIME 0x0002 /* MICD_DBTIME */ | ||
1317 | #define WM8996_MICD_DBTIME_MASK 0x0002 /* MICD_DBTIME */ | ||
1318 | #define WM8996_MICD_DBTIME_SHIFT 1 /* MICD_DBTIME */ | ||
1319 | #define WM8996_MICD_DBTIME_WIDTH 1 /* MICD_DBTIME */ | ||
1320 | #define WM8996_MICD_ENA 0x0001 /* MICD_ENA */ | ||
1321 | #define WM8996_MICD_ENA_MASK 0x0001 /* MICD_ENA */ | ||
1322 | #define WM8996_MICD_ENA_SHIFT 0 /* MICD_ENA */ | ||
1323 | #define WM8996_MICD_ENA_WIDTH 1 /* MICD_ENA */ | ||
1324 | |||
1325 | /* | ||
1326 | * R57 (0x39) - Mic Detect 2 | ||
1327 | */ | ||
1328 | #define WM8996_MICD_LVL_SEL_MASK 0x00FF /* MICD_LVL_SEL - [7:0] */ | ||
1329 | #define WM8996_MICD_LVL_SEL_SHIFT 0 /* MICD_LVL_SEL - [7:0] */ | ||
1330 | #define WM8996_MICD_LVL_SEL_WIDTH 8 /* MICD_LVL_SEL - [7:0] */ | ||
1331 | |||
1332 | /* | ||
1333 | * R58 (0x3A) - Mic Detect 3 | ||
1334 | */ | ||
1335 | #define WM8996_MICD_LVL_MASK 0x07FC /* MICD_LVL - [10:2] */ | ||
1336 | #define WM8996_MICD_LVL_SHIFT 2 /* MICD_LVL - [10:2] */ | ||
1337 | #define WM8996_MICD_LVL_WIDTH 9 /* MICD_LVL - [10:2] */ | ||
1338 | #define WM8996_MICD_VALID 0x0002 /* MICD_VALID */ | ||
1339 | #define WM8996_MICD_VALID_MASK 0x0002 /* MICD_VALID */ | ||
1340 | #define WM8996_MICD_VALID_SHIFT 1 /* MICD_VALID */ | ||
1341 | #define WM8996_MICD_VALID_WIDTH 1 /* MICD_VALID */ | ||
1342 | #define WM8996_MICD_STS 0x0001 /* MICD_STS */ | ||
1343 | #define WM8996_MICD_STS_MASK 0x0001 /* MICD_STS */ | ||
1344 | #define WM8996_MICD_STS_SHIFT 0 /* MICD_STS */ | ||
1345 | #define WM8996_MICD_STS_WIDTH 1 /* MICD_STS */ | ||
1346 | |||
1347 | /* | ||
1348 | * R64 (0x40) - Charge Pump (1) | ||
1349 | */ | ||
1350 | #define WM8996_CP_ENA 0x8000 /* CP_ENA */ | ||
1351 | #define WM8996_CP_ENA_MASK 0x8000 /* CP_ENA */ | ||
1352 | #define WM8996_CP_ENA_SHIFT 15 /* CP_ENA */ | ||
1353 | #define WM8996_CP_ENA_WIDTH 1 /* CP_ENA */ | ||
1354 | |||
1355 | /* | ||
1356 | * R65 (0x41) - Charge Pump (2) | ||
1357 | */ | ||
1358 | #define WM8996_CP_DISCH 0x8000 /* CP_DISCH */ | ||
1359 | #define WM8996_CP_DISCH_MASK 0x8000 /* CP_DISCH */ | ||
1360 | #define WM8996_CP_DISCH_SHIFT 15 /* CP_DISCH */ | ||
1361 | #define WM8996_CP_DISCH_WIDTH 1 /* CP_DISCH */ | ||
1362 | |||
1363 | /* | ||
1364 | * R80 (0x50) - DC Servo (1) | ||
1365 | */ | ||
1366 | #define WM8996_DCS_ENA_CHAN_3 0x0008 /* DCS_ENA_CHAN_3 */ | ||
1367 | #define WM8996_DCS_ENA_CHAN_3_MASK 0x0008 /* DCS_ENA_CHAN_3 */ | ||
1368 | #define WM8996_DCS_ENA_CHAN_3_SHIFT 3 /* DCS_ENA_CHAN_3 */ | ||
1369 | #define WM8996_DCS_ENA_CHAN_3_WIDTH 1 /* DCS_ENA_CHAN_3 */ | ||
1370 | #define WM8996_DCS_ENA_CHAN_2 0x0004 /* DCS_ENA_CHAN_2 */ | ||
1371 | #define WM8996_DCS_ENA_CHAN_2_MASK 0x0004 /* DCS_ENA_CHAN_2 */ | ||
1372 | #define WM8996_DCS_ENA_CHAN_2_SHIFT 2 /* DCS_ENA_CHAN_2 */ | ||
1373 | #define WM8996_DCS_ENA_CHAN_2_WIDTH 1 /* DCS_ENA_CHAN_2 */ | ||
1374 | #define WM8996_DCS_ENA_CHAN_1 0x0002 /* DCS_ENA_CHAN_1 */ | ||
1375 | #define WM8996_DCS_ENA_CHAN_1_MASK 0x0002 /* DCS_ENA_CHAN_1 */ | ||
1376 | #define WM8996_DCS_ENA_CHAN_1_SHIFT 1 /* DCS_ENA_CHAN_1 */ | ||
1377 | #define WM8996_DCS_ENA_CHAN_1_WIDTH 1 /* DCS_ENA_CHAN_1 */ | ||
1378 | #define WM8996_DCS_ENA_CHAN_0 0x0001 /* DCS_ENA_CHAN_0 */ | ||
1379 | #define WM8996_DCS_ENA_CHAN_0_MASK 0x0001 /* DCS_ENA_CHAN_0 */ | ||
1380 | #define WM8996_DCS_ENA_CHAN_0_SHIFT 0 /* DCS_ENA_CHAN_0 */ | ||
1381 | #define WM8996_DCS_ENA_CHAN_0_WIDTH 1 /* DCS_ENA_CHAN_0 */ | ||
1382 | |||
1383 | /* | ||
1384 | * R81 (0x51) - DC Servo (2) | ||
1385 | */ | ||
1386 | #define WM8996_DCS_TRIG_SINGLE_3 0x8000 /* DCS_TRIG_SINGLE_3 */ | ||
1387 | #define WM8996_DCS_TRIG_SINGLE_3_MASK 0x8000 /* DCS_TRIG_SINGLE_3 */ | ||
1388 | #define WM8996_DCS_TRIG_SINGLE_3_SHIFT 15 /* DCS_TRIG_SINGLE_3 */ | ||
1389 | #define WM8996_DCS_TRIG_SINGLE_3_WIDTH 1 /* DCS_TRIG_SINGLE_3 */ | ||
1390 | #define WM8996_DCS_TRIG_SINGLE_2 0x4000 /* DCS_TRIG_SINGLE_2 */ | ||
1391 | #define WM8996_DCS_TRIG_SINGLE_2_MASK 0x4000 /* DCS_TRIG_SINGLE_2 */ | ||
1392 | #define WM8996_DCS_TRIG_SINGLE_2_SHIFT 14 /* DCS_TRIG_SINGLE_2 */ | ||
1393 | #define WM8996_DCS_TRIG_SINGLE_2_WIDTH 1 /* DCS_TRIG_SINGLE_2 */ | ||
1394 | #define WM8996_DCS_TRIG_SINGLE_1 0x2000 /* DCS_TRIG_SINGLE_1 */ | ||
1395 | #define WM8996_DCS_TRIG_SINGLE_1_MASK 0x2000 /* DCS_TRIG_SINGLE_1 */ | ||
1396 | #define WM8996_DCS_TRIG_SINGLE_1_SHIFT 13 /* DCS_TRIG_SINGLE_1 */ | ||
1397 | #define WM8996_DCS_TRIG_SINGLE_1_WIDTH 1 /* DCS_TRIG_SINGLE_1 */ | ||
1398 | #define WM8996_DCS_TRIG_SINGLE_0 0x1000 /* DCS_TRIG_SINGLE_0 */ | ||
1399 | #define WM8996_DCS_TRIG_SINGLE_0_MASK 0x1000 /* DCS_TRIG_SINGLE_0 */ | ||
1400 | #define WM8996_DCS_TRIG_SINGLE_0_SHIFT 12 /* DCS_TRIG_SINGLE_0 */ | ||
1401 | #define WM8996_DCS_TRIG_SINGLE_0_WIDTH 1 /* DCS_TRIG_SINGLE_0 */ | ||
1402 | #define WM8996_DCS_TRIG_SERIES_3 0x0800 /* DCS_TRIG_SERIES_3 */ | ||
1403 | #define WM8996_DCS_TRIG_SERIES_3_MASK 0x0800 /* DCS_TRIG_SERIES_3 */ | ||
1404 | #define WM8996_DCS_TRIG_SERIES_3_SHIFT 11 /* DCS_TRIG_SERIES_3 */ | ||
1405 | #define WM8996_DCS_TRIG_SERIES_3_WIDTH 1 /* DCS_TRIG_SERIES_3 */ | ||
1406 | #define WM8996_DCS_TRIG_SERIES_2 0x0400 /* DCS_TRIG_SERIES_2 */ | ||
1407 | #define WM8996_DCS_TRIG_SERIES_2_MASK 0x0400 /* DCS_TRIG_SERIES_2 */ | ||
1408 | #define WM8996_DCS_TRIG_SERIES_2_SHIFT 10 /* DCS_TRIG_SERIES_2 */ | ||
1409 | #define WM8996_DCS_TRIG_SERIES_2_WIDTH 1 /* DCS_TRIG_SERIES_2 */ | ||
1410 | #define WM8996_DCS_TRIG_SERIES_1 0x0200 /* DCS_TRIG_SERIES_1 */ | ||
1411 | #define WM8996_DCS_TRIG_SERIES_1_MASK 0x0200 /* DCS_TRIG_SERIES_1 */ | ||
1412 | #define WM8996_DCS_TRIG_SERIES_1_SHIFT 9 /* DCS_TRIG_SERIES_1 */ | ||
1413 | #define WM8996_DCS_TRIG_SERIES_1_WIDTH 1 /* DCS_TRIG_SERIES_1 */ | ||
1414 | #define WM8996_DCS_TRIG_SERIES_0 0x0100 /* DCS_TRIG_SERIES_0 */ | ||
1415 | #define WM8996_DCS_TRIG_SERIES_0_MASK 0x0100 /* DCS_TRIG_SERIES_0 */ | ||
1416 | #define WM8996_DCS_TRIG_SERIES_0_SHIFT 8 /* DCS_TRIG_SERIES_0 */ | ||
1417 | #define WM8996_DCS_TRIG_SERIES_0_WIDTH 1 /* DCS_TRIG_SERIES_0 */ | ||
1418 | #define WM8996_DCS_TRIG_STARTUP_3 0x0080 /* DCS_TRIG_STARTUP_3 */ | ||
1419 | #define WM8996_DCS_TRIG_STARTUP_3_MASK 0x0080 /* DCS_TRIG_STARTUP_3 */ | ||
1420 | #define WM8996_DCS_TRIG_STARTUP_3_SHIFT 7 /* DCS_TRIG_STARTUP_3 */ | ||
1421 | #define WM8996_DCS_TRIG_STARTUP_3_WIDTH 1 /* DCS_TRIG_STARTUP_3 */ | ||
1422 | #define WM8996_DCS_TRIG_STARTUP_2 0x0040 /* DCS_TRIG_STARTUP_2 */ | ||
1423 | #define WM8996_DCS_TRIG_STARTUP_2_MASK 0x0040 /* DCS_TRIG_STARTUP_2 */ | ||
1424 | #define WM8996_DCS_TRIG_STARTUP_2_SHIFT 6 /* DCS_TRIG_STARTUP_2 */ | ||
1425 | #define WM8996_DCS_TRIG_STARTUP_2_WIDTH 1 /* DCS_TRIG_STARTUP_2 */ | ||
1426 | #define WM8996_DCS_TRIG_STARTUP_1 0x0020 /* DCS_TRIG_STARTUP_1 */ | ||
1427 | #define WM8996_DCS_TRIG_STARTUP_1_MASK 0x0020 /* DCS_TRIG_STARTUP_1 */ | ||
1428 | #define WM8996_DCS_TRIG_STARTUP_1_SHIFT 5 /* DCS_TRIG_STARTUP_1 */ | ||
1429 | #define WM8996_DCS_TRIG_STARTUP_1_WIDTH 1 /* DCS_TRIG_STARTUP_1 */ | ||
1430 | #define WM8996_DCS_TRIG_STARTUP_0 0x0010 /* DCS_TRIG_STARTUP_0 */ | ||
1431 | #define WM8996_DCS_TRIG_STARTUP_0_MASK 0x0010 /* DCS_TRIG_STARTUP_0 */ | ||
1432 | #define WM8996_DCS_TRIG_STARTUP_0_SHIFT 4 /* DCS_TRIG_STARTUP_0 */ | ||
1433 | #define WM8996_DCS_TRIG_STARTUP_0_WIDTH 1 /* DCS_TRIG_STARTUP_0 */ | ||
1434 | #define WM8996_DCS_TRIG_DAC_WR_3 0x0008 /* DCS_TRIG_DAC_WR_3 */ | ||
1435 | #define WM8996_DCS_TRIG_DAC_WR_3_MASK 0x0008 /* DCS_TRIG_DAC_WR_3 */ | ||
1436 | #define WM8996_DCS_TRIG_DAC_WR_3_SHIFT 3 /* DCS_TRIG_DAC_WR_3 */ | ||
1437 | #define WM8996_DCS_TRIG_DAC_WR_3_WIDTH 1 /* DCS_TRIG_DAC_WR_3 */ | ||
1438 | #define WM8996_DCS_TRIG_DAC_WR_2 0x0004 /* DCS_TRIG_DAC_WR_2 */ | ||
1439 | #define WM8996_DCS_TRIG_DAC_WR_2_MASK 0x0004 /* DCS_TRIG_DAC_WR_2 */ | ||
1440 | #define WM8996_DCS_TRIG_DAC_WR_2_SHIFT 2 /* DCS_TRIG_DAC_WR_2 */ | ||
1441 | #define WM8996_DCS_TRIG_DAC_WR_2_WIDTH 1 /* DCS_TRIG_DAC_WR_2 */ | ||
1442 | #define WM8996_DCS_TRIG_DAC_WR_1 0x0002 /* DCS_TRIG_DAC_WR_1 */ | ||
1443 | #define WM8996_DCS_TRIG_DAC_WR_1_MASK 0x0002 /* DCS_TRIG_DAC_WR_1 */ | ||
1444 | #define WM8996_DCS_TRIG_DAC_WR_1_SHIFT 1 /* DCS_TRIG_DAC_WR_1 */ | ||
1445 | #define WM8996_DCS_TRIG_DAC_WR_1_WIDTH 1 /* DCS_TRIG_DAC_WR_1 */ | ||
1446 | #define WM8996_DCS_TRIG_DAC_WR_0 0x0001 /* DCS_TRIG_DAC_WR_0 */ | ||
1447 | #define WM8996_DCS_TRIG_DAC_WR_0_MASK 0x0001 /* DCS_TRIG_DAC_WR_0 */ | ||
1448 | #define WM8996_DCS_TRIG_DAC_WR_0_SHIFT 0 /* DCS_TRIG_DAC_WR_0 */ | ||
1449 | #define WM8996_DCS_TRIG_DAC_WR_0_WIDTH 1 /* DCS_TRIG_DAC_WR_0 */ | ||
1450 | |||
1451 | /* | ||
1452 | * R82 (0x52) - DC Servo (3) | ||
1453 | */ | ||
1454 | #define WM8996_DCS_TIMER_PERIOD_23_MASK 0x0F00 /* DCS_TIMER_PERIOD_23 - [11:8] */ | ||
1455 | #define WM8996_DCS_TIMER_PERIOD_23_SHIFT 8 /* DCS_TIMER_PERIOD_23 - [11:8] */ | ||
1456 | #define WM8996_DCS_TIMER_PERIOD_23_WIDTH 4 /* DCS_TIMER_PERIOD_23 - [11:8] */ | ||
1457 | #define WM8996_DCS_TIMER_PERIOD_01_MASK 0x000F /* DCS_TIMER_PERIOD_01 - [3:0] */ | ||
1458 | #define WM8996_DCS_TIMER_PERIOD_01_SHIFT 0 /* DCS_TIMER_PERIOD_01 - [3:0] */ | ||
1459 | #define WM8996_DCS_TIMER_PERIOD_01_WIDTH 4 /* DCS_TIMER_PERIOD_01 - [3:0] */ | ||
1460 | |||
1461 | /* | ||
1462 | * R84 (0x54) - DC Servo (5) | ||
1463 | */ | ||
1464 | #define WM8996_DCS_SERIES_NO_23_MASK 0x7F00 /* DCS_SERIES_NO_23 - [14:8] */ | ||
1465 | #define WM8996_DCS_SERIES_NO_23_SHIFT 8 /* DCS_SERIES_NO_23 - [14:8] */ | ||
1466 | #define WM8996_DCS_SERIES_NO_23_WIDTH 7 /* DCS_SERIES_NO_23 - [14:8] */ | ||
1467 | #define WM8996_DCS_SERIES_NO_01_MASK 0x007F /* DCS_SERIES_NO_01 - [6:0] */ | ||
1468 | #define WM8996_DCS_SERIES_NO_01_SHIFT 0 /* DCS_SERIES_NO_01 - [6:0] */ | ||
1469 | #define WM8996_DCS_SERIES_NO_01_WIDTH 7 /* DCS_SERIES_NO_01 - [6:0] */ | ||
1470 | |||
1471 | /* | ||
1472 | * R85 (0x55) - DC Servo (6) | ||
1473 | */ | ||
1474 | #define WM8996_DCS_DAC_WR_VAL_3_MASK 0xFF00 /* DCS_DAC_WR_VAL_3 - [15:8] */ | ||
1475 | #define WM8996_DCS_DAC_WR_VAL_3_SHIFT 8 /* DCS_DAC_WR_VAL_3 - [15:8] */ | ||
1476 | #define WM8996_DCS_DAC_WR_VAL_3_WIDTH 8 /* DCS_DAC_WR_VAL_3 - [15:8] */ | ||
1477 | #define WM8996_DCS_DAC_WR_VAL_2_MASK 0x00FF /* DCS_DAC_WR_VAL_2 - [7:0] */ | ||
1478 | #define WM8996_DCS_DAC_WR_VAL_2_SHIFT 0 /* DCS_DAC_WR_VAL_2 - [7:0] */ | ||
1479 | #define WM8996_DCS_DAC_WR_VAL_2_WIDTH 8 /* DCS_DAC_WR_VAL_2 - [7:0] */ | ||
1480 | |||
1481 | /* | ||
1482 | * R86 (0x56) - DC Servo (7) | ||
1483 | */ | ||
1484 | #define WM8996_DCS_DAC_WR_VAL_1_MASK 0xFF00 /* DCS_DAC_WR_VAL_1 - [15:8] */ | ||
1485 | #define WM8996_DCS_DAC_WR_VAL_1_SHIFT 8 /* DCS_DAC_WR_VAL_1 - [15:8] */ | ||
1486 | #define WM8996_DCS_DAC_WR_VAL_1_WIDTH 8 /* DCS_DAC_WR_VAL_1 - [15:8] */ | ||
1487 | #define WM8996_DCS_DAC_WR_VAL_0_MASK 0x00FF /* DCS_DAC_WR_VAL_0 - [7:0] */ | ||
1488 | #define WM8996_DCS_DAC_WR_VAL_0_SHIFT 0 /* DCS_DAC_WR_VAL_0 - [7:0] */ | ||
1489 | #define WM8996_DCS_DAC_WR_VAL_0_WIDTH 8 /* DCS_DAC_WR_VAL_0 - [7:0] */ | ||
1490 | |||
1491 | /* | ||
1492 | * R87 (0x57) - DC Servo Readback 0 | ||
1493 | */ | ||
1494 | #define WM8996_DCS_CAL_COMPLETE_MASK 0x0F00 /* DCS_CAL_COMPLETE - [11:8] */ | ||
1495 | #define WM8996_DCS_CAL_COMPLETE_SHIFT 8 /* DCS_CAL_COMPLETE - [11:8] */ | ||
1496 | #define WM8996_DCS_CAL_COMPLETE_WIDTH 4 /* DCS_CAL_COMPLETE - [11:8] */ | ||
1497 | #define WM8996_DCS_DAC_WR_COMPLETE_MASK 0x00F0 /* DCS_DAC_WR_COMPLETE - [7:4] */ | ||
1498 | #define WM8996_DCS_DAC_WR_COMPLETE_SHIFT 4 /* DCS_DAC_WR_COMPLETE - [7:4] */ | ||
1499 | #define WM8996_DCS_DAC_WR_COMPLETE_WIDTH 4 /* DCS_DAC_WR_COMPLETE - [7:4] */ | ||
1500 | #define WM8996_DCS_STARTUP_COMPLETE_MASK 0x000F /* DCS_STARTUP_COMPLETE - [3:0] */ | ||
1501 | #define WM8996_DCS_STARTUP_COMPLETE_SHIFT 0 /* DCS_STARTUP_COMPLETE - [3:0] */ | ||
1502 | #define WM8996_DCS_STARTUP_COMPLETE_WIDTH 4 /* DCS_STARTUP_COMPLETE - [3:0] */ | ||
1503 | |||
1504 | /* | ||
1505 | * R96 (0x60) - Analogue HP (1) | ||
1506 | */ | ||
1507 | #define WM8996_HPOUT1L_RMV_SHORT 0x0080 /* HPOUT1L_RMV_SHORT */ | ||
1508 | #define WM8996_HPOUT1L_RMV_SHORT_MASK 0x0080 /* HPOUT1L_RMV_SHORT */ | ||
1509 | #define WM8996_HPOUT1L_RMV_SHORT_SHIFT 7 /* HPOUT1L_RMV_SHORT */ | ||
1510 | #define WM8996_HPOUT1L_RMV_SHORT_WIDTH 1 /* HPOUT1L_RMV_SHORT */ | ||
1511 | #define WM8996_HPOUT1L_OUTP 0x0040 /* HPOUT1L_OUTP */ | ||
1512 | #define WM8996_HPOUT1L_OUTP_MASK 0x0040 /* HPOUT1L_OUTP */ | ||
1513 | #define WM8996_HPOUT1L_OUTP_SHIFT 6 /* HPOUT1L_OUTP */ | ||
1514 | #define WM8996_HPOUT1L_OUTP_WIDTH 1 /* HPOUT1L_OUTP */ | ||
1515 | #define WM8996_HPOUT1L_DLY 0x0020 /* HPOUT1L_DLY */ | ||
1516 | #define WM8996_HPOUT1L_DLY_MASK 0x0020 /* HPOUT1L_DLY */ | ||
1517 | #define WM8996_HPOUT1L_DLY_SHIFT 5 /* HPOUT1L_DLY */ | ||
1518 | #define WM8996_HPOUT1L_DLY_WIDTH 1 /* HPOUT1L_DLY */ | ||
1519 | #define WM8996_HPOUT1R_RMV_SHORT 0x0008 /* HPOUT1R_RMV_SHORT */ | ||
1520 | #define WM8996_HPOUT1R_RMV_SHORT_MASK 0x0008 /* HPOUT1R_RMV_SHORT */ | ||
1521 | #define WM8996_HPOUT1R_RMV_SHORT_SHIFT 3 /* HPOUT1R_RMV_SHORT */ | ||
1522 | #define WM8996_HPOUT1R_RMV_SHORT_WIDTH 1 /* HPOUT1R_RMV_SHORT */ | ||
1523 | #define WM8996_HPOUT1R_OUTP 0x0004 /* HPOUT1R_OUTP */ | ||
1524 | #define WM8996_HPOUT1R_OUTP_MASK 0x0004 /* HPOUT1R_OUTP */ | ||
1525 | #define WM8996_HPOUT1R_OUTP_SHIFT 2 /* HPOUT1R_OUTP */ | ||
1526 | #define WM8996_HPOUT1R_OUTP_WIDTH 1 /* HPOUT1R_OUTP */ | ||
1527 | #define WM8996_HPOUT1R_DLY 0x0002 /* HPOUT1R_DLY */ | ||
1528 | #define WM8996_HPOUT1R_DLY_MASK 0x0002 /* HPOUT1R_DLY */ | ||
1529 | #define WM8996_HPOUT1R_DLY_SHIFT 1 /* HPOUT1R_DLY */ | ||
1530 | #define WM8996_HPOUT1R_DLY_WIDTH 1 /* HPOUT1R_DLY */ | ||
1531 | |||
1532 | /* | ||
1533 | * R97 (0x61) - Analogue HP (2) | ||
1534 | */ | ||
1535 | #define WM8996_HPOUT2L_RMV_SHORT 0x0080 /* HPOUT2L_RMV_SHORT */ | ||
1536 | #define WM8996_HPOUT2L_RMV_SHORT_MASK 0x0080 /* HPOUT2L_RMV_SHORT */ | ||
1537 | #define WM8996_HPOUT2L_RMV_SHORT_SHIFT 7 /* HPOUT2L_RMV_SHORT */ | ||
1538 | #define WM8996_HPOUT2L_RMV_SHORT_WIDTH 1 /* HPOUT2L_RMV_SHORT */ | ||
1539 | #define WM8996_HPOUT2L_OUTP 0x0040 /* HPOUT2L_OUTP */ | ||
1540 | #define WM8996_HPOUT2L_OUTP_MASK 0x0040 /* HPOUT2L_OUTP */ | ||
1541 | #define WM8996_HPOUT2L_OUTP_SHIFT 6 /* HPOUT2L_OUTP */ | ||
1542 | #define WM8996_HPOUT2L_OUTP_WIDTH 1 /* HPOUT2L_OUTP */ | ||
1543 | #define WM8996_HPOUT2L_DLY 0x0020 /* HPOUT2L_DLY */ | ||
1544 | #define WM8996_HPOUT2L_DLY_MASK 0x0020 /* HPOUT2L_DLY */ | ||
1545 | #define WM8996_HPOUT2L_DLY_SHIFT 5 /* HPOUT2L_DLY */ | ||
1546 | #define WM8996_HPOUT2L_DLY_WIDTH 1 /* HPOUT2L_DLY */ | ||
1547 | #define WM8996_HPOUT2R_RMV_SHORT 0x0008 /* HPOUT2R_RMV_SHORT */ | ||
1548 | #define WM8996_HPOUT2R_RMV_SHORT_MASK 0x0008 /* HPOUT2R_RMV_SHORT */ | ||
1549 | #define WM8996_HPOUT2R_RMV_SHORT_SHIFT 3 /* HPOUT2R_RMV_SHORT */ | ||
1550 | #define WM8996_HPOUT2R_RMV_SHORT_WIDTH 1 /* HPOUT2R_RMV_SHORT */ | ||
1551 | #define WM8996_HPOUT2R_OUTP 0x0004 /* HPOUT2R_OUTP */ | ||
1552 | #define WM8996_HPOUT2R_OUTP_MASK 0x0004 /* HPOUT2R_OUTP */ | ||
1553 | #define WM8996_HPOUT2R_OUTP_SHIFT 2 /* HPOUT2R_OUTP */ | ||
1554 | #define WM8996_HPOUT2R_OUTP_WIDTH 1 /* HPOUT2R_OUTP */ | ||
1555 | #define WM8996_HPOUT2R_DLY 0x0002 /* HPOUT2R_DLY */ | ||
1556 | #define WM8996_HPOUT2R_DLY_MASK 0x0002 /* HPOUT2R_DLY */ | ||
1557 | #define WM8996_HPOUT2R_DLY_SHIFT 1 /* HPOUT2R_DLY */ | ||
1558 | #define WM8996_HPOUT2R_DLY_WIDTH 1 /* HPOUT2R_DLY */ | ||
1559 | |||
1560 | /* | ||
1561 | * R256 (0x100) - Chip Revision | ||
1562 | */ | ||
1563 | #define WM8996_CHIP_REV_MASK 0x000F /* CHIP_REV - [3:0] */ | ||
1564 | #define WM8996_CHIP_REV_SHIFT 0 /* CHIP_REV - [3:0] */ | ||
1565 | #define WM8996_CHIP_REV_WIDTH 4 /* CHIP_REV - [3:0] */ | ||
1566 | |||
1567 | /* | ||
1568 | * R257 (0x101) - Control Interface (1) | ||
1569 | */ | ||
1570 | #define WM8996_AUTO_INC 0x0004 /* AUTO_INC */ | ||
1571 | #define WM8996_AUTO_INC_MASK 0x0004 /* AUTO_INC */ | ||
1572 | #define WM8996_AUTO_INC_SHIFT 2 /* AUTO_INC */ | ||
1573 | #define WM8996_AUTO_INC_WIDTH 1 /* AUTO_INC */ | ||
1574 | |||
1575 | /* | ||
1576 | * R272 (0x110) - Write Sequencer Ctrl (1) | ||
1577 | */ | ||
1578 | #define WM8996_WSEQ_ENA 0x8000 /* WSEQ_ENA */ | ||
1579 | #define WM8996_WSEQ_ENA_MASK 0x8000 /* WSEQ_ENA */ | ||
1580 | #define WM8996_WSEQ_ENA_SHIFT 15 /* WSEQ_ENA */ | ||
1581 | #define WM8996_WSEQ_ENA_WIDTH 1 /* WSEQ_ENA */ | ||
1582 | #define WM8996_WSEQ_ABORT 0x0200 /* WSEQ_ABORT */ | ||
1583 | #define WM8996_WSEQ_ABORT_MASK 0x0200 /* WSEQ_ABORT */ | ||
1584 | #define WM8996_WSEQ_ABORT_SHIFT 9 /* WSEQ_ABORT */ | ||
1585 | #define WM8996_WSEQ_ABORT_WIDTH 1 /* WSEQ_ABORT */ | ||
1586 | #define WM8996_WSEQ_START 0x0100 /* WSEQ_START */ | ||
1587 | #define WM8996_WSEQ_START_MASK 0x0100 /* WSEQ_START */ | ||
1588 | #define WM8996_WSEQ_START_SHIFT 8 /* WSEQ_START */ | ||
1589 | #define WM8996_WSEQ_START_WIDTH 1 /* WSEQ_START */ | ||
1590 | #define WM8996_WSEQ_START_INDEX_MASK 0x007F /* WSEQ_START_INDEX - [6:0] */ | ||
1591 | #define WM8996_WSEQ_START_INDEX_SHIFT 0 /* WSEQ_START_INDEX - [6:0] */ | ||
1592 | #define WM8996_WSEQ_START_INDEX_WIDTH 7 /* WSEQ_START_INDEX - [6:0] */ | ||
1593 | |||
1594 | /* | ||
1595 | * R273 (0x111) - Write Sequencer Ctrl (2) | ||
1596 | */ | ||
1597 | #define WM8996_WSEQ_BUSY 0x0100 /* WSEQ_BUSY */ | ||
1598 | #define WM8996_WSEQ_BUSY_MASK 0x0100 /* WSEQ_BUSY */ | ||
1599 | #define WM8996_WSEQ_BUSY_SHIFT 8 /* WSEQ_BUSY */ | ||
1600 | #define WM8996_WSEQ_BUSY_WIDTH 1 /* WSEQ_BUSY */ | ||
1601 | #define WM8996_WSEQ_CURRENT_INDEX_MASK 0x007F /* WSEQ_CURRENT_INDEX - [6:0] */ | ||
1602 | #define WM8996_WSEQ_CURRENT_INDEX_SHIFT 0 /* WSEQ_CURRENT_INDEX - [6:0] */ | ||
1603 | #define WM8996_WSEQ_CURRENT_INDEX_WIDTH 7 /* WSEQ_CURRENT_INDEX - [6:0] */ | ||
1604 | |||
1605 | /* | ||
1606 | * R512 (0x200) - AIF Clocking (1) | ||
1607 | */ | ||
1608 | #define WM8996_SYSCLK_SRC_MASK 0x0018 /* SYSCLK_SRC - [4:3] */ | ||
1609 | #define WM8996_SYSCLK_SRC_SHIFT 3 /* SYSCLK_SRC - [4:3] */ | ||
1610 | #define WM8996_SYSCLK_SRC_WIDTH 2 /* SYSCLK_SRC - [4:3] */ | ||
1611 | #define WM8996_SYSCLK_INV 0x0004 /* SYSCLK_INV */ | ||
1612 | #define WM8996_SYSCLK_INV_MASK 0x0004 /* SYSCLK_INV */ | ||
1613 | #define WM8996_SYSCLK_INV_SHIFT 2 /* SYSCLK_INV */ | ||
1614 | #define WM8996_SYSCLK_INV_WIDTH 1 /* SYSCLK_INV */ | ||
1615 | #define WM8996_SYSCLK_DIV 0x0002 /* SYSCLK_DIV */ | ||
1616 | #define WM8996_SYSCLK_DIV_MASK 0x0002 /* SYSCLK_DIV */ | ||
1617 | #define WM8996_SYSCLK_DIV_SHIFT 1 /* SYSCLK_DIV */ | ||
1618 | #define WM8996_SYSCLK_DIV_WIDTH 1 /* SYSCLK_DIV */ | ||
1619 | #define WM8996_SYSCLK_ENA 0x0001 /* SYSCLK_ENA */ | ||
1620 | #define WM8996_SYSCLK_ENA_MASK 0x0001 /* SYSCLK_ENA */ | ||
1621 | #define WM8996_SYSCLK_ENA_SHIFT 0 /* SYSCLK_ENA */ | ||
1622 | #define WM8996_SYSCLK_ENA_WIDTH 1 /* SYSCLK_ENA */ | ||
1623 | |||
1624 | /* | ||
1625 | * R513 (0x201) - AIF Clocking (2) | ||
1626 | */ | ||
1627 | #define WM8996_DSP2_DIV_MASK 0x0018 /* DSP2_DIV - [4:3] */ | ||
1628 | #define WM8996_DSP2_DIV_SHIFT 3 /* DSP2_DIV - [4:3] */ | ||
1629 | #define WM8996_DSP2_DIV_WIDTH 2 /* DSP2_DIV - [4:3] */ | ||
1630 | #define WM8996_DSP1_DIV_MASK 0x0003 /* DSP1_DIV - [1:0] */ | ||
1631 | #define WM8996_DSP1_DIV_SHIFT 0 /* DSP1_DIV - [1:0] */ | ||
1632 | #define WM8996_DSP1_DIV_WIDTH 2 /* DSP1_DIV - [1:0] */ | ||
1633 | |||
1634 | /* | ||
1635 | * R520 (0x208) - Clocking (1) | ||
1636 | */ | ||
1637 | #define WM8996_LFCLK_ENA 0x0020 /* LFCLK_ENA */ | ||
1638 | #define WM8996_LFCLK_ENA_MASK 0x0020 /* LFCLK_ENA */ | ||
1639 | #define WM8996_LFCLK_ENA_SHIFT 5 /* LFCLK_ENA */ | ||
1640 | #define WM8996_LFCLK_ENA_WIDTH 1 /* LFCLK_ENA */ | ||
1641 | #define WM8996_TOCLK_ENA 0x0010 /* TOCLK_ENA */ | ||
1642 | #define WM8996_TOCLK_ENA_MASK 0x0010 /* TOCLK_ENA */ | ||
1643 | #define WM8996_TOCLK_ENA_SHIFT 4 /* TOCLK_ENA */ | ||
1644 | #define WM8996_TOCLK_ENA_WIDTH 1 /* TOCLK_ENA */ | ||
1645 | #define WM8996_AIFCLK_ENA 0x0004 /* AIFCLK_ENA */ | ||
1646 | #define WM8996_AIFCLK_ENA_MASK 0x0004 /* AIFCLK_ENA */ | ||
1647 | #define WM8996_AIFCLK_ENA_SHIFT 2 /* AIFCLK_ENA */ | ||
1648 | #define WM8996_AIFCLK_ENA_WIDTH 1 /* AIFCLK_ENA */ | ||
1649 | #define WM8996_SYSDSPCLK_ENA 0x0002 /* SYSDSPCLK_ENA */ | ||
1650 | #define WM8996_SYSDSPCLK_ENA_MASK 0x0002 /* SYSDSPCLK_ENA */ | ||
1651 | #define WM8996_SYSDSPCLK_ENA_SHIFT 1 /* SYSDSPCLK_ENA */ | ||
1652 | #define WM8996_SYSDSPCLK_ENA_WIDTH 1 /* SYSDSPCLK_ENA */ | ||
1653 | |||
1654 | /* | ||
1655 | * R521 (0x209) - Clocking (2) | ||
1656 | */ | ||
1657 | #define WM8996_TOCLK_DIV_MASK 0x0700 /* TOCLK_DIV - [10:8] */ | ||
1658 | #define WM8996_TOCLK_DIV_SHIFT 8 /* TOCLK_DIV - [10:8] */ | ||
1659 | #define WM8996_TOCLK_DIV_WIDTH 3 /* TOCLK_DIV - [10:8] */ | ||
1660 | #define WM8996_DBCLK_DIV_MASK 0x00F0 /* DBCLK_DIV - [7:4] */ | ||
1661 | #define WM8996_DBCLK_DIV_SHIFT 4 /* DBCLK_DIV - [7:4] */ | ||
1662 | #define WM8996_DBCLK_DIV_WIDTH 4 /* DBCLK_DIV - [7:4] */ | ||
1663 | #define WM8996_OPCLK_DIV_MASK 0x0007 /* OPCLK_DIV - [2:0] */ | ||
1664 | #define WM8996_OPCLK_DIV_SHIFT 0 /* OPCLK_DIV - [2:0] */ | ||
1665 | #define WM8996_OPCLK_DIV_WIDTH 3 /* OPCLK_DIV - [2:0] */ | ||
1666 | |||
1667 | /* | ||
1668 | * R528 (0x210) - AIF Rate | ||
1669 | */ | ||
1670 | #define WM8996_SYSCLK_RATE 0x0001 /* SYSCLK_RATE */ | ||
1671 | #define WM8996_SYSCLK_RATE_MASK 0x0001 /* SYSCLK_RATE */ | ||
1672 | #define WM8996_SYSCLK_RATE_SHIFT 0 /* SYSCLK_RATE */ | ||
1673 | #define WM8996_SYSCLK_RATE_WIDTH 1 /* SYSCLK_RATE */ | ||
1674 | |||
1675 | /* | ||
1676 | * R544 (0x220) - FLL Control (1) | ||
1677 | */ | ||
1678 | #define WM8996_FLL_OSC_ENA 0x0002 /* FLL_OSC_ENA */ | ||
1679 | #define WM8996_FLL_OSC_ENA_MASK 0x0002 /* FLL_OSC_ENA */ | ||
1680 | #define WM8996_FLL_OSC_ENA_SHIFT 1 /* FLL_OSC_ENA */ | ||
1681 | #define WM8996_FLL_OSC_ENA_WIDTH 1 /* FLL_OSC_ENA */ | ||
1682 | #define WM8996_FLL_ENA 0x0001 /* FLL_ENA */ | ||
1683 | #define WM8996_FLL_ENA_MASK 0x0001 /* FLL_ENA */ | ||
1684 | #define WM8996_FLL_ENA_SHIFT 0 /* FLL_ENA */ | ||
1685 | #define WM8996_FLL_ENA_WIDTH 1 /* FLL_ENA */ | ||
1686 | |||
1687 | /* | ||
1688 | * R545 (0x221) - FLL Control (2) | ||
1689 | */ | ||
1690 | #define WM8996_FLL_OUTDIV_MASK 0x3F00 /* FLL_OUTDIV - [13:8] */ | ||
1691 | #define WM8996_FLL_OUTDIV_SHIFT 8 /* FLL_OUTDIV - [13:8] */ | ||
1692 | #define WM8996_FLL_OUTDIV_WIDTH 6 /* FLL_OUTDIV - [13:8] */ | ||
1693 | #define WM8996_FLL_FRATIO_MASK 0x0007 /* FLL_FRATIO - [2:0] */ | ||
1694 | #define WM8996_FLL_FRATIO_SHIFT 0 /* FLL_FRATIO - [2:0] */ | ||
1695 | #define WM8996_FLL_FRATIO_WIDTH 3 /* FLL_FRATIO - [2:0] */ | ||
1696 | |||
1697 | /* | ||
1698 | * R546 (0x222) - FLL Control (3) | ||
1699 | */ | ||
1700 | #define WM8996_FLL_THETA_MASK 0xFFFF /* FLL_THETA - [15:0] */ | ||
1701 | #define WM8996_FLL_THETA_SHIFT 0 /* FLL_THETA - [15:0] */ | ||
1702 | #define WM8996_FLL_THETA_WIDTH 16 /* FLL_THETA - [15:0] */ | ||
1703 | |||
1704 | /* | ||
1705 | * R547 (0x223) - FLL Control (4) | ||
1706 | */ | ||
1707 | #define WM8996_FLL_N_MASK 0x7FE0 /* FLL_N - [14:5] */ | ||
1708 | #define WM8996_FLL_N_SHIFT 5 /* FLL_N - [14:5] */ | ||
1709 | #define WM8996_FLL_N_WIDTH 10 /* FLL_N - [14:5] */ | ||
1710 | #define WM8996_FLL_LOOP_GAIN_MASK 0x000F /* FLL_LOOP_GAIN - [3:0] */ | ||
1711 | #define WM8996_FLL_LOOP_GAIN_SHIFT 0 /* FLL_LOOP_GAIN - [3:0] */ | ||
1712 | #define WM8996_FLL_LOOP_GAIN_WIDTH 4 /* FLL_LOOP_GAIN - [3:0] */ | ||
1713 | |||
1714 | /* | ||
1715 | * R548 (0x224) - FLL Control (5) | ||
1716 | */ | ||
1717 | #define WM8996_FLL_FRC_NCO_VAL_MASK 0x1F80 /* FLL_FRC_NCO_VAL - [12:7] */ | ||
1718 | #define WM8996_FLL_FRC_NCO_VAL_SHIFT 7 /* FLL_FRC_NCO_VAL - [12:7] */ | ||
1719 | #define WM8996_FLL_FRC_NCO_VAL_WIDTH 6 /* FLL_FRC_NCO_VAL - [12:7] */ | ||
1720 | #define WM8996_FLL_FRC_NCO 0x0040 /* FLL_FRC_NCO */ | ||
1721 | #define WM8996_FLL_FRC_NCO_MASK 0x0040 /* FLL_FRC_NCO */ | ||
1722 | #define WM8996_FLL_FRC_NCO_SHIFT 6 /* FLL_FRC_NCO */ | ||
1723 | #define WM8996_FLL_FRC_NCO_WIDTH 1 /* FLL_FRC_NCO */ | ||
1724 | #define WM8996_FLL_REFCLK_DIV_MASK 0x0018 /* FLL_REFCLK_DIV - [4:3] */ | ||
1725 | #define WM8996_FLL_REFCLK_DIV_SHIFT 3 /* FLL_REFCLK_DIV - [4:3] */ | ||
1726 | #define WM8996_FLL_REFCLK_DIV_WIDTH 2 /* FLL_REFCLK_DIV - [4:3] */ | ||
1727 | #define WM8996_FLL_REF_FREQ 0x0004 /* FLL_REF_FREQ */ | ||
1728 | #define WM8996_FLL_REF_FREQ_MASK 0x0004 /* FLL_REF_FREQ */ | ||
1729 | #define WM8996_FLL_REF_FREQ_SHIFT 2 /* FLL_REF_FREQ */ | ||
1730 | #define WM8996_FLL_REF_FREQ_WIDTH 1 /* FLL_REF_FREQ */ | ||
1731 | #define WM8996_FLL_REFCLK_SRC_MASK 0x0003 /* FLL_REFCLK_SRC - [1:0] */ | ||
1732 | #define WM8996_FLL_REFCLK_SRC_SHIFT 0 /* FLL_REFCLK_SRC - [1:0] */ | ||
1733 | #define WM8996_FLL_REFCLK_SRC_WIDTH 2 /* FLL_REFCLK_SRC - [1:0] */ | ||
1734 | |||
1735 | /* | ||
1736 | * R549 (0x225) - FLL Control (6) | ||
1737 | */ | ||
1738 | #define WM8996_FLL_REFCLK_SRC_STS_MASK 0x000C /* FLL_REFCLK_SRC_STS - [3:2] */ | ||
1739 | #define WM8996_FLL_REFCLK_SRC_STS_SHIFT 2 /* FLL_REFCLK_SRC_STS - [3:2] */ | ||
1740 | #define WM8996_FLL_REFCLK_SRC_STS_WIDTH 2 /* FLL_REFCLK_SRC_STS - [3:2] */ | ||
1741 | #define WM8996_FLL_SWITCH_CLK 0x0001 /* FLL_SWITCH_CLK */ | ||
1742 | #define WM8996_FLL_SWITCH_CLK_MASK 0x0001 /* FLL_SWITCH_CLK */ | ||
1743 | #define WM8996_FLL_SWITCH_CLK_SHIFT 0 /* FLL_SWITCH_CLK */ | ||
1744 | #define WM8996_FLL_SWITCH_CLK_WIDTH 1 /* FLL_SWITCH_CLK */ | ||
1745 | |||
1746 | /* | ||
1747 | * R550 (0x226) - FLL EFS 1 | ||
1748 | */ | ||
1749 | #define WM8996_FLL_LAMBDA_MASK 0xFFFF /* FLL_LAMBDA - [15:0] */ | ||
1750 | #define WM8996_FLL_LAMBDA_SHIFT 0 /* FLL_LAMBDA - [15:0] */ | ||
1751 | #define WM8996_FLL_LAMBDA_WIDTH 16 /* FLL_LAMBDA - [15:0] */ | ||
1752 | |||
1753 | /* | ||
1754 | * R551 (0x227) - FLL EFS 2 | ||
1755 | */ | ||
1756 | #define WM8996_FLL_LFSR_SEL_MASK 0x0006 /* FLL_LFSR_SEL - [2:1] */ | ||
1757 | #define WM8996_FLL_LFSR_SEL_SHIFT 1 /* FLL_LFSR_SEL - [2:1] */ | ||
1758 | #define WM8996_FLL_LFSR_SEL_WIDTH 2 /* FLL_LFSR_SEL - [2:1] */ | ||
1759 | #define WM8996_FLL_EFS_ENA 0x0001 /* FLL_EFS_ENA */ | ||
1760 | #define WM8996_FLL_EFS_ENA_MASK 0x0001 /* FLL_EFS_ENA */ | ||
1761 | #define WM8996_FLL_EFS_ENA_SHIFT 0 /* FLL_EFS_ENA */ | ||
1762 | #define WM8996_FLL_EFS_ENA_WIDTH 1 /* FLL_EFS_ENA */ | ||
1763 | |||
1764 | /* | ||
1765 | * R768 (0x300) - AIF1 Control | ||
1766 | */ | ||
1767 | #define WM8996_AIF1_TRI 0x0004 /* AIF1_TRI */ | ||
1768 | #define WM8996_AIF1_TRI_MASK 0x0004 /* AIF1_TRI */ | ||
1769 | #define WM8996_AIF1_TRI_SHIFT 2 /* AIF1_TRI */ | ||
1770 | #define WM8996_AIF1_TRI_WIDTH 1 /* AIF1_TRI */ | ||
1771 | #define WM8996_AIF1_FMT_MASK 0x0003 /* AIF1_FMT - [1:0] */ | ||
1772 | #define WM8996_AIF1_FMT_SHIFT 0 /* AIF1_FMT - [1:0] */ | ||
1773 | #define WM8996_AIF1_FMT_WIDTH 2 /* AIF1_FMT - [1:0] */ | ||
1774 | |||
1775 | /* | ||
1776 | * R769 (0x301) - AIF1 BCLK | ||
1777 | */ | ||
1778 | #define WM8996_AIF1_BCLK_INV 0x0400 /* AIF1_BCLK_INV */ | ||
1779 | #define WM8996_AIF1_BCLK_INV_MASK 0x0400 /* AIF1_BCLK_INV */ | ||
1780 | #define WM8996_AIF1_BCLK_INV_SHIFT 10 /* AIF1_BCLK_INV */ | ||
1781 | #define WM8996_AIF1_BCLK_INV_WIDTH 1 /* AIF1_BCLK_INV */ | ||
1782 | #define WM8996_AIF1_BCLK_FRC 0x0200 /* AIF1_BCLK_FRC */ | ||
1783 | #define WM8996_AIF1_BCLK_FRC_MASK 0x0200 /* AIF1_BCLK_FRC */ | ||
1784 | #define WM8996_AIF1_BCLK_FRC_SHIFT 9 /* AIF1_BCLK_FRC */ | ||
1785 | #define WM8996_AIF1_BCLK_FRC_WIDTH 1 /* AIF1_BCLK_FRC */ | ||
1786 | #define WM8996_AIF1_BCLK_MSTR 0x0100 /* AIF1_BCLK_MSTR */ | ||
1787 | #define WM8996_AIF1_BCLK_MSTR_MASK 0x0100 /* AIF1_BCLK_MSTR */ | ||
1788 | #define WM8996_AIF1_BCLK_MSTR_SHIFT 8 /* AIF1_BCLK_MSTR */ | ||
1789 | #define WM8996_AIF1_BCLK_MSTR_WIDTH 1 /* AIF1_BCLK_MSTR */ | ||
1790 | #define WM8996_AIF1_BCLK_DIV_MASK 0x000F /* AIF1_BCLK_DIV - [3:0] */ | ||
1791 | #define WM8996_AIF1_BCLK_DIV_SHIFT 0 /* AIF1_BCLK_DIV - [3:0] */ | ||
1792 | #define WM8996_AIF1_BCLK_DIV_WIDTH 4 /* AIF1_BCLK_DIV - [3:0] */ | ||
1793 | |||
1794 | /* | ||
1795 | * R770 (0x302) - AIF1 TX LRCLK(1) | ||
1796 | */ | ||
1797 | #define WM8996_AIF1TX_RATE_MASK 0x07FF /* AIF1TX_RATE - [10:0] */ | ||
1798 | #define WM8996_AIF1TX_RATE_SHIFT 0 /* AIF1TX_RATE - [10:0] */ | ||
1799 | #define WM8996_AIF1TX_RATE_WIDTH 11 /* AIF1TX_RATE - [10:0] */ | ||
1800 | |||
1801 | /* | ||
1802 | * R771 (0x303) - AIF1 TX LRCLK(2) | ||
1803 | */ | ||
1804 | #define WM8996_AIF1TX_LRCLK_MODE 0x0008 /* AIF1TX_LRCLK_MODE */ | ||
1805 | #define WM8996_AIF1TX_LRCLK_MODE_MASK 0x0008 /* AIF1TX_LRCLK_MODE */ | ||
1806 | #define WM8996_AIF1TX_LRCLK_MODE_SHIFT 3 /* AIF1TX_LRCLK_MODE */ | ||
1807 | #define WM8996_AIF1TX_LRCLK_MODE_WIDTH 1 /* AIF1TX_LRCLK_MODE */ | ||
1808 | #define WM8996_AIF1TX_LRCLK_INV 0x0004 /* AIF1TX_LRCLK_INV */ | ||
1809 | #define WM8996_AIF1TX_LRCLK_INV_MASK 0x0004 /* AIF1TX_LRCLK_INV */ | ||
1810 | #define WM8996_AIF1TX_LRCLK_INV_SHIFT 2 /* AIF1TX_LRCLK_INV */ | ||
1811 | #define WM8996_AIF1TX_LRCLK_INV_WIDTH 1 /* AIF1TX_LRCLK_INV */ | ||
1812 | #define WM8996_AIF1TX_LRCLK_FRC 0x0002 /* AIF1TX_LRCLK_FRC */ | ||
1813 | #define WM8996_AIF1TX_LRCLK_FRC_MASK 0x0002 /* AIF1TX_LRCLK_FRC */ | ||
1814 | #define WM8996_AIF1TX_LRCLK_FRC_SHIFT 1 /* AIF1TX_LRCLK_FRC */ | ||
1815 | #define WM8996_AIF1TX_LRCLK_FRC_WIDTH 1 /* AIF1TX_LRCLK_FRC */ | ||
1816 | #define WM8996_AIF1TX_LRCLK_MSTR 0x0001 /* AIF1TX_LRCLK_MSTR */ | ||
1817 | #define WM8996_AIF1TX_LRCLK_MSTR_MASK 0x0001 /* AIF1TX_LRCLK_MSTR */ | ||
1818 | #define WM8996_AIF1TX_LRCLK_MSTR_SHIFT 0 /* AIF1TX_LRCLK_MSTR */ | ||
1819 | #define WM8996_AIF1TX_LRCLK_MSTR_WIDTH 1 /* AIF1TX_LRCLK_MSTR */ | ||
1820 | |||
1821 | /* | ||
1822 | * R772 (0x304) - AIF1 RX LRCLK(1) | ||
1823 | */ | ||
1824 | #define WM8996_AIF1RX_RATE_MASK 0x07FF /* AIF1RX_RATE - [10:0] */ | ||
1825 | #define WM8996_AIF1RX_RATE_SHIFT 0 /* AIF1RX_RATE - [10:0] */ | ||
1826 | #define WM8996_AIF1RX_RATE_WIDTH 11 /* AIF1RX_RATE - [10:0] */ | ||
1827 | |||
1828 | /* | ||
1829 | * R773 (0x305) - AIF1 RX LRCLK(2) | ||
1830 | */ | ||
1831 | #define WM8996_AIF1RX_LRCLK_INV 0x0004 /* AIF1RX_LRCLK_INV */ | ||
1832 | #define WM8996_AIF1RX_LRCLK_INV_MASK 0x0004 /* AIF1RX_LRCLK_INV */ | ||
1833 | #define WM8996_AIF1RX_LRCLK_INV_SHIFT 2 /* AIF1RX_LRCLK_INV */ | ||
1834 | #define WM8996_AIF1RX_LRCLK_INV_WIDTH 1 /* AIF1RX_LRCLK_INV */ | ||
1835 | #define WM8996_AIF1RX_LRCLK_FRC 0x0002 /* AIF1RX_LRCLK_FRC */ | ||
1836 | #define WM8996_AIF1RX_LRCLK_FRC_MASK 0x0002 /* AIF1RX_LRCLK_FRC */ | ||
1837 | #define WM8996_AIF1RX_LRCLK_FRC_SHIFT 1 /* AIF1RX_LRCLK_FRC */ | ||
1838 | #define WM8996_AIF1RX_LRCLK_FRC_WIDTH 1 /* AIF1RX_LRCLK_FRC */ | ||
1839 | #define WM8996_AIF1RX_LRCLK_MSTR 0x0001 /* AIF1RX_LRCLK_MSTR */ | ||
1840 | #define WM8996_AIF1RX_LRCLK_MSTR_MASK 0x0001 /* AIF1RX_LRCLK_MSTR */ | ||
1841 | #define WM8996_AIF1RX_LRCLK_MSTR_SHIFT 0 /* AIF1RX_LRCLK_MSTR */ | ||
1842 | #define WM8996_AIF1RX_LRCLK_MSTR_WIDTH 1 /* AIF1RX_LRCLK_MSTR */ | ||
1843 | |||
1844 | /* | ||
1845 | * R774 (0x306) - AIF1TX Data Configuration (1) | ||
1846 | */ | ||
1847 | #define WM8996_AIF1TX_WL_MASK 0xFF00 /* AIF1TX_WL - [15:8] */ | ||
1848 | #define WM8996_AIF1TX_WL_SHIFT 8 /* AIF1TX_WL - [15:8] */ | ||
1849 | #define WM8996_AIF1TX_WL_WIDTH 8 /* AIF1TX_WL - [15:8] */ | ||
1850 | #define WM8996_AIF1TX_SLOT_LEN_MASK 0x00FF /* AIF1TX_SLOT_LEN - [7:0] */ | ||
1851 | #define WM8996_AIF1TX_SLOT_LEN_SHIFT 0 /* AIF1TX_SLOT_LEN - [7:0] */ | ||
1852 | #define WM8996_AIF1TX_SLOT_LEN_WIDTH 8 /* AIF1TX_SLOT_LEN - [7:0] */ | ||
1853 | |||
1854 | /* | ||
1855 | * R775 (0x307) - AIF1TX Data Configuration (2) | ||
1856 | */ | ||
1857 | #define WM8996_AIF1TX_DAT_TRI 0x0001 /* AIF1TX_DAT_TRI */ | ||
1858 | #define WM8996_AIF1TX_DAT_TRI_MASK 0x0001 /* AIF1TX_DAT_TRI */ | ||
1859 | #define WM8996_AIF1TX_DAT_TRI_SHIFT 0 /* AIF1TX_DAT_TRI */ | ||
1860 | #define WM8996_AIF1TX_DAT_TRI_WIDTH 1 /* AIF1TX_DAT_TRI */ | ||
1861 | |||
1862 | /* | ||
1863 | * R776 (0x308) - AIF1RX Data Configuration | ||
1864 | */ | ||
1865 | #define WM8996_AIF1RX_WL_MASK 0xFF00 /* AIF1RX_WL - [15:8] */ | ||
1866 | #define WM8996_AIF1RX_WL_SHIFT 8 /* AIF1RX_WL - [15:8] */ | ||
1867 | #define WM8996_AIF1RX_WL_WIDTH 8 /* AIF1RX_WL - [15:8] */ | ||
1868 | #define WM8996_AIF1RX_SLOT_LEN_MASK 0x00FF /* AIF1RX_SLOT_LEN - [7:0] */ | ||
1869 | #define WM8996_AIF1RX_SLOT_LEN_SHIFT 0 /* AIF1RX_SLOT_LEN - [7:0] */ | ||
1870 | #define WM8996_AIF1RX_SLOT_LEN_WIDTH 8 /* AIF1RX_SLOT_LEN - [7:0] */ | ||
1871 | |||
1872 | /* | ||
1873 | * R777 (0x309) - AIF1TX Channel 0 Configuration | ||
1874 | */ | ||
1875 | #define WM8996_AIF1TX_CHAN0_DAT_INV 0x8000 /* AIF1TX_CHAN0_DAT_INV */ | ||
1876 | #define WM8996_AIF1TX_CHAN0_DAT_INV_MASK 0x8000 /* AIF1TX_CHAN0_DAT_INV */ | ||
1877 | #define WM8996_AIF1TX_CHAN0_DAT_INV_SHIFT 15 /* AIF1TX_CHAN0_DAT_INV */ | ||
1878 | #define WM8996_AIF1TX_CHAN0_DAT_INV_WIDTH 1 /* AIF1TX_CHAN0_DAT_INV */ | ||
1879 | #define WM8996_AIF1TX_CHAN0_SPACING_MASK 0x7E00 /* AIF1TX_CHAN0_SPACING - [14:9] */ | ||
1880 | #define WM8996_AIF1TX_CHAN0_SPACING_SHIFT 9 /* AIF1TX_CHAN0_SPACING - [14:9] */ | ||
1881 | #define WM8996_AIF1TX_CHAN0_SPACING_WIDTH 6 /* AIF1TX_CHAN0_SPACING - [14:9] */ | ||
1882 | #define WM8996_AIF1TX_CHAN0_SLOTS_MASK 0x01C0 /* AIF1TX_CHAN0_SLOTS - [8:6] */ | ||
1883 | #define WM8996_AIF1TX_CHAN0_SLOTS_SHIFT 6 /* AIF1TX_CHAN0_SLOTS - [8:6] */ | ||
1884 | #define WM8996_AIF1TX_CHAN0_SLOTS_WIDTH 3 /* AIF1TX_CHAN0_SLOTS - [8:6] */ | ||
1885 | #define WM8996_AIF1TX_CHAN0_START_SLOT_MASK 0x003F /* AIF1TX_CHAN0_START_SLOT - [5:0] */ | ||
1886 | #define WM8996_AIF1TX_CHAN0_START_SLOT_SHIFT 0 /* AIF1TX_CHAN0_START_SLOT - [5:0] */ | ||
1887 | #define WM8996_AIF1TX_CHAN0_START_SLOT_WIDTH 6 /* AIF1TX_CHAN0_START_SLOT - [5:0] */ | ||
1888 | |||
1889 | /* | ||
1890 | * R778 (0x30A) - AIF1TX Channel 1 Configuration | ||
1891 | */ | ||
1892 | #define WM8996_AIF1TX_CHAN1_DAT_INV 0x8000 /* AIF1TX_CHAN1_DAT_INV */ | ||
1893 | #define WM8996_AIF1TX_CHAN1_DAT_INV_MASK 0x8000 /* AIF1TX_CHAN1_DAT_INV */ | ||
1894 | #define WM8996_AIF1TX_CHAN1_DAT_INV_SHIFT 15 /* AIF1TX_CHAN1_DAT_INV */ | ||
1895 | #define WM8996_AIF1TX_CHAN1_DAT_INV_WIDTH 1 /* AIF1TX_CHAN1_DAT_INV */ | ||
1896 | #define WM8996_AIF1TX_CHAN1_SPACING_MASK 0x7E00 /* AIF1TX_CHAN1_SPACING - [14:9] */ | ||
1897 | #define WM8996_AIF1TX_CHAN1_SPACING_SHIFT 9 /* AIF1TX_CHAN1_SPACING - [14:9] */ | ||
1898 | #define WM8996_AIF1TX_CHAN1_SPACING_WIDTH 6 /* AIF1TX_CHAN1_SPACING - [14:9] */ | ||
1899 | #define WM8996_AIF1TX_CHAN1_SLOTS_MASK 0x01C0 /* AIF1TX_CHAN1_SLOTS - [8:6] */ | ||
1900 | #define WM8996_AIF1TX_CHAN1_SLOTS_SHIFT 6 /* AIF1TX_CHAN1_SLOTS - [8:6] */ | ||
1901 | #define WM8996_AIF1TX_CHAN1_SLOTS_WIDTH 3 /* AIF1TX_CHAN1_SLOTS - [8:6] */ | ||
1902 | #define WM8996_AIF1TX_CHAN1_START_SLOT_MASK 0x003F /* AIF1TX_CHAN1_START_SLOT - [5:0] */ | ||
1903 | #define WM8996_AIF1TX_CHAN1_START_SLOT_SHIFT 0 /* AIF1TX_CHAN1_START_SLOT - [5:0] */ | ||
1904 | #define WM8996_AIF1TX_CHAN1_START_SLOT_WIDTH 6 /* AIF1TX_CHAN1_START_SLOT - [5:0] */ | ||
1905 | |||
1906 | /* | ||
1907 | * R779 (0x30B) - AIF1TX Channel 2 Configuration | ||
1908 | */ | ||
1909 | #define WM8996_AIF1TX_CHAN2_DAT_INV 0x8000 /* AIF1TX_CHAN2_DAT_INV */ | ||
1910 | #define WM8996_AIF1TX_CHAN2_DAT_INV_MASK 0x8000 /* AIF1TX_CHAN2_DAT_INV */ | ||
1911 | #define WM8996_AIF1TX_CHAN2_DAT_INV_SHIFT 15 /* AIF1TX_CHAN2_DAT_INV */ | ||
1912 | #define WM8996_AIF1TX_CHAN2_DAT_INV_WIDTH 1 /* AIF1TX_CHAN2_DAT_INV */ | ||
1913 | #define WM8996_AIF1TX_CHAN2_SPACING_MASK 0x7E00 /* AIF1TX_CHAN2_SPACING - [14:9] */ | ||
1914 | #define WM8996_AIF1TX_CHAN2_SPACING_SHIFT 9 /* AIF1TX_CHAN2_SPACING - [14:9] */ | ||
1915 | #define WM8996_AIF1TX_CHAN2_SPACING_WIDTH 6 /* AIF1TX_CHAN2_SPACING - [14:9] */ | ||
1916 | #define WM8996_AIF1TX_CHAN2_SLOTS_MASK 0x01C0 /* AIF1TX_CHAN2_SLOTS - [8:6] */ | ||
1917 | #define WM8996_AIF1TX_CHAN2_SLOTS_SHIFT 6 /* AIF1TX_CHAN2_SLOTS - [8:6] */ | ||
1918 | #define WM8996_AIF1TX_CHAN2_SLOTS_WIDTH 3 /* AIF1TX_CHAN2_SLOTS - [8:6] */ | ||
1919 | #define WM8996_AIF1TX_CHAN2_START_SLOT_MASK 0x003F /* AIF1TX_CHAN2_START_SLOT - [5:0] */ | ||
1920 | #define WM8996_AIF1TX_CHAN2_START_SLOT_SHIFT 0 /* AIF1TX_CHAN2_START_SLOT - [5:0] */ | ||
1921 | #define WM8996_AIF1TX_CHAN2_START_SLOT_WIDTH 6 /* AIF1TX_CHAN2_START_SLOT - [5:0] */ | ||
1922 | |||
1923 | /* | ||
1924 | * R780 (0x30C) - AIF1TX Channel 3 Configuration | ||
1925 | */ | ||
1926 | #define WM8996_AIF1TX_CHAN3_DAT_INV 0x8000 /* AIF1TX_CHAN3_DAT_INV */ | ||
1927 | #define WM8996_AIF1TX_CHAN3_DAT_INV_MASK 0x8000 /* AIF1TX_CHAN3_DAT_INV */ | ||
1928 | #define WM8996_AIF1TX_CHAN3_DAT_INV_SHIFT 15 /* AIF1TX_CHAN3_DAT_INV */ | ||
1929 | #define WM8996_AIF1TX_CHAN3_DAT_INV_WIDTH 1 /* AIF1TX_CHAN3_DAT_INV */ | ||
1930 | #define WM8996_AIF1TX_CHAN3_SPACING_MASK 0x7E00 /* AIF1TX_CHAN3_SPACING - [14:9] */ | ||
1931 | #define WM8996_AIF1TX_CHAN3_SPACING_SHIFT 9 /* AIF1TX_CHAN3_SPACING - [14:9] */ | ||
1932 | #define WM8996_AIF1TX_CHAN3_SPACING_WIDTH 6 /* AIF1TX_CHAN3_SPACING - [14:9] */ | ||
1933 | #define WM8996_AIF1TX_CHAN3_SLOTS_MASK 0x01C0 /* AIF1TX_CHAN3_SLOTS - [8:6] */ | ||
1934 | #define WM8996_AIF1TX_CHAN3_SLOTS_SHIFT 6 /* AIF1TX_CHAN3_SLOTS - [8:6] */ | ||
1935 | #define WM8996_AIF1TX_CHAN3_SLOTS_WIDTH 3 /* AIF1TX_CHAN3_SLOTS - [8:6] */ | ||
1936 | #define WM8996_AIF1TX_CHAN3_START_SLOT_MASK 0x003F /* AIF1TX_CHAN3_START_SLOT - [5:0] */ | ||
1937 | #define WM8996_AIF1TX_CHAN3_START_SLOT_SHIFT 0 /* AIF1TX_CHAN3_START_SLOT - [5:0] */ | ||
1938 | #define WM8996_AIF1TX_CHAN3_START_SLOT_WIDTH 6 /* AIF1TX_CHAN3_START_SLOT - [5:0] */ | ||
1939 | |||
1940 | /* | ||
1941 | * R781 (0x30D) - AIF1TX Channel 4 Configuration | ||
1942 | */ | ||
1943 | #define WM8996_AIF1TX_CHAN4_DAT_INV 0x8000 /* AIF1TX_CHAN4_DAT_INV */ | ||
1944 | #define WM8996_AIF1TX_CHAN4_DAT_INV_MASK 0x8000 /* AIF1TX_CHAN4_DAT_INV */ | ||
1945 | #define WM8996_AIF1TX_CHAN4_DAT_INV_SHIFT 15 /* AIF1TX_CHAN4_DAT_INV */ | ||
1946 | #define WM8996_AIF1TX_CHAN4_DAT_INV_WIDTH 1 /* AIF1TX_CHAN4_DAT_INV */ | ||
1947 | #define WM8996_AIF1TX_CHAN4_SPACING_MASK 0x7E00 /* AIF1TX_CHAN4_SPACING - [14:9] */ | ||
1948 | #define WM8996_AIF1TX_CHAN4_SPACING_SHIFT 9 /* AIF1TX_CHAN4_SPACING - [14:9] */ | ||
1949 | #define WM8996_AIF1TX_CHAN4_SPACING_WIDTH 6 /* AIF1TX_CHAN4_SPACING - [14:9] */ | ||
1950 | #define WM8996_AIF1TX_CHAN4_SLOTS_MASK 0x01C0 /* AIF1TX_CHAN4_SLOTS - [8:6] */ | ||
1951 | #define WM8996_AIF1TX_CHAN4_SLOTS_SHIFT 6 /* AIF1TX_CHAN4_SLOTS - [8:6] */ | ||
1952 | #define WM8996_AIF1TX_CHAN4_SLOTS_WIDTH 3 /* AIF1TX_CHAN4_SLOTS - [8:6] */ | ||
1953 | #define WM8996_AIF1TX_CHAN4_START_SLOT_MASK 0x003F /* AIF1TX_CHAN4_START_SLOT - [5:0] */ | ||
1954 | #define WM8996_AIF1TX_CHAN4_START_SLOT_SHIFT 0 /* AIF1TX_CHAN4_START_SLOT - [5:0] */ | ||
1955 | #define WM8996_AIF1TX_CHAN4_START_SLOT_WIDTH 6 /* AIF1TX_CHAN4_START_SLOT - [5:0] */ | ||
1956 | |||
1957 | /* | ||
1958 | * R782 (0x30E) - AIF1TX Channel 5 Configuration | ||
1959 | */ | ||
1960 | #define WM8996_AIF1TX_CHAN5_DAT_INV 0x8000 /* AIF1TX_CHAN5_DAT_INV */ | ||
1961 | #define WM8996_AIF1TX_CHAN5_DAT_INV_MASK 0x8000 /* AIF1TX_CHAN5_DAT_INV */ | ||
1962 | #define WM8996_AIF1TX_CHAN5_DAT_INV_SHIFT 15 /* AIF1TX_CHAN5_DAT_INV */ | ||
1963 | #define WM8996_AIF1TX_CHAN5_DAT_INV_WIDTH 1 /* AIF1TX_CHAN5_DAT_INV */ | ||
1964 | #define WM8996_AIF1TX_CHAN5_SPACING_MASK 0x7E00 /* AIF1TX_CHAN5_SPACING - [14:9] */ | ||
1965 | #define WM8996_AIF1TX_CHAN5_SPACING_SHIFT 9 /* AIF1TX_CHAN5_SPACING - [14:9] */ | ||
1966 | #define WM8996_AIF1TX_CHAN5_SPACING_WIDTH 6 /* AIF1TX_CHAN5_SPACING - [14:9] */ | ||
1967 | #define WM8996_AIF1TX_CHAN5_SLOTS_MASK 0x01C0 /* AIF1TX_CHAN5_SLOTS - [8:6] */ | ||
1968 | #define WM8996_AIF1TX_CHAN5_SLOTS_SHIFT 6 /* AIF1TX_CHAN5_SLOTS - [8:6] */ | ||
1969 | #define WM8996_AIF1TX_CHAN5_SLOTS_WIDTH 3 /* AIF1TX_CHAN5_SLOTS - [8:6] */ | ||
1970 | #define WM8996_AIF1TX_CHAN5_START_SLOT_MASK 0x003F /* AIF1TX_CHAN5_START_SLOT - [5:0] */ | ||
1971 | #define WM8996_AIF1TX_CHAN5_START_SLOT_SHIFT 0 /* AIF1TX_CHAN5_START_SLOT - [5:0] */ | ||
1972 | #define WM8996_AIF1TX_CHAN5_START_SLOT_WIDTH 6 /* AIF1TX_CHAN5_START_SLOT - [5:0] */ | ||
1973 | |||
1974 | /* | ||
1975 | * R783 (0x30F) - AIF1RX Channel 0 Configuration | ||
1976 | */ | ||
1977 | #define WM8996_AIF1RX_CHAN0_DAT_INV 0x8000 /* AIF1RX_CHAN0_DAT_INV */ | ||
1978 | #define WM8996_AIF1RX_CHAN0_DAT_INV_MASK 0x8000 /* AIF1RX_CHAN0_DAT_INV */ | ||
1979 | #define WM8996_AIF1RX_CHAN0_DAT_INV_SHIFT 15 /* AIF1RX_CHAN0_DAT_INV */ | ||
1980 | #define WM8996_AIF1RX_CHAN0_DAT_INV_WIDTH 1 /* AIF1RX_CHAN0_DAT_INV */ | ||
1981 | #define WM8996_AIF1RX_CHAN0_SPACING_MASK 0x7E00 /* AIF1RX_CHAN0_SPACING - [14:9] */ | ||
1982 | #define WM8996_AIF1RX_CHAN0_SPACING_SHIFT 9 /* AIF1RX_CHAN0_SPACING - [14:9] */ | ||
1983 | #define WM8996_AIF1RX_CHAN0_SPACING_WIDTH 6 /* AIF1RX_CHAN0_SPACING - [14:9] */ | ||
1984 | #define WM8996_AIF1RX_CHAN0_SLOTS_MASK 0x01C0 /* AIF1RX_CHAN0_SLOTS - [8:6] */ | ||
1985 | #define WM8996_AIF1RX_CHAN0_SLOTS_SHIFT 6 /* AIF1RX_CHAN0_SLOTS - [8:6] */ | ||
1986 | #define WM8996_AIF1RX_CHAN0_SLOTS_WIDTH 3 /* AIF1RX_CHAN0_SLOTS - [8:6] */ | ||
1987 | #define WM8996_AIF1RX_CHAN0_START_SLOT_MASK 0x003F /* AIF1RX_CHAN0_START_SLOT - [5:0] */ | ||
1988 | #define WM8996_AIF1RX_CHAN0_START_SLOT_SHIFT 0 /* AIF1RX_CHAN0_START_SLOT - [5:0] */ | ||
1989 | #define WM8996_AIF1RX_CHAN0_START_SLOT_WIDTH 6 /* AIF1RX_CHAN0_START_SLOT - [5:0] */ | ||
1990 | |||
1991 | /* | ||
1992 | * R784 (0x310) - AIF1RX Channel 1 Configuration | ||
1993 | */ | ||
1994 | #define WM8996_AIF1RX_CHAN1_DAT_INV 0x8000 /* AIF1RX_CHAN1_DAT_INV */ | ||
1995 | #define WM8996_AIF1RX_CHAN1_DAT_INV_MASK 0x8000 /* AIF1RX_CHAN1_DAT_INV */ | ||
1996 | #define WM8996_AIF1RX_CHAN1_DAT_INV_SHIFT 15 /* AIF1RX_CHAN1_DAT_INV */ | ||
1997 | #define WM8996_AIF1RX_CHAN1_DAT_INV_WIDTH 1 /* AIF1RX_CHAN1_DAT_INV */ | ||
1998 | #define WM8996_AIF1RX_CHAN1_SPACING_MASK 0x7E00 /* AIF1RX_CHAN1_SPACING - [14:9] */ | ||
1999 | #define WM8996_AIF1RX_CHAN1_SPACING_SHIFT 9 /* AIF1RX_CHAN1_SPACING - [14:9] */ | ||
2000 | #define WM8996_AIF1RX_CHAN1_SPACING_WIDTH 6 /* AIF1RX_CHAN1_SPACING - [14:9] */ | ||
2001 | #define WM8996_AIF1RX_CHAN1_SLOTS_MASK 0x01C0 /* AIF1RX_CHAN1_SLOTS - [8:6] */ | ||
2002 | #define WM8996_AIF1RX_CHAN1_SLOTS_SHIFT 6 /* AIF1RX_CHAN1_SLOTS - [8:6] */ | ||
2003 | #define WM8996_AIF1RX_CHAN1_SLOTS_WIDTH 3 /* AIF1RX_CHAN1_SLOTS - [8:6] */ | ||
2004 | #define WM8996_AIF1RX_CHAN1_START_SLOT_MASK 0x003F /* AIF1RX_CHAN1_START_SLOT - [5:0] */ | ||
2005 | #define WM8996_AIF1RX_CHAN1_START_SLOT_SHIFT 0 /* AIF1RX_CHAN1_START_SLOT - [5:0] */ | ||
2006 | #define WM8996_AIF1RX_CHAN1_START_SLOT_WIDTH 6 /* AIF1RX_CHAN1_START_SLOT - [5:0] */ | ||
2007 | |||
2008 | /* | ||
2009 | * R785 (0x311) - AIF1RX Channel 2 Configuration | ||
2010 | */ | ||
2011 | #define WM8996_AIF1RX_CHAN2_DAT_INV 0x8000 /* AIF1RX_CHAN2_DAT_INV */ | ||
2012 | #define WM8996_AIF1RX_CHAN2_DAT_INV_MASK 0x8000 /* AIF1RX_CHAN2_DAT_INV */ | ||
2013 | #define WM8996_AIF1RX_CHAN2_DAT_INV_SHIFT 15 /* AIF1RX_CHAN2_DAT_INV */ | ||
2014 | #define WM8996_AIF1RX_CHAN2_DAT_INV_WIDTH 1 /* AIF1RX_CHAN2_DAT_INV */ | ||
2015 | #define WM8996_AIF1RX_CHAN2_SPACING_MASK 0x7E00 /* AIF1RX_CHAN2_SPACING - [14:9] */ | ||
2016 | #define WM8996_AIF1RX_CHAN2_SPACING_SHIFT 9 /* AIF1RX_CHAN2_SPACING - [14:9] */ | ||
2017 | #define WM8996_AIF1RX_CHAN2_SPACING_WIDTH 6 /* AIF1RX_CHAN2_SPACING - [14:9] */ | ||
2018 | #define WM8996_AIF1RX_CHAN2_SLOTS_MASK 0x01C0 /* AIF1RX_CHAN2_SLOTS - [8:6] */ | ||
2019 | #define WM8996_AIF1RX_CHAN2_SLOTS_SHIFT 6 /* AIF1RX_CHAN2_SLOTS - [8:6] */ | ||
2020 | #define WM8996_AIF1RX_CHAN2_SLOTS_WIDTH 3 /* AIF1RX_CHAN2_SLOTS - [8:6] */ | ||
2021 | #define WM8996_AIF1RX_CHAN2_START_SLOT_MASK 0x003F /* AIF1RX_CHAN2_START_SLOT - [5:0] */ | ||
2022 | #define WM8996_AIF1RX_CHAN2_START_SLOT_SHIFT 0 /* AIF1RX_CHAN2_START_SLOT - [5:0] */ | ||
2023 | #define WM8996_AIF1RX_CHAN2_START_SLOT_WIDTH 6 /* AIF1RX_CHAN2_START_SLOT - [5:0] */ | ||
2024 | |||
2025 | /* | ||
2026 | * R786 (0x312) - AIF1RX Channel 3 Configuration | ||
2027 | */ | ||
2028 | #define WM8996_AIF1RX_CHAN3_DAT_INV 0x8000 /* AIF1RX_CHAN3_DAT_INV */ | ||
2029 | #define WM8996_AIF1RX_CHAN3_DAT_INV_MASK 0x8000 /* AIF1RX_CHAN3_DAT_INV */ | ||
2030 | #define WM8996_AIF1RX_CHAN3_DAT_INV_SHIFT 15 /* AIF1RX_CHAN3_DAT_INV */ | ||
2031 | #define WM8996_AIF1RX_CHAN3_DAT_INV_WIDTH 1 /* AIF1RX_CHAN3_DAT_INV */ | ||
2032 | #define WM8996_AIF1RX_CHAN3_SPACING_MASK 0x7E00 /* AIF1RX_CHAN3_SPACING - [14:9] */ | ||
2033 | #define WM8996_AIF1RX_CHAN3_SPACING_SHIFT 9 /* AIF1RX_CHAN3_SPACING - [14:9] */ | ||
2034 | #define WM8996_AIF1RX_CHAN3_SPACING_WIDTH 6 /* AIF1RX_CHAN3_SPACING - [14:9] */ | ||
2035 | #define WM8996_AIF1RX_CHAN3_SLOTS_MASK 0x01C0 /* AIF1RX_CHAN3_SLOTS - [8:6] */ | ||
2036 | #define WM8996_AIF1RX_CHAN3_SLOTS_SHIFT 6 /* AIF1RX_CHAN3_SLOTS - [8:6] */ | ||
2037 | #define WM8996_AIF1RX_CHAN3_SLOTS_WIDTH 3 /* AIF1RX_CHAN3_SLOTS - [8:6] */ | ||
2038 | #define WM8996_AIF1RX_CHAN3_START_SLOT_MASK 0x003F /* AIF1RX_CHAN3_START_SLOT - [5:0] */ | ||
2039 | #define WM8996_AIF1RX_CHAN3_START_SLOT_SHIFT 0 /* AIF1RX_CHAN3_START_SLOT - [5:0] */ | ||
2040 | #define WM8996_AIF1RX_CHAN3_START_SLOT_WIDTH 6 /* AIF1RX_CHAN3_START_SLOT - [5:0] */ | ||
2041 | |||
2042 | /* | ||
2043 | * R787 (0x313) - AIF1RX Channel 4 Configuration | ||
2044 | */ | ||
2045 | #define WM8996_AIF1RX_CHAN4_DAT_INV 0x8000 /* AIF1RX_CHAN4_DAT_INV */ | ||
2046 | #define WM8996_AIF1RX_CHAN4_DAT_INV_MASK 0x8000 /* AIF1RX_CHAN4_DAT_INV */ | ||
2047 | #define WM8996_AIF1RX_CHAN4_DAT_INV_SHIFT 15 /* AIF1RX_CHAN4_DAT_INV */ | ||
2048 | #define WM8996_AIF1RX_CHAN4_DAT_INV_WIDTH 1 /* AIF1RX_CHAN4_DAT_INV */ | ||
2049 | #define WM8996_AIF1RX_CHAN4_SPACING_MASK 0x7E00 /* AIF1RX_CHAN4_SPACING - [14:9] */ | ||
2050 | #define WM8996_AIF1RX_CHAN4_SPACING_SHIFT 9 /* AIF1RX_CHAN4_SPACING - [14:9] */ | ||
2051 | #define WM8996_AIF1RX_CHAN4_SPACING_WIDTH 6 /* AIF1RX_CHAN4_SPACING - [14:9] */ | ||
2052 | #define WM8996_AIF1RX_CHAN4_SLOTS_MASK 0x01C0 /* AIF1RX_CHAN4_SLOTS - [8:6] */ | ||
2053 | #define WM8996_AIF1RX_CHAN4_SLOTS_SHIFT 6 /* AIF1RX_CHAN4_SLOTS - [8:6] */ | ||
2054 | #define WM8996_AIF1RX_CHAN4_SLOTS_WIDTH 3 /* AIF1RX_CHAN4_SLOTS - [8:6] */ | ||
2055 | #define WM8996_AIF1RX_CHAN4_START_SLOT_MASK 0x003F /* AIF1RX_CHAN4_START_SLOT - [5:0] */ | ||
2056 | #define WM8996_AIF1RX_CHAN4_START_SLOT_SHIFT 0 /* AIF1RX_CHAN4_START_SLOT - [5:0] */ | ||
2057 | #define WM8996_AIF1RX_CHAN4_START_SLOT_WIDTH 6 /* AIF1RX_CHAN4_START_SLOT - [5:0] */ | ||
2058 | |||
2059 | /* | ||
2060 | * R788 (0x314) - AIF1RX Channel 5 Configuration | ||
2061 | */ | ||
2062 | #define WM8996_AIF1RX_CHAN5_DAT_INV 0x8000 /* AIF1RX_CHAN5_DAT_INV */ | ||
2063 | #define WM8996_AIF1RX_CHAN5_DAT_INV_MASK 0x8000 /* AIF1RX_CHAN5_DAT_INV */ | ||
2064 | #define WM8996_AIF1RX_CHAN5_DAT_INV_SHIFT 15 /* AIF1RX_CHAN5_DAT_INV */ | ||
2065 | #define WM8996_AIF1RX_CHAN5_DAT_INV_WIDTH 1 /* AIF1RX_CHAN5_DAT_INV */ | ||
2066 | #define WM8996_AIF1RX_CHAN5_SPACING_MASK 0x7E00 /* AIF1RX_CHAN5_SPACING - [14:9] */ | ||
2067 | #define WM8996_AIF1RX_CHAN5_SPACING_SHIFT 9 /* AIF1RX_CHAN5_SPACING - [14:9] */ | ||
2068 | #define WM8996_AIF1RX_CHAN5_SPACING_WIDTH 6 /* AIF1RX_CHAN5_SPACING - [14:9] */ | ||
2069 | #define WM8996_AIF1RX_CHAN5_SLOTS_MASK 0x01C0 /* AIF1RX_CHAN5_SLOTS - [8:6] */ | ||
2070 | #define WM8996_AIF1RX_CHAN5_SLOTS_SHIFT 6 /* AIF1RX_CHAN5_SLOTS - [8:6] */ | ||
2071 | #define WM8996_AIF1RX_CHAN5_SLOTS_WIDTH 3 /* AIF1RX_CHAN5_SLOTS - [8:6] */ | ||
2072 | #define WM8996_AIF1RX_CHAN5_START_SLOT_MASK 0x003F /* AIF1RX_CHAN5_START_SLOT - [5:0] */ | ||
2073 | #define WM8996_AIF1RX_CHAN5_START_SLOT_SHIFT 0 /* AIF1RX_CHAN5_START_SLOT - [5:0] */ | ||
2074 | #define WM8996_AIF1RX_CHAN5_START_SLOT_WIDTH 6 /* AIF1RX_CHAN5_START_SLOT - [5:0] */ | ||
2075 | |||
2076 | /* | ||
2077 | * R789 (0x315) - AIF1RX Mono Configuration | ||
2078 | */ | ||
2079 | #define WM8996_AIF1RX_CHAN4_MONO_MODE 0x0004 /* AIF1RX_CHAN4_MONO_MODE */ | ||
2080 | #define WM8996_AIF1RX_CHAN4_MONO_MODE_MASK 0x0004 /* AIF1RX_CHAN4_MONO_MODE */ | ||
2081 | #define WM8996_AIF1RX_CHAN4_MONO_MODE_SHIFT 2 /* AIF1RX_CHAN4_MONO_MODE */ | ||
2082 | #define WM8996_AIF1RX_CHAN4_MONO_MODE_WIDTH 1 /* AIF1RX_CHAN4_MONO_MODE */ | ||
2083 | #define WM8996_AIF1RX_CHAN2_MONO_MODE 0x0002 /* AIF1RX_CHAN2_MONO_MODE */ | ||
2084 | #define WM8996_AIF1RX_CHAN2_MONO_MODE_MASK 0x0002 /* AIF1RX_CHAN2_MONO_MODE */ | ||
2085 | #define WM8996_AIF1RX_CHAN2_MONO_MODE_SHIFT 1 /* AIF1RX_CHAN2_MONO_MODE */ | ||
2086 | #define WM8996_AIF1RX_CHAN2_MONO_MODE_WIDTH 1 /* AIF1RX_CHAN2_MONO_MODE */ | ||
2087 | #define WM8996_AIF1RX_CHAN0_MONO_MODE 0x0001 /* AIF1RX_CHAN0_MONO_MODE */ | ||
2088 | #define WM8996_AIF1RX_CHAN0_MONO_MODE_MASK 0x0001 /* AIF1RX_CHAN0_MONO_MODE */ | ||
2089 | #define WM8996_AIF1RX_CHAN0_MONO_MODE_SHIFT 0 /* AIF1RX_CHAN0_MONO_MODE */ | ||
2090 | #define WM8996_AIF1RX_CHAN0_MONO_MODE_WIDTH 1 /* AIF1RX_CHAN0_MONO_MODE */ | ||
2091 | |||
2092 | /* | ||
2093 | * R794 (0x31A) - AIF1TX Test | ||
2094 | */ | ||
2095 | #define WM8996_AIF1TX45_DITHER_ENA 0x0004 /* AIF1TX45_DITHER_ENA */ | ||
2096 | #define WM8996_AIF1TX45_DITHER_ENA_MASK 0x0004 /* AIF1TX45_DITHER_ENA */ | ||
2097 | #define WM8996_AIF1TX45_DITHER_ENA_SHIFT 2 /* AIF1TX45_DITHER_ENA */ | ||
2098 | #define WM8996_AIF1TX45_DITHER_ENA_WIDTH 1 /* AIF1TX45_DITHER_ENA */ | ||
2099 | #define WM8996_AIF1TX23_DITHER_ENA 0x0002 /* AIF1TX23_DITHER_ENA */ | ||
2100 | #define WM8996_AIF1TX23_DITHER_ENA_MASK 0x0002 /* AIF1TX23_DITHER_ENA */ | ||
2101 | #define WM8996_AIF1TX23_DITHER_ENA_SHIFT 1 /* AIF1TX23_DITHER_ENA */ | ||
2102 | #define WM8996_AIF1TX23_DITHER_ENA_WIDTH 1 /* AIF1TX23_DITHER_ENA */ | ||
2103 | #define WM8996_AIF1TX01_DITHER_ENA 0x0001 /* AIF1TX01_DITHER_ENA */ | ||
2104 | #define WM8996_AIF1TX01_DITHER_ENA_MASK 0x0001 /* AIF1TX01_DITHER_ENA */ | ||
2105 | #define WM8996_AIF1TX01_DITHER_ENA_SHIFT 0 /* AIF1TX01_DITHER_ENA */ | ||
2106 | #define WM8996_AIF1TX01_DITHER_ENA_WIDTH 1 /* AIF1TX01_DITHER_ENA */ | ||
2107 | |||
2108 | /* | ||
2109 | * R800 (0x320) - AIF2 Control | ||
2110 | */ | ||
2111 | #define WM8996_AIF2_TRI 0x0004 /* AIF2_TRI */ | ||
2112 | #define WM8996_AIF2_TRI_MASK 0x0004 /* AIF2_TRI */ | ||
2113 | #define WM8996_AIF2_TRI_SHIFT 2 /* AIF2_TRI */ | ||
2114 | #define WM8996_AIF2_TRI_WIDTH 1 /* AIF2_TRI */ | ||
2115 | #define WM8996_AIF2_FMT_MASK 0x0003 /* AIF2_FMT - [1:0] */ | ||
2116 | #define WM8996_AIF2_FMT_SHIFT 0 /* AIF2_FMT - [1:0] */ | ||
2117 | #define WM8996_AIF2_FMT_WIDTH 2 /* AIF2_FMT - [1:0] */ | ||
2118 | |||
2119 | /* | ||
2120 | * R801 (0x321) - AIF2 BCLK | ||
2121 | */ | ||
2122 | #define WM8996_AIF2_BCLK_INV 0x0400 /* AIF2_BCLK_INV */ | ||
2123 | #define WM8996_AIF2_BCLK_INV_MASK 0x0400 /* AIF2_BCLK_INV */ | ||
2124 | #define WM8996_AIF2_BCLK_INV_SHIFT 10 /* AIF2_BCLK_INV */ | ||
2125 | #define WM8996_AIF2_BCLK_INV_WIDTH 1 /* AIF2_BCLK_INV */ | ||
2126 | #define WM8996_AIF2_BCLK_FRC 0x0200 /* AIF2_BCLK_FRC */ | ||
2127 | #define WM8996_AIF2_BCLK_FRC_MASK 0x0200 /* AIF2_BCLK_FRC */ | ||
2128 | #define WM8996_AIF2_BCLK_FRC_SHIFT 9 /* AIF2_BCLK_FRC */ | ||
2129 | #define WM8996_AIF2_BCLK_FRC_WIDTH 1 /* AIF2_BCLK_FRC */ | ||
2130 | #define WM8996_AIF2_BCLK_MSTR 0x0100 /* AIF2_BCLK_MSTR */ | ||
2131 | #define WM8996_AIF2_BCLK_MSTR_MASK 0x0100 /* AIF2_BCLK_MSTR */ | ||
2132 | #define WM8996_AIF2_BCLK_MSTR_SHIFT 8 /* AIF2_BCLK_MSTR */ | ||
2133 | #define WM8996_AIF2_BCLK_MSTR_WIDTH 1 /* AIF2_BCLK_MSTR */ | ||
2134 | #define WM8996_AIF2_BCLK_DIV_MASK 0x000F /* AIF2_BCLK_DIV - [3:0] */ | ||
2135 | #define WM8996_AIF2_BCLK_DIV_SHIFT 0 /* AIF2_BCLK_DIV - [3:0] */ | ||
2136 | #define WM8996_AIF2_BCLK_DIV_WIDTH 4 /* AIF2_BCLK_DIV - [3:0] */ | ||
2137 | |||
2138 | /* | ||
2139 | * R802 (0x322) - AIF2 TX LRCLK(1) | ||
2140 | */ | ||
2141 | #define WM8996_AIF2TX_RATE_MASK 0x07FF /* AIF2TX_RATE - [10:0] */ | ||
2142 | #define WM8996_AIF2TX_RATE_SHIFT 0 /* AIF2TX_RATE - [10:0] */ | ||
2143 | #define WM8996_AIF2TX_RATE_WIDTH 11 /* AIF2TX_RATE - [10:0] */ | ||
2144 | |||
2145 | /* | ||
2146 | * R803 (0x323) - AIF2 TX LRCLK(2) | ||
2147 | */ | ||
2148 | #define WM8996_AIF2TX_LRCLK_MODE 0x0008 /* AIF2TX_LRCLK_MODE */ | ||
2149 | #define WM8996_AIF2TX_LRCLK_MODE_MASK 0x0008 /* AIF2TX_LRCLK_MODE */ | ||
2150 | #define WM8996_AIF2TX_LRCLK_MODE_SHIFT 3 /* AIF2TX_LRCLK_MODE */ | ||
2151 | #define WM8996_AIF2TX_LRCLK_MODE_WIDTH 1 /* AIF2TX_LRCLK_MODE */ | ||
2152 | #define WM8996_AIF2TX_LRCLK_INV 0x0004 /* AIF2TX_LRCLK_INV */ | ||
2153 | #define WM8996_AIF2TX_LRCLK_INV_MASK 0x0004 /* AIF2TX_LRCLK_INV */ | ||
2154 | #define WM8996_AIF2TX_LRCLK_INV_SHIFT 2 /* AIF2TX_LRCLK_INV */ | ||
2155 | #define WM8996_AIF2TX_LRCLK_INV_WIDTH 1 /* AIF2TX_LRCLK_INV */ | ||
2156 | #define WM8996_AIF2TX_LRCLK_FRC 0x0002 /* AIF2TX_LRCLK_FRC */ | ||
2157 | #define WM8996_AIF2TX_LRCLK_FRC_MASK 0x0002 /* AIF2TX_LRCLK_FRC */ | ||
2158 | #define WM8996_AIF2TX_LRCLK_FRC_SHIFT 1 /* AIF2TX_LRCLK_FRC */ | ||
2159 | #define WM8996_AIF2TX_LRCLK_FRC_WIDTH 1 /* AIF2TX_LRCLK_FRC */ | ||
2160 | #define WM8996_AIF2TX_LRCLK_MSTR 0x0001 /* AIF2TX_LRCLK_MSTR */ | ||
2161 | #define WM8996_AIF2TX_LRCLK_MSTR_MASK 0x0001 /* AIF2TX_LRCLK_MSTR */ | ||
2162 | #define WM8996_AIF2TX_LRCLK_MSTR_SHIFT 0 /* AIF2TX_LRCLK_MSTR */ | ||
2163 | #define WM8996_AIF2TX_LRCLK_MSTR_WIDTH 1 /* AIF2TX_LRCLK_MSTR */ | ||
2164 | |||
2165 | /* | ||
2166 | * R804 (0x324) - AIF2 RX LRCLK(1) | ||
2167 | */ | ||
2168 | #define WM8996_AIF2RX_RATE_MASK 0x07FF /* AIF2RX_RATE - [10:0] */ | ||
2169 | #define WM8996_AIF2RX_RATE_SHIFT 0 /* AIF2RX_RATE - [10:0] */ | ||
2170 | #define WM8996_AIF2RX_RATE_WIDTH 11 /* AIF2RX_RATE - [10:0] */ | ||
2171 | |||
2172 | /* | ||
2173 | * R805 (0x325) - AIF2 RX LRCLK(2) | ||
2174 | */ | ||
2175 | #define WM8996_AIF2RX_LRCLK_INV 0x0004 /* AIF2RX_LRCLK_INV */ | ||
2176 | #define WM8996_AIF2RX_LRCLK_INV_MASK 0x0004 /* AIF2RX_LRCLK_INV */ | ||
2177 | #define WM8996_AIF2RX_LRCLK_INV_SHIFT 2 /* AIF2RX_LRCLK_INV */ | ||
2178 | #define WM8996_AIF2RX_LRCLK_INV_WIDTH 1 /* AIF2RX_LRCLK_INV */ | ||
2179 | #define WM8996_AIF2RX_LRCLK_FRC 0x0002 /* AIF2RX_LRCLK_FRC */ | ||
2180 | #define WM8996_AIF2RX_LRCLK_FRC_MASK 0x0002 /* AIF2RX_LRCLK_FRC */ | ||
2181 | #define WM8996_AIF2RX_LRCLK_FRC_SHIFT 1 /* AIF2RX_LRCLK_FRC */ | ||
2182 | #define WM8996_AIF2RX_LRCLK_FRC_WIDTH 1 /* AIF2RX_LRCLK_FRC */ | ||
2183 | #define WM8996_AIF2RX_LRCLK_MSTR 0x0001 /* AIF2RX_LRCLK_MSTR */ | ||
2184 | #define WM8996_AIF2RX_LRCLK_MSTR_MASK 0x0001 /* AIF2RX_LRCLK_MSTR */ | ||
2185 | #define WM8996_AIF2RX_LRCLK_MSTR_SHIFT 0 /* AIF2RX_LRCLK_MSTR */ | ||
2186 | #define WM8996_AIF2RX_LRCLK_MSTR_WIDTH 1 /* AIF2RX_LRCLK_MSTR */ | ||
2187 | |||
2188 | /* | ||
2189 | * R806 (0x326) - AIF2TX Data Configuration (1) | ||
2190 | */ | ||
2191 | #define WM8996_AIF2TX_WL_MASK 0xFF00 /* AIF2TX_WL - [15:8] */ | ||
2192 | #define WM8996_AIF2TX_WL_SHIFT 8 /* AIF2TX_WL - [15:8] */ | ||
2193 | #define WM8996_AIF2TX_WL_WIDTH 8 /* AIF2TX_WL - [15:8] */ | ||
2194 | #define WM8996_AIF2TX_SLOT_LEN_MASK 0x00FF /* AIF2TX_SLOT_LEN - [7:0] */ | ||
2195 | #define WM8996_AIF2TX_SLOT_LEN_SHIFT 0 /* AIF2TX_SLOT_LEN - [7:0] */ | ||
2196 | #define WM8996_AIF2TX_SLOT_LEN_WIDTH 8 /* AIF2TX_SLOT_LEN - [7:0] */ | ||
2197 | |||
2198 | /* | ||
2199 | * R807 (0x327) - AIF2TX Data Configuration (2) | ||
2200 | */ | ||
2201 | #define WM8996_AIF2TX_DAT_TRI 0x0001 /* AIF2TX_DAT_TRI */ | ||
2202 | #define WM8996_AIF2TX_DAT_TRI_MASK 0x0001 /* AIF2TX_DAT_TRI */ | ||
2203 | #define WM8996_AIF2TX_DAT_TRI_SHIFT 0 /* AIF2TX_DAT_TRI */ | ||
2204 | #define WM8996_AIF2TX_DAT_TRI_WIDTH 1 /* AIF2TX_DAT_TRI */ | ||
2205 | |||
2206 | /* | ||
2207 | * R808 (0x328) - AIF2RX Data Configuration | ||
2208 | */ | ||
2209 | #define WM8996_AIF2RX_WL_MASK 0xFF00 /* AIF2RX_WL - [15:8] */ | ||
2210 | #define WM8996_AIF2RX_WL_SHIFT 8 /* AIF2RX_WL - [15:8] */ | ||
2211 | #define WM8996_AIF2RX_WL_WIDTH 8 /* AIF2RX_WL - [15:8] */ | ||
2212 | #define WM8996_AIF2RX_SLOT_LEN_MASK 0x00FF /* AIF2RX_SLOT_LEN - [7:0] */ | ||
2213 | #define WM8996_AIF2RX_SLOT_LEN_SHIFT 0 /* AIF2RX_SLOT_LEN - [7:0] */ | ||
2214 | #define WM8996_AIF2RX_SLOT_LEN_WIDTH 8 /* AIF2RX_SLOT_LEN - [7:0] */ | ||
2215 | |||
2216 | /* | ||
2217 | * R809 (0x329) - AIF2TX Channel 0 Configuration | ||
2218 | */ | ||
2219 | #define WM8996_AIF2TX_CHAN0_DAT_INV 0x8000 /* AIF2TX_CHAN0_DAT_INV */ | ||
2220 | #define WM8996_AIF2TX_CHAN0_DAT_INV_MASK 0x8000 /* AIF2TX_CHAN0_DAT_INV */ | ||
2221 | #define WM8996_AIF2TX_CHAN0_DAT_INV_SHIFT 15 /* AIF2TX_CHAN0_DAT_INV */ | ||
2222 | #define WM8996_AIF2TX_CHAN0_DAT_INV_WIDTH 1 /* AIF2TX_CHAN0_DAT_INV */ | ||
2223 | #define WM8996_AIF2TX_CHAN0_SPACING_MASK 0x7E00 /* AIF2TX_CHAN0_SPACING - [14:9] */ | ||
2224 | #define WM8996_AIF2TX_CHAN0_SPACING_SHIFT 9 /* AIF2TX_CHAN0_SPACING - [14:9] */ | ||
2225 | #define WM8996_AIF2TX_CHAN0_SPACING_WIDTH 6 /* AIF2TX_CHAN0_SPACING - [14:9] */ | ||
2226 | #define WM8996_AIF2TX_CHAN0_SLOTS_MASK 0x01C0 /* AIF2TX_CHAN0_SLOTS - [8:6] */ | ||
2227 | #define WM8996_AIF2TX_CHAN0_SLOTS_SHIFT 6 /* AIF2TX_CHAN0_SLOTS - [8:6] */ | ||
2228 | #define WM8996_AIF2TX_CHAN0_SLOTS_WIDTH 3 /* AIF2TX_CHAN0_SLOTS - [8:6] */ | ||
2229 | #define WM8996_AIF2TX_CHAN0_START_SLOT_MASK 0x003F /* AIF2TX_CHAN0_START_SLOT - [5:0] */ | ||
2230 | #define WM8996_AIF2TX_CHAN0_START_SLOT_SHIFT 0 /* AIF2TX_CHAN0_START_SLOT - [5:0] */ | ||
2231 | #define WM8996_AIF2TX_CHAN0_START_SLOT_WIDTH 6 /* AIF2TX_CHAN0_START_SLOT - [5:0] */ | ||
2232 | |||
2233 | /* | ||
2234 | * R810 (0x32A) - AIF2TX Channel 1 Configuration | ||
2235 | */ | ||
2236 | #define WM8996_AIF2TX_CHAN1_DAT_INV 0x8000 /* AIF2TX_CHAN1_DAT_INV */ | ||
2237 | #define WM8996_AIF2TX_CHAN1_DAT_INV_MASK 0x8000 /* AIF2TX_CHAN1_DAT_INV */ | ||
2238 | #define WM8996_AIF2TX_CHAN1_DAT_INV_SHIFT 15 /* AIF2TX_CHAN1_DAT_INV */ | ||
2239 | #define WM8996_AIF2TX_CHAN1_DAT_INV_WIDTH 1 /* AIF2TX_CHAN1_DAT_INV */ | ||
2240 | #define WM8996_AIF2TX_CHAN1_SPACING_MASK 0x7E00 /* AIF2TX_CHAN1_SPACING - [14:9] */ | ||
2241 | #define WM8996_AIF2TX_CHAN1_SPACING_SHIFT 9 /* AIF2TX_CHAN1_SPACING - [14:9] */ | ||
2242 | #define WM8996_AIF2TX_CHAN1_SPACING_WIDTH 6 /* AIF2TX_CHAN1_SPACING - [14:9] */ | ||
2243 | #define WM8996_AIF2TX_CHAN1_SLOTS_MASK 0x01C0 /* AIF2TX_CHAN1_SLOTS - [8:6] */ | ||
2244 | #define WM8996_AIF2TX_CHAN1_SLOTS_SHIFT 6 /* AIF2TX_CHAN1_SLOTS - [8:6] */ | ||
2245 | #define WM8996_AIF2TX_CHAN1_SLOTS_WIDTH 3 /* AIF2TX_CHAN1_SLOTS - [8:6] */ | ||
2246 | #define WM8996_AIF2TX_CHAN1_START_SLOT_MASK 0x003F /* AIF2TX_CHAN1_START_SLOT - [5:0] */ | ||
2247 | #define WM8996_AIF2TX_CHAN1_START_SLOT_SHIFT 0 /* AIF2TX_CHAN1_START_SLOT - [5:0] */ | ||
2248 | #define WM8996_AIF2TX_CHAN1_START_SLOT_WIDTH 6 /* AIF2TX_CHAN1_START_SLOT - [5:0] */ | ||
2249 | |||
2250 | /* | ||
2251 | * R811 (0x32B) - AIF2RX Channel 0 Configuration | ||
2252 | */ | ||
2253 | #define WM8996_AIF2RX_CHAN0_DAT_INV 0x8000 /* AIF2RX_CHAN0_DAT_INV */ | ||
2254 | #define WM8996_AIF2RX_CHAN0_DAT_INV_MASK 0x8000 /* AIF2RX_CHAN0_DAT_INV */ | ||
2255 | #define WM8996_AIF2RX_CHAN0_DAT_INV_SHIFT 15 /* AIF2RX_CHAN0_DAT_INV */ | ||
2256 | #define WM8996_AIF2RX_CHAN0_DAT_INV_WIDTH 1 /* AIF2RX_CHAN0_DAT_INV */ | ||
2257 | #define WM8996_AIF2RX_CHAN0_SPACING_MASK 0x7E00 /* AIF2RX_CHAN0_SPACING - [14:9] */ | ||
2258 | #define WM8996_AIF2RX_CHAN0_SPACING_SHIFT 9 /* AIF2RX_CHAN0_SPACING - [14:9] */ | ||
2259 | #define WM8996_AIF2RX_CHAN0_SPACING_WIDTH 6 /* AIF2RX_CHAN0_SPACING - [14:9] */ | ||
2260 | #define WM8996_AIF2RX_CHAN0_SLOTS_MASK 0x01C0 /* AIF2RX_CHAN0_SLOTS - [8:6] */ | ||
2261 | #define WM8996_AIF2RX_CHAN0_SLOTS_SHIFT 6 /* AIF2RX_CHAN0_SLOTS - [8:6] */ | ||
2262 | #define WM8996_AIF2RX_CHAN0_SLOTS_WIDTH 3 /* AIF2RX_CHAN0_SLOTS - [8:6] */ | ||
2263 | #define WM8996_AIF2RX_CHAN0_START_SLOT_MASK 0x003F /* AIF2RX_CHAN0_START_SLOT - [5:0] */ | ||
2264 | #define WM8996_AIF2RX_CHAN0_START_SLOT_SHIFT 0 /* AIF2RX_CHAN0_START_SLOT - [5:0] */ | ||
2265 | #define WM8996_AIF2RX_CHAN0_START_SLOT_WIDTH 6 /* AIF2RX_CHAN0_START_SLOT - [5:0] */ | ||
2266 | |||
2267 | /* | ||
2268 | * R812 (0x32C) - AIF2RX Channel 1 Configuration | ||
2269 | */ | ||
2270 | #define WM8996_AIF2RX_CHAN1_DAT_INV 0x8000 /* AIF2RX_CHAN1_DAT_INV */ | ||
2271 | #define WM8996_AIF2RX_CHAN1_DAT_INV_MASK 0x8000 /* AIF2RX_CHAN1_DAT_INV */ | ||
2272 | #define WM8996_AIF2RX_CHAN1_DAT_INV_SHIFT 15 /* AIF2RX_CHAN1_DAT_INV */ | ||
2273 | #define WM8996_AIF2RX_CHAN1_DAT_INV_WIDTH 1 /* AIF2RX_CHAN1_DAT_INV */ | ||
2274 | #define WM8996_AIF2RX_CHAN1_SPACING_MASK 0x7E00 /* AIF2RX_CHAN1_SPACING - [14:9] */ | ||
2275 | #define WM8996_AIF2RX_CHAN1_SPACING_SHIFT 9 /* AIF2RX_CHAN1_SPACING - [14:9] */ | ||
2276 | #define WM8996_AIF2RX_CHAN1_SPACING_WIDTH 6 /* AIF2RX_CHAN1_SPACING - [14:9] */ | ||
2277 | #define WM8996_AIF2RX_CHAN1_SLOTS_MASK 0x01C0 /* AIF2RX_CHAN1_SLOTS - [8:6] */ | ||
2278 | #define WM8996_AIF2RX_CHAN1_SLOTS_SHIFT 6 /* AIF2RX_CHAN1_SLOTS - [8:6] */ | ||
2279 | #define WM8996_AIF2RX_CHAN1_SLOTS_WIDTH 3 /* AIF2RX_CHAN1_SLOTS - [8:6] */ | ||
2280 | #define WM8996_AIF2RX_CHAN1_START_SLOT_MASK 0x003F /* AIF2RX_CHAN1_START_SLOT - [5:0] */ | ||
2281 | #define WM8996_AIF2RX_CHAN1_START_SLOT_SHIFT 0 /* AIF2RX_CHAN1_START_SLOT - [5:0] */ | ||
2282 | #define WM8996_AIF2RX_CHAN1_START_SLOT_WIDTH 6 /* AIF2RX_CHAN1_START_SLOT - [5:0] */ | ||
2283 | |||
2284 | /* | ||
2285 | * R813 (0x32D) - AIF2RX Mono Configuration | ||
2286 | */ | ||
2287 | #define WM8996_AIF2RX_CHAN0_MONO_MODE 0x0001 /* AIF2RX_CHAN0_MONO_MODE */ | ||
2288 | #define WM8996_AIF2RX_CHAN0_MONO_MODE_MASK 0x0001 /* AIF2RX_CHAN0_MONO_MODE */ | ||
2289 | #define WM8996_AIF2RX_CHAN0_MONO_MODE_SHIFT 0 /* AIF2RX_CHAN0_MONO_MODE */ | ||
2290 | #define WM8996_AIF2RX_CHAN0_MONO_MODE_WIDTH 1 /* AIF2RX_CHAN0_MONO_MODE */ | ||
2291 | |||
2292 | /* | ||
2293 | * R815 (0x32F) - AIF2TX Test | ||
2294 | */ | ||
2295 | #define WM8996_AIF2TX_DITHER_ENA 0x0001 /* AIF2TX_DITHER_ENA */ | ||
2296 | #define WM8996_AIF2TX_DITHER_ENA_MASK 0x0001 /* AIF2TX_DITHER_ENA */ | ||
2297 | #define WM8996_AIF2TX_DITHER_ENA_SHIFT 0 /* AIF2TX_DITHER_ENA */ | ||
2298 | #define WM8996_AIF2TX_DITHER_ENA_WIDTH 1 /* AIF2TX_DITHER_ENA */ | ||
2299 | |||
2300 | /* | ||
2301 | * R1024 (0x400) - DSP1 TX Left Volume | ||
2302 | */ | ||
2303 | #define WM8996_DSP1TX_VU 0x0100 /* DSP1TX_VU */ | ||
2304 | #define WM8996_DSP1TX_VU_MASK 0x0100 /* DSP1TX_VU */ | ||
2305 | #define WM8996_DSP1TX_VU_SHIFT 8 /* DSP1TX_VU */ | ||
2306 | #define WM8996_DSP1TX_VU_WIDTH 1 /* DSP1TX_VU */ | ||
2307 | #define WM8996_DSP1TXL_VOL_MASK 0x00FF /* DSP1TXL_VOL - [7:0] */ | ||
2308 | #define WM8996_DSP1TXL_VOL_SHIFT 0 /* DSP1TXL_VOL - [7:0] */ | ||
2309 | #define WM8996_DSP1TXL_VOL_WIDTH 8 /* DSP1TXL_VOL - [7:0] */ | ||
2310 | |||
2311 | /* | ||
2312 | * R1025 (0x401) - DSP1 TX Right Volume | ||
2313 | */ | ||
2314 | #define WM8996_DSP1TX_VU 0x0100 /* DSP1TX_VU */ | ||
2315 | #define WM8996_DSP1TX_VU_MASK 0x0100 /* DSP1TX_VU */ | ||
2316 | #define WM8996_DSP1TX_VU_SHIFT 8 /* DSP1TX_VU */ | ||
2317 | #define WM8996_DSP1TX_VU_WIDTH 1 /* DSP1TX_VU */ | ||
2318 | #define WM8996_DSP1TXR_VOL_MASK 0x00FF /* DSP1TXR_VOL - [7:0] */ | ||
2319 | #define WM8996_DSP1TXR_VOL_SHIFT 0 /* DSP1TXR_VOL - [7:0] */ | ||
2320 | #define WM8996_DSP1TXR_VOL_WIDTH 8 /* DSP1TXR_VOL - [7:0] */ | ||
2321 | |||
2322 | /* | ||
2323 | * R1026 (0x402) - DSP1 RX Left Volume | ||
2324 | */ | ||
2325 | #define WM8996_DSP1RX_VU 0x0100 /* DSP1RX_VU */ | ||
2326 | #define WM8996_DSP1RX_VU_MASK 0x0100 /* DSP1RX_VU */ | ||
2327 | #define WM8996_DSP1RX_VU_SHIFT 8 /* DSP1RX_VU */ | ||
2328 | #define WM8996_DSP1RX_VU_WIDTH 1 /* DSP1RX_VU */ | ||
2329 | #define WM8996_DSP1RXL_VOL_MASK 0x00FF /* DSP1RXL_VOL - [7:0] */ | ||
2330 | #define WM8996_DSP1RXL_VOL_SHIFT 0 /* DSP1RXL_VOL - [7:0] */ | ||
2331 | #define WM8996_DSP1RXL_VOL_WIDTH 8 /* DSP1RXL_VOL - [7:0] */ | ||
2332 | |||
2333 | /* | ||
2334 | * R1027 (0x403) - DSP1 RX Right Volume | ||
2335 | */ | ||
2336 | #define WM8996_DSP1RX_VU 0x0100 /* DSP1RX_VU */ | ||
2337 | #define WM8996_DSP1RX_VU_MASK 0x0100 /* DSP1RX_VU */ | ||
2338 | #define WM8996_DSP1RX_VU_SHIFT 8 /* DSP1RX_VU */ | ||
2339 | #define WM8996_DSP1RX_VU_WIDTH 1 /* DSP1RX_VU */ | ||
2340 | #define WM8996_DSP1RXR_VOL_MASK 0x00FF /* DSP1RXR_VOL - [7:0] */ | ||
2341 | #define WM8996_DSP1RXR_VOL_SHIFT 0 /* DSP1RXR_VOL - [7:0] */ | ||
2342 | #define WM8996_DSP1RXR_VOL_WIDTH 8 /* DSP1RXR_VOL - [7:0] */ | ||
2343 | |||
2344 | /* | ||
2345 | * R1040 (0x410) - DSP1 TX Filters | ||
2346 | */ | ||
2347 | #define WM8996_DSP1TX_NF 0x2000 /* DSP1TX_NF */ | ||
2348 | #define WM8996_DSP1TX_NF_MASK 0x2000 /* DSP1TX_NF */ | ||
2349 | #define WM8996_DSP1TX_NF_SHIFT 13 /* DSP1TX_NF */ | ||
2350 | #define WM8996_DSP1TX_NF_WIDTH 1 /* DSP1TX_NF */ | ||
2351 | #define WM8996_DSP1TXL_HPF 0x1000 /* DSP1TXL_HPF */ | ||
2352 | #define WM8996_DSP1TXL_HPF_MASK 0x1000 /* DSP1TXL_HPF */ | ||
2353 | #define WM8996_DSP1TXL_HPF_SHIFT 12 /* DSP1TXL_HPF */ | ||
2354 | #define WM8996_DSP1TXL_HPF_WIDTH 1 /* DSP1TXL_HPF */ | ||
2355 | #define WM8996_DSP1TXR_HPF 0x0800 /* DSP1TXR_HPF */ | ||
2356 | #define WM8996_DSP1TXR_HPF_MASK 0x0800 /* DSP1TXR_HPF */ | ||
2357 | #define WM8996_DSP1TXR_HPF_SHIFT 11 /* DSP1TXR_HPF */ | ||
2358 | #define WM8996_DSP1TXR_HPF_WIDTH 1 /* DSP1TXR_HPF */ | ||
2359 | #define WM8996_DSP1TX_HPF_MODE_MASK 0x0018 /* DSP1TX_HPF_MODE - [4:3] */ | ||
2360 | #define WM8996_DSP1TX_HPF_MODE_SHIFT 3 /* DSP1TX_HPF_MODE - [4:3] */ | ||
2361 | #define WM8996_DSP1TX_HPF_MODE_WIDTH 2 /* DSP1TX_HPF_MODE - [4:3] */ | ||
2362 | #define WM8996_DSP1TX_HPF_CUT_MASK 0x0007 /* DSP1TX_HPF_CUT - [2:0] */ | ||
2363 | #define WM8996_DSP1TX_HPF_CUT_SHIFT 0 /* DSP1TX_HPF_CUT - [2:0] */ | ||
2364 | #define WM8996_DSP1TX_HPF_CUT_WIDTH 3 /* DSP1TX_HPF_CUT - [2:0] */ | ||
2365 | |||
2366 | /* | ||
2367 | * R1056 (0x420) - DSP1 RX Filters (1) | ||
2368 | */ | ||
2369 | #define WM8996_DSP1RX_MUTE 0x0200 /* DSP1RX_MUTE */ | ||
2370 | #define WM8996_DSP1RX_MUTE_MASK 0x0200 /* DSP1RX_MUTE */ | ||
2371 | #define WM8996_DSP1RX_MUTE_SHIFT 9 /* DSP1RX_MUTE */ | ||
2372 | #define WM8996_DSP1RX_MUTE_WIDTH 1 /* DSP1RX_MUTE */ | ||
2373 | #define WM8996_DSP1RX_MONO 0x0080 /* DSP1RX_MONO */ | ||
2374 | #define WM8996_DSP1RX_MONO_MASK 0x0080 /* DSP1RX_MONO */ | ||
2375 | #define WM8996_DSP1RX_MONO_SHIFT 7 /* DSP1RX_MONO */ | ||
2376 | #define WM8996_DSP1RX_MONO_WIDTH 1 /* DSP1RX_MONO */ | ||
2377 | #define WM8996_DSP1RX_MUTERATE 0x0020 /* DSP1RX_MUTERATE */ | ||
2378 | #define WM8996_DSP1RX_MUTERATE_MASK 0x0020 /* DSP1RX_MUTERATE */ | ||
2379 | #define WM8996_DSP1RX_MUTERATE_SHIFT 5 /* DSP1RX_MUTERATE */ | ||
2380 | #define WM8996_DSP1RX_MUTERATE_WIDTH 1 /* DSP1RX_MUTERATE */ | ||
2381 | #define WM8996_DSP1RX_UNMUTE_RAMP 0x0010 /* DSP1RX_UNMUTE_RAMP */ | ||
2382 | #define WM8996_DSP1RX_UNMUTE_RAMP_MASK 0x0010 /* DSP1RX_UNMUTE_RAMP */ | ||
2383 | #define WM8996_DSP1RX_UNMUTE_RAMP_SHIFT 4 /* DSP1RX_UNMUTE_RAMP */ | ||
2384 | #define WM8996_DSP1RX_UNMUTE_RAMP_WIDTH 1 /* DSP1RX_UNMUTE_RAMP */ | ||
2385 | |||
2386 | /* | ||
2387 | * R1057 (0x421) - DSP1 RX Filters (2) | ||
2388 | */ | ||
2389 | #define WM8996_DSP1RX_3D_GAIN_MASK 0x3E00 /* DSP1RX_3D_GAIN - [13:9] */ | ||
2390 | #define WM8996_DSP1RX_3D_GAIN_SHIFT 9 /* DSP1RX_3D_GAIN - [13:9] */ | ||
2391 | #define WM8996_DSP1RX_3D_GAIN_WIDTH 5 /* DSP1RX_3D_GAIN - [13:9] */ | ||
2392 | #define WM8996_DSP1RX_3D_ENA 0x0100 /* DSP1RX_3D_ENA */ | ||
2393 | #define WM8996_DSP1RX_3D_ENA_MASK 0x0100 /* DSP1RX_3D_ENA */ | ||
2394 | #define WM8996_DSP1RX_3D_ENA_SHIFT 8 /* DSP1RX_3D_ENA */ | ||
2395 | #define WM8996_DSP1RX_3D_ENA_WIDTH 1 /* DSP1RX_3D_ENA */ | ||
2396 | |||
2397 | /* | ||
2398 | * R1088 (0x440) - DSP1 DRC (1) | ||
2399 | */ | ||
2400 | #define WM8996_DSP1DRC_SIG_DET_RMS_MASK 0xF800 /* DSP1DRC_SIG_DET_RMS - [15:11] */ | ||
2401 | #define WM8996_DSP1DRC_SIG_DET_RMS_SHIFT 11 /* DSP1DRC_SIG_DET_RMS - [15:11] */ | ||
2402 | #define WM8996_DSP1DRC_SIG_DET_RMS_WIDTH 5 /* DSP1DRC_SIG_DET_RMS - [15:11] */ | ||
2403 | #define WM8996_DSP1DRC_SIG_DET_PK_MASK 0x0600 /* DSP1DRC_SIG_DET_PK - [10:9] */ | ||
2404 | #define WM8996_DSP1DRC_SIG_DET_PK_SHIFT 9 /* DSP1DRC_SIG_DET_PK - [10:9] */ | ||
2405 | #define WM8996_DSP1DRC_SIG_DET_PK_WIDTH 2 /* DSP1DRC_SIG_DET_PK - [10:9] */ | ||
2406 | #define WM8996_DSP1DRC_NG_ENA 0x0100 /* DSP1DRC_NG_ENA */ | ||
2407 | #define WM8996_DSP1DRC_NG_ENA_MASK 0x0100 /* DSP1DRC_NG_ENA */ | ||
2408 | #define WM8996_DSP1DRC_NG_ENA_SHIFT 8 /* DSP1DRC_NG_ENA */ | ||
2409 | #define WM8996_DSP1DRC_NG_ENA_WIDTH 1 /* DSP1DRC_NG_ENA */ | ||
2410 | #define WM8996_DSP1DRC_SIG_DET_MODE 0x0080 /* DSP1DRC_SIG_DET_MODE */ | ||
2411 | #define WM8996_DSP1DRC_SIG_DET_MODE_MASK 0x0080 /* DSP1DRC_SIG_DET_MODE */ | ||
2412 | #define WM8996_DSP1DRC_SIG_DET_MODE_SHIFT 7 /* DSP1DRC_SIG_DET_MODE */ | ||
2413 | #define WM8996_DSP1DRC_SIG_DET_MODE_WIDTH 1 /* DSP1DRC_SIG_DET_MODE */ | ||
2414 | #define WM8996_DSP1DRC_SIG_DET 0x0040 /* DSP1DRC_SIG_DET */ | ||
2415 | #define WM8996_DSP1DRC_SIG_DET_MASK 0x0040 /* DSP1DRC_SIG_DET */ | ||
2416 | #define WM8996_DSP1DRC_SIG_DET_SHIFT 6 /* DSP1DRC_SIG_DET */ | ||
2417 | #define WM8996_DSP1DRC_SIG_DET_WIDTH 1 /* DSP1DRC_SIG_DET */ | ||
2418 | #define WM8996_DSP1DRC_KNEE2_OP_ENA 0x0020 /* DSP1DRC_KNEE2_OP_ENA */ | ||
2419 | #define WM8996_DSP1DRC_KNEE2_OP_ENA_MASK 0x0020 /* DSP1DRC_KNEE2_OP_ENA */ | ||
2420 | #define WM8996_DSP1DRC_KNEE2_OP_ENA_SHIFT 5 /* DSP1DRC_KNEE2_OP_ENA */ | ||
2421 | #define WM8996_DSP1DRC_KNEE2_OP_ENA_WIDTH 1 /* DSP1DRC_KNEE2_OP_ENA */ | ||
2422 | #define WM8996_DSP1DRC_QR 0x0010 /* DSP1DRC_QR */ | ||
2423 | #define WM8996_DSP1DRC_QR_MASK 0x0010 /* DSP1DRC_QR */ | ||
2424 | #define WM8996_DSP1DRC_QR_SHIFT 4 /* DSP1DRC_QR */ | ||
2425 | #define WM8996_DSP1DRC_QR_WIDTH 1 /* DSP1DRC_QR */ | ||
2426 | #define WM8996_DSP1DRC_ANTICLIP 0x0008 /* DSP1DRC_ANTICLIP */ | ||
2427 | #define WM8996_DSP1DRC_ANTICLIP_MASK 0x0008 /* DSP1DRC_ANTICLIP */ | ||
2428 | #define WM8996_DSP1DRC_ANTICLIP_SHIFT 3 /* DSP1DRC_ANTICLIP */ | ||
2429 | #define WM8996_DSP1DRC_ANTICLIP_WIDTH 1 /* DSP1DRC_ANTICLIP */ | ||
2430 | #define WM8996_DSP1RX_DRC_ENA 0x0004 /* DSP1RX_DRC_ENA */ | ||
2431 | #define WM8996_DSP1RX_DRC_ENA_MASK 0x0004 /* DSP1RX_DRC_ENA */ | ||
2432 | #define WM8996_DSP1RX_DRC_ENA_SHIFT 2 /* DSP1RX_DRC_ENA */ | ||
2433 | #define WM8996_DSP1RX_DRC_ENA_WIDTH 1 /* DSP1RX_DRC_ENA */ | ||
2434 | #define WM8996_DSP1TXL_DRC_ENA 0x0002 /* DSP1TXL_DRC_ENA */ | ||
2435 | #define WM8996_DSP1TXL_DRC_ENA_MASK 0x0002 /* DSP1TXL_DRC_ENA */ | ||
2436 | #define WM8996_DSP1TXL_DRC_ENA_SHIFT 1 /* DSP1TXL_DRC_ENA */ | ||
2437 | #define WM8996_DSP1TXL_DRC_ENA_WIDTH 1 /* DSP1TXL_DRC_ENA */ | ||
2438 | #define WM8996_DSP1TXR_DRC_ENA 0x0001 /* DSP1TXR_DRC_ENA */ | ||
2439 | #define WM8996_DSP1TXR_DRC_ENA_MASK 0x0001 /* DSP1TXR_DRC_ENA */ | ||
2440 | #define WM8996_DSP1TXR_DRC_ENA_SHIFT 0 /* DSP1TXR_DRC_ENA */ | ||
2441 | #define WM8996_DSP1TXR_DRC_ENA_WIDTH 1 /* DSP1TXR_DRC_ENA */ | ||
2442 | |||
2443 | /* | ||
2444 | * R1089 (0x441) - DSP1 DRC (2) | ||
2445 | */ | ||
2446 | #define WM8996_DSP1DRC_ATK_MASK 0x1E00 /* DSP1DRC_ATK - [12:9] */ | ||
2447 | #define WM8996_DSP1DRC_ATK_SHIFT 9 /* DSP1DRC_ATK - [12:9] */ | ||
2448 | #define WM8996_DSP1DRC_ATK_WIDTH 4 /* DSP1DRC_ATK - [12:9] */ | ||
2449 | #define WM8996_DSP1DRC_DCY_MASK 0x01E0 /* DSP1DRC_DCY - [8:5] */ | ||
2450 | #define WM8996_DSP1DRC_DCY_SHIFT 5 /* DSP1DRC_DCY - [8:5] */ | ||
2451 | #define WM8996_DSP1DRC_DCY_WIDTH 4 /* DSP1DRC_DCY - [8:5] */ | ||
2452 | #define WM8996_DSP1DRC_MINGAIN_MASK 0x001C /* DSP1DRC_MINGAIN - [4:2] */ | ||
2453 | #define WM8996_DSP1DRC_MINGAIN_SHIFT 2 /* DSP1DRC_MINGAIN - [4:2] */ | ||
2454 | #define WM8996_DSP1DRC_MINGAIN_WIDTH 3 /* DSP1DRC_MINGAIN - [4:2] */ | ||
2455 | #define WM8996_DSP1DRC_MAXGAIN_MASK 0x0003 /* DSP1DRC_MAXGAIN - [1:0] */ | ||
2456 | #define WM8996_DSP1DRC_MAXGAIN_SHIFT 0 /* DSP1DRC_MAXGAIN - [1:0] */ | ||
2457 | #define WM8996_DSP1DRC_MAXGAIN_WIDTH 2 /* DSP1DRC_MAXGAIN - [1:0] */ | ||
2458 | |||
2459 | /* | ||
2460 | * R1090 (0x442) - DSP1 DRC (3) | ||
2461 | */ | ||
2462 | #define WM8996_DSP1DRC_NG_MINGAIN_MASK 0xF000 /* DSP1DRC_NG_MINGAIN - [15:12] */ | ||
2463 | #define WM8996_DSP1DRC_NG_MINGAIN_SHIFT 12 /* DSP1DRC_NG_MINGAIN - [15:12] */ | ||
2464 | #define WM8996_DSP1DRC_NG_MINGAIN_WIDTH 4 /* DSP1DRC_NG_MINGAIN - [15:12] */ | ||
2465 | #define WM8996_DSP1DRC_NG_EXP_MASK 0x0C00 /* DSP1DRC_NG_EXP - [11:10] */ | ||
2466 | #define WM8996_DSP1DRC_NG_EXP_SHIFT 10 /* DSP1DRC_NG_EXP - [11:10] */ | ||
2467 | #define WM8996_DSP1DRC_NG_EXP_WIDTH 2 /* DSP1DRC_NG_EXP - [11:10] */ | ||
2468 | #define WM8996_DSP1DRC_QR_THR_MASK 0x0300 /* DSP1DRC_QR_THR - [9:8] */ | ||
2469 | #define WM8996_DSP1DRC_QR_THR_SHIFT 8 /* DSP1DRC_QR_THR - [9:8] */ | ||
2470 | #define WM8996_DSP1DRC_QR_THR_WIDTH 2 /* DSP1DRC_QR_THR - [9:8] */ | ||
2471 | #define WM8996_DSP1DRC_QR_DCY_MASK 0x00C0 /* DSP1DRC_QR_DCY - [7:6] */ | ||
2472 | #define WM8996_DSP1DRC_QR_DCY_SHIFT 6 /* DSP1DRC_QR_DCY - [7:6] */ | ||
2473 | #define WM8996_DSP1DRC_QR_DCY_WIDTH 2 /* DSP1DRC_QR_DCY - [7:6] */ | ||
2474 | #define WM8996_DSP1DRC_HI_COMP_MASK 0x0038 /* DSP1DRC_HI_COMP - [5:3] */ | ||
2475 | #define WM8996_DSP1DRC_HI_COMP_SHIFT 3 /* DSP1DRC_HI_COMP - [5:3] */ | ||
2476 | #define WM8996_DSP1DRC_HI_COMP_WIDTH 3 /* DSP1DRC_HI_COMP - [5:3] */ | ||
2477 | #define WM8996_DSP1DRC_LO_COMP_MASK 0x0007 /* DSP1DRC_LO_COMP - [2:0] */ | ||
2478 | #define WM8996_DSP1DRC_LO_COMP_SHIFT 0 /* DSP1DRC_LO_COMP - [2:0] */ | ||
2479 | #define WM8996_DSP1DRC_LO_COMP_WIDTH 3 /* DSP1DRC_LO_COMP - [2:0] */ | ||
2480 | |||
2481 | /* | ||
2482 | * R1091 (0x443) - DSP1 DRC (4) | ||
2483 | */ | ||
2484 | #define WM8996_DSP1DRC_KNEE_IP_MASK 0x07E0 /* DSP1DRC_KNEE_IP - [10:5] */ | ||
2485 | #define WM8996_DSP1DRC_KNEE_IP_SHIFT 5 /* DSP1DRC_KNEE_IP - [10:5] */ | ||
2486 | #define WM8996_DSP1DRC_KNEE_IP_WIDTH 6 /* DSP1DRC_KNEE_IP - [10:5] */ | ||
2487 | #define WM8996_DSP1DRC_KNEE_OP_MASK 0x001F /* DSP1DRC_KNEE_OP - [4:0] */ | ||
2488 | #define WM8996_DSP1DRC_KNEE_OP_SHIFT 0 /* DSP1DRC_KNEE_OP - [4:0] */ | ||
2489 | #define WM8996_DSP1DRC_KNEE_OP_WIDTH 5 /* DSP1DRC_KNEE_OP - [4:0] */ | ||
2490 | |||
2491 | /* | ||
2492 | * R1092 (0x444) - DSP1 DRC (5) | ||
2493 | */ | ||
2494 | #define WM8996_DSP1DRC_KNEE2_IP_MASK 0x03E0 /* DSP1DRC_KNEE2_IP - [9:5] */ | ||
2495 | #define WM8996_DSP1DRC_KNEE2_IP_SHIFT 5 /* DSP1DRC_KNEE2_IP - [9:5] */ | ||
2496 | #define WM8996_DSP1DRC_KNEE2_IP_WIDTH 5 /* DSP1DRC_KNEE2_IP - [9:5] */ | ||
2497 | #define WM8996_DSP1DRC_KNEE2_OP_MASK 0x001F /* DSP1DRC_KNEE2_OP - [4:0] */ | ||
2498 | #define WM8996_DSP1DRC_KNEE2_OP_SHIFT 0 /* DSP1DRC_KNEE2_OP - [4:0] */ | ||
2499 | #define WM8996_DSP1DRC_KNEE2_OP_WIDTH 5 /* DSP1DRC_KNEE2_OP - [4:0] */ | ||
2500 | |||
2501 | /* | ||
2502 | * R1152 (0x480) - DSP1 RX EQ Gains (1) | ||
2503 | */ | ||
2504 | #define WM8996_DSP1RX_EQ_B1_GAIN_MASK 0xF800 /* DSP1RX_EQ_B1_GAIN - [15:11] */ | ||
2505 | #define WM8996_DSP1RX_EQ_B1_GAIN_SHIFT 11 /* DSP1RX_EQ_B1_GAIN - [15:11] */ | ||
2506 | #define WM8996_DSP1RX_EQ_B1_GAIN_WIDTH 5 /* DSP1RX_EQ_B1_GAIN - [15:11] */ | ||
2507 | #define WM8996_DSP1RX_EQ_B2_GAIN_MASK 0x07C0 /* DSP1RX_EQ_B2_GAIN - [10:6] */ | ||
2508 | #define WM8996_DSP1RX_EQ_B2_GAIN_SHIFT 6 /* DSP1RX_EQ_B2_GAIN - [10:6] */ | ||
2509 | #define WM8996_DSP1RX_EQ_B2_GAIN_WIDTH 5 /* DSP1RX_EQ_B2_GAIN - [10:6] */ | ||
2510 | #define WM8996_DSP1RX_EQ_B3_GAIN_MASK 0x003E /* DSP1RX_EQ_B3_GAIN - [5:1] */ | ||
2511 | #define WM8996_DSP1RX_EQ_B3_GAIN_SHIFT 1 /* DSP1RX_EQ_B3_GAIN - [5:1] */ | ||
2512 | #define WM8996_DSP1RX_EQ_B3_GAIN_WIDTH 5 /* DSP1RX_EQ_B3_GAIN - [5:1] */ | ||
2513 | #define WM8996_DSP1RX_EQ_ENA 0x0001 /* DSP1RX_EQ_ENA */ | ||
2514 | #define WM8996_DSP1RX_EQ_ENA_MASK 0x0001 /* DSP1RX_EQ_ENA */ | ||
2515 | #define WM8996_DSP1RX_EQ_ENA_SHIFT 0 /* DSP1RX_EQ_ENA */ | ||
2516 | #define WM8996_DSP1RX_EQ_ENA_WIDTH 1 /* DSP1RX_EQ_ENA */ | ||
2517 | |||
2518 | /* | ||
2519 | * R1153 (0x481) - DSP1 RX EQ Gains (2) | ||
2520 | */ | ||
2521 | #define WM8996_DSP1RX_EQ_B4_GAIN_MASK 0xF800 /* DSP1RX_EQ_B4_GAIN - [15:11] */ | ||
2522 | #define WM8996_DSP1RX_EQ_B4_GAIN_SHIFT 11 /* DSP1RX_EQ_B4_GAIN - [15:11] */ | ||
2523 | #define WM8996_DSP1RX_EQ_B4_GAIN_WIDTH 5 /* DSP1RX_EQ_B4_GAIN - [15:11] */ | ||
2524 | #define WM8996_DSP1RX_EQ_B5_GAIN_MASK 0x07C0 /* DSP1RX_EQ_B5_GAIN - [10:6] */ | ||
2525 | #define WM8996_DSP1RX_EQ_B5_GAIN_SHIFT 6 /* DSP1RX_EQ_B5_GAIN - [10:6] */ | ||
2526 | #define WM8996_DSP1RX_EQ_B5_GAIN_WIDTH 5 /* DSP1RX_EQ_B5_GAIN - [10:6] */ | ||
2527 | |||
2528 | /* | ||
2529 | * R1154 (0x482) - DSP1 RX EQ Band 1 A | ||
2530 | */ | ||
2531 | #define WM8996_DSP1RX_EQ_B1_A_MASK 0xFFFF /* DSP1RX_EQ_B1_A - [15:0] */ | ||
2532 | #define WM8996_DSP1RX_EQ_B1_A_SHIFT 0 /* DSP1RX_EQ_B1_A - [15:0] */ | ||
2533 | #define WM8996_DSP1RX_EQ_B1_A_WIDTH 16 /* DSP1RX_EQ_B1_A - [15:0] */ | ||
2534 | |||
2535 | /* | ||
2536 | * R1155 (0x483) - DSP1 RX EQ Band 1 B | ||
2537 | */ | ||
2538 | #define WM8996_DSP1RX_EQ_B1_B_MASK 0xFFFF /* DSP1RX_EQ_B1_B - [15:0] */ | ||
2539 | #define WM8996_DSP1RX_EQ_B1_B_SHIFT 0 /* DSP1RX_EQ_B1_B - [15:0] */ | ||
2540 | #define WM8996_DSP1RX_EQ_B1_B_WIDTH 16 /* DSP1RX_EQ_B1_B - [15:0] */ | ||
2541 | |||
2542 | /* | ||
2543 | * R1156 (0x484) - DSP1 RX EQ Band 1 PG | ||
2544 | */ | ||
2545 | #define WM8996_DSP1RX_EQ_B1_PG_MASK 0xFFFF /* DSP1RX_EQ_B1_PG - [15:0] */ | ||
2546 | #define WM8996_DSP1RX_EQ_B1_PG_SHIFT 0 /* DSP1RX_EQ_B1_PG - [15:0] */ | ||
2547 | #define WM8996_DSP1RX_EQ_B1_PG_WIDTH 16 /* DSP1RX_EQ_B1_PG - [15:0] */ | ||
2548 | |||
2549 | /* | ||
2550 | * R1157 (0x485) - DSP1 RX EQ Band 2 A | ||
2551 | */ | ||
2552 | #define WM8996_DSP1RX_EQ_B2_A_MASK 0xFFFF /* DSP1RX_EQ_B2_A - [15:0] */ | ||
2553 | #define WM8996_DSP1RX_EQ_B2_A_SHIFT 0 /* DSP1RX_EQ_B2_A - [15:0] */ | ||
2554 | #define WM8996_DSP1RX_EQ_B2_A_WIDTH 16 /* DSP1RX_EQ_B2_A - [15:0] */ | ||
2555 | |||
2556 | /* | ||
2557 | * R1158 (0x486) - DSP1 RX EQ Band 2 B | ||
2558 | */ | ||
2559 | #define WM8996_DSP1RX_EQ_B2_B_MASK 0xFFFF /* DSP1RX_EQ_B2_B - [15:0] */ | ||
2560 | #define WM8996_DSP1RX_EQ_B2_B_SHIFT 0 /* DSP1RX_EQ_B2_B - [15:0] */ | ||
2561 | #define WM8996_DSP1RX_EQ_B2_B_WIDTH 16 /* DSP1RX_EQ_B2_B - [15:0] */ | ||
2562 | |||
2563 | /* | ||
2564 | * R1159 (0x487) - DSP1 RX EQ Band 2 C | ||
2565 | */ | ||
2566 | #define WM8996_DSP1RX_EQ_B2_C_MASK 0xFFFF /* DSP1RX_EQ_B2_C - [15:0] */ | ||
2567 | #define WM8996_DSP1RX_EQ_B2_C_SHIFT 0 /* DSP1RX_EQ_B2_C - [15:0] */ | ||
2568 | #define WM8996_DSP1RX_EQ_B2_C_WIDTH 16 /* DSP1RX_EQ_B2_C - [15:0] */ | ||
2569 | |||
2570 | /* | ||
2571 | * R1160 (0x488) - DSP1 RX EQ Band 2 PG | ||
2572 | */ | ||
2573 | #define WM8996_DSP1RX_EQ_B2_PG_MASK 0xFFFF /* DSP1RX_EQ_B2_PG - [15:0] */ | ||
2574 | #define WM8996_DSP1RX_EQ_B2_PG_SHIFT 0 /* DSP1RX_EQ_B2_PG - [15:0] */ | ||
2575 | #define WM8996_DSP1RX_EQ_B2_PG_WIDTH 16 /* DSP1RX_EQ_B2_PG - [15:0] */ | ||
2576 | |||
2577 | /* | ||
2578 | * R1161 (0x489) - DSP1 RX EQ Band 3 A | ||
2579 | */ | ||
2580 | #define WM8996_DSP1RX_EQ_B3_A_MASK 0xFFFF /* DSP1RX_EQ_B3_A - [15:0] */ | ||
2581 | #define WM8996_DSP1RX_EQ_B3_A_SHIFT 0 /* DSP1RX_EQ_B3_A - [15:0] */ | ||
2582 | #define WM8996_DSP1RX_EQ_B3_A_WIDTH 16 /* DSP1RX_EQ_B3_A - [15:0] */ | ||
2583 | |||
2584 | /* | ||
2585 | * R1162 (0x48A) - DSP1 RX EQ Band 3 B | ||
2586 | */ | ||
2587 | #define WM8996_DSP1RX_EQ_B3_B_MASK 0xFFFF /* DSP1RX_EQ_B3_B - [15:0] */ | ||
2588 | #define WM8996_DSP1RX_EQ_B3_B_SHIFT 0 /* DSP1RX_EQ_B3_B - [15:0] */ | ||
2589 | #define WM8996_DSP1RX_EQ_B3_B_WIDTH 16 /* DSP1RX_EQ_B3_B - [15:0] */ | ||
2590 | |||
2591 | /* | ||
2592 | * R1163 (0x48B) - DSP1 RX EQ Band 3 C | ||
2593 | */ | ||
2594 | #define WM8996_DSP1RX_EQ_B3_C_MASK 0xFFFF /* DSP1RX_EQ_B3_C - [15:0] */ | ||
2595 | #define WM8996_DSP1RX_EQ_B3_C_SHIFT 0 /* DSP1RX_EQ_B3_C - [15:0] */ | ||
2596 | #define WM8996_DSP1RX_EQ_B3_C_WIDTH 16 /* DSP1RX_EQ_B3_C - [15:0] */ | ||
2597 | |||
2598 | /* | ||
2599 | * R1164 (0x48C) - DSP1 RX EQ Band 3 PG | ||
2600 | */ | ||
2601 | #define WM8996_DSP1RX_EQ_B3_PG_MASK 0xFFFF /* DSP1RX_EQ_B3_PG - [15:0] */ | ||
2602 | #define WM8996_DSP1RX_EQ_B3_PG_SHIFT 0 /* DSP1RX_EQ_B3_PG - [15:0] */ | ||
2603 | #define WM8996_DSP1RX_EQ_B3_PG_WIDTH 16 /* DSP1RX_EQ_B3_PG - [15:0] */ | ||
2604 | |||
2605 | /* | ||
2606 | * R1165 (0x48D) - DSP1 RX EQ Band 4 A | ||
2607 | */ | ||
2608 | #define WM8996_DSP1RX_EQ_B4_A_MASK 0xFFFF /* DSP1RX_EQ_B4_A - [15:0] */ | ||
2609 | #define WM8996_DSP1RX_EQ_B4_A_SHIFT 0 /* DSP1RX_EQ_B4_A - [15:0] */ | ||
2610 | #define WM8996_DSP1RX_EQ_B4_A_WIDTH 16 /* DSP1RX_EQ_B4_A - [15:0] */ | ||
2611 | |||
2612 | /* | ||
2613 | * R1166 (0x48E) - DSP1 RX EQ Band 4 B | ||
2614 | */ | ||
2615 | #define WM8996_DSP1RX_EQ_B4_B_MASK 0xFFFF /* DSP1RX_EQ_B4_B - [15:0] */ | ||
2616 | #define WM8996_DSP1RX_EQ_B4_B_SHIFT 0 /* DSP1RX_EQ_B4_B - [15:0] */ | ||
2617 | #define WM8996_DSP1RX_EQ_B4_B_WIDTH 16 /* DSP1RX_EQ_B4_B - [15:0] */ | ||
2618 | |||
2619 | /* | ||
2620 | * R1167 (0x48F) - DSP1 RX EQ Band 4 C | ||
2621 | */ | ||
2622 | #define WM8996_DSP1RX_EQ_B4_C_MASK 0xFFFF /* DSP1RX_EQ_B4_C - [15:0] */ | ||
2623 | #define WM8996_DSP1RX_EQ_B4_C_SHIFT 0 /* DSP1RX_EQ_B4_C - [15:0] */ | ||
2624 | #define WM8996_DSP1RX_EQ_B4_C_WIDTH 16 /* DSP1RX_EQ_B4_C - [15:0] */ | ||
2625 | |||
2626 | /* | ||
2627 | * R1168 (0x490) - DSP1 RX EQ Band 4 PG | ||
2628 | */ | ||
2629 | #define WM8996_DSP1RX_EQ_B4_PG_MASK 0xFFFF /* DSP1RX_EQ_B4_PG - [15:0] */ | ||
2630 | #define WM8996_DSP1RX_EQ_B4_PG_SHIFT 0 /* DSP1RX_EQ_B4_PG - [15:0] */ | ||
2631 | #define WM8996_DSP1RX_EQ_B4_PG_WIDTH 16 /* DSP1RX_EQ_B4_PG - [15:0] */ | ||
2632 | |||
2633 | /* | ||
2634 | * R1169 (0x491) - DSP1 RX EQ Band 5 A | ||
2635 | */ | ||
2636 | #define WM8996_DSP1RX_EQ_B5_A_MASK 0xFFFF /* DSP1RX_EQ_B5_A - [15:0] */ | ||
2637 | #define WM8996_DSP1RX_EQ_B5_A_SHIFT 0 /* DSP1RX_EQ_B5_A - [15:0] */ | ||
2638 | #define WM8996_DSP1RX_EQ_B5_A_WIDTH 16 /* DSP1RX_EQ_B5_A - [15:0] */ | ||
2639 | |||
2640 | /* | ||
2641 | * R1170 (0x492) - DSP1 RX EQ Band 5 B | ||
2642 | */ | ||
2643 | #define WM8996_DSP1RX_EQ_B5_B_MASK 0xFFFF /* DSP1RX_EQ_B5_B - [15:0] */ | ||
2644 | #define WM8996_DSP1RX_EQ_B5_B_SHIFT 0 /* DSP1RX_EQ_B5_B - [15:0] */ | ||
2645 | #define WM8996_DSP1RX_EQ_B5_B_WIDTH 16 /* DSP1RX_EQ_B5_B - [15:0] */ | ||
2646 | |||
2647 | /* | ||
2648 | * R1171 (0x493) - DSP1 RX EQ Band 5 PG | ||
2649 | */ | ||
2650 | #define WM8996_DSP1RX_EQ_B5_PG_MASK 0xFFFF /* DSP1RX_EQ_B5_PG - [15:0] */ | ||
2651 | #define WM8996_DSP1RX_EQ_B5_PG_SHIFT 0 /* DSP1RX_EQ_B5_PG - [15:0] */ | ||
2652 | #define WM8996_DSP1RX_EQ_B5_PG_WIDTH 16 /* DSP1RX_EQ_B5_PG - [15:0] */ | ||
2653 | |||
2654 | /* | ||
2655 | * R1280 (0x500) - DSP2 TX Left Volume | ||
2656 | */ | ||
2657 | #define WM8996_DSP2TX_VU 0x0100 /* DSP2TX_VU */ | ||
2658 | #define WM8996_DSP2TX_VU_MASK 0x0100 /* DSP2TX_VU */ | ||
2659 | #define WM8996_DSP2TX_VU_SHIFT 8 /* DSP2TX_VU */ | ||
2660 | #define WM8996_DSP2TX_VU_WIDTH 1 /* DSP2TX_VU */ | ||
2661 | #define WM8996_DSP2TXL_VOL_MASK 0x00FF /* DSP2TXL_VOL - [7:0] */ | ||
2662 | #define WM8996_DSP2TXL_VOL_SHIFT 0 /* DSP2TXL_VOL - [7:0] */ | ||
2663 | #define WM8996_DSP2TXL_VOL_WIDTH 8 /* DSP2TXL_VOL - [7:0] */ | ||
2664 | |||
2665 | /* | ||
2666 | * R1281 (0x501) - DSP2 TX Right Volume | ||
2667 | */ | ||
2668 | #define WM8996_DSP2TX_VU 0x0100 /* DSP2TX_VU */ | ||
2669 | #define WM8996_DSP2TX_VU_MASK 0x0100 /* DSP2TX_VU */ | ||
2670 | #define WM8996_DSP2TX_VU_SHIFT 8 /* DSP2TX_VU */ | ||
2671 | #define WM8996_DSP2TX_VU_WIDTH 1 /* DSP2TX_VU */ | ||
2672 | #define WM8996_DSP2TXR_VOL_MASK 0x00FF /* DSP2TXR_VOL - [7:0] */ | ||
2673 | #define WM8996_DSP2TXR_VOL_SHIFT 0 /* DSP2TXR_VOL - [7:0] */ | ||
2674 | #define WM8996_DSP2TXR_VOL_WIDTH 8 /* DSP2TXR_VOL - [7:0] */ | ||
2675 | |||
2676 | /* | ||
2677 | * R1282 (0x502) - DSP2 RX Left Volume | ||
2678 | */ | ||
2679 | #define WM8996_DSP2RX_VU 0x0100 /* DSP2RX_VU */ | ||
2680 | #define WM8996_DSP2RX_VU_MASK 0x0100 /* DSP2RX_VU */ | ||
2681 | #define WM8996_DSP2RX_VU_SHIFT 8 /* DSP2RX_VU */ | ||
2682 | #define WM8996_DSP2RX_VU_WIDTH 1 /* DSP2RX_VU */ | ||
2683 | #define WM8996_DSP2RXL_VOL_MASK 0x00FF /* DSP2RXL_VOL - [7:0] */ | ||
2684 | #define WM8996_DSP2RXL_VOL_SHIFT 0 /* DSP2RXL_VOL - [7:0] */ | ||
2685 | #define WM8996_DSP2RXL_VOL_WIDTH 8 /* DSP2RXL_VOL - [7:0] */ | ||
2686 | |||
2687 | /* | ||
2688 | * R1283 (0x503) - DSP2 RX Right Volume | ||
2689 | */ | ||
2690 | #define WM8996_DSP2RX_VU 0x0100 /* DSP2RX_VU */ | ||
2691 | #define WM8996_DSP2RX_VU_MASK 0x0100 /* DSP2RX_VU */ | ||
2692 | #define WM8996_DSP2RX_VU_SHIFT 8 /* DSP2RX_VU */ | ||
2693 | #define WM8996_DSP2RX_VU_WIDTH 1 /* DSP2RX_VU */ | ||
2694 | #define WM8996_DSP2RXR_VOL_MASK 0x00FF /* DSP2RXR_VOL - [7:0] */ | ||
2695 | #define WM8996_DSP2RXR_VOL_SHIFT 0 /* DSP2RXR_VOL - [7:0] */ | ||
2696 | #define WM8996_DSP2RXR_VOL_WIDTH 8 /* DSP2RXR_VOL - [7:0] */ | ||
2697 | |||
2698 | /* | ||
2699 | * R1296 (0x510) - DSP2 TX Filters | ||
2700 | */ | ||
2701 | #define WM8996_DSP2TX_NF 0x2000 /* DSP2TX_NF */ | ||
2702 | #define WM8996_DSP2TX_NF_MASK 0x2000 /* DSP2TX_NF */ | ||
2703 | #define WM8996_DSP2TX_NF_SHIFT 13 /* DSP2TX_NF */ | ||
2704 | #define WM8996_DSP2TX_NF_WIDTH 1 /* DSP2TX_NF */ | ||
2705 | #define WM8996_DSP2TXL_HPF 0x1000 /* DSP2TXL_HPF */ | ||
2706 | #define WM8996_DSP2TXL_HPF_MASK 0x1000 /* DSP2TXL_HPF */ | ||
2707 | #define WM8996_DSP2TXL_HPF_SHIFT 12 /* DSP2TXL_HPF */ | ||
2708 | #define WM8996_DSP2TXL_HPF_WIDTH 1 /* DSP2TXL_HPF */ | ||
2709 | #define WM8996_DSP2TXR_HPF 0x0800 /* DSP2TXR_HPF */ | ||
2710 | #define WM8996_DSP2TXR_HPF_MASK 0x0800 /* DSP2TXR_HPF */ | ||
2711 | #define WM8996_DSP2TXR_HPF_SHIFT 11 /* DSP2TXR_HPF */ | ||
2712 | #define WM8996_DSP2TXR_HPF_WIDTH 1 /* DSP2TXR_HPF */ | ||
2713 | #define WM8996_DSP2TX_HPF_MODE_MASK 0x0018 /* DSP2TX_HPF_MODE - [4:3] */ | ||
2714 | #define WM8996_DSP2TX_HPF_MODE_SHIFT 3 /* DSP2TX_HPF_MODE - [4:3] */ | ||
2715 | #define WM8996_DSP2TX_HPF_MODE_WIDTH 2 /* DSP2TX_HPF_MODE - [4:3] */ | ||
2716 | #define WM8996_DSP2TX_HPF_CUT_MASK 0x0007 /* DSP2TX_HPF_CUT - [2:0] */ | ||
2717 | #define WM8996_DSP2TX_HPF_CUT_SHIFT 0 /* DSP2TX_HPF_CUT - [2:0] */ | ||
2718 | #define WM8996_DSP2TX_HPF_CUT_WIDTH 3 /* DSP2TX_HPF_CUT - [2:0] */ | ||
2719 | |||
2720 | /* | ||
2721 | * R1312 (0x520) - DSP2 RX Filters (1) | ||
2722 | */ | ||
2723 | #define WM8996_DSP2RX_MUTE 0x0200 /* DSP2RX_MUTE */ | ||
2724 | #define WM8996_DSP2RX_MUTE_MASK 0x0200 /* DSP2RX_MUTE */ | ||
2725 | #define WM8996_DSP2RX_MUTE_SHIFT 9 /* DSP2RX_MUTE */ | ||
2726 | #define WM8996_DSP2RX_MUTE_WIDTH 1 /* DSP2RX_MUTE */ | ||
2727 | #define WM8996_DSP2RX_MONO 0x0080 /* DSP2RX_MONO */ | ||
2728 | #define WM8996_DSP2RX_MONO_MASK 0x0080 /* DSP2RX_MONO */ | ||
2729 | #define WM8996_DSP2RX_MONO_SHIFT 7 /* DSP2RX_MONO */ | ||
2730 | #define WM8996_DSP2RX_MONO_WIDTH 1 /* DSP2RX_MONO */ | ||
2731 | #define WM8996_DSP2RX_MUTERATE 0x0020 /* DSP2RX_MUTERATE */ | ||
2732 | #define WM8996_DSP2RX_MUTERATE_MASK 0x0020 /* DSP2RX_MUTERATE */ | ||
2733 | #define WM8996_DSP2RX_MUTERATE_SHIFT 5 /* DSP2RX_MUTERATE */ | ||
2734 | #define WM8996_DSP2RX_MUTERATE_WIDTH 1 /* DSP2RX_MUTERATE */ | ||
2735 | #define WM8996_DSP2RX_UNMUTE_RAMP 0x0010 /* DSP2RX_UNMUTE_RAMP */ | ||
2736 | #define WM8996_DSP2RX_UNMUTE_RAMP_MASK 0x0010 /* DSP2RX_UNMUTE_RAMP */ | ||
2737 | #define WM8996_DSP2RX_UNMUTE_RAMP_SHIFT 4 /* DSP2RX_UNMUTE_RAMP */ | ||
2738 | #define WM8996_DSP2RX_UNMUTE_RAMP_WIDTH 1 /* DSP2RX_UNMUTE_RAMP */ | ||
2739 | |||
2740 | /* | ||
2741 | * R1313 (0x521) - DSP2 RX Filters (2) | ||
2742 | */ | ||
2743 | #define WM8996_DSP2RX_3D_GAIN_MASK 0x3E00 /* DSP2RX_3D_GAIN - [13:9] */ | ||
2744 | #define WM8996_DSP2RX_3D_GAIN_SHIFT 9 /* DSP2RX_3D_GAIN - [13:9] */ | ||
2745 | #define WM8996_DSP2RX_3D_GAIN_WIDTH 5 /* DSP2RX_3D_GAIN - [13:9] */ | ||
2746 | #define WM8996_DSP2RX_3D_ENA 0x0100 /* DSP2RX_3D_ENA */ | ||
2747 | #define WM8996_DSP2RX_3D_ENA_MASK 0x0100 /* DSP2RX_3D_ENA */ | ||
2748 | #define WM8996_DSP2RX_3D_ENA_SHIFT 8 /* DSP2RX_3D_ENA */ | ||
2749 | #define WM8996_DSP2RX_3D_ENA_WIDTH 1 /* DSP2RX_3D_ENA */ | ||
2750 | |||
2751 | /* | ||
2752 | * R1344 (0x540) - DSP2 DRC (1) | ||
2753 | */ | ||
2754 | #define WM8996_DSP2DRC_SIG_DET_RMS_MASK 0xF800 /* DSP2DRC_SIG_DET_RMS - [15:11] */ | ||
2755 | #define WM8996_DSP2DRC_SIG_DET_RMS_SHIFT 11 /* DSP2DRC_SIG_DET_RMS - [15:11] */ | ||
2756 | #define WM8996_DSP2DRC_SIG_DET_RMS_WIDTH 5 /* DSP2DRC_SIG_DET_RMS - [15:11] */ | ||
2757 | #define WM8996_DSP2DRC_SIG_DET_PK_MASK 0x0600 /* DSP2DRC_SIG_DET_PK - [10:9] */ | ||
2758 | #define WM8996_DSP2DRC_SIG_DET_PK_SHIFT 9 /* DSP2DRC_SIG_DET_PK - [10:9] */ | ||
2759 | #define WM8996_DSP2DRC_SIG_DET_PK_WIDTH 2 /* DSP2DRC_SIG_DET_PK - [10:9] */ | ||
2760 | #define WM8996_DSP2DRC_NG_ENA 0x0100 /* DSP2DRC_NG_ENA */ | ||
2761 | #define WM8996_DSP2DRC_NG_ENA_MASK 0x0100 /* DSP2DRC_NG_ENA */ | ||
2762 | #define WM8996_DSP2DRC_NG_ENA_SHIFT 8 /* DSP2DRC_NG_ENA */ | ||
2763 | #define WM8996_DSP2DRC_NG_ENA_WIDTH 1 /* DSP2DRC_NG_ENA */ | ||
2764 | #define WM8996_DSP2DRC_SIG_DET_MODE 0x0080 /* DSP2DRC_SIG_DET_MODE */ | ||
2765 | #define WM8996_DSP2DRC_SIG_DET_MODE_MASK 0x0080 /* DSP2DRC_SIG_DET_MODE */ | ||
2766 | #define WM8996_DSP2DRC_SIG_DET_MODE_SHIFT 7 /* DSP2DRC_SIG_DET_MODE */ | ||
2767 | #define WM8996_DSP2DRC_SIG_DET_MODE_WIDTH 1 /* DSP2DRC_SIG_DET_MODE */ | ||
2768 | #define WM8996_DSP2DRC_SIG_DET 0x0040 /* DSP2DRC_SIG_DET */ | ||
2769 | #define WM8996_DSP2DRC_SIG_DET_MASK 0x0040 /* DSP2DRC_SIG_DET */ | ||
2770 | #define WM8996_DSP2DRC_SIG_DET_SHIFT 6 /* DSP2DRC_SIG_DET */ | ||
2771 | #define WM8996_DSP2DRC_SIG_DET_WIDTH 1 /* DSP2DRC_SIG_DET */ | ||
2772 | #define WM8996_DSP2DRC_KNEE2_OP_ENA 0x0020 /* DSP2DRC_KNEE2_OP_ENA */ | ||
2773 | #define WM8996_DSP2DRC_KNEE2_OP_ENA_MASK 0x0020 /* DSP2DRC_KNEE2_OP_ENA */ | ||
2774 | #define WM8996_DSP2DRC_KNEE2_OP_ENA_SHIFT 5 /* DSP2DRC_KNEE2_OP_ENA */ | ||
2775 | #define WM8996_DSP2DRC_KNEE2_OP_ENA_WIDTH 1 /* DSP2DRC_KNEE2_OP_ENA */ | ||
2776 | #define WM8996_DSP2DRC_QR 0x0010 /* DSP2DRC_QR */ | ||
2777 | #define WM8996_DSP2DRC_QR_MASK 0x0010 /* DSP2DRC_QR */ | ||
2778 | #define WM8996_DSP2DRC_QR_SHIFT 4 /* DSP2DRC_QR */ | ||
2779 | #define WM8996_DSP2DRC_QR_WIDTH 1 /* DSP2DRC_QR */ | ||
2780 | #define WM8996_DSP2DRC_ANTICLIP 0x0008 /* DSP2DRC_ANTICLIP */ | ||
2781 | #define WM8996_DSP2DRC_ANTICLIP_MASK 0x0008 /* DSP2DRC_ANTICLIP */ | ||
2782 | #define WM8996_DSP2DRC_ANTICLIP_SHIFT 3 /* DSP2DRC_ANTICLIP */ | ||
2783 | #define WM8996_DSP2DRC_ANTICLIP_WIDTH 1 /* DSP2DRC_ANTICLIP */ | ||
2784 | #define WM8996_DSP2RX_DRC_ENA 0x0004 /* DSP2RX_DRC_ENA */ | ||
2785 | #define WM8996_DSP2RX_DRC_ENA_MASK 0x0004 /* DSP2RX_DRC_ENA */ | ||
2786 | #define WM8996_DSP2RX_DRC_ENA_SHIFT 2 /* DSP2RX_DRC_ENA */ | ||
2787 | #define WM8996_DSP2RX_DRC_ENA_WIDTH 1 /* DSP2RX_DRC_ENA */ | ||
2788 | #define WM8996_DSP2TXL_DRC_ENA 0x0002 /* DSP2TXL_DRC_ENA */ | ||
2789 | #define WM8996_DSP2TXL_DRC_ENA_MASK 0x0002 /* DSP2TXL_DRC_ENA */ | ||
2790 | #define WM8996_DSP2TXL_DRC_ENA_SHIFT 1 /* DSP2TXL_DRC_ENA */ | ||
2791 | #define WM8996_DSP2TXL_DRC_ENA_WIDTH 1 /* DSP2TXL_DRC_ENA */ | ||
2792 | #define WM8996_DSP2TXR_DRC_ENA 0x0001 /* DSP2TXR_DRC_ENA */ | ||
2793 | #define WM8996_DSP2TXR_DRC_ENA_MASK 0x0001 /* DSP2TXR_DRC_ENA */ | ||
2794 | #define WM8996_DSP2TXR_DRC_ENA_SHIFT 0 /* DSP2TXR_DRC_ENA */ | ||
2795 | #define WM8996_DSP2TXR_DRC_ENA_WIDTH 1 /* DSP2TXR_DRC_ENA */ | ||
2796 | |||
2797 | /* | ||
2798 | * R1345 (0x541) - DSP2 DRC (2) | ||
2799 | */ | ||
2800 | #define WM8996_DSP2DRC_ATK_MASK 0x1E00 /* DSP2DRC_ATK - [12:9] */ | ||
2801 | #define WM8996_DSP2DRC_ATK_SHIFT 9 /* DSP2DRC_ATK - [12:9] */ | ||
2802 | #define WM8996_DSP2DRC_ATK_WIDTH 4 /* DSP2DRC_ATK - [12:9] */ | ||
2803 | #define WM8996_DSP2DRC_DCY_MASK 0x01E0 /* DSP2DRC_DCY - [8:5] */ | ||
2804 | #define WM8996_DSP2DRC_DCY_SHIFT 5 /* DSP2DRC_DCY - [8:5] */ | ||
2805 | #define WM8996_DSP2DRC_DCY_WIDTH 4 /* DSP2DRC_DCY - [8:5] */ | ||
2806 | #define WM8996_DSP2DRC_MINGAIN_MASK 0x001C /* DSP2DRC_MINGAIN - [4:2] */ | ||
2807 | #define WM8996_DSP2DRC_MINGAIN_SHIFT 2 /* DSP2DRC_MINGAIN - [4:2] */ | ||
2808 | #define WM8996_DSP2DRC_MINGAIN_WIDTH 3 /* DSP2DRC_MINGAIN - [4:2] */ | ||
2809 | #define WM8996_DSP2DRC_MAXGAIN_MASK 0x0003 /* DSP2DRC_MAXGAIN - [1:0] */ | ||
2810 | #define WM8996_DSP2DRC_MAXGAIN_SHIFT 0 /* DSP2DRC_MAXGAIN - [1:0] */ | ||
2811 | #define WM8996_DSP2DRC_MAXGAIN_WIDTH 2 /* DSP2DRC_MAXGAIN - [1:0] */ | ||
2812 | |||
2813 | /* | ||
2814 | * R1346 (0x542) - DSP2 DRC (3) | ||
2815 | */ | ||
2816 | #define WM8996_DSP2DRC_NG_MINGAIN_MASK 0xF000 /* DSP2DRC_NG_MINGAIN - [15:12] */ | ||
2817 | #define WM8996_DSP2DRC_NG_MINGAIN_SHIFT 12 /* DSP2DRC_NG_MINGAIN - [15:12] */ | ||
2818 | #define WM8996_DSP2DRC_NG_MINGAIN_WIDTH 4 /* DSP2DRC_NG_MINGAIN - [15:12] */ | ||
2819 | #define WM8996_DSP2DRC_NG_EXP_MASK 0x0C00 /* DSP2DRC_NG_EXP - [11:10] */ | ||
2820 | #define WM8996_DSP2DRC_NG_EXP_SHIFT 10 /* DSP2DRC_NG_EXP - [11:10] */ | ||
2821 | #define WM8996_DSP2DRC_NG_EXP_WIDTH 2 /* DSP2DRC_NG_EXP - [11:10] */ | ||
2822 | #define WM8996_DSP2DRC_QR_THR_MASK 0x0300 /* DSP2DRC_QR_THR - [9:8] */ | ||
2823 | #define WM8996_DSP2DRC_QR_THR_SHIFT 8 /* DSP2DRC_QR_THR - [9:8] */ | ||
2824 | #define WM8996_DSP2DRC_QR_THR_WIDTH 2 /* DSP2DRC_QR_THR - [9:8] */ | ||
2825 | #define WM8996_DSP2DRC_QR_DCY_MASK 0x00C0 /* DSP2DRC_QR_DCY - [7:6] */ | ||
2826 | #define WM8996_DSP2DRC_QR_DCY_SHIFT 6 /* DSP2DRC_QR_DCY - [7:6] */ | ||
2827 | #define WM8996_DSP2DRC_QR_DCY_WIDTH 2 /* DSP2DRC_QR_DCY - [7:6] */ | ||
2828 | #define WM8996_DSP2DRC_HI_COMP_MASK 0x0038 /* DSP2DRC_HI_COMP - [5:3] */ | ||
2829 | #define WM8996_DSP2DRC_HI_COMP_SHIFT 3 /* DSP2DRC_HI_COMP - [5:3] */ | ||
2830 | #define WM8996_DSP2DRC_HI_COMP_WIDTH 3 /* DSP2DRC_HI_COMP - [5:3] */ | ||
2831 | #define WM8996_DSP2DRC_LO_COMP_MASK 0x0007 /* DSP2DRC_LO_COMP - [2:0] */ | ||
2832 | #define WM8996_DSP2DRC_LO_COMP_SHIFT 0 /* DSP2DRC_LO_COMP - [2:0] */ | ||
2833 | #define WM8996_DSP2DRC_LO_COMP_WIDTH 3 /* DSP2DRC_LO_COMP - [2:0] */ | ||
2834 | |||
2835 | /* | ||
2836 | * R1347 (0x543) - DSP2 DRC (4) | ||
2837 | */ | ||
2838 | #define WM8996_DSP2DRC_KNEE_IP_MASK 0x07E0 /* DSP2DRC_KNEE_IP - [10:5] */ | ||
2839 | #define WM8996_DSP2DRC_KNEE_IP_SHIFT 5 /* DSP2DRC_KNEE_IP - [10:5] */ | ||
2840 | #define WM8996_DSP2DRC_KNEE_IP_WIDTH 6 /* DSP2DRC_KNEE_IP - [10:5] */ | ||
2841 | #define WM8996_DSP2DRC_KNEE_OP_MASK 0x001F /* DSP2DRC_KNEE_OP - [4:0] */ | ||
2842 | #define WM8996_DSP2DRC_KNEE_OP_SHIFT 0 /* DSP2DRC_KNEE_OP - [4:0] */ | ||
2843 | #define WM8996_DSP2DRC_KNEE_OP_WIDTH 5 /* DSP2DRC_KNEE_OP - [4:0] */ | ||
2844 | |||
2845 | /* | ||
2846 | * R1348 (0x544) - DSP2 DRC (5) | ||
2847 | */ | ||
2848 | #define WM8996_DSP2DRC_KNEE2_IP_MASK 0x03E0 /* DSP2DRC_KNEE2_IP - [9:5] */ | ||
2849 | #define WM8996_DSP2DRC_KNEE2_IP_SHIFT 5 /* DSP2DRC_KNEE2_IP - [9:5] */ | ||
2850 | #define WM8996_DSP2DRC_KNEE2_IP_WIDTH 5 /* DSP2DRC_KNEE2_IP - [9:5] */ | ||
2851 | #define WM8996_DSP2DRC_KNEE2_OP_MASK 0x001F /* DSP2DRC_KNEE2_OP - [4:0] */ | ||
2852 | #define WM8996_DSP2DRC_KNEE2_OP_SHIFT 0 /* DSP2DRC_KNEE2_OP - [4:0] */ | ||
2853 | #define WM8996_DSP2DRC_KNEE2_OP_WIDTH 5 /* DSP2DRC_KNEE2_OP - [4:0] */ | ||
2854 | |||
2855 | /* | ||
2856 | * R1408 (0x580) - DSP2 RX EQ Gains (1) | ||
2857 | */ | ||
2858 | #define WM8996_DSP2RX_EQ_B1_GAIN_MASK 0xF800 /* DSP2RX_EQ_B1_GAIN - [15:11] */ | ||
2859 | #define WM8996_DSP2RX_EQ_B1_GAIN_SHIFT 11 /* DSP2RX_EQ_B1_GAIN - [15:11] */ | ||
2860 | #define WM8996_DSP2RX_EQ_B1_GAIN_WIDTH 5 /* DSP2RX_EQ_B1_GAIN - [15:11] */ | ||
2861 | #define WM8996_DSP2RX_EQ_B2_GAIN_MASK 0x07C0 /* DSP2RX_EQ_B2_GAIN - [10:6] */ | ||
2862 | #define WM8996_DSP2RX_EQ_B2_GAIN_SHIFT 6 /* DSP2RX_EQ_B2_GAIN - [10:6] */ | ||
2863 | #define WM8996_DSP2RX_EQ_B2_GAIN_WIDTH 5 /* DSP2RX_EQ_B2_GAIN - [10:6] */ | ||
2864 | #define WM8996_DSP2RX_EQ_B3_GAIN_MASK 0x003E /* DSP2RX_EQ_B3_GAIN - [5:1] */ | ||
2865 | #define WM8996_DSP2RX_EQ_B3_GAIN_SHIFT 1 /* DSP2RX_EQ_B3_GAIN - [5:1] */ | ||
2866 | #define WM8996_DSP2RX_EQ_B3_GAIN_WIDTH 5 /* DSP2RX_EQ_B3_GAIN - [5:1] */ | ||
2867 | #define WM8996_DSP2RX_EQ_ENA 0x0001 /* DSP2RX_EQ_ENA */ | ||
2868 | #define WM8996_DSP2RX_EQ_ENA_MASK 0x0001 /* DSP2RX_EQ_ENA */ | ||
2869 | #define WM8996_DSP2RX_EQ_ENA_SHIFT 0 /* DSP2RX_EQ_ENA */ | ||
2870 | #define WM8996_DSP2RX_EQ_ENA_WIDTH 1 /* DSP2RX_EQ_ENA */ | ||
2871 | |||
2872 | /* | ||
2873 | * R1409 (0x581) - DSP2 RX EQ Gains (2) | ||
2874 | */ | ||
2875 | #define WM8996_DSP2RX_EQ_B4_GAIN_MASK 0xF800 /* DSP2RX_EQ_B4_GAIN - [15:11] */ | ||
2876 | #define WM8996_DSP2RX_EQ_B4_GAIN_SHIFT 11 /* DSP2RX_EQ_B4_GAIN - [15:11] */ | ||
2877 | #define WM8996_DSP2RX_EQ_B4_GAIN_WIDTH 5 /* DSP2RX_EQ_B4_GAIN - [15:11] */ | ||
2878 | #define WM8996_DSP2RX_EQ_B5_GAIN_MASK 0x07C0 /* DSP2RX_EQ_B5_GAIN - [10:6] */ | ||
2879 | #define WM8996_DSP2RX_EQ_B5_GAIN_SHIFT 6 /* DSP2RX_EQ_B5_GAIN - [10:6] */ | ||
2880 | #define WM8996_DSP2RX_EQ_B5_GAIN_WIDTH 5 /* DSP2RX_EQ_B5_GAIN - [10:6] */ | ||
2881 | |||
2882 | /* | ||
2883 | * R1410 (0x582) - DSP2 RX EQ Band 1 A | ||
2884 | */ | ||
2885 | #define WM8996_DSP2RX_EQ_B1_A_MASK 0xFFFF /* DSP2RX_EQ_B1_A - [15:0] */ | ||
2886 | #define WM8996_DSP2RX_EQ_B1_A_SHIFT 0 /* DSP2RX_EQ_B1_A - [15:0] */ | ||
2887 | #define WM8996_DSP2RX_EQ_B1_A_WIDTH 16 /* DSP2RX_EQ_B1_A - [15:0] */ | ||
2888 | |||
2889 | /* | ||
2890 | * R1411 (0x583) - DSP2 RX EQ Band 1 B | ||
2891 | */ | ||
2892 | #define WM8996_DSP2RX_EQ_B1_B_MASK 0xFFFF /* DSP2RX_EQ_B1_B - [15:0] */ | ||
2893 | #define WM8996_DSP2RX_EQ_B1_B_SHIFT 0 /* DSP2RX_EQ_B1_B - [15:0] */ | ||
2894 | #define WM8996_DSP2RX_EQ_B1_B_WIDTH 16 /* DSP2RX_EQ_B1_B - [15:0] */ | ||
2895 | |||
2896 | /* | ||
2897 | * R1412 (0x584) - DSP2 RX EQ Band 1 PG | ||
2898 | */ | ||
2899 | #define WM8996_DSP2RX_EQ_B1_PG_MASK 0xFFFF /* DSP2RX_EQ_B1_PG - [15:0] */ | ||
2900 | #define WM8996_DSP2RX_EQ_B1_PG_SHIFT 0 /* DSP2RX_EQ_B1_PG - [15:0] */ | ||
2901 | #define WM8996_DSP2RX_EQ_B1_PG_WIDTH 16 /* DSP2RX_EQ_B1_PG - [15:0] */ | ||
2902 | |||
2903 | /* | ||
2904 | * R1413 (0x585) - DSP2 RX EQ Band 2 A | ||
2905 | */ | ||
2906 | #define WM8996_DSP2RX_EQ_B2_A_MASK 0xFFFF /* DSP2RX_EQ_B2_A - [15:0] */ | ||
2907 | #define WM8996_DSP2RX_EQ_B2_A_SHIFT 0 /* DSP2RX_EQ_B2_A - [15:0] */ | ||
2908 | #define WM8996_DSP2RX_EQ_B2_A_WIDTH 16 /* DSP2RX_EQ_B2_A - [15:0] */ | ||
2909 | |||
2910 | /* | ||
2911 | * R1414 (0x586) - DSP2 RX EQ Band 2 B | ||
2912 | */ | ||
2913 | #define WM8996_DSP2RX_EQ_B2_B_MASK 0xFFFF /* DSP2RX_EQ_B2_B - [15:0] */ | ||
2914 | #define WM8996_DSP2RX_EQ_B2_B_SHIFT 0 /* DSP2RX_EQ_B2_B - [15:0] */ | ||
2915 | #define WM8996_DSP2RX_EQ_B2_B_WIDTH 16 /* DSP2RX_EQ_B2_B - [15:0] */ | ||
2916 | |||
2917 | /* | ||
2918 | * R1415 (0x587) - DSP2 RX EQ Band 2 C | ||
2919 | */ | ||
2920 | #define WM8996_DSP2RX_EQ_B2_C_MASK 0xFFFF /* DSP2RX_EQ_B2_C - [15:0] */ | ||
2921 | #define WM8996_DSP2RX_EQ_B2_C_SHIFT 0 /* DSP2RX_EQ_B2_C - [15:0] */ | ||
2922 | #define WM8996_DSP2RX_EQ_B2_C_WIDTH 16 /* DSP2RX_EQ_B2_C - [15:0] */ | ||
2923 | |||
2924 | /* | ||
2925 | * R1416 (0x588) - DSP2 RX EQ Band 2 PG | ||
2926 | */ | ||
2927 | #define WM8996_DSP2RX_EQ_B2_PG_MASK 0xFFFF /* DSP2RX_EQ_B2_PG - [15:0] */ | ||
2928 | #define WM8996_DSP2RX_EQ_B2_PG_SHIFT 0 /* DSP2RX_EQ_B2_PG - [15:0] */ | ||
2929 | #define WM8996_DSP2RX_EQ_B2_PG_WIDTH 16 /* DSP2RX_EQ_B2_PG - [15:0] */ | ||
2930 | |||
2931 | /* | ||
2932 | * R1417 (0x589) - DSP2 RX EQ Band 3 A | ||
2933 | */ | ||
2934 | #define WM8996_DSP2RX_EQ_B3_A_MASK 0xFFFF /* DSP2RX_EQ_B3_A - [15:0] */ | ||
2935 | #define WM8996_DSP2RX_EQ_B3_A_SHIFT 0 /* DSP2RX_EQ_B3_A - [15:0] */ | ||
2936 | #define WM8996_DSP2RX_EQ_B3_A_WIDTH 16 /* DSP2RX_EQ_B3_A - [15:0] */ | ||
2937 | |||
2938 | /* | ||
2939 | * R1418 (0x58A) - DSP2 RX EQ Band 3 B | ||
2940 | */ | ||
2941 | #define WM8996_DSP2RX_EQ_B3_B_MASK 0xFFFF /* DSP2RX_EQ_B3_B - [15:0] */ | ||
2942 | #define WM8996_DSP2RX_EQ_B3_B_SHIFT 0 /* DSP2RX_EQ_B3_B - [15:0] */ | ||
2943 | #define WM8996_DSP2RX_EQ_B3_B_WIDTH 16 /* DSP2RX_EQ_B3_B - [15:0] */ | ||
2944 | |||
2945 | /* | ||
2946 | * R1419 (0x58B) - DSP2 RX EQ Band 3 C | ||
2947 | */ | ||
2948 | #define WM8996_DSP2RX_EQ_B3_C_MASK 0xFFFF /* DSP2RX_EQ_B3_C - [15:0] */ | ||
2949 | #define WM8996_DSP2RX_EQ_B3_C_SHIFT 0 /* DSP2RX_EQ_B3_C - [15:0] */ | ||
2950 | #define WM8996_DSP2RX_EQ_B3_C_WIDTH 16 /* DSP2RX_EQ_B3_C - [15:0] */ | ||
2951 | |||
2952 | /* | ||
2953 | * R1420 (0x58C) - DSP2 RX EQ Band 3 PG | ||
2954 | */ | ||
2955 | #define WM8996_DSP2RX_EQ_B3_PG_MASK 0xFFFF /* DSP2RX_EQ_B3_PG - [15:0] */ | ||
2956 | #define WM8996_DSP2RX_EQ_B3_PG_SHIFT 0 /* DSP2RX_EQ_B3_PG - [15:0] */ | ||
2957 | #define WM8996_DSP2RX_EQ_B3_PG_WIDTH 16 /* DSP2RX_EQ_B3_PG - [15:0] */ | ||
2958 | |||
2959 | /* | ||
2960 | * R1421 (0x58D) - DSP2 RX EQ Band 4 A | ||
2961 | */ | ||
2962 | #define WM8996_DSP2RX_EQ_B4_A_MASK 0xFFFF /* DSP2RX_EQ_B4_A - [15:0] */ | ||
2963 | #define WM8996_DSP2RX_EQ_B4_A_SHIFT 0 /* DSP2RX_EQ_B4_A - [15:0] */ | ||
2964 | #define WM8996_DSP2RX_EQ_B4_A_WIDTH 16 /* DSP2RX_EQ_B4_A - [15:0] */ | ||
2965 | |||
2966 | /* | ||
2967 | * R1422 (0x58E) - DSP2 RX EQ Band 4 B | ||
2968 | */ | ||
2969 | #define WM8996_DSP2RX_EQ_B4_B_MASK 0xFFFF /* DSP2RX_EQ_B4_B - [15:0] */ | ||
2970 | #define WM8996_DSP2RX_EQ_B4_B_SHIFT 0 /* DSP2RX_EQ_B4_B - [15:0] */ | ||
2971 | #define WM8996_DSP2RX_EQ_B4_B_WIDTH 16 /* DSP2RX_EQ_B4_B - [15:0] */ | ||
2972 | |||
2973 | /* | ||
2974 | * R1423 (0x58F) - DSP2 RX EQ Band 4 C | ||
2975 | */ | ||
2976 | #define WM8996_DSP2RX_EQ_B4_C_MASK 0xFFFF /* DSP2RX_EQ_B4_C - [15:0] */ | ||
2977 | #define WM8996_DSP2RX_EQ_B4_C_SHIFT 0 /* DSP2RX_EQ_B4_C - [15:0] */ | ||
2978 | #define WM8996_DSP2RX_EQ_B4_C_WIDTH 16 /* DSP2RX_EQ_B4_C - [15:0] */ | ||
2979 | |||
2980 | /* | ||
2981 | * R1424 (0x590) - DSP2 RX EQ Band 4 PG | ||
2982 | */ | ||
2983 | #define WM8996_DSP2RX_EQ_B4_PG_MASK 0xFFFF /* DSP2RX_EQ_B4_PG - [15:0] */ | ||
2984 | #define WM8996_DSP2RX_EQ_B4_PG_SHIFT 0 /* DSP2RX_EQ_B4_PG - [15:0] */ | ||
2985 | #define WM8996_DSP2RX_EQ_B4_PG_WIDTH 16 /* DSP2RX_EQ_B4_PG - [15:0] */ | ||
2986 | |||
2987 | /* | ||
2988 | * R1425 (0x591) - DSP2 RX EQ Band 5 A | ||
2989 | */ | ||
2990 | #define WM8996_DSP2RX_EQ_B5_A_MASK 0xFFFF /* DSP2RX_EQ_B5_A - [15:0] */ | ||
2991 | #define WM8996_DSP2RX_EQ_B5_A_SHIFT 0 /* DSP2RX_EQ_B5_A - [15:0] */ | ||
2992 | #define WM8996_DSP2RX_EQ_B5_A_WIDTH 16 /* DSP2RX_EQ_B5_A - [15:0] */ | ||
2993 | |||
2994 | /* | ||
2995 | * R1426 (0x592) - DSP2 RX EQ Band 5 B | ||
2996 | */ | ||
2997 | #define WM8996_DSP2RX_EQ_B5_B_MASK 0xFFFF /* DSP2RX_EQ_B5_B - [15:0] */ | ||
2998 | #define WM8996_DSP2RX_EQ_B5_B_SHIFT 0 /* DSP2RX_EQ_B5_B - [15:0] */ | ||
2999 | #define WM8996_DSP2RX_EQ_B5_B_WIDTH 16 /* DSP2RX_EQ_B5_B - [15:0] */ | ||
3000 | |||
3001 | /* | ||
3002 | * R1427 (0x593) - DSP2 RX EQ Band 5 PG | ||
3003 | */ | ||
3004 | #define WM8996_DSP2RX_EQ_B5_PG_MASK 0xFFFF /* DSP2RX_EQ_B5_PG - [15:0] */ | ||
3005 | #define WM8996_DSP2RX_EQ_B5_PG_SHIFT 0 /* DSP2RX_EQ_B5_PG - [15:0] */ | ||
3006 | #define WM8996_DSP2RX_EQ_B5_PG_WIDTH 16 /* DSP2RX_EQ_B5_PG - [15:0] */ | ||
3007 | |||
3008 | /* | ||
3009 | * R1536 (0x600) - DAC1 Mixer Volumes | ||
3010 | */ | ||
3011 | #define WM8996_ADCR_DAC1_VOL_MASK 0x03E0 /* ADCR_DAC1_VOL - [9:5] */ | ||
3012 | #define WM8996_ADCR_DAC1_VOL_SHIFT 5 /* ADCR_DAC1_VOL - [9:5] */ | ||
3013 | #define WM8996_ADCR_DAC1_VOL_WIDTH 5 /* ADCR_DAC1_VOL - [9:5] */ | ||
3014 | #define WM8996_ADCL_DAC1_VOL_MASK 0x001F /* ADCL_DAC1_VOL - [4:0] */ | ||
3015 | #define WM8996_ADCL_DAC1_VOL_SHIFT 0 /* ADCL_DAC1_VOL - [4:0] */ | ||
3016 | #define WM8996_ADCL_DAC1_VOL_WIDTH 5 /* ADCL_DAC1_VOL - [4:0] */ | ||
3017 | |||
3018 | /* | ||
3019 | * R1537 (0x601) - DAC1 Left Mixer Routing | ||
3020 | */ | ||
3021 | #define WM8996_ADCR_TO_DAC1L 0x0020 /* ADCR_TO_DAC1L */ | ||
3022 | #define WM8996_ADCR_TO_DAC1L_MASK 0x0020 /* ADCR_TO_DAC1L */ | ||
3023 | #define WM8996_ADCR_TO_DAC1L_SHIFT 5 /* ADCR_TO_DAC1L */ | ||
3024 | #define WM8996_ADCR_TO_DAC1L_WIDTH 1 /* ADCR_TO_DAC1L */ | ||
3025 | #define WM8996_ADCL_TO_DAC1L 0x0010 /* ADCL_TO_DAC1L */ | ||
3026 | #define WM8996_ADCL_TO_DAC1L_MASK 0x0010 /* ADCL_TO_DAC1L */ | ||
3027 | #define WM8996_ADCL_TO_DAC1L_SHIFT 4 /* ADCL_TO_DAC1L */ | ||
3028 | #define WM8996_ADCL_TO_DAC1L_WIDTH 1 /* ADCL_TO_DAC1L */ | ||
3029 | #define WM8996_DSP2RXL_TO_DAC1L 0x0002 /* DSP2RXL_TO_DAC1L */ | ||
3030 | #define WM8996_DSP2RXL_TO_DAC1L_MASK 0x0002 /* DSP2RXL_TO_DAC1L */ | ||
3031 | #define WM8996_DSP2RXL_TO_DAC1L_SHIFT 1 /* DSP2RXL_TO_DAC1L */ | ||
3032 | #define WM8996_DSP2RXL_TO_DAC1L_WIDTH 1 /* DSP2RXL_TO_DAC1L */ | ||
3033 | #define WM8996_DSP1RXL_TO_DAC1L 0x0001 /* DSP1RXL_TO_DAC1L */ | ||
3034 | #define WM8996_DSP1RXL_TO_DAC1L_MASK 0x0001 /* DSP1RXL_TO_DAC1L */ | ||
3035 | #define WM8996_DSP1RXL_TO_DAC1L_SHIFT 0 /* DSP1RXL_TO_DAC1L */ | ||
3036 | #define WM8996_DSP1RXL_TO_DAC1L_WIDTH 1 /* DSP1RXL_TO_DAC1L */ | ||
3037 | |||
3038 | /* | ||
3039 | * R1538 (0x602) - DAC1 Right Mixer Routing | ||
3040 | */ | ||
3041 | #define WM8996_ADCR_TO_DAC1R 0x0020 /* ADCR_TO_DAC1R */ | ||
3042 | #define WM8996_ADCR_TO_DAC1R_MASK 0x0020 /* ADCR_TO_DAC1R */ | ||
3043 | #define WM8996_ADCR_TO_DAC1R_SHIFT 5 /* ADCR_TO_DAC1R */ | ||
3044 | #define WM8996_ADCR_TO_DAC1R_WIDTH 1 /* ADCR_TO_DAC1R */ | ||
3045 | #define WM8996_ADCL_TO_DAC1R 0x0010 /* ADCL_TO_DAC1R */ | ||
3046 | #define WM8996_ADCL_TO_DAC1R_MASK 0x0010 /* ADCL_TO_DAC1R */ | ||
3047 | #define WM8996_ADCL_TO_DAC1R_SHIFT 4 /* ADCL_TO_DAC1R */ | ||
3048 | #define WM8996_ADCL_TO_DAC1R_WIDTH 1 /* ADCL_TO_DAC1R */ | ||
3049 | #define WM8996_DSP2RXR_TO_DAC1R 0x0002 /* DSP2RXR_TO_DAC1R */ | ||
3050 | #define WM8996_DSP2RXR_TO_DAC1R_MASK 0x0002 /* DSP2RXR_TO_DAC1R */ | ||
3051 | #define WM8996_DSP2RXR_TO_DAC1R_SHIFT 1 /* DSP2RXR_TO_DAC1R */ | ||
3052 | #define WM8996_DSP2RXR_TO_DAC1R_WIDTH 1 /* DSP2RXR_TO_DAC1R */ | ||
3053 | #define WM8996_DSP1RXR_TO_DAC1R 0x0001 /* DSP1RXR_TO_DAC1R */ | ||
3054 | #define WM8996_DSP1RXR_TO_DAC1R_MASK 0x0001 /* DSP1RXR_TO_DAC1R */ | ||
3055 | #define WM8996_DSP1RXR_TO_DAC1R_SHIFT 0 /* DSP1RXR_TO_DAC1R */ | ||
3056 | #define WM8996_DSP1RXR_TO_DAC1R_WIDTH 1 /* DSP1RXR_TO_DAC1R */ | ||
3057 | |||
3058 | /* | ||
3059 | * R1539 (0x603) - DAC2 Mixer Volumes | ||
3060 | */ | ||
3061 | #define WM8996_ADCR_DAC2_VOL_MASK 0x03E0 /* ADCR_DAC2_VOL - [9:5] */ | ||
3062 | #define WM8996_ADCR_DAC2_VOL_SHIFT 5 /* ADCR_DAC2_VOL - [9:5] */ | ||
3063 | #define WM8996_ADCR_DAC2_VOL_WIDTH 5 /* ADCR_DAC2_VOL - [9:5] */ | ||
3064 | #define WM8996_ADCL_DAC2_VOL_MASK 0x001F /* ADCL_DAC2_VOL - [4:0] */ | ||
3065 | #define WM8996_ADCL_DAC2_VOL_SHIFT 0 /* ADCL_DAC2_VOL - [4:0] */ | ||
3066 | #define WM8996_ADCL_DAC2_VOL_WIDTH 5 /* ADCL_DAC2_VOL - [4:0] */ | ||
3067 | |||
3068 | /* | ||
3069 | * R1540 (0x604) - DAC2 Left Mixer Routing | ||
3070 | */ | ||
3071 | #define WM8996_ADCR_TO_DAC2L 0x0020 /* ADCR_TO_DAC2L */ | ||
3072 | #define WM8996_ADCR_TO_DAC2L_MASK 0x0020 /* ADCR_TO_DAC2L */ | ||
3073 | #define WM8996_ADCR_TO_DAC2L_SHIFT 5 /* ADCR_TO_DAC2L */ | ||
3074 | #define WM8996_ADCR_TO_DAC2L_WIDTH 1 /* ADCR_TO_DAC2L */ | ||
3075 | #define WM8996_ADCL_TO_DAC2L 0x0010 /* ADCL_TO_DAC2L */ | ||
3076 | #define WM8996_ADCL_TO_DAC2L_MASK 0x0010 /* ADCL_TO_DAC2L */ | ||
3077 | #define WM8996_ADCL_TO_DAC2L_SHIFT 4 /* ADCL_TO_DAC2L */ | ||
3078 | #define WM8996_ADCL_TO_DAC2L_WIDTH 1 /* ADCL_TO_DAC2L */ | ||
3079 | #define WM8996_DSP2RXL_TO_DAC2L 0x0002 /* DSP2RXL_TO_DAC2L */ | ||
3080 | #define WM8996_DSP2RXL_TO_DAC2L_MASK 0x0002 /* DSP2RXL_TO_DAC2L */ | ||
3081 | #define WM8996_DSP2RXL_TO_DAC2L_SHIFT 1 /* DSP2RXL_TO_DAC2L */ | ||
3082 | #define WM8996_DSP2RXL_TO_DAC2L_WIDTH 1 /* DSP2RXL_TO_DAC2L */ | ||
3083 | #define WM8996_DSP1RXL_TO_DAC2L 0x0001 /* DSP1RXL_TO_DAC2L */ | ||
3084 | #define WM8996_DSP1RXL_TO_DAC2L_MASK 0x0001 /* DSP1RXL_TO_DAC2L */ | ||
3085 | #define WM8996_DSP1RXL_TO_DAC2L_SHIFT 0 /* DSP1RXL_TO_DAC2L */ | ||
3086 | #define WM8996_DSP1RXL_TO_DAC2L_WIDTH 1 /* DSP1RXL_TO_DAC2L */ | ||
3087 | |||
3088 | /* | ||
3089 | * R1541 (0x605) - DAC2 Right Mixer Routing | ||
3090 | */ | ||
3091 | #define WM8996_ADCR_TO_DAC2R 0x0020 /* ADCR_TO_DAC2R */ | ||
3092 | #define WM8996_ADCR_TO_DAC2R_MASK 0x0020 /* ADCR_TO_DAC2R */ | ||
3093 | #define WM8996_ADCR_TO_DAC2R_SHIFT 5 /* ADCR_TO_DAC2R */ | ||
3094 | #define WM8996_ADCR_TO_DAC2R_WIDTH 1 /* ADCR_TO_DAC2R */ | ||
3095 | #define WM8996_ADCL_TO_DAC2R 0x0010 /* ADCL_TO_DAC2R */ | ||
3096 | #define WM8996_ADCL_TO_DAC2R_MASK 0x0010 /* ADCL_TO_DAC2R */ | ||
3097 | #define WM8996_ADCL_TO_DAC2R_SHIFT 4 /* ADCL_TO_DAC2R */ | ||
3098 | #define WM8996_ADCL_TO_DAC2R_WIDTH 1 /* ADCL_TO_DAC2R */ | ||
3099 | #define WM8996_DSP2RXR_TO_DAC2R 0x0002 /* DSP2RXR_TO_DAC2R */ | ||
3100 | #define WM8996_DSP2RXR_TO_DAC2R_MASK 0x0002 /* DSP2RXR_TO_DAC2R */ | ||
3101 | #define WM8996_DSP2RXR_TO_DAC2R_SHIFT 1 /* DSP2RXR_TO_DAC2R */ | ||
3102 | #define WM8996_DSP2RXR_TO_DAC2R_WIDTH 1 /* DSP2RXR_TO_DAC2R */ | ||
3103 | #define WM8996_DSP1RXR_TO_DAC2R 0x0001 /* DSP1RXR_TO_DAC2R */ | ||
3104 | #define WM8996_DSP1RXR_TO_DAC2R_MASK 0x0001 /* DSP1RXR_TO_DAC2R */ | ||
3105 | #define WM8996_DSP1RXR_TO_DAC2R_SHIFT 0 /* DSP1RXR_TO_DAC2R */ | ||
3106 | #define WM8996_DSP1RXR_TO_DAC2R_WIDTH 1 /* DSP1RXR_TO_DAC2R */ | ||
3107 | |||
3108 | /* | ||
3109 | * R1542 (0x606) - DSP1 TX Left Mixer Routing | ||
3110 | */ | ||
3111 | #define WM8996_ADC1L_TO_DSP1TXL 0x0002 /* ADC1L_TO_DSP1TXL */ | ||
3112 | #define WM8996_ADC1L_TO_DSP1TXL_MASK 0x0002 /* ADC1L_TO_DSP1TXL */ | ||
3113 | #define WM8996_ADC1L_TO_DSP1TXL_SHIFT 1 /* ADC1L_TO_DSP1TXL */ | ||
3114 | #define WM8996_ADC1L_TO_DSP1TXL_WIDTH 1 /* ADC1L_TO_DSP1TXL */ | ||
3115 | #define WM8996_DACL_TO_DSP1TXL 0x0001 /* DACL_TO_DSP1TXL */ | ||
3116 | #define WM8996_DACL_TO_DSP1TXL_MASK 0x0001 /* DACL_TO_DSP1TXL */ | ||
3117 | #define WM8996_DACL_TO_DSP1TXL_SHIFT 0 /* DACL_TO_DSP1TXL */ | ||
3118 | #define WM8996_DACL_TO_DSP1TXL_WIDTH 1 /* DACL_TO_DSP1TXL */ | ||
3119 | |||
3120 | /* | ||
3121 | * R1543 (0x607) - DSP1 TX Right Mixer Routing | ||
3122 | */ | ||
3123 | #define WM8996_ADC1R_TO_DSP1TXR 0x0002 /* ADC1R_TO_DSP1TXR */ | ||
3124 | #define WM8996_ADC1R_TO_DSP1TXR_MASK 0x0002 /* ADC1R_TO_DSP1TXR */ | ||
3125 | #define WM8996_ADC1R_TO_DSP1TXR_SHIFT 1 /* ADC1R_TO_DSP1TXR */ | ||
3126 | #define WM8996_ADC1R_TO_DSP1TXR_WIDTH 1 /* ADC1R_TO_DSP1TXR */ | ||
3127 | #define WM8996_DACR_TO_DSP1TXR 0x0001 /* DACR_TO_DSP1TXR */ | ||
3128 | #define WM8996_DACR_TO_DSP1TXR_MASK 0x0001 /* DACR_TO_DSP1TXR */ | ||
3129 | #define WM8996_DACR_TO_DSP1TXR_SHIFT 0 /* DACR_TO_DSP1TXR */ | ||
3130 | #define WM8996_DACR_TO_DSP1TXR_WIDTH 1 /* DACR_TO_DSP1TXR */ | ||
3131 | |||
3132 | /* | ||
3133 | * R1544 (0x608) - DSP2 TX Left Mixer Routing | ||
3134 | */ | ||
3135 | #define WM8996_ADC2L_TO_DSP2TXL 0x0002 /* ADC2L_TO_DSP2TXL */ | ||
3136 | #define WM8996_ADC2L_TO_DSP2TXL_MASK 0x0002 /* ADC2L_TO_DSP2TXL */ | ||
3137 | #define WM8996_ADC2L_TO_DSP2TXL_SHIFT 1 /* ADC2L_TO_DSP2TXL */ | ||
3138 | #define WM8996_ADC2L_TO_DSP2TXL_WIDTH 1 /* ADC2L_TO_DSP2TXL */ | ||
3139 | #define WM8996_DACL_TO_DSP2TXL 0x0001 /* DACL_TO_DSP2TXL */ | ||
3140 | #define WM8996_DACL_TO_DSP2TXL_MASK 0x0001 /* DACL_TO_DSP2TXL */ | ||
3141 | #define WM8996_DACL_TO_DSP2TXL_SHIFT 0 /* DACL_TO_DSP2TXL */ | ||
3142 | #define WM8996_DACL_TO_DSP2TXL_WIDTH 1 /* DACL_TO_DSP2TXL */ | ||
3143 | |||
3144 | /* | ||
3145 | * R1545 (0x609) - DSP2 TX Right Mixer Routing | ||
3146 | */ | ||
3147 | #define WM8996_ADC2R_TO_DSP2TXR 0x0002 /* ADC2R_TO_DSP2TXR */ | ||
3148 | #define WM8996_ADC2R_TO_DSP2TXR_MASK 0x0002 /* ADC2R_TO_DSP2TXR */ | ||
3149 | #define WM8996_ADC2R_TO_DSP2TXR_SHIFT 1 /* ADC2R_TO_DSP2TXR */ | ||
3150 | #define WM8996_ADC2R_TO_DSP2TXR_WIDTH 1 /* ADC2R_TO_DSP2TXR */ | ||
3151 | #define WM8996_DACR_TO_DSP2TXR 0x0001 /* DACR_TO_DSP2TXR */ | ||
3152 | #define WM8996_DACR_TO_DSP2TXR_MASK 0x0001 /* DACR_TO_DSP2TXR */ | ||
3153 | #define WM8996_DACR_TO_DSP2TXR_SHIFT 0 /* DACR_TO_DSP2TXR */ | ||
3154 | #define WM8996_DACR_TO_DSP2TXR_WIDTH 1 /* DACR_TO_DSP2TXR */ | ||
3155 | |||
3156 | /* | ||
3157 | * R1546 (0x60A) - DSP TX Mixer Select | ||
3158 | */ | ||
3159 | #define WM8996_DAC_TO_DSPTX_SRC 0x0001 /* DAC_TO_DSPTX_SRC */ | ||
3160 | #define WM8996_DAC_TO_DSPTX_SRC_MASK 0x0001 /* DAC_TO_DSPTX_SRC */ | ||
3161 | #define WM8996_DAC_TO_DSPTX_SRC_SHIFT 0 /* DAC_TO_DSPTX_SRC */ | ||
3162 | #define WM8996_DAC_TO_DSPTX_SRC_WIDTH 1 /* DAC_TO_DSPTX_SRC */ | ||
3163 | |||
3164 | /* | ||
3165 | * R1552 (0x610) - DAC Softmute | ||
3166 | */ | ||
3167 | #define WM8996_DAC_SOFTMUTEMODE 0x0002 /* DAC_SOFTMUTEMODE */ | ||
3168 | #define WM8996_DAC_SOFTMUTEMODE_MASK 0x0002 /* DAC_SOFTMUTEMODE */ | ||
3169 | #define WM8996_DAC_SOFTMUTEMODE_SHIFT 1 /* DAC_SOFTMUTEMODE */ | ||
3170 | #define WM8996_DAC_SOFTMUTEMODE_WIDTH 1 /* DAC_SOFTMUTEMODE */ | ||
3171 | #define WM8996_DAC_MUTERATE 0x0001 /* DAC_MUTERATE */ | ||
3172 | #define WM8996_DAC_MUTERATE_MASK 0x0001 /* DAC_MUTERATE */ | ||
3173 | #define WM8996_DAC_MUTERATE_SHIFT 0 /* DAC_MUTERATE */ | ||
3174 | #define WM8996_DAC_MUTERATE_WIDTH 1 /* DAC_MUTERATE */ | ||
3175 | |||
3176 | /* | ||
3177 | * R1568 (0x620) - Oversampling | ||
3178 | */ | ||
3179 | #define WM8996_SPK_OSR128 0x0008 /* SPK_OSR128 */ | ||
3180 | #define WM8996_SPK_OSR128_MASK 0x0008 /* SPK_OSR128 */ | ||
3181 | #define WM8996_SPK_OSR128_SHIFT 3 /* SPK_OSR128 */ | ||
3182 | #define WM8996_SPK_OSR128_WIDTH 1 /* SPK_OSR128 */ | ||
3183 | #define WM8996_DMIC_OSR64 0x0004 /* DMIC_OSR64 */ | ||
3184 | #define WM8996_DMIC_OSR64_MASK 0x0004 /* DMIC_OSR64 */ | ||
3185 | #define WM8996_DMIC_OSR64_SHIFT 2 /* DMIC_OSR64 */ | ||
3186 | #define WM8996_DMIC_OSR64_WIDTH 1 /* DMIC_OSR64 */ | ||
3187 | #define WM8996_ADC_OSR128 0x0002 /* ADC_OSR128 */ | ||
3188 | #define WM8996_ADC_OSR128_MASK 0x0002 /* ADC_OSR128 */ | ||
3189 | #define WM8996_ADC_OSR128_SHIFT 1 /* ADC_OSR128 */ | ||
3190 | #define WM8996_ADC_OSR128_WIDTH 1 /* ADC_OSR128 */ | ||
3191 | #define WM8996_DAC_OSR128 0x0001 /* DAC_OSR128 */ | ||
3192 | #define WM8996_DAC_OSR128_MASK 0x0001 /* DAC_OSR128 */ | ||
3193 | #define WM8996_DAC_OSR128_SHIFT 0 /* DAC_OSR128 */ | ||
3194 | #define WM8996_DAC_OSR128_WIDTH 1 /* DAC_OSR128 */ | ||
3195 | |||
3196 | /* | ||
3197 | * R1569 (0x621) - Sidetone | ||
3198 | */ | ||
3199 | #define WM8996_ST_LPF 0x1000 /* ST_LPF */ | ||
3200 | #define WM8996_ST_LPF_MASK 0x1000 /* ST_LPF */ | ||
3201 | #define WM8996_ST_LPF_SHIFT 12 /* ST_LPF */ | ||
3202 | #define WM8996_ST_LPF_WIDTH 1 /* ST_LPF */ | ||
3203 | #define WM8996_ST_HPF_CUT_MASK 0x0380 /* ST_HPF_CUT - [9:7] */ | ||
3204 | #define WM8996_ST_HPF_CUT_SHIFT 7 /* ST_HPF_CUT - [9:7] */ | ||
3205 | #define WM8996_ST_HPF_CUT_WIDTH 3 /* ST_HPF_CUT - [9:7] */ | ||
3206 | #define WM8996_ST_HPF 0x0040 /* ST_HPF */ | ||
3207 | #define WM8996_ST_HPF_MASK 0x0040 /* ST_HPF */ | ||
3208 | #define WM8996_ST_HPF_SHIFT 6 /* ST_HPF */ | ||
3209 | #define WM8996_ST_HPF_WIDTH 1 /* ST_HPF */ | ||
3210 | #define WM8996_STR_SEL 0x0002 /* STR_SEL */ | ||
3211 | #define WM8996_STR_SEL_MASK 0x0002 /* STR_SEL */ | ||
3212 | #define WM8996_STR_SEL_SHIFT 1 /* STR_SEL */ | ||
3213 | #define WM8996_STR_SEL_WIDTH 1 /* STR_SEL */ | ||
3214 | #define WM8996_STL_SEL 0x0001 /* STL_SEL */ | ||
3215 | #define WM8996_STL_SEL_MASK 0x0001 /* STL_SEL */ | ||
3216 | #define WM8996_STL_SEL_SHIFT 0 /* STL_SEL */ | ||
3217 | #define WM8996_STL_SEL_WIDTH 1 /* STL_SEL */ | ||
3218 | |||
3219 | /* | ||
3220 | * R1792 (0x700) - GPIO 1 | ||
3221 | */ | ||
3222 | #define WM8996_GP1_DIR 0x8000 /* GP1_DIR */ | ||
3223 | #define WM8996_GP1_DIR_MASK 0x8000 /* GP1_DIR */ | ||
3224 | #define WM8996_GP1_DIR_SHIFT 15 /* GP1_DIR */ | ||
3225 | #define WM8996_GP1_DIR_WIDTH 1 /* GP1_DIR */ | ||
3226 | #define WM8996_GP1_PU 0x4000 /* GP1_PU */ | ||
3227 | #define WM8996_GP1_PU_MASK 0x4000 /* GP1_PU */ | ||
3228 | #define WM8996_GP1_PU_SHIFT 14 /* GP1_PU */ | ||
3229 | #define WM8996_GP1_PU_WIDTH 1 /* GP1_PU */ | ||
3230 | #define WM8996_GP1_PD 0x2000 /* GP1_PD */ | ||
3231 | #define WM8996_GP1_PD_MASK 0x2000 /* GP1_PD */ | ||
3232 | #define WM8996_GP1_PD_SHIFT 13 /* GP1_PD */ | ||
3233 | #define WM8996_GP1_PD_WIDTH 1 /* GP1_PD */ | ||
3234 | #define WM8996_GP1_POL 0x0400 /* GP1_POL */ | ||
3235 | #define WM8996_GP1_POL_MASK 0x0400 /* GP1_POL */ | ||
3236 | #define WM8996_GP1_POL_SHIFT 10 /* GP1_POL */ | ||
3237 | #define WM8996_GP1_POL_WIDTH 1 /* GP1_POL */ | ||
3238 | #define WM8996_GP1_OP_CFG 0x0200 /* GP1_OP_CFG */ | ||
3239 | #define WM8996_GP1_OP_CFG_MASK 0x0200 /* GP1_OP_CFG */ | ||
3240 | #define WM8996_GP1_OP_CFG_SHIFT 9 /* GP1_OP_CFG */ | ||
3241 | #define WM8996_GP1_OP_CFG_WIDTH 1 /* GP1_OP_CFG */ | ||
3242 | #define WM8996_GP1_DB 0x0100 /* GP1_DB */ | ||
3243 | #define WM8996_GP1_DB_MASK 0x0100 /* GP1_DB */ | ||
3244 | #define WM8996_GP1_DB_SHIFT 8 /* GP1_DB */ | ||
3245 | #define WM8996_GP1_DB_WIDTH 1 /* GP1_DB */ | ||
3246 | #define WM8996_GP1_LVL 0x0040 /* GP1_LVL */ | ||
3247 | #define WM8996_GP1_LVL_MASK 0x0040 /* GP1_LVL */ | ||
3248 | #define WM8996_GP1_LVL_SHIFT 6 /* GP1_LVL */ | ||
3249 | #define WM8996_GP1_LVL_WIDTH 1 /* GP1_LVL */ | ||
3250 | #define WM8996_GP1_FN_MASK 0x000F /* GP1_FN - [3:0] */ | ||
3251 | #define WM8996_GP1_FN_SHIFT 0 /* GP1_FN - [3:0] */ | ||
3252 | #define WM8996_GP1_FN_WIDTH 4 /* GP1_FN - [3:0] */ | ||
3253 | |||
3254 | /* | ||
3255 | * R1793 (0x701) - GPIO 2 | ||
3256 | */ | ||
3257 | #define WM8996_GP2_DIR 0x8000 /* GP2_DIR */ | ||
3258 | #define WM8996_GP2_DIR_MASK 0x8000 /* GP2_DIR */ | ||
3259 | #define WM8996_GP2_DIR_SHIFT 15 /* GP2_DIR */ | ||
3260 | #define WM8996_GP2_DIR_WIDTH 1 /* GP2_DIR */ | ||
3261 | #define WM8996_GP2_PU 0x4000 /* GP2_PU */ | ||
3262 | #define WM8996_GP2_PU_MASK 0x4000 /* GP2_PU */ | ||
3263 | #define WM8996_GP2_PU_SHIFT 14 /* GP2_PU */ | ||
3264 | #define WM8996_GP2_PU_WIDTH 1 /* GP2_PU */ | ||
3265 | #define WM8996_GP2_PD 0x2000 /* GP2_PD */ | ||
3266 | #define WM8996_GP2_PD_MASK 0x2000 /* GP2_PD */ | ||
3267 | #define WM8996_GP2_PD_SHIFT 13 /* GP2_PD */ | ||
3268 | #define WM8996_GP2_PD_WIDTH 1 /* GP2_PD */ | ||
3269 | #define WM8996_GP2_POL 0x0400 /* GP2_POL */ | ||
3270 | #define WM8996_GP2_POL_MASK 0x0400 /* GP2_POL */ | ||
3271 | #define WM8996_GP2_POL_SHIFT 10 /* GP2_POL */ | ||
3272 | #define WM8996_GP2_POL_WIDTH 1 /* GP2_POL */ | ||
3273 | #define WM8996_GP2_OP_CFG 0x0200 /* GP2_OP_CFG */ | ||
3274 | #define WM8996_GP2_OP_CFG_MASK 0x0200 /* GP2_OP_CFG */ | ||
3275 | #define WM8996_GP2_OP_CFG_SHIFT 9 /* GP2_OP_CFG */ | ||
3276 | #define WM8996_GP2_OP_CFG_WIDTH 1 /* GP2_OP_CFG */ | ||
3277 | #define WM8996_GP2_DB 0x0100 /* GP2_DB */ | ||
3278 | #define WM8996_GP2_DB_MASK 0x0100 /* GP2_DB */ | ||
3279 | #define WM8996_GP2_DB_SHIFT 8 /* GP2_DB */ | ||
3280 | #define WM8996_GP2_DB_WIDTH 1 /* GP2_DB */ | ||
3281 | #define WM8996_GP2_LVL 0x0040 /* GP2_LVL */ | ||
3282 | #define WM8996_GP2_LVL_MASK 0x0040 /* GP2_LVL */ | ||
3283 | #define WM8996_GP2_LVL_SHIFT 6 /* GP2_LVL */ | ||
3284 | #define WM8996_GP2_LVL_WIDTH 1 /* GP2_LVL */ | ||
3285 | #define WM8996_GP2_FN_MASK 0x000F /* GP2_FN - [3:0] */ | ||
3286 | #define WM8996_GP2_FN_SHIFT 0 /* GP2_FN - [3:0] */ | ||
3287 | #define WM8996_GP2_FN_WIDTH 4 /* GP2_FN - [3:0] */ | ||
3288 | |||
3289 | /* | ||
3290 | * R1794 (0x702) - GPIO 3 | ||
3291 | */ | ||
3292 | #define WM8996_GP3_DIR 0x8000 /* GP3_DIR */ | ||
3293 | #define WM8996_GP3_DIR_MASK 0x8000 /* GP3_DIR */ | ||
3294 | #define WM8996_GP3_DIR_SHIFT 15 /* GP3_DIR */ | ||
3295 | #define WM8996_GP3_DIR_WIDTH 1 /* GP3_DIR */ | ||
3296 | #define WM8996_GP3_PU 0x4000 /* GP3_PU */ | ||
3297 | #define WM8996_GP3_PU_MASK 0x4000 /* GP3_PU */ | ||
3298 | #define WM8996_GP3_PU_SHIFT 14 /* GP3_PU */ | ||
3299 | #define WM8996_GP3_PU_WIDTH 1 /* GP3_PU */ | ||
3300 | #define WM8996_GP3_PD 0x2000 /* GP3_PD */ | ||
3301 | #define WM8996_GP3_PD_MASK 0x2000 /* GP3_PD */ | ||
3302 | #define WM8996_GP3_PD_SHIFT 13 /* GP3_PD */ | ||
3303 | #define WM8996_GP3_PD_WIDTH 1 /* GP3_PD */ | ||
3304 | #define WM8996_GP3_POL 0x0400 /* GP3_POL */ | ||
3305 | #define WM8996_GP3_POL_MASK 0x0400 /* GP3_POL */ | ||
3306 | #define WM8996_GP3_POL_SHIFT 10 /* GP3_POL */ | ||
3307 | #define WM8996_GP3_POL_WIDTH 1 /* GP3_POL */ | ||
3308 | #define WM8996_GP3_OP_CFG 0x0200 /* GP3_OP_CFG */ | ||
3309 | #define WM8996_GP3_OP_CFG_MASK 0x0200 /* GP3_OP_CFG */ | ||
3310 | #define WM8996_GP3_OP_CFG_SHIFT 9 /* GP3_OP_CFG */ | ||
3311 | #define WM8996_GP3_OP_CFG_WIDTH 1 /* GP3_OP_CFG */ | ||
3312 | #define WM8996_GP3_DB 0x0100 /* GP3_DB */ | ||
3313 | #define WM8996_GP3_DB_MASK 0x0100 /* GP3_DB */ | ||
3314 | #define WM8996_GP3_DB_SHIFT 8 /* GP3_DB */ | ||
3315 | #define WM8996_GP3_DB_WIDTH 1 /* GP3_DB */ | ||
3316 | #define WM8996_GP3_LVL 0x0040 /* GP3_LVL */ | ||
3317 | #define WM8996_GP3_LVL_MASK 0x0040 /* GP3_LVL */ | ||
3318 | #define WM8996_GP3_LVL_SHIFT 6 /* GP3_LVL */ | ||
3319 | #define WM8996_GP3_LVL_WIDTH 1 /* GP3_LVL */ | ||
3320 | #define WM8996_GP3_FN_MASK 0x000F /* GP3_FN - [3:0] */ | ||
3321 | #define WM8996_GP3_FN_SHIFT 0 /* GP3_FN - [3:0] */ | ||
3322 | #define WM8996_GP3_FN_WIDTH 4 /* GP3_FN - [3:0] */ | ||
3323 | |||
3324 | /* | ||
3325 | * R1795 (0x703) - GPIO 4 | ||
3326 | */ | ||
3327 | #define WM8996_GP4_DIR 0x8000 /* GP4_DIR */ | ||
3328 | #define WM8996_GP4_DIR_MASK 0x8000 /* GP4_DIR */ | ||
3329 | #define WM8996_GP4_DIR_SHIFT 15 /* GP4_DIR */ | ||
3330 | #define WM8996_GP4_DIR_WIDTH 1 /* GP4_DIR */ | ||
3331 | #define WM8996_GP4_PU 0x4000 /* GP4_PU */ | ||
3332 | #define WM8996_GP4_PU_MASK 0x4000 /* GP4_PU */ | ||
3333 | #define WM8996_GP4_PU_SHIFT 14 /* GP4_PU */ | ||
3334 | #define WM8996_GP4_PU_WIDTH 1 /* GP4_PU */ | ||
3335 | #define WM8996_GP4_PD 0x2000 /* GP4_PD */ | ||
3336 | #define WM8996_GP4_PD_MASK 0x2000 /* GP4_PD */ | ||
3337 | #define WM8996_GP4_PD_SHIFT 13 /* GP4_PD */ | ||
3338 | #define WM8996_GP4_PD_WIDTH 1 /* GP4_PD */ | ||
3339 | #define WM8996_GP4_POL 0x0400 /* GP4_POL */ | ||
3340 | #define WM8996_GP4_POL_MASK 0x0400 /* GP4_POL */ | ||
3341 | #define WM8996_GP4_POL_SHIFT 10 /* GP4_POL */ | ||
3342 | #define WM8996_GP4_POL_WIDTH 1 /* GP4_POL */ | ||
3343 | #define WM8996_GP4_OP_CFG 0x0200 /* GP4_OP_CFG */ | ||
3344 | #define WM8996_GP4_OP_CFG_MASK 0x0200 /* GP4_OP_CFG */ | ||
3345 | #define WM8996_GP4_OP_CFG_SHIFT 9 /* GP4_OP_CFG */ | ||
3346 | #define WM8996_GP4_OP_CFG_WIDTH 1 /* GP4_OP_CFG */ | ||
3347 | #define WM8996_GP4_DB 0x0100 /* GP4_DB */ | ||
3348 | #define WM8996_GP4_DB_MASK 0x0100 /* GP4_DB */ | ||
3349 | #define WM8996_GP4_DB_SHIFT 8 /* GP4_DB */ | ||
3350 | #define WM8996_GP4_DB_WIDTH 1 /* GP4_DB */ | ||
3351 | #define WM8996_GP4_LVL 0x0040 /* GP4_LVL */ | ||
3352 | #define WM8996_GP4_LVL_MASK 0x0040 /* GP4_LVL */ | ||
3353 | #define WM8996_GP4_LVL_SHIFT 6 /* GP4_LVL */ | ||
3354 | #define WM8996_GP4_LVL_WIDTH 1 /* GP4_LVL */ | ||
3355 | #define WM8996_GP4_FN_MASK 0x000F /* GP4_FN - [3:0] */ | ||
3356 | #define WM8996_GP4_FN_SHIFT 0 /* GP4_FN - [3:0] */ | ||
3357 | #define WM8996_GP4_FN_WIDTH 4 /* GP4_FN - [3:0] */ | ||
3358 | |||
3359 | /* | ||
3360 | * R1796 (0x704) - GPIO 5 | ||
3361 | */ | ||
3362 | #define WM8996_GP5_DIR 0x8000 /* GP5_DIR */ | ||
3363 | #define WM8996_GP5_DIR_MASK 0x8000 /* GP5_DIR */ | ||
3364 | #define WM8996_GP5_DIR_SHIFT 15 /* GP5_DIR */ | ||
3365 | #define WM8996_GP5_DIR_WIDTH 1 /* GP5_DIR */ | ||
3366 | #define WM8996_GP5_PU 0x4000 /* GP5_PU */ | ||
3367 | #define WM8996_GP5_PU_MASK 0x4000 /* GP5_PU */ | ||
3368 | #define WM8996_GP5_PU_SHIFT 14 /* GP5_PU */ | ||
3369 | #define WM8996_GP5_PU_WIDTH 1 /* GP5_PU */ | ||
3370 | #define WM8996_GP5_PD 0x2000 /* GP5_PD */ | ||
3371 | #define WM8996_GP5_PD_MASK 0x2000 /* GP5_PD */ | ||
3372 | #define WM8996_GP5_PD_SHIFT 13 /* GP5_PD */ | ||
3373 | #define WM8996_GP5_PD_WIDTH 1 /* GP5_PD */ | ||
3374 | #define WM8996_GP5_POL 0x0400 /* GP5_POL */ | ||
3375 | #define WM8996_GP5_POL_MASK 0x0400 /* GP5_POL */ | ||
3376 | #define WM8996_GP5_POL_SHIFT 10 /* GP5_POL */ | ||
3377 | #define WM8996_GP5_POL_WIDTH 1 /* GP5_POL */ | ||
3378 | #define WM8996_GP5_OP_CFG 0x0200 /* GP5_OP_CFG */ | ||
3379 | #define WM8996_GP5_OP_CFG_MASK 0x0200 /* GP5_OP_CFG */ | ||
3380 | #define WM8996_GP5_OP_CFG_SHIFT 9 /* GP5_OP_CFG */ | ||
3381 | #define WM8996_GP5_OP_CFG_WIDTH 1 /* GP5_OP_CFG */ | ||
3382 | #define WM8996_GP5_DB 0x0100 /* GP5_DB */ | ||
3383 | #define WM8996_GP5_DB_MASK 0x0100 /* GP5_DB */ | ||
3384 | #define WM8996_GP5_DB_SHIFT 8 /* GP5_DB */ | ||
3385 | #define WM8996_GP5_DB_WIDTH 1 /* GP5_DB */ | ||
3386 | #define WM8996_GP5_LVL 0x0040 /* GP5_LVL */ | ||
3387 | #define WM8996_GP5_LVL_MASK 0x0040 /* GP5_LVL */ | ||
3388 | #define WM8996_GP5_LVL_SHIFT 6 /* GP5_LVL */ | ||
3389 | #define WM8996_GP5_LVL_WIDTH 1 /* GP5_LVL */ | ||
3390 | #define WM8996_GP5_FN_MASK 0x000F /* GP5_FN - [3:0] */ | ||
3391 | #define WM8996_GP5_FN_SHIFT 0 /* GP5_FN - [3:0] */ | ||
3392 | #define WM8996_GP5_FN_WIDTH 4 /* GP5_FN - [3:0] */ | ||
3393 | |||
3394 | /* | ||
3395 | * R1824 (0x720) - Pull Control (1) | ||
3396 | */ | ||
3397 | #define WM8996_DMICDAT2_PD 0x1000 /* DMICDAT2_PD */ | ||
3398 | #define WM8996_DMICDAT2_PD_MASK 0x1000 /* DMICDAT2_PD */ | ||
3399 | #define WM8996_DMICDAT2_PD_SHIFT 12 /* DMICDAT2_PD */ | ||
3400 | #define WM8996_DMICDAT2_PD_WIDTH 1 /* DMICDAT2_PD */ | ||
3401 | #define WM8996_DMICDAT1_PD 0x0400 /* DMICDAT1_PD */ | ||
3402 | #define WM8996_DMICDAT1_PD_MASK 0x0400 /* DMICDAT1_PD */ | ||
3403 | #define WM8996_DMICDAT1_PD_SHIFT 10 /* DMICDAT1_PD */ | ||
3404 | #define WM8996_DMICDAT1_PD_WIDTH 1 /* DMICDAT1_PD */ | ||
3405 | #define WM8996_MCLK2_PU 0x0200 /* MCLK2_PU */ | ||
3406 | #define WM8996_MCLK2_PU_MASK 0x0200 /* MCLK2_PU */ | ||
3407 | #define WM8996_MCLK2_PU_SHIFT 9 /* MCLK2_PU */ | ||
3408 | #define WM8996_MCLK2_PU_WIDTH 1 /* MCLK2_PU */ | ||
3409 | #define WM8996_MCLK2_PD 0x0100 /* MCLK2_PD */ | ||
3410 | #define WM8996_MCLK2_PD_MASK 0x0100 /* MCLK2_PD */ | ||
3411 | #define WM8996_MCLK2_PD_SHIFT 8 /* MCLK2_PD */ | ||
3412 | #define WM8996_MCLK2_PD_WIDTH 1 /* MCLK2_PD */ | ||
3413 | #define WM8996_MCLK1_PU 0x0080 /* MCLK1_PU */ | ||
3414 | #define WM8996_MCLK1_PU_MASK 0x0080 /* MCLK1_PU */ | ||
3415 | #define WM8996_MCLK1_PU_SHIFT 7 /* MCLK1_PU */ | ||
3416 | #define WM8996_MCLK1_PU_WIDTH 1 /* MCLK1_PU */ | ||
3417 | #define WM8996_MCLK1_PD 0x0040 /* MCLK1_PD */ | ||
3418 | #define WM8996_MCLK1_PD_MASK 0x0040 /* MCLK1_PD */ | ||
3419 | #define WM8996_MCLK1_PD_SHIFT 6 /* MCLK1_PD */ | ||
3420 | #define WM8996_MCLK1_PD_WIDTH 1 /* MCLK1_PD */ | ||
3421 | #define WM8996_DACDAT1_PU 0x0020 /* DACDAT1_PU */ | ||
3422 | #define WM8996_DACDAT1_PU_MASK 0x0020 /* DACDAT1_PU */ | ||
3423 | #define WM8996_DACDAT1_PU_SHIFT 5 /* DACDAT1_PU */ | ||
3424 | #define WM8996_DACDAT1_PU_WIDTH 1 /* DACDAT1_PU */ | ||
3425 | #define WM8996_DACDAT1_PD 0x0010 /* DACDAT1_PD */ | ||
3426 | #define WM8996_DACDAT1_PD_MASK 0x0010 /* DACDAT1_PD */ | ||
3427 | #define WM8996_DACDAT1_PD_SHIFT 4 /* DACDAT1_PD */ | ||
3428 | #define WM8996_DACDAT1_PD_WIDTH 1 /* DACDAT1_PD */ | ||
3429 | #define WM8996_DACLRCLK1_PU 0x0008 /* DACLRCLK1_PU */ | ||
3430 | #define WM8996_DACLRCLK1_PU_MASK 0x0008 /* DACLRCLK1_PU */ | ||
3431 | #define WM8996_DACLRCLK1_PU_SHIFT 3 /* DACLRCLK1_PU */ | ||
3432 | #define WM8996_DACLRCLK1_PU_WIDTH 1 /* DACLRCLK1_PU */ | ||
3433 | #define WM8996_DACLRCLK1_PD 0x0004 /* DACLRCLK1_PD */ | ||
3434 | #define WM8996_DACLRCLK1_PD_MASK 0x0004 /* DACLRCLK1_PD */ | ||
3435 | #define WM8996_DACLRCLK1_PD_SHIFT 2 /* DACLRCLK1_PD */ | ||
3436 | #define WM8996_DACLRCLK1_PD_WIDTH 1 /* DACLRCLK1_PD */ | ||
3437 | #define WM8996_BCLK1_PU 0x0002 /* BCLK1_PU */ | ||
3438 | #define WM8996_BCLK1_PU_MASK 0x0002 /* BCLK1_PU */ | ||
3439 | #define WM8996_BCLK1_PU_SHIFT 1 /* BCLK1_PU */ | ||
3440 | #define WM8996_BCLK1_PU_WIDTH 1 /* BCLK1_PU */ | ||
3441 | #define WM8996_BCLK1_PD 0x0001 /* BCLK1_PD */ | ||
3442 | #define WM8996_BCLK1_PD_MASK 0x0001 /* BCLK1_PD */ | ||
3443 | #define WM8996_BCLK1_PD_SHIFT 0 /* BCLK1_PD */ | ||
3444 | #define WM8996_BCLK1_PD_WIDTH 1 /* BCLK1_PD */ | ||
3445 | |||
3446 | /* | ||
3447 | * R1825 (0x721) - Pull Control (2) | ||
3448 | */ | ||
3449 | #define WM8996_LDO1ENA_PD 0x0100 /* LDO1ENA_PD */ | ||
3450 | #define WM8996_LDO1ENA_PD_MASK 0x0100 /* LDO1ENA_PD */ | ||
3451 | #define WM8996_LDO1ENA_PD_SHIFT 8 /* LDO1ENA_PD */ | ||
3452 | #define WM8996_LDO1ENA_PD_WIDTH 1 /* LDO1ENA_PD */ | ||
3453 | #define WM8996_ADDR_PD 0x0040 /* ADDR_PD */ | ||
3454 | #define WM8996_ADDR_PD_MASK 0x0040 /* ADDR_PD */ | ||
3455 | #define WM8996_ADDR_PD_SHIFT 6 /* ADDR_PD */ | ||
3456 | #define WM8996_ADDR_PD_WIDTH 1 /* ADDR_PD */ | ||
3457 | #define WM8996_DACDAT2_PU 0x0020 /* DACDAT2_PU */ | ||
3458 | #define WM8996_DACDAT2_PU_MASK 0x0020 /* DACDAT2_PU */ | ||
3459 | #define WM8996_DACDAT2_PU_SHIFT 5 /* DACDAT2_PU */ | ||
3460 | #define WM8996_DACDAT2_PU_WIDTH 1 /* DACDAT2_PU */ | ||
3461 | #define WM8996_DACDAT2_PD 0x0010 /* DACDAT2_PD */ | ||
3462 | #define WM8996_DACDAT2_PD_MASK 0x0010 /* DACDAT2_PD */ | ||
3463 | #define WM8996_DACDAT2_PD_SHIFT 4 /* DACDAT2_PD */ | ||
3464 | #define WM8996_DACDAT2_PD_WIDTH 1 /* DACDAT2_PD */ | ||
3465 | #define WM8996_DACLRCLK2_PU 0x0008 /* DACLRCLK2_PU */ | ||
3466 | #define WM8996_DACLRCLK2_PU_MASK 0x0008 /* DACLRCLK2_PU */ | ||
3467 | #define WM8996_DACLRCLK2_PU_SHIFT 3 /* DACLRCLK2_PU */ | ||
3468 | #define WM8996_DACLRCLK2_PU_WIDTH 1 /* DACLRCLK2_PU */ | ||
3469 | #define WM8996_DACLRCLK2_PD 0x0004 /* DACLRCLK2_PD */ | ||
3470 | #define WM8996_DACLRCLK2_PD_MASK 0x0004 /* DACLRCLK2_PD */ | ||
3471 | #define WM8996_DACLRCLK2_PD_SHIFT 2 /* DACLRCLK2_PD */ | ||
3472 | #define WM8996_DACLRCLK2_PD_WIDTH 1 /* DACLRCLK2_PD */ | ||
3473 | #define WM8996_BCLK2_PU 0x0002 /* BCLK2_PU */ | ||
3474 | #define WM8996_BCLK2_PU_MASK 0x0002 /* BCLK2_PU */ | ||
3475 | #define WM8996_BCLK2_PU_SHIFT 1 /* BCLK2_PU */ | ||
3476 | #define WM8996_BCLK2_PU_WIDTH 1 /* BCLK2_PU */ | ||
3477 | #define WM8996_BCLK2_PD 0x0001 /* BCLK2_PD */ | ||
3478 | #define WM8996_BCLK2_PD_MASK 0x0001 /* BCLK2_PD */ | ||
3479 | #define WM8996_BCLK2_PD_SHIFT 0 /* BCLK2_PD */ | ||
3480 | #define WM8996_BCLK2_PD_WIDTH 1 /* BCLK2_PD */ | ||
3481 | |||
3482 | /* | ||
3483 | * R1840 (0x730) - Interrupt Status 1 | ||
3484 | */ | ||
3485 | #define WM8996_GP5_EINT 0x0010 /* GP5_EINT */ | ||
3486 | #define WM8996_GP5_EINT_MASK 0x0010 /* GP5_EINT */ | ||
3487 | #define WM8996_GP5_EINT_SHIFT 4 /* GP5_EINT */ | ||
3488 | #define WM8996_GP5_EINT_WIDTH 1 /* GP5_EINT */ | ||
3489 | #define WM8996_GP4_EINT 0x0008 /* GP4_EINT */ | ||
3490 | #define WM8996_GP4_EINT_MASK 0x0008 /* GP4_EINT */ | ||
3491 | #define WM8996_GP4_EINT_SHIFT 3 /* GP4_EINT */ | ||
3492 | #define WM8996_GP4_EINT_WIDTH 1 /* GP4_EINT */ | ||
3493 | #define WM8996_GP3_EINT 0x0004 /* GP3_EINT */ | ||
3494 | #define WM8996_GP3_EINT_MASK 0x0004 /* GP3_EINT */ | ||
3495 | #define WM8996_GP3_EINT_SHIFT 2 /* GP3_EINT */ | ||
3496 | #define WM8996_GP3_EINT_WIDTH 1 /* GP3_EINT */ | ||
3497 | #define WM8996_GP2_EINT 0x0002 /* GP2_EINT */ | ||
3498 | #define WM8996_GP2_EINT_MASK 0x0002 /* GP2_EINT */ | ||
3499 | #define WM8996_GP2_EINT_SHIFT 1 /* GP2_EINT */ | ||
3500 | #define WM8996_GP2_EINT_WIDTH 1 /* GP2_EINT */ | ||
3501 | #define WM8996_GP1_EINT 0x0001 /* GP1_EINT */ | ||
3502 | #define WM8996_GP1_EINT_MASK 0x0001 /* GP1_EINT */ | ||
3503 | #define WM8996_GP1_EINT_SHIFT 0 /* GP1_EINT */ | ||
3504 | #define WM8996_GP1_EINT_WIDTH 1 /* GP1_EINT */ | ||
3505 | |||
3506 | /* | ||
3507 | * R1841 (0x731) - Interrupt Status 2 | ||
3508 | */ | ||
3509 | #define WM8996_DCS_DONE_23_EINT 0x1000 /* DCS_DONE_23_EINT */ | ||
3510 | #define WM8996_DCS_DONE_23_EINT_MASK 0x1000 /* DCS_DONE_23_EINT */ | ||
3511 | #define WM8996_DCS_DONE_23_EINT_SHIFT 12 /* DCS_DONE_23_EINT */ | ||
3512 | #define WM8996_DCS_DONE_23_EINT_WIDTH 1 /* DCS_DONE_23_EINT */ | ||
3513 | #define WM8996_DCS_DONE_01_EINT 0x0800 /* DCS_DONE_01_EINT */ | ||
3514 | #define WM8996_DCS_DONE_01_EINT_MASK 0x0800 /* DCS_DONE_01_EINT */ | ||
3515 | #define WM8996_DCS_DONE_01_EINT_SHIFT 11 /* DCS_DONE_01_EINT */ | ||
3516 | #define WM8996_DCS_DONE_01_EINT_WIDTH 1 /* DCS_DONE_01_EINT */ | ||
3517 | #define WM8996_WSEQ_DONE_EINT 0x0400 /* WSEQ_DONE_EINT */ | ||
3518 | #define WM8996_WSEQ_DONE_EINT_MASK 0x0400 /* WSEQ_DONE_EINT */ | ||
3519 | #define WM8996_WSEQ_DONE_EINT_SHIFT 10 /* WSEQ_DONE_EINT */ | ||
3520 | #define WM8996_WSEQ_DONE_EINT_WIDTH 1 /* WSEQ_DONE_EINT */ | ||
3521 | #define WM8996_FIFOS_ERR_EINT 0x0200 /* FIFOS_ERR_EINT */ | ||
3522 | #define WM8996_FIFOS_ERR_EINT_MASK 0x0200 /* FIFOS_ERR_EINT */ | ||
3523 | #define WM8996_FIFOS_ERR_EINT_SHIFT 9 /* FIFOS_ERR_EINT */ | ||
3524 | #define WM8996_FIFOS_ERR_EINT_WIDTH 1 /* FIFOS_ERR_EINT */ | ||
3525 | #define WM8996_DSP2DRC_SIG_DET_EINT 0x0080 /* DSP2DRC_SIG_DET_EINT */ | ||
3526 | #define WM8996_DSP2DRC_SIG_DET_EINT_MASK 0x0080 /* DSP2DRC_SIG_DET_EINT */ | ||
3527 | #define WM8996_DSP2DRC_SIG_DET_EINT_SHIFT 7 /* DSP2DRC_SIG_DET_EINT */ | ||
3528 | #define WM8996_DSP2DRC_SIG_DET_EINT_WIDTH 1 /* DSP2DRC_SIG_DET_EINT */ | ||
3529 | #define WM8996_DSP1DRC_SIG_DET_EINT 0x0040 /* DSP1DRC_SIG_DET_EINT */ | ||
3530 | #define WM8996_DSP1DRC_SIG_DET_EINT_MASK 0x0040 /* DSP1DRC_SIG_DET_EINT */ | ||
3531 | #define WM8996_DSP1DRC_SIG_DET_EINT_SHIFT 6 /* DSP1DRC_SIG_DET_EINT */ | ||
3532 | #define WM8996_DSP1DRC_SIG_DET_EINT_WIDTH 1 /* DSP1DRC_SIG_DET_EINT */ | ||
3533 | #define WM8996_FLL_SW_CLK_DONE_EINT 0x0008 /* FLL_SW_CLK_DONE_EINT */ | ||
3534 | #define WM8996_FLL_SW_CLK_DONE_EINT_MASK 0x0008 /* FLL_SW_CLK_DONE_EINT */ | ||
3535 | #define WM8996_FLL_SW_CLK_DONE_EINT_SHIFT 3 /* FLL_SW_CLK_DONE_EINT */ | ||
3536 | #define WM8996_FLL_SW_CLK_DONE_EINT_WIDTH 1 /* FLL_SW_CLK_DONE_EINT */ | ||
3537 | #define WM8996_FLL_LOCK_EINT 0x0004 /* FLL_LOCK_EINT */ | ||
3538 | #define WM8996_FLL_LOCK_EINT_MASK 0x0004 /* FLL_LOCK_EINT */ | ||
3539 | #define WM8996_FLL_LOCK_EINT_SHIFT 2 /* FLL_LOCK_EINT */ | ||
3540 | #define WM8996_FLL_LOCK_EINT_WIDTH 1 /* FLL_LOCK_EINT */ | ||
3541 | #define WM8996_HP_DONE_EINT 0x0002 /* HP_DONE_EINT */ | ||
3542 | #define WM8996_HP_DONE_EINT_MASK 0x0002 /* HP_DONE_EINT */ | ||
3543 | #define WM8996_HP_DONE_EINT_SHIFT 1 /* HP_DONE_EINT */ | ||
3544 | #define WM8996_HP_DONE_EINT_WIDTH 1 /* HP_DONE_EINT */ | ||
3545 | #define WM8996_MICD_EINT 0x0001 /* MICD_EINT */ | ||
3546 | #define WM8996_MICD_EINT_MASK 0x0001 /* MICD_EINT */ | ||
3547 | #define WM8996_MICD_EINT_SHIFT 0 /* MICD_EINT */ | ||
3548 | #define WM8996_MICD_EINT_WIDTH 1 /* MICD_EINT */ | ||
3549 | |||
3550 | /* | ||
3551 | * R1842 (0x732) - Interrupt Raw Status 2 | ||
3552 | */ | ||
3553 | #define WM8996_DCS_DONE_23_STS 0x1000 /* DCS_DONE_23_STS */ | ||
3554 | #define WM8996_DCS_DONE_23_STS_MASK 0x1000 /* DCS_DONE_23_STS */ | ||
3555 | #define WM8996_DCS_DONE_23_STS_SHIFT 12 /* DCS_DONE_23_STS */ | ||
3556 | #define WM8996_DCS_DONE_23_STS_WIDTH 1 /* DCS_DONE_23_STS */ | ||
3557 | #define WM8996_DCS_DONE_01_STS 0x0800 /* DCS_DONE_01_STS */ | ||
3558 | #define WM8996_DCS_DONE_01_STS_MASK 0x0800 /* DCS_DONE_01_STS */ | ||
3559 | #define WM8996_DCS_DONE_01_STS_SHIFT 11 /* DCS_DONE_01_STS */ | ||
3560 | #define WM8996_DCS_DONE_01_STS_WIDTH 1 /* DCS_DONE_01_STS */ | ||
3561 | #define WM8996_WSEQ_DONE_STS 0x0400 /* WSEQ_DONE_STS */ | ||
3562 | #define WM8996_WSEQ_DONE_STS_MASK 0x0400 /* WSEQ_DONE_STS */ | ||
3563 | #define WM8996_WSEQ_DONE_STS_SHIFT 10 /* WSEQ_DONE_STS */ | ||
3564 | #define WM8996_WSEQ_DONE_STS_WIDTH 1 /* WSEQ_DONE_STS */ | ||
3565 | #define WM8996_FIFOS_ERR_STS 0x0200 /* FIFOS_ERR_STS */ | ||
3566 | #define WM8996_FIFOS_ERR_STS_MASK 0x0200 /* FIFOS_ERR_STS */ | ||
3567 | #define WM8996_FIFOS_ERR_STS_SHIFT 9 /* FIFOS_ERR_STS */ | ||
3568 | #define WM8996_FIFOS_ERR_STS_WIDTH 1 /* FIFOS_ERR_STS */ | ||
3569 | #define WM8996_DSP2DRC_SIG_DET_STS 0x0080 /* DSP2DRC_SIG_DET_STS */ | ||
3570 | #define WM8996_DSP2DRC_SIG_DET_STS_MASK 0x0080 /* DSP2DRC_SIG_DET_STS */ | ||
3571 | #define WM8996_DSP2DRC_SIG_DET_STS_SHIFT 7 /* DSP2DRC_SIG_DET_STS */ | ||
3572 | #define WM8996_DSP2DRC_SIG_DET_STS_WIDTH 1 /* DSP2DRC_SIG_DET_STS */ | ||
3573 | #define WM8996_DSP1DRC_SIG_DET_STS 0x0040 /* DSP1DRC_SIG_DET_STS */ | ||
3574 | #define WM8996_DSP1DRC_SIG_DET_STS_MASK 0x0040 /* DSP1DRC_SIG_DET_STS */ | ||
3575 | #define WM8996_DSP1DRC_SIG_DET_STS_SHIFT 6 /* DSP1DRC_SIG_DET_STS */ | ||
3576 | #define WM8996_DSP1DRC_SIG_DET_STS_WIDTH 1 /* DSP1DRC_SIG_DET_STS */ | ||
3577 | #define WM8996_FLL_LOCK_STS 0x0004 /* FLL_LOCK_STS */ | ||
3578 | #define WM8996_FLL_LOCK_STS_MASK 0x0004 /* FLL_LOCK_STS */ | ||
3579 | #define WM8996_FLL_LOCK_STS_SHIFT 2 /* FLL_LOCK_STS */ | ||
3580 | #define WM8996_FLL_LOCK_STS_WIDTH 1 /* FLL_LOCK_STS */ | ||
3581 | |||
3582 | /* | ||
3583 | * R1848 (0x738) - Interrupt Status 1 Mask | ||
3584 | */ | ||
3585 | #define WM8996_IM_GP5_EINT 0x0010 /* IM_GP5_EINT */ | ||
3586 | #define WM8996_IM_GP5_EINT_MASK 0x0010 /* IM_GP5_EINT */ | ||
3587 | #define WM8996_IM_GP5_EINT_SHIFT 4 /* IM_GP5_EINT */ | ||
3588 | #define WM8996_IM_GP5_EINT_WIDTH 1 /* IM_GP5_EINT */ | ||
3589 | #define WM8996_IM_GP4_EINT 0x0008 /* IM_GP4_EINT */ | ||
3590 | #define WM8996_IM_GP4_EINT_MASK 0x0008 /* IM_GP4_EINT */ | ||
3591 | #define WM8996_IM_GP4_EINT_SHIFT 3 /* IM_GP4_EINT */ | ||
3592 | #define WM8996_IM_GP4_EINT_WIDTH 1 /* IM_GP4_EINT */ | ||
3593 | #define WM8996_IM_GP3_EINT 0x0004 /* IM_GP3_EINT */ | ||
3594 | #define WM8996_IM_GP3_EINT_MASK 0x0004 /* IM_GP3_EINT */ | ||
3595 | #define WM8996_IM_GP3_EINT_SHIFT 2 /* IM_GP3_EINT */ | ||
3596 | #define WM8996_IM_GP3_EINT_WIDTH 1 /* IM_GP3_EINT */ | ||
3597 | #define WM8996_IM_GP2_EINT 0x0002 /* IM_GP2_EINT */ | ||
3598 | #define WM8996_IM_GP2_EINT_MASK 0x0002 /* IM_GP2_EINT */ | ||
3599 | #define WM8996_IM_GP2_EINT_SHIFT 1 /* IM_GP2_EINT */ | ||
3600 | #define WM8996_IM_GP2_EINT_WIDTH 1 /* IM_GP2_EINT */ | ||
3601 | #define WM8996_IM_GP1_EINT 0x0001 /* IM_GP1_EINT */ | ||
3602 | #define WM8996_IM_GP1_EINT_MASK 0x0001 /* IM_GP1_EINT */ | ||
3603 | #define WM8996_IM_GP1_EINT_SHIFT 0 /* IM_GP1_EINT */ | ||
3604 | #define WM8996_IM_GP1_EINT_WIDTH 1 /* IM_GP1_EINT */ | ||
3605 | |||
3606 | /* | ||
3607 | * R1849 (0x739) - Interrupt Status 2 Mask | ||
3608 | */ | ||
3609 | #define WM8996_IM_DCS_DONE_23_EINT 0x1000 /* IM_DCS_DONE_23_EINT */ | ||
3610 | #define WM8996_IM_DCS_DONE_23_EINT_MASK 0x1000 /* IM_DCS_DONE_23_EINT */ | ||
3611 | #define WM8996_IM_DCS_DONE_23_EINT_SHIFT 12 /* IM_DCS_DONE_23_EINT */ | ||
3612 | #define WM8996_IM_DCS_DONE_23_EINT_WIDTH 1 /* IM_DCS_DONE_23_EINT */ | ||
3613 | #define WM8996_IM_DCS_DONE_01_EINT 0x0800 /* IM_DCS_DONE_01_EINT */ | ||
3614 | #define WM8996_IM_DCS_DONE_01_EINT_MASK 0x0800 /* IM_DCS_DONE_01_EINT */ | ||
3615 | #define WM8996_IM_DCS_DONE_01_EINT_SHIFT 11 /* IM_DCS_DONE_01_EINT */ | ||
3616 | #define WM8996_IM_DCS_DONE_01_EINT_WIDTH 1 /* IM_DCS_DONE_01_EINT */ | ||
3617 | #define WM8996_IM_WSEQ_DONE_EINT 0x0400 /* IM_WSEQ_DONE_EINT */ | ||
3618 | #define WM8996_IM_WSEQ_DONE_EINT_MASK 0x0400 /* IM_WSEQ_DONE_EINT */ | ||
3619 | #define WM8996_IM_WSEQ_DONE_EINT_SHIFT 10 /* IM_WSEQ_DONE_EINT */ | ||
3620 | #define WM8996_IM_WSEQ_DONE_EINT_WIDTH 1 /* IM_WSEQ_DONE_EINT */ | ||
3621 | #define WM8996_IM_FIFOS_ERR_EINT 0x0200 /* IM_FIFOS_ERR_EINT */ | ||
3622 | #define WM8996_IM_FIFOS_ERR_EINT_MASK 0x0200 /* IM_FIFOS_ERR_EINT */ | ||
3623 | #define WM8996_IM_FIFOS_ERR_EINT_SHIFT 9 /* IM_FIFOS_ERR_EINT */ | ||
3624 | #define WM8996_IM_FIFOS_ERR_EINT_WIDTH 1 /* IM_FIFOS_ERR_EINT */ | ||
3625 | #define WM8996_IM_DSP2DRC_SIG_DET_EINT 0x0080 /* IM_DSP2DRC_SIG_DET_EINT */ | ||
3626 | #define WM8996_IM_DSP2DRC_SIG_DET_EINT_MASK 0x0080 /* IM_DSP2DRC_SIG_DET_EINT */ | ||
3627 | #define WM8996_IM_DSP2DRC_SIG_DET_EINT_SHIFT 7 /* IM_DSP2DRC_SIG_DET_EINT */ | ||
3628 | #define WM8996_IM_DSP2DRC_SIG_DET_EINT_WIDTH 1 /* IM_DSP2DRC_SIG_DET_EINT */ | ||
3629 | #define WM8996_IM_DSP1DRC_SIG_DET_EINT 0x0040 /* IM_DSP1DRC_SIG_DET_EINT */ | ||
3630 | #define WM8996_IM_DSP1DRC_SIG_DET_EINT_MASK 0x0040 /* IM_DSP1DRC_SIG_DET_EINT */ | ||
3631 | #define WM8996_IM_DSP1DRC_SIG_DET_EINT_SHIFT 6 /* IM_DSP1DRC_SIG_DET_EINT */ | ||
3632 | #define WM8996_IM_DSP1DRC_SIG_DET_EINT_WIDTH 1 /* IM_DSP1DRC_SIG_DET_EINT */ | ||
3633 | #define WM8996_IM_FLL_SW_CLK_DONE_EINT 0x0008 /* IM_FLL_SW_CLK_DONE_EINT */ | ||
3634 | #define WM8996_IM_FLL_SW_CLK_DONE_EINT_MASK 0x0008 /* IM_FLL_SW_CLK_DONE_EINT */ | ||
3635 | #define WM8996_IM_FLL_SW_CLK_DONE_EINT_SHIFT 3 /* IM_FLL_SW_CLK_DONE_EINT */ | ||
3636 | #define WM8996_IM_FLL_SW_CLK_DONE_EINT_WIDTH 1 /* IM_FLL_SW_CLK_DONE_EINT */ | ||
3637 | #define WM8996_IM_FLL_LOCK_EINT 0x0004 /* IM_FLL_LOCK_EINT */ | ||
3638 | #define WM8996_IM_FLL_LOCK_EINT_MASK 0x0004 /* IM_FLL_LOCK_EINT */ | ||
3639 | #define WM8996_IM_FLL_LOCK_EINT_SHIFT 2 /* IM_FLL_LOCK_EINT */ | ||
3640 | #define WM8996_IM_FLL_LOCK_EINT_WIDTH 1 /* IM_FLL_LOCK_EINT */ | ||
3641 | #define WM8996_IM_HP_DONE_EINT 0x0002 /* IM_HP_DONE_EINT */ | ||
3642 | #define WM8996_IM_HP_DONE_EINT_MASK 0x0002 /* IM_HP_DONE_EINT */ | ||
3643 | #define WM8996_IM_HP_DONE_EINT_SHIFT 1 /* IM_HP_DONE_EINT */ | ||
3644 | #define WM8996_IM_HP_DONE_EINT_WIDTH 1 /* IM_HP_DONE_EINT */ | ||
3645 | #define WM8996_IM_MICD_EINT 0x0001 /* IM_MICD_EINT */ | ||
3646 | #define WM8996_IM_MICD_EINT_MASK 0x0001 /* IM_MICD_EINT */ | ||
3647 | #define WM8996_IM_MICD_EINT_SHIFT 0 /* IM_MICD_EINT */ | ||
3648 | #define WM8996_IM_MICD_EINT_WIDTH 1 /* IM_MICD_EINT */ | ||
3649 | |||
3650 | /* | ||
3651 | * R1856 (0x740) - Interrupt Control | ||
3652 | */ | ||
3653 | #define WM8996_IM_IRQ 0x0001 /* IM_IRQ */ | ||
3654 | #define WM8996_IM_IRQ_MASK 0x0001 /* IM_IRQ */ | ||
3655 | #define WM8996_IM_IRQ_SHIFT 0 /* IM_IRQ */ | ||
3656 | #define WM8996_IM_IRQ_WIDTH 1 /* IM_IRQ */ | ||
3657 | |||
3658 | /* | ||
3659 | * R2048 (0x800) - Left PDM Speaker | ||
3660 | */ | ||
3661 | #define WM8996_SPKL_ENA 0x0010 /* SPKL_ENA */ | ||
3662 | #define WM8996_SPKL_ENA_MASK 0x0010 /* SPKL_ENA */ | ||
3663 | #define WM8996_SPKL_ENA_SHIFT 4 /* SPKL_ENA */ | ||
3664 | #define WM8996_SPKL_ENA_WIDTH 1 /* SPKL_ENA */ | ||
3665 | #define WM8996_SPKL_MUTE 0x0008 /* SPKL_MUTE */ | ||
3666 | #define WM8996_SPKL_MUTE_MASK 0x0008 /* SPKL_MUTE */ | ||
3667 | #define WM8996_SPKL_MUTE_SHIFT 3 /* SPKL_MUTE */ | ||
3668 | #define WM8996_SPKL_MUTE_WIDTH 1 /* SPKL_MUTE */ | ||
3669 | #define WM8996_SPKL_MUTE_ZC 0x0004 /* SPKL_MUTE_ZC */ | ||
3670 | #define WM8996_SPKL_MUTE_ZC_MASK 0x0004 /* SPKL_MUTE_ZC */ | ||
3671 | #define WM8996_SPKL_MUTE_ZC_SHIFT 2 /* SPKL_MUTE_ZC */ | ||
3672 | #define WM8996_SPKL_MUTE_ZC_WIDTH 1 /* SPKL_MUTE_ZC */ | ||
3673 | #define WM8996_SPKL_SRC_MASK 0x0003 /* SPKL_SRC - [1:0] */ | ||
3674 | #define WM8996_SPKL_SRC_SHIFT 0 /* SPKL_SRC - [1:0] */ | ||
3675 | #define WM8996_SPKL_SRC_WIDTH 2 /* SPKL_SRC - [1:0] */ | ||
3676 | |||
3677 | /* | ||
3678 | * R2049 (0x801) - Right PDM Speaker | ||
3679 | */ | ||
3680 | #define WM8996_SPKR_ENA 0x0010 /* SPKR_ENA */ | ||
3681 | #define WM8996_SPKR_ENA_MASK 0x0010 /* SPKR_ENA */ | ||
3682 | #define WM8996_SPKR_ENA_SHIFT 4 /* SPKR_ENA */ | ||
3683 | #define WM8996_SPKR_ENA_WIDTH 1 /* SPKR_ENA */ | ||
3684 | #define WM8996_SPKR_MUTE 0x0008 /* SPKR_MUTE */ | ||
3685 | #define WM8996_SPKR_MUTE_MASK 0x0008 /* SPKR_MUTE */ | ||
3686 | #define WM8996_SPKR_MUTE_SHIFT 3 /* SPKR_MUTE */ | ||
3687 | #define WM8996_SPKR_MUTE_WIDTH 1 /* SPKR_MUTE */ | ||
3688 | #define WM8996_SPKR_MUTE_ZC 0x0004 /* SPKR_MUTE_ZC */ | ||
3689 | #define WM8996_SPKR_MUTE_ZC_MASK 0x0004 /* SPKR_MUTE_ZC */ | ||
3690 | #define WM8996_SPKR_MUTE_ZC_SHIFT 2 /* SPKR_MUTE_ZC */ | ||
3691 | #define WM8996_SPKR_MUTE_ZC_WIDTH 1 /* SPKR_MUTE_ZC */ | ||
3692 | #define WM8996_SPKR_SRC_MASK 0x0003 /* SPKR_SRC - [1:0] */ | ||
3693 | #define WM8996_SPKR_SRC_SHIFT 0 /* SPKR_SRC - [1:0] */ | ||
3694 | #define WM8996_SPKR_SRC_WIDTH 2 /* SPKR_SRC - [1:0] */ | ||
3695 | |||
3696 | /* | ||
3697 | * R2050 (0x802) - PDM Speaker Mute Sequence | ||
3698 | */ | ||
3699 | #define WM8996_SPK_MUTE_ENDIAN 0x0100 /* SPK_MUTE_ENDIAN */ | ||
3700 | #define WM8996_SPK_MUTE_ENDIAN_MASK 0x0100 /* SPK_MUTE_ENDIAN */ | ||
3701 | #define WM8996_SPK_MUTE_ENDIAN_SHIFT 8 /* SPK_MUTE_ENDIAN */ | ||
3702 | #define WM8996_SPK_MUTE_ENDIAN_WIDTH 1 /* SPK_MUTE_ENDIAN */ | ||
3703 | #define WM8996_SPK_MUTE_SEQ1_MASK 0x00FF /* SPK_MUTE_SEQ1 - [7:0] */ | ||
3704 | #define WM8996_SPK_MUTE_SEQ1_SHIFT 0 /* SPK_MUTE_SEQ1 - [7:0] */ | ||
3705 | #define WM8996_SPK_MUTE_SEQ1_WIDTH 8 /* SPK_MUTE_SEQ1 - [7:0] */ | ||
3706 | |||
3707 | /* | ||
3708 | * R2051 (0x803) - PDM Speaker Volume | ||
3709 | */ | ||
3710 | #define WM8996_SPKR_VOL_MASK 0x00F0 /* SPKR_VOL - [7:4] */ | ||
3711 | #define WM8996_SPKR_VOL_SHIFT 4 /* SPKR_VOL - [7:4] */ | ||
3712 | #define WM8996_SPKR_VOL_WIDTH 4 /* SPKR_VOL - [7:4] */ | ||
3713 | #define WM8996_SPKL_VOL_MASK 0x000F /* SPKL_VOL - [3:0] */ | ||
3714 | #define WM8996_SPKL_VOL_SHIFT 0 /* SPKL_VOL - [3:0] */ | ||
3715 | #define WM8996_SPKL_VOL_WIDTH 4 /* SPKL_VOL - [3:0] */ | ||
3716 | |||
3717 | #endif | ||
diff --git a/sound/soc/codecs/wm_hubs.c b/sound/soc/codecs/wm_hubs.c index 4cc2d567f22f..e763c54c55dc 100644 --- a/sound/soc/codecs/wm_hubs.c +++ b/sound/soc/codecs/wm_hubs.c | |||
@@ -440,9 +440,8 @@ static int hp_event(struct snd_soc_dapm_widget *w, | |||
440 | reg |= WM8993_HPOUT1L_DLY | WM8993_HPOUT1R_DLY; | 440 | reg |= WM8993_HPOUT1L_DLY | WM8993_HPOUT1R_DLY; |
441 | snd_soc_write(codec, WM8993_ANALOGUE_HP_0, reg); | 441 | snd_soc_write(codec, WM8993_ANALOGUE_HP_0, reg); |
442 | 442 | ||
443 | /* Smallest supported update interval */ | ||
444 | snd_soc_update_bits(codec, WM8993_DC_SERVO_1, | 443 | snd_soc_update_bits(codec, WM8993_DC_SERVO_1, |
445 | WM8993_DCS_TIMER_PERIOD_01_MASK, 1); | 444 | WM8993_DCS_TIMER_PERIOD_01_MASK, 0); |
446 | 445 | ||
447 | calibrate_dc_servo(codec); | 446 | calibrate_dc_servo(codec); |
448 | 447 | ||
diff --git a/sound/soc/samsung/Kconfig b/sound/soc/samsung/Kconfig index 54b0e4b7faf7..b99091fc34eb 100644 --- a/sound/soc/samsung/Kconfig +++ b/sound/soc/samsung/Kconfig | |||
@@ -183,7 +183,7 @@ config SND_SOC_SPEYSIDE | |||
183 | tristate "Audio support for Wolfson Speyside" | 183 | tristate "Audio support for Wolfson Speyside" |
184 | depends on SND_SOC_SAMSUNG && MACH_WLF_CRAGG_6410 | 184 | depends on SND_SOC_SAMSUNG && MACH_WLF_CRAGG_6410 |
185 | select SND_SAMSUNG_I2S | 185 | select SND_SAMSUNG_I2S |
186 | select SND_SOC_WM8915 | 186 | select SND_SOC_WM8996 |
187 | select SND_SOC_WM9081 | 187 | select SND_SOC_WM9081 |
188 | 188 | ||
189 | config SND_SOC_SPEYSIDE_WM8962 | 189 | config SND_SOC_SPEYSIDE_WM8962 |
diff --git a/sound/soc/samsung/speyside.c b/sound/soc/samsung/speyside.c index d6dee4d02036..590e9274b062 100644 --- a/sound/soc/samsung/speyside.c +++ b/sound/soc/samsung/speyside.c | |||
@@ -14,10 +14,10 @@ | |||
14 | #include <sound/jack.h> | 14 | #include <sound/jack.h> |
15 | #include <linux/gpio.h> | 15 | #include <linux/gpio.h> |
16 | 16 | ||
17 | #include "../codecs/wm8915.h" | 17 | #include "../codecs/wm8996.h" |
18 | #include "../codecs/wm9081.h" | 18 | #include "../codecs/wm9081.h" |
19 | 19 | ||
20 | #define WM8915_HPSEL_GPIO 214 | 20 | #define WM8996_HPSEL_GPIO 214 |
21 | 21 | ||
22 | static int speyside_set_bias_level(struct snd_soc_card *card, | 22 | static int speyside_set_bias_level(struct snd_soc_card *card, |
23 | struct snd_soc_dapm_context *dapm, | 23 | struct snd_soc_dapm_context *dapm, |
@@ -31,12 +31,12 @@ static int speyside_set_bias_level(struct snd_soc_card *card, | |||
31 | 31 | ||
32 | switch (level) { | 32 | switch (level) { |
33 | case SND_SOC_BIAS_STANDBY: | 33 | case SND_SOC_BIAS_STANDBY: |
34 | ret = snd_soc_dai_set_sysclk(codec_dai, WM8915_SYSCLK_MCLK2, | 34 | ret = snd_soc_dai_set_sysclk(codec_dai, WM8996_SYSCLK_MCLK2, |
35 | 32768, SND_SOC_CLOCK_IN); | 35 | 32768, SND_SOC_CLOCK_IN); |
36 | if (ret < 0) | 36 | if (ret < 0) |
37 | return ret; | 37 | return ret; |
38 | 38 | ||
39 | ret = snd_soc_dai_set_pll(codec_dai, WM8915_FLL_MCLK2, | 39 | ret = snd_soc_dai_set_pll(codec_dai, WM8996_FLL_MCLK2, |
40 | 0, 0, 0); | 40 | 0, 0, 0); |
41 | if (ret < 0) { | 41 | if (ret < 0) { |
42 | pr_err("Failed to stop FLL\n"); | 42 | pr_err("Failed to stop FLL\n"); |
@@ -65,7 +65,7 @@ static int speyside_set_bias_level_post(struct snd_soc_card *card, | |||
65 | case SND_SOC_BIAS_PREPARE: | 65 | case SND_SOC_BIAS_PREPARE: |
66 | if (card->dapm.bias_level == SND_SOC_BIAS_STANDBY) { | 66 | if (card->dapm.bias_level == SND_SOC_BIAS_STANDBY) { |
67 | ret = snd_soc_dai_set_pll(codec_dai, 0, | 67 | ret = snd_soc_dai_set_pll(codec_dai, 0, |
68 | WM8915_FLL_MCLK2, | 68 | WM8996_FLL_MCLK2, |
69 | 32768, 48000 * 256); | 69 | 32768, 48000 * 256); |
70 | if (ret < 0) { | 70 | if (ret < 0) { |
71 | pr_err("Failed to start FLL\n"); | 71 | pr_err("Failed to start FLL\n"); |
@@ -73,7 +73,7 @@ static int speyside_set_bias_level_post(struct snd_soc_card *card, | |||
73 | } | 73 | } |
74 | 74 | ||
75 | ret = snd_soc_dai_set_sysclk(codec_dai, | 75 | ret = snd_soc_dai_set_sysclk(codec_dai, |
76 | WM8915_SYSCLK_FLL, | 76 | WM8996_SYSCLK_FLL, |
77 | 48000 * 256, | 77 | 48000 * 256, |
78 | SND_SOC_CLOCK_IN); | 78 | SND_SOC_CLOCK_IN); |
79 | if (ret < 0) | 79 | if (ret < 0) |
@@ -149,26 +149,26 @@ static void speyside_set_polarity(struct snd_soc_codec *codec, | |||
149 | int polarity) | 149 | int polarity) |
150 | { | 150 | { |
151 | speyside_jack_polarity = !polarity; | 151 | speyside_jack_polarity = !polarity; |
152 | gpio_direction_output(WM8915_HPSEL_GPIO, speyside_jack_polarity); | 152 | gpio_direction_output(WM8996_HPSEL_GPIO, speyside_jack_polarity); |
153 | 153 | ||
154 | /* Re-run DAPM to make sure we're using the correct mic bias */ | 154 | /* Re-run DAPM to make sure we're using the correct mic bias */ |
155 | snd_soc_dapm_sync(&codec->dapm); | 155 | snd_soc_dapm_sync(&codec->dapm); |
156 | } | 156 | } |
157 | 157 | ||
158 | static int speyside_wm8915_init(struct snd_soc_pcm_runtime *rtd) | 158 | static int speyside_wm8996_init(struct snd_soc_pcm_runtime *rtd) |
159 | { | 159 | { |
160 | struct snd_soc_dai *dai = rtd->codec_dai; | 160 | struct snd_soc_dai *dai = rtd->codec_dai; |
161 | struct snd_soc_codec *codec = rtd->codec; | 161 | struct snd_soc_codec *codec = rtd->codec; |
162 | int ret; | 162 | int ret; |
163 | 163 | ||
164 | ret = snd_soc_dai_set_sysclk(dai, WM8915_SYSCLK_MCLK2, 32768, 0); | 164 | ret = snd_soc_dai_set_sysclk(dai, WM8996_SYSCLK_MCLK2, 32768, 0); |
165 | if (ret < 0) | 165 | if (ret < 0) |
166 | return ret; | 166 | return ret; |
167 | 167 | ||
168 | ret = gpio_request(WM8915_HPSEL_GPIO, "HP_SEL"); | 168 | ret = gpio_request(WM8996_HPSEL_GPIO, "HP_SEL"); |
169 | if (ret != 0) | 169 | if (ret != 0) |
170 | pr_err("Failed to request HP_SEL GPIO: %d\n", ret); | 170 | pr_err("Failed to request HP_SEL GPIO: %d\n", ret); |
171 | gpio_direction_output(WM8915_HPSEL_GPIO, speyside_jack_polarity); | 171 | gpio_direction_output(WM8996_HPSEL_GPIO, speyside_jack_polarity); |
172 | 172 | ||
173 | ret = snd_soc_jack_new(codec, "Headset", | 173 | ret = snd_soc_jack_new(codec, "Headset", |
174 | SND_JACK_HEADSET | SND_JACK_BTN_0, | 174 | SND_JACK_HEADSET | SND_JACK_BTN_0, |
@@ -182,7 +182,7 @@ static int speyside_wm8915_init(struct snd_soc_pcm_runtime *rtd) | |||
182 | if (ret) | 182 | if (ret) |
183 | return ret; | 183 | return ret; |
184 | 184 | ||
185 | wm8915_detect(codec, &speyside_headset, speyside_set_polarity); | 185 | wm8996_detect(codec, &speyside_headset, speyside_set_polarity); |
186 | 186 | ||
187 | return 0; | 187 | return 0; |
188 | } | 188 | } |
@@ -205,16 +205,16 @@ static struct snd_soc_dai_link speyside_dai[] = { | |||
205 | .name = "CPU", | 205 | .name = "CPU", |
206 | .stream_name = "CPU", | 206 | .stream_name = "CPU", |
207 | .cpu_dai_name = "samsung-i2s.0", | 207 | .cpu_dai_name = "samsung-i2s.0", |
208 | .codec_dai_name = "wm8915-aif1", | 208 | .codec_dai_name = "wm8996-aif1", |
209 | .platform_name = "samsung-audio", | 209 | .platform_name = "samsung-audio", |
210 | .codec_name = "wm8915.1-001a", | 210 | .codec_name = "wm8996.1-001a", |
211 | .init = speyside_wm8915_init, | 211 | .init = speyside_wm8996_init, |
212 | .ops = &speyside_ops, | 212 | .ops = &speyside_ops, |
213 | }, | 213 | }, |
214 | { | 214 | { |
215 | .name = "Baseband", | 215 | .name = "Baseband", |
216 | .stream_name = "Baseband", | 216 | .stream_name = "Baseband", |
217 | .cpu_dai_name = "wm8915-aif2", | 217 | .cpu_dai_name = "wm8996-aif2", |
218 | .codec_dai_name = "wm1250-ev1", | 218 | .codec_dai_name = "wm1250-ev1", |
219 | .codec_name = "wm1250-ev1.1-0027", | 219 | .codec_name = "wm1250-ev1.1-0027", |
220 | .ops = &speyside_ops, | 220 | .ops = &speyside_ops, |
diff --git a/sound/usb/caiaq/input.c b/sound/usb/caiaq/input.c index 4432ef7a70a9..a213813487bd 100644 --- a/sound/usb/caiaq/input.c +++ b/sound/usb/caiaq/input.c | |||
@@ -30,7 +30,7 @@ static unsigned short keycode_ak1[] = { KEY_C, KEY_B, KEY_A }; | |||
30 | static unsigned short keycode_rk2[] = { KEY_1, KEY_2, KEY_3, KEY_4, | 30 | static unsigned short keycode_rk2[] = { KEY_1, KEY_2, KEY_3, KEY_4, |
31 | KEY_5, KEY_6, KEY_7 }; | 31 | KEY_5, KEY_6, KEY_7 }; |
32 | static unsigned short keycode_rk3[] = { KEY_1, KEY_2, KEY_3, KEY_4, | 32 | static unsigned short keycode_rk3[] = { KEY_1, KEY_2, KEY_3, KEY_4, |
33 | KEY_5, KEY_6, KEY_7, KEY_5, KEY_6 }; | 33 | KEY_5, KEY_6, KEY_7, KEY_8, KEY_9 }; |
34 | 34 | ||
35 | static unsigned short keycode_kore[] = { | 35 | static unsigned short keycode_kore[] = { |
36 | KEY_FN_F1, /* "menu" */ | 36 | KEY_FN_F1, /* "menu" */ |
diff --git a/sound/usb/endpoint.c b/sound/usb/endpoint.c index 7c0d21ecd821..7d46e482375d 100644 --- a/sound/usb/endpoint.c +++ b/sound/usb/endpoint.c | |||
@@ -352,7 +352,7 @@ int snd_usb_parse_audio_endpoints(struct snd_usb_audio *chip, int iface_no) | |||
352 | continue; | 352 | continue; |
353 | } | 353 | } |
354 | if (((protocol == UAC_VERSION_1) && (fmt->bLength < 8)) || | 354 | if (((protocol == UAC_VERSION_1) && (fmt->bLength < 8)) || |
355 | ((protocol == UAC_VERSION_2) && (fmt->bLength != 6))) { | 355 | ((protocol == UAC_VERSION_2) && (fmt->bLength < 6))) { |
356 | snd_printk(KERN_ERR "%d:%u:%d : invalid UAC_FORMAT_TYPE desc\n", | 356 | snd_printk(KERN_ERR "%d:%u:%d : invalid UAC_FORMAT_TYPE desc\n", |
357 | dev->devnum, iface_no, altno); | 357 | dev->devnum, iface_no, altno); |
358 | continue; | 358 | continue; |
diff --git a/sound/usb/mixer.c b/sound/usb/mixer.c index c22fa76e363a..c04d7c71ac88 100644 --- a/sound/usb/mixer.c +++ b/sound/usb/mixer.c | |||
@@ -1191,6 +1191,11 @@ static int parse_audio_feature_unit(struct mixer_build *state, int unitid, void | |||
1191 | 1191 | ||
1192 | if (state->mixer->protocol == UAC_VERSION_1) { | 1192 | if (state->mixer->protocol == UAC_VERSION_1) { |
1193 | csize = hdr->bControlSize; | 1193 | csize = hdr->bControlSize; |
1194 | if (!csize) { | ||
1195 | snd_printdd(KERN_ERR "usbaudio: unit %u: " | ||
1196 | "invalid bControlSize == 0\n", unitid); | ||
1197 | return -EINVAL; | ||
1198 | } | ||
1194 | channels = (hdr->bLength - 7) / csize - 1; | 1199 | channels = (hdr->bLength - 7) / csize - 1; |
1195 | bmaControls = hdr->bmaControls; | 1200 | bmaControls = hdr->bmaControls; |
1196 | } else { | 1201 | } else { |
@@ -1934,15 +1939,13 @@ static int snd_usb_mixer_controls(struct usb_mixer_interface *mixer) | |||
1934 | struct mixer_build state; | 1939 | struct mixer_build state; |
1935 | int err; | 1940 | int err; |
1936 | const struct usbmix_ctl_map *map; | 1941 | const struct usbmix_ctl_map *map; |
1937 | struct usb_host_interface *hostif; | ||
1938 | void *p; | 1942 | void *p; |
1939 | 1943 | ||
1940 | hostif = mixer->chip->ctrl_intf; | ||
1941 | memset(&state, 0, sizeof(state)); | 1944 | memset(&state, 0, sizeof(state)); |
1942 | state.chip = mixer->chip; | 1945 | state.chip = mixer->chip; |
1943 | state.mixer = mixer; | 1946 | state.mixer = mixer; |
1944 | state.buffer = hostif->extra; | 1947 | state.buffer = mixer->hostif->extra; |
1945 | state.buflen = hostif->extralen; | 1948 | state.buflen = mixer->hostif->extralen; |
1946 | 1949 | ||
1947 | /* check the mapping table */ | 1950 | /* check the mapping table */ |
1948 | for (map = usbmix_ctl_maps; map->id; map++) { | 1951 | for (map = usbmix_ctl_maps; map->id; map++) { |
@@ -1955,7 +1958,8 @@ static int snd_usb_mixer_controls(struct usb_mixer_interface *mixer) | |||
1955 | } | 1958 | } |
1956 | 1959 | ||
1957 | p = NULL; | 1960 | p = NULL; |
1958 | while ((p = snd_usb_find_csint_desc(hostif->extra, hostif->extralen, p, UAC_OUTPUT_TERMINAL)) != NULL) { | 1961 | while ((p = snd_usb_find_csint_desc(mixer->hostif->extra, mixer->hostif->extralen, |
1962 | p, UAC_OUTPUT_TERMINAL)) != NULL) { | ||
1959 | if (mixer->protocol == UAC_VERSION_1) { | 1963 | if (mixer->protocol == UAC_VERSION_1) { |
1960 | struct uac1_output_terminal_descriptor *desc = p; | 1964 | struct uac1_output_terminal_descriptor *desc = p; |
1961 | 1965 | ||
@@ -2162,17 +2166,15 @@ int snd_usb_mixer_activate(struct usb_mixer_interface *mixer) | |||
2162 | /* create the handler for the optional status interrupt endpoint */ | 2166 | /* create the handler for the optional status interrupt endpoint */ |
2163 | static int snd_usb_mixer_status_create(struct usb_mixer_interface *mixer) | 2167 | static int snd_usb_mixer_status_create(struct usb_mixer_interface *mixer) |
2164 | { | 2168 | { |
2165 | struct usb_host_interface *hostif; | ||
2166 | struct usb_endpoint_descriptor *ep; | 2169 | struct usb_endpoint_descriptor *ep; |
2167 | void *transfer_buffer; | 2170 | void *transfer_buffer; |
2168 | int buffer_length; | 2171 | int buffer_length; |
2169 | unsigned int epnum; | 2172 | unsigned int epnum; |
2170 | 2173 | ||
2171 | hostif = mixer->chip->ctrl_intf; | ||
2172 | /* we need one interrupt input endpoint */ | 2174 | /* we need one interrupt input endpoint */ |
2173 | if (get_iface_desc(hostif)->bNumEndpoints < 1) | 2175 | if (get_iface_desc(mixer->hostif)->bNumEndpoints < 1) |
2174 | return 0; | 2176 | return 0; |
2175 | ep = get_endpoint(hostif, 0); | 2177 | ep = get_endpoint(mixer->hostif, 0); |
2176 | if (!usb_endpoint_dir_in(ep) || !usb_endpoint_xfer_int(ep)) | 2178 | if (!usb_endpoint_dir_in(ep) || !usb_endpoint_xfer_int(ep)) |
2177 | return 0; | 2179 | return 0; |
2178 | 2180 | ||
@@ -2202,7 +2204,6 @@ int snd_usb_create_mixer(struct snd_usb_audio *chip, int ctrlif, | |||
2202 | }; | 2204 | }; |
2203 | struct usb_mixer_interface *mixer; | 2205 | struct usb_mixer_interface *mixer; |
2204 | struct snd_info_entry *entry; | 2206 | struct snd_info_entry *entry; |
2205 | struct usb_host_interface *host_iface; | ||
2206 | int err; | 2207 | int err; |
2207 | 2208 | ||
2208 | strcpy(chip->card->mixername, "USB Mixer"); | 2209 | strcpy(chip->card->mixername, "USB Mixer"); |
@@ -2219,8 +2220,8 @@ int snd_usb_create_mixer(struct snd_usb_audio *chip, int ctrlif, | |||
2219 | return -ENOMEM; | 2220 | return -ENOMEM; |
2220 | } | 2221 | } |
2221 | 2222 | ||
2222 | host_iface = &usb_ifnum_to_if(chip->dev, ctrlif)->altsetting[0]; | 2223 | mixer->hostif = &usb_ifnum_to_if(chip->dev, ctrlif)->altsetting[0]; |
2223 | switch (get_iface_desc(host_iface)->bInterfaceProtocol) { | 2224 | switch (get_iface_desc(mixer->hostif)->bInterfaceProtocol) { |
2224 | case UAC_VERSION_1: | 2225 | case UAC_VERSION_1: |
2225 | default: | 2226 | default: |
2226 | mixer->protocol = UAC_VERSION_1; | 2227 | mixer->protocol = UAC_VERSION_1; |
diff --git a/sound/usb/mixer.h b/sound/usb/mixer.h index ae1a14dcfe82..81b2d8a32fb0 100644 --- a/sound/usb/mixer.h +++ b/sound/usb/mixer.h | |||
@@ -3,6 +3,7 @@ | |||
3 | 3 | ||
4 | struct usb_mixer_interface { | 4 | struct usb_mixer_interface { |
5 | struct snd_usb_audio *chip; | 5 | struct snd_usb_audio *chip; |
6 | struct usb_host_interface *hostif; | ||
6 | struct list_head list; | 7 | struct list_head list; |
7 | unsigned int ignore_ctl_error; | 8 | unsigned int ignore_ctl_error; |
8 | struct urb *urb; | 9 | struct urb *urb; |
diff --git a/sound/usb/quirks-table.h b/sound/usb/quirks-table.h index dba0b7f11c54..4d4f86552a23 100644 --- a/sound/usb/quirks-table.h +++ b/sound/usb/quirks-table.h | |||
@@ -2417,6 +2417,12 @@ YAMAHA_DEVICE(0x7010, "UB99"), | |||
2417 | .idProduct = 0x1020, | 2417 | .idProduct = 0x1020, |
2418 | }, | 2418 | }, |
2419 | 2419 | ||
2420 | /* KeithMcMillen Stringport */ | ||
2421 | { | ||
2422 | USB_DEVICE(0x1f38, 0x0001), | ||
2423 | .bInterfaceClass = USB_CLASS_AUDIO, | ||
2424 | }, | ||
2425 | |||
2420 | /* Miditech devices */ | 2426 | /* Miditech devices */ |
2421 | { | 2427 | { |
2422 | USB_DEVICE(0x4752, 0x0011), | 2428 | USB_DEVICE(0x4752, 0x0011), |
diff --git a/sound/usb/quirks.c b/sound/usb/quirks.c index 77762c99afbe..81e07d842581 100644 --- a/sound/usb/quirks.c +++ b/sound/usb/quirks.c | |||
@@ -426,7 +426,7 @@ static int snd_usb_cm106_boot_quirk(struct usb_device *dev) | |||
426 | */ | 426 | */ |
427 | static int snd_usb_cm6206_boot_quirk(struct usb_device *dev) | 427 | static int snd_usb_cm6206_boot_quirk(struct usb_device *dev) |
428 | { | 428 | { |
429 | int err, reg; | 429 | int err = 0, reg; |
430 | int val[] = {0x2004, 0x3000, 0xf800, 0x143f, 0x0000, 0x3000}; | 430 | int val[] = {0x2004, 0x3000, 0xf800, 0x143f, 0x0000, 0x3000}; |
431 | 431 | ||
432 | for (reg = 0; reg < ARRAY_SIZE(val); reg++) { | 432 | for (reg = 0; reg < ARRAY_SIZE(val); reg++) { |
diff --git a/tools/perf/Makefile b/tools/perf/Makefile index 56d62d3fb167..3b8f7b80376b 100644 --- a/tools/perf/Makefile +++ b/tools/perf/Makefile | |||
@@ -181,9 +181,9 @@ strip-libs = $(filter-out -l%,$(1)) | |||
181 | 181 | ||
182 | $(OUTPUT)python/perf.so: $(PYRF_OBJS) | 182 | $(OUTPUT)python/perf.so: $(PYRF_OBJS) |
183 | $(QUIET_GEN)CFLAGS='$(BASIC_CFLAGS)' $(PYTHON_WORD) util/setup.py \ | 183 | $(QUIET_GEN)CFLAGS='$(BASIC_CFLAGS)' $(PYTHON_WORD) util/setup.py \ |
184 | --quiet build_ext \ | 184 | --quiet build_ext; \ |
185 | --build-lib='$(OUTPUT)python' \ | 185 | mkdir -p $(OUTPUT)python && \ |
186 | --build-temp='$(OUTPUT)python/temp' | 186 | cp $(PYTHON_EXTBUILD_LIB)perf.so $(OUTPUT)python/ |
187 | # | 187 | # |
188 | # No Perl scripts right now: | 188 | # No Perl scripts right now: |
189 | # | 189 | # |
@@ -509,9 +509,13 @@ else | |||
509 | 509 | ||
510 | PYTHON_WORD := $(call shell-wordify,$(PYTHON)) | 510 | PYTHON_WORD := $(call shell-wordify,$(PYTHON)) |
511 | 511 | ||
512 | python-clean := $(PYTHON_WORD) util/setup.py clean \ | 512 | # python extension build directories |
513 | --build-lib='$(OUTPUT)python' \ | 513 | PYTHON_EXTBUILD := $(OUTPUT)python_ext_build/ |
514 | --build-temp='$(OUTPUT)python/temp' | 514 | PYTHON_EXTBUILD_LIB := $(PYTHON_EXTBUILD)lib/ |
515 | PYTHON_EXTBUILD_TMP := $(PYTHON_EXTBUILD)tmp/ | ||
516 | export PYTHON_EXTBUILD_LIB PYTHON_EXTBUILD_TMP | ||
517 | |||
518 | python-clean := rm -rf $(PYTHON_EXTBUILD) $(OUTPUT)python/perf.so | ||
515 | 519 | ||
516 | ifdef NO_LIBPYTHON | 520 | ifdef NO_LIBPYTHON |
517 | $(call disable-python) | 521 | $(call disable-python) |
@@ -868,6 +872,9 @@ install: all | |||
868 | $(INSTALL) scripts/python/*.py -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/python' | 872 | $(INSTALL) scripts/python/*.py -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/python' |
869 | $(INSTALL) scripts/python/bin/* -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/python/bin' | 873 | $(INSTALL) scripts/python/bin/* -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/python/bin' |
870 | 874 | ||
875 | install-python_ext: | ||
876 | $(PYTHON_WORD) util/setup.py --quiet install --root='/$(DESTDIR_SQ)' | ||
877 | |||
871 | install-doc: | 878 | install-doc: |
872 | $(MAKE) -C Documentation install | 879 | $(MAKE) -C Documentation install |
873 | 880 | ||
@@ -895,7 +902,7 @@ quick-install-html: | |||
895 | ### Cleaning rules | 902 | ### Cleaning rules |
896 | 903 | ||
897 | clean: | 904 | clean: |
898 | $(RM) $(OUTPUT){*.o,*/*.o,*/*/*.o,*/*/*/*.o,$(LIB_FILE),perf-archive} | 905 | $(RM) $(LIB_OBJS) $(BUILTIN_OBJS) $(LIB_FILE) $(OUTPUT)perf-archive $(OUTPUT)perf.o $(LANG_BINDINGS) |
899 | $(RM) $(ALL_PROGRAMS) perf | 906 | $(RM) $(ALL_PROGRAMS) perf |
900 | $(RM) *.spec *.pyc *.pyo */*.pyc */*.pyo $(OUTPUT)common-cmds.h TAGS tags cscope* | 907 | $(RM) *.spec *.pyc *.pyo */*.pyc */*.pyo $(OUTPUT)common-cmds.h TAGS tags cscope* |
901 | $(MAKE) -C Documentation/ clean | 908 | $(MAKE) -C Documentation/ clean |
diff --git a/tools/perf/builtin-lock.c b/tools/perf/builtin-lock.c index 9ac05aafd9b2..899080ace267 100644 --- a/tools/perf/builtin-lock.c +++ b/tools/perf/builtin-lock.c | |||
@@ -942,10 +942,10 @@ static const char *record_args[] = { | |||
942 | "-f", | 942 | "-f", |
943 | "-m", "1024", | 943 | "-m", "1024", |
944 | "-c", "1", | 944 | "-c", "1", |
945 | "-e", "lock:lock_acquire:r", | 945 | "-e", "lock:lock_acquire", |
946 | "-e", "lock:lock_acquired:r", | 946 | "-e", "lock:lock_acquired", |
947 | "-e", "lock:lock_contended:r", | 947 | "-e", "lock:lock_contended", |
948 | "-e", "lock:lock_release:r", | 948 | "-e", "lock:lock_release", |
949 | }; | 949 | }; |
950 | 950 | ||
951 | static int __cmd_record(int argc, const char **argv) | 951 | static int __cmd_record(int argc, const char **argv) |
diff --git a/tools/perf/builtin-record.c b/tools/perf/builtin-record.c index 80dc5b790e47..f6426b496f4a 100644 --- a/tools/perf/builtin-record.c +++ b/tools/perf/builtin-record.c | |||
@@ -30,8 +30,6 @@ | |||
30 | #include <sched.h> | 30 | #include <sched.h> |
31 | #include <sys/mman.h> | 31 | #include <sys/mman.h> |
32 | 32 | ||
33 | #define FD(e, x, y) (*(int *)xyarray__entry(e->fd, x, y)) | ||
34 | |||
35 | enum write_mode_t { | 33 | enum write_mode_t { |
36 | WRITE_FORCE, | 34 | WRITE_FORCE, |
37 | WRITE_APPEND | 35 | WRITE_APPEND |
@@ -438,7 +436,6 @@ static void mmap_read_all(void) | |||
438 | 436 | ||
439 | static int __cmd_record(int argc, const char **argv) | 437 | static int __cmd_record(int argc, const char **argv) |
440 | { | 438 | { |
441 | int i; | ||
442 | struct stat st; | 439 | struct stat st; |
443 | int flags; | 440 | int flags; |
444 | int err; | 441 | int err; |
@@ -682,7 +679,6 @@ static int __cmd_record(int argc, const char **argv) | |||
682 | 679 | ||
683 | for (;;) { | 680 | for (;;) { |
684 | int hits = samples; | 681 | int hits = samples; |
685 | int thread; | ||
686 | 682 | ||
687 | mmap_read_all(); | 683 | mmap_read_all(); |
688 | 684 | ||
@@ -693,19 +689,8 @@ static int __cmd_record(int argc, const char **argv) | |||
693 | waking++; | 689 | waking++; |
694 | } | 690 | } |
695 | 691 | ||
696 | if (done) { | 692 | if (done) |
697 | for (i = 0; i < evsel_list->cpus->nr; i++) { | 693 | perf_evlist__disable(evsel_list); |
698 | struct perf_evsel *pos; | ||
699 | |||
700 | list_for_each_entry(pos, &evsel_list->entries, node) { | ||
701 | for (thread = 0; | ||
702 | thread < evsel_list->threads->nr; | ||
703 | thread++) | ||
704 | ioctl(FD(pos, i, thread), | ||
705 | PERF_EVENT_IOC_DISABLE); | ||
706 | } | ||
707 | } | ||
708 | } | ||
709 | } | 694 | } |
710 | 695 | ||
711 | if (quiet || signr == SIGUSR1) | 696 | if (quiet || signr == SIGUSR1) |
diff --git a/tools/perf/builtin-report.c b/tools/perf/builtin-report.c index f854efda7686..d7ff277bdb78 100644 --- a/tools/perf/builtin-report.c +++ b/tools/perf/builtin-report.c | |||
@@ -162,23 +162,22 @@ static int perf_session__setup_sample_type(struct perf_session *self) | |||
162 | { | 162 | { |
163 | if (!(self->sample_type & PERF_SAMPLE_CALLCHAIN)) { | 163 | if (!(self->sample_type & PERF_SAMPLE_CALLCHAIN)) { |
164 | if (sort__has_parent) { | 164 | if (sort__has_parent) { |
165 | fprintf(stderr, "selected --sort parent, but no" | 165 | ui__warning("Selected --sort parent, but no " |
166 | " callchain data. Did you call" | 166 | "callchain data. Did you call " |
167 | " perf record without -g?\n"); | 167 | "'perf record' without -g?\n"); |
168 | return -EINVAL; | 168 | return -EINVAL; |
169 | } | 169 | } |
170 | if (symbol_conf.use_callchain) { | 170 | if (symbol_conf.use_callchain) { |
171 | fprintf(stderr, "selected -g but no callchain data." | 171 | ui__warning("Selected -g but no callchain data. Did " |
172 | " Did you call perf record without" | 172 | "you call 'perf record' without -g?\n"); |
173 | " -g?\n"); | ||
174 | return -1; | 173 | return -1; |
175 | } | 174 | } |
176 | } else if (!dont_use_callchains && callchain_param.mode != CHAIN_NONE && | 175 | } else if (!dont_use_callchains && callchain_param.mode != CHAIN_NONE && |
177 | !symbol_conf.use_callchain) { | 176 | !symbol_conf.use_callchain) { |
178 | symbol_conf.use_callchain = true; | 177 | symbol_conf.use_callchain = true; |
179 | if (callchain_register_param(&callchain_param) < 0) { | 178 | if (callchain_register_param(&callchain_param) < 0) { |
180 | fprintf(stderr, "Can't register callchain" | 179 | ui__warning("Can't register callchain " |
181 | " params\n"); | 180 | "params.\n"); |
182 | return -EINVAL; | 181 | return -EINVAL; |
183 | } | 182 | } |
184 | } | 183 | } |
diff --git a/tools/perf/builtin-sched.c b/tools/perf/builtin-sched.c index dcfe8873c9a1..5177964943e7 100644 --- a/tools/perf/builtin-sched.c +++ b/tools/perf/builtin-sched.c | |||
@@ -1637,23 +1637,29 @@ static struct perf_event_ops event_ops = { | |||
1637 | .ordered_samples = true, | 1637 | .ordered_samples = true, |
1638 | }; | 1638 | }; |
1639 | 1639 | ||
1640 | static int read_events(void) | 1640 | static void read_events(bool destroy, struct perf_session **psession) |
1641 | { | 1641 | { |
1642 | int err = -EINVAL; | 1642 | int err = -EINVAL; |
1643 | struct perf_session *session = perf_session__new(input_name, O_RDONLY, | 1643 | struct perf_session *session = perf_session__new(input_name, O_RDONLY, |
1644 | 0, false, &event_ops); | 1644 | 0, false, &event_ops); |
1645 | if (session == NULL) | 1645 | if (session == NULL) |
1646 | return -ENOMEM; | 1646 | die("No Memory"); |
1647 | 1647 | ||
1648 | if (perf_session__has_traces(session, "record -R")) { | 1648 | if (perf_session__has_traces(session, "record -R")) { |
1649 | err = perf_session__process_events(session, &event_ops); | 1649 | err = perf_session__process_events(session, &event_ops); |
1650 | if (err) | ||
1651 | die("Failed to process events, error %d", err); | ||
1652 | |||
1650 | nr_events = session->hists.stats.nr_events[0]; | 1653 | nr_events = session->hists.stats.nr_events[0]; |
1651 | nr_lost_events = session->hists.stats.total_lost; | 1654 | nr_lost_events = session->hists.stats.total_lost; |
1652 | nr_lost_chunks = session->hists.stats.nr_events[PERF_RECORD_LOST]; | 1655 | nr_lost_chunks = session->hists.stats.nr_events[PERF_RECORD_LOST]; |
1653 | } | 1656 | } |
1654 | 1657 | ||
1655 | perf_session__delete(session); | 1658 | if (destroy) |
1656 | return err; | 1659 | perf_session__delete(session); |
1660 | |||
1661 | if (psession) | ||
1662 | *psession = session; | ||
1657 | } | 1663 | } |
1658 | 1664 | ||
1659 | static void print_bad_events(void) | 1665 | static void print_bad_events(void) |
@@ -1689,9 +1695,10 @@ static void print_bad_events(void) | |||
1689 | static void __cmd_lat(void) | 1695 | static void __cmd_lat(void) |
1690 | { | 1696 | { |
1691 | struct rb_node *next; | 1697 | struct rb_node *next; |
1698 | struct perf_session *session; | ||
1692 | 1699 | ||
1693 | setup_pager(); | 1700 | setup_pager(); |
1694 | read_events(); | 1701 | read_events(false, &session); |
1695 | sort_lat(); | 1702 | sort_lat(); |
1696 | 1703 | ||
1697 | printf("\n ---------------------------------------------------------------------------------------------------------------\n"); | 1704 | printf("\n ---------------------------------------------------------------------------------------------------------------\n"); |
@@ -1717,6 +1724,7 @@ static void __cmd_lat(void) | |||
1717 | print_bad_events(); | 1724 | print_bad_events(); |
1718 | printf("\n"); | 1725 | printf("\n"); |
1719 | 1726 | ||
1727 | perf_session__delete(session); | ||
1720 | } | 1728 | } |
1721 | 1729 | ||
1722 | static struct trace_sched_handler map_ops = { | 1730 | static struct trace_sched_handler map_ops = { |
@@ -1731,7 +1739,7 @@ static void __cmd_map(void) | |||
1731 | max_cpu = sysconf(_SC_NPROCESSORS_CONF); | 1739 | max_cpu = sysconf(_SC_NPROCESSORS_CONF); |
1732 | 1740 | ||
1733 | setup_pager(); | 1741 | setup_pager(); |
1734 | read_events(); | 1742 | read_events(true, NULL); |
1735 | print_bad_events(); | 1743 | print_bad_events(); |
1736 | } | 1744 | } |
1737 | 1745 | ||
@@ -1744,7 +1752,7 @@ static void __cmd_replay(void) | |||
1744 | 1752 | ||
1745 | test_calibrations(); | 1753 | test_calibrations(); |
1746 | 1754 | ||
1747 | read_events(); | 1755 | read_events(true, NULL); |
1748 | 1756 | ||
1749 | printf("nr_run_events: %ld\n", nr_run_events); | 1757 | printf("nr_run_events: %ld\n", nr_run_events); |
1750 | printf("nr_sleep_events: %ld\n", nr_sleep_events); | 1758 | printf("nr_sleep_events: %ld\n", nr_sleep_events); |
@@ -1769,7 +1777,7 @@ static void __cmd_replay(void) | |||
1769 | 1777 | ||
1770 | 1778 | ||
1771 | static const char * const sched_usage[] = { | 1779 | static const char * const sched_usage[] = { |
1772 | "perf sched [<options>] {record|latency|map|replay|trace}", | 1780 | "perf sched [<options>] {record|latency|map|replay|script}", |
1773 | NULL | 1781 | NULL |
1774 | }; | 1782 | }; |
1775 | 1783 | ||
diff --git a/tools/perf/util/config.c b/tools/perf/util/config.c index e02d78cae70f..fe02903f7d0f 100644 --- a/tools/perf/util/config.c +++ b/tools/perf/util/config.c | |||
@@ -399,7 +399,6 @@ static int perf_config_global(void) | |||
399 | int perf_config(config_fn_t fn, void *data) | 399 | int perf_config(config_fn_t fn, void *data) |
400 | { | 400 | { |
401 | int ret = 0, found = 0; | 401 | int ret = 0, found = 0; |
402 | char *repo_config = NULL; | ||
403 | const char *home = NULL; | 402 | const char *home = NULL; |
404 | 403 | ||
405 | /* Setting $PERF_CONFIG makes perf read _only_ the given config file. */ | 404 | /* Setting $PERF_CONFIG makes perf read _only_ the given config file. */ |
@@ -414,19 +413,32 @@ int perf_config(config_fn_t fn, void *data) | |||
414 | home = getenv("HOME"); | 413 | home = getenv("HOME"); |
415 | if (perf_config_global() && home) { | 414 | if (perf_config_global() && home) { |
416 | char *user_config = strdup(mkpath("%s/.perfconfig", home)); | 415 | char *user_config = strdup(mkpath("%s/.perfconfig", home)); |
417 | if (!access(user_config, R_OK)) { | 416 | struct stat st; |
418 | ret += perf_config_from_file(fn, user_config, data); | 417 | |
419 | found += 1; | 418 | if (user_config == NULL) { |
419 | warning("Not enough memory to process %s/.perfconfig, " | ||
420 | "ignoring it.", home); | ||
421 | goto out; | ||
420 | } | 422 | } |
421 | free(user_config); | ||
422 | } | ||
423 | 423 | ||
424 | repo_config = perf_pathdup("config"); | 424 | if (stat(user_config, &st) < 0) |
425 | if (!access(repo_config, R_OK)) { | 425 | goto out_free; |
426 | ret += perf_config_from_file(fn, repo_config, data); | 426 | |
427 | if (st.st_uid && (st.st_uid != geteuid())) { | ||
428 | warning("File %s not owned by current user or root, " | ||
429 | "ignoring it.", user_config); | ||
430 | goto out_free; | ||
431 | } | ||
432 | |||
433 | if (!st.st_size) | ||
434 | goto out_free; | ||
435 | |||
436 | ret += perf_config_from_file(fn, user_config, data); | ||
427 | found += 1; | 437 | found += 1; |
438 | out_free: | ||
439 | free(user_config); | ||
428 | } | 440 | } |
429 | free(repo_config); | 441 | out: |
430 | if (found == 0) | 442 | if (found == 0) |
431 | return -1; | 443 | return -1; |
432 | return ret; | 444 | return ret; |
diff --git a/tools/perf/util/evlist.c b/tools/perf/util/evlist.c index b021ea9265c3..e03e7bc8205e 100644 --- a/tools/perf/util/evlist.c +++ b/tools/perf/util/evlist.c | |||
@@ -91,6 +91,19 @@ int perf_evlist__add_default(struct perf_evlist *evlist) | |||
91 | return 0; | 91 | return 0; |
92 | } | 92 | } |
93 | 93 | ||
94 | void perf_evlist__disable(struct perf_evlist *evlist) | ||
95 | { | ||
96 | int cpu, thread; | ||
97 | struct perf_evsel *pos; | ||
98 | |||
99 | for (cpu = 0; cpu < evlist->cpus->nr; cpu++) { | ||
100 | list_for_each_entry(pos, &evlist->entries, node) { | ||
101 | for (thread = 0; thread < evlist->threads->nr; thread++) | ||
102 | ioctl(FD(pos, cpu, thread), PERF_EVENT_IOC_DISABLE); | ||
103 | } | ||
104 | } | ||
105 | } | ||
106 | |||
94 | int perf_evlist__alloc_pollfd(struct perf_evlist *evlist) | 107 | int perf_evlist__alloc_pollfd(struct perf_evlist *evlist) |
95 | { | 108 | { |
96 | int nfds = evlist->cpus->nr * evlist->threads->nr * evlist->nr_entries; | 109 | int nfds = evlist->cpus->nr * evlist->threads->nr * evlist->nr_entries; |
diff --git a/tools/perf/util/evlist.h b/tools/perf/util/evlist.h index b2b862374f37..ce85ae9ae57a 100644 --- a/tools/perf/util/evlist.h +++ b/tools/perf/util/evlist.h | |||
@@ -53,6 +53,8 @@ int perf_evlist__alloc_mmap(struct perf_evlist *evlist); | |||
53 | int perf_evlist__mmap(struct perf_evlist *evlist, int pages, bool overwrite); | 53 | int perf_evlist__mmap(struct perf_evlist *evlist, int pages, bool overwrite); |
54 | void perf_evlist__munmap(struct perf_evlist *evlist); | 54 | void perf_evlist__munmap(struct perf_evlist *evlist); |
55 | 55 | ||
56 | void perf_evlist__disable(struct perf_evlist *evlist); | ||
57 | |||
56 | static inline void perf_evlist__set_maps(struct perf_evlist *evlist, | 58 | static inline void perf_evlist__set_maps(struct perf_evlist *evlist, |
57 | struct cpu_map *cpus, | 59 | struct cpu_map *cpus, |
58 | struct thread_map *threads) | 60 | struct thread_map *threads) |
diff --git a/tools/perf/util/header.c b/tools/perf/util/header.c index cb2959a3fb43..d4f3101773db 100644 --- a/tools/perf/util/header.c +++ b/tools/perf/util/header.c | |||
@@ -189,8 +189,8 @@ int build_id_cache__add_s(const char *sbuild_id, const char *debugdir, | |||
189 | const char *name, bool is_kallsyms) | 189 | const char *name, bool is_kallsyms) |
190 | { | 190 | { |
191 | const size_t size = PATH_MAX; | 191 | const size_t size = PATH_MAX; |
192 | char *realname, *filename = malloc(size), | 192 | char *realname, *filename = zalloc(size), |
193 | *linkname = malloc(size), *targetname; | 193 | *linkname = zalloc(size), *targetname; |
194 | int len, err = -1; | 194 | int len, err = -1; |
195 | 195 | ||
196 | if (is_kallsyms) { | 196 | if (is_kallsyms) { |
@@ -254,8 +254,8 @@ static int build_id_cache__add_b(const u8 *build_id, size_t build_id_size, | |||
254 | int build_id_cache__remove_s(const char *sbuild_id, const char *debugdir) | 254 | int build_id_cache__remove_s(const char *sbuild_id, const char *debugdir) |
255 | { | 255 | { |
256 | const size_t size = PATH_MAX; | 256 | const size_t size = PATH_MAX; |
257 | char *filename = malloc(size), | 257 | char *filename = zalloc(size), |
258 | *linkname = malloc(size); | 258 | *linkname = zalloc(size); |
259 | int err = -1; | 259 | int err = -1; |
260 | 260 | ||
261 | if (filename == NULL || linkname == NULL) | 261 | if (filename == NULL || linkname == NULL) |
diff --git a/tools/perf/util/probe-event.c b/tools/perf/util/probe-event.c index b82d54fa2c56..1c7bfa5fe0a8 100644 --- a/tools/perf/util/probe-event.c +++ b/tools/perf/util/probe-event.c | |||
@@ -1820,11 +1820,15 @@ static int convert_to_probe_trace_events(struct perf_probe_event *pev, | |||
1820 | ret = -ENOMEM; | 1820 | ret = -ENOMEM; |
1821 | goto error; | 1821 | goto error; |
1822 | } | 1822 | } |
1823 | tev->point.module = strdup(module); | 1823 | |
1824 | if (tev->point.module == NULL) { | 1824 | if (module) { |
1825 | ret = -ENOMEM; | 1825 | tev->point.module = strdup(module); |
1826 | goto error; | 1826 | if (tev->point.module == NULL) { |
1827 | ret = -ENOMEM; | ||
1828 | goto error; | ||
1829 | } | ||
1827 | } | 1830 | } |
1831 | |||
1828 | tev->point.offset = pev->point.offset; | 1832 | tev->point.offset = pev->point.offset; |
1829 | tev->point.retprobe = pev->point.retprobe; | 1833 | tev->point.retprobe = pev->point.retprobe; |
1830 | tev->nargs = pev->nargs; | 1834 | tev->nargs = pev->nargs; |
diff --git a/tools/perf/util/python.c b/tools/perf/util/python.c index 8e0b5a39d8a7..cbc8f215d4b7 100644 --- a/tools/perf/util/python.c +++ b/tools/perf/util/python.c | |||
@@ -187,16 +187,119 @@ static PyTypeObject pyrf_throttle_event__type = { | |||
187 | .tp_repr = (reprfunc)pyrf_throttle_event__repr, | 187 | .tp_repr = (reprfunc)pyrf_throttle_event__repr, |
188 | }; | 188 | }; |
189 | 189 | ||
190 | static char pyrf_lost_event__doc[] = PyDoc_STR("perf lost event object."); | ||
191 | |||
192 | static PyMemberDef pyrf_lost_event__members[] = { | ||
193 | sample_members | ||
194 | member_def(lost_event, id, T_ULONGLONG, "event id"), | ||
195 | member_def(lost_event, lost, T_ULONGLONG, "number of lost events"), | ||
196 | { .name = NULL, }, | ||
197 | }; | ||
198 | |||
199 | static PyObject *pyrf_lost_event__repr(struct pyrf_event *pevent) | ||
200 | { | ||
201 | PyObject *ret; | ||
202 | char *s; | ||
203 | |||
204 | if (asprintf(&s, "{ type: lost, id: %#" PRIx64 ", " | ||
205 | "lost: %#" PRIx64 " }", | ||
206 | pevent->event.lost.id, pevent->event.lost.lost) < 0) { | ||
207 | ret = PyErr_NoMemory(); | ||
208 | } else { | ||
209 | ret = PyString_FromString(s); | ||
210 | free(s); | ||
211 | } | ||
212 | return ret; | ||
213 | } | ||
214 | |||
215 | static PyTypeObject pyrf_lost_event__type = { | ||
216 | PyVarObject_HEAD_INIT(NULL, 0) | ||
217 | .tp_name = "perf.lost_event", | ||
218 | .tp_basicsize = sizeof(struct pyrf_event), | ||
219 | .tp_flags = Py_TPFLAGS_DEFAULT|Py_TPFLAGS_BASETYPE, | ||
220 | .tp_doc = pyrf_lost_event__doc, | ||
221 | .tp_members = pyrf_lost_event__members, | ||
222 | .tp_repr = (reprfunc)pyrf_lost_event__repr, | ||
223 | }; | ||
224 | |||
225 | static char pyrf_read_event__doc[] = PyDoc_STR("perf read event object."); | ||
226 | |||
227 | static PyMemberDef pyrf_read_event__members[] = { | ||
228 | sample_members | ||
229 | member_def(read_event, pid, T_UINT, "event pid"), | ||
230 | member_def(read_event, tid, T_UINT, "event tid"), | ||
231 | { .name = NULL, }, | ||
232 | }; | ||
233 | |||
234 | static PyObject *pyrf_read_event__repr(struct pyrf_event *pevent) | ||
235 | { | ||
236 | return PyString_FromFormat("{ type: read, pid: %u, tid: %u }", | ||
237 | pevent->event.read.pid, | ||
238 | pevent->event.read.tid); | ||
239 | /* | ||
240 | * FIXME: return the array of read values, | ||
241 | * making this method useful ;-) | ||
242 | */ | ||
243 | } | ||
244 | |||
245 | static PyTypeObject pyrf_read_event__type = { | ||
246 | PyVarObject_HEAD_INIT(NULL, 0) | ||
247 | .tp_name = "perf.read_event", | ||
248 | .tp_basicsize = sizeof(struct pyrf_event), | ||
249 | .tp_flags = Py_TPFLAGS_DEFAULT|Py_TPFLAGS_BASETYPE, | ||
250 | .tp_doc = pyrf_read_event__doc, | ||
251 | .tp_members = pyrf_read_event__members, | ||
252 | .tp_repr = (reprfunc)pyrf_read_event__repr, | ||
253 | }; | ||
254 | |||
255 | static char pyrf_sample_event__doc[] = PyDoc_STR("perf sample event object."); | ||
256 | |||
257 | static PyMemberDef pyrf_sample_event__members[] = { | ||
258 | sample_members | ||
259 | member_def(perf_event_header, type, T_UINT, "event type"), | ||
260 | { .name = NULL, }, | ||
261 | }; | ||
262 | |||
263 | static PyObject *pyrf_sample_event__repr(struct pyrf_event *pevent) | ||
264 | { | ||
265 | PyObject *ret; | ||
266 | char *s; | ||
267 | |||
268 | if (asprintf(&s, "{ type: sample }") < 0) { | ||
269 | ret = PyErr_NoMemory(); | ||
270 | } else { | ||
271 | ret = PyString_FromString(s); | ||
272 | free(s); | ||
273 | } | ||
274 | return ret; | ||
275 | } | ||
276 | |||
277 | static PyTypeObject pyrf_sample_event__type = { | ||
278 | PyVarObject_HEAD_INIT(NULL, 0) | ||
279 | .tp_name = "perf.sample_event", | ||
280 | .tp_basicsize = sizeof(struct pyrf_event), | ||
281 | .tp_flags = Py_TPFLAGS_DEFAULT|Py_TPFLAGS_BASETYPE, | ||
282 | .tp_doc = pyrf_sample_event__doc, | ||
283 | .tp_members = pyrf_sample_event__members, | ||
284 | .tp_repr = (reprfunc)pyrf_sample_event__repr, | ||
285 | }; | ||
286 | |||
190 | static int pyrf_event__setup_types(void) | 287 | static int pyrf_event__setup_types(void) |
191 | { | 288 | { |
192 | int err; | 289 | int err; |
193 | pyrf_mmap_event__type.tp_new = | 290 | pyrf_mmap_event__type.tp_new = |
194 | pyrf_task_event__type.tp_new = | 291 | pyrf_task_event__type.tp_new = |
195 | pyrf_comm_event__type.tp_new = | 292 | pyrf_comm_event__type.tp_new = |
293 | pyrf_lost_event__type.tp_new = | ||
294 | pyrf_read_event__type.tp_new = | ||
295 | pyrf_sample_event__type.tp_new = | ||
196 | pyrf_throttle_event__type.tp_new = PyType_GenericNew; | 296 | pyrf_throttle_event__type.tp_new = PyType_GenericNew; |
197 | err = PyType_Ready(&pyrf_mmap_event__type); | 297 | err = PyType_Ready(&pyrf_mmap_event__type); |
198 | if (err < 0) | 298 | if (err < 0) |
199 | goto out; | 299 | goto out; |
300 | err = PyType_Ready(&pyrf_lost_event__type); | ||
301 | if (err < 0) | ||
302 | goto out; | ||
200 | err = PyType_Ready(&pyrf_task_event__type); | 303 | err = PyType_Ready(&pyrf_task_event__type); |
201 | if (err < 0) | 304 | if (err < 0) |
202 | goto out; | 305 | goto out; |
@@ -206,20 +309,26 @@ static int pyrf_event__setup_types(void) | |||
206 | err = PyType_Ready(&pyrf_throttle_event__type); | 309 | err = PyType_Ready(&pyrf_throttle_event__type); |
207 | if (err < 0) | 310 | if (err < 0) |
208 | goto out; | 311 | goto out; |
312 | err = PyType_Ready(&pyrf_read_event__type); | ||
313 | if (err < 0) | ||
314 | goto out; | ||
315 | err = PyType_Ready(&pyrf_sample_event__type); | ||
316 | if (err < 0) | ||
317 | goto out; | ||
209 | out: | 318 | out: |
210 | return err; | 319 | return err; |
211 | } | 320 | } |
212 | 321 | ||
213 | static PyTypeObject *pyrf_event__type[] = { | 322 | static PyTypeObject *pyrf_event__type[] = { |
214 | [PERF_RECORD_MMAP] = &pyrf_mmap_event__type, | 323 | [PERF_RECORD_MMAP] = &pyrf_mmap_event__type, |
215 | [PERF_RECORD_LOST] = &pyrf_mmap_event__type, | 324 | [PERF_RECORD_LOST] = &pyrf_lost_event__type, |
216 | [PERF_RECORD_COMM] = &pyrf_comm_event__type, | 325 | [PERF_RECORD_COMM] = &pyrf_comm_event__type, |
217 | [PERF_RECORD_EXIT] = &pyrf_task_event__type, | 326 | [PERF_RECORD_EXIT] = &pyrf_task_event__type, |
218 | [PERF_RECORD_THROTTLE] = &pyrf_throttle_event__type, | 327 | [PERF_RECORD_THROTTLE] = &pyrf_throttle_event__type, |
219 | [PERF_RECORD_UNTHROTTLE] = &pyrf_throttle_event__type, | 328 | [PERF_RECORD_UNTHROTTLE] = &pyrf_throttle_event__type, |
220 | [PERF_RECORD_FORK] = &pyrf_task_event__type, | 329 | [PERF_RECORD_FORK] = &pyrf_task_event__type, |
221 | [PERF_RECORD_READ] = &pyrf_mmap_event__type, | 330 | [PERF_RECORD_READ] = &pyrf_read_event__type, |
222 | [PERF_RECORD_SAMPLE] = &pyrf_mmap_event__type, | 331 | [PERF_RECORD_SAMPLE] = &pyrf_sample_event__type, |
223 | }; | 332 | }; |
224 | 333 | ||
225 | static PyObject *pyrf_event__new(union perf_event *event) | 334 | static PyObject *pyrf_event__new(union perf_event *event) |
diff --git a/tools/perf/util/setup.py b/tools/perf/util/setup.py index bbc982f5dd8b..95d370074928 100644 --- a/tools/perf/util/setup.py +++ b/tools/perf/util/setup.py | |||
@@ -3,9 +3,27 @@ | |||
3 | from distutils.core import setup, Extension | 3 | from distutils.core import setup, Extension |
4 | from os import getenv | 4 | from os import getenv |
5 | 5 | ||
6 | from distutils.command.build_ext import build_ext as _build_ext | ||
7 | from distutils.command.install_lib import install_lib as _install_lib | ||
8 | |||
9 | class build_ext(_build_ext): | ||
10 | def finalize_options(self): | ||
11 | _build_ext.finalize_options(self) | ||
12 | self.build_lib = build_lib | ||
13 | self.build_temp = build_tmp | ||
14 | |||
15 | class install_lib(_install_lib): | ||
16 | def finalize_options(self): | ||
17 | _install_lib.finalize_options(self) | ||
18 | self.build_dir = build_lib | ||
19 | |||
20 | |||
6 | cflags = ['-fno-strict-aliasing', '-Wno-write-strings'] | 21 | cflags = ['-fno-strict-aliasing', '-Wno-write-strings'] |
7 | cflags += getenv('CFLAGS', '').split() | 22 | cflags += getenv('CFLAGS', '').split() |
8 | 23 | ||
24 | build_lib = getenv('PYTHON_EXTBUILD_LIB') | ||
25 | build_tmp = getenv('PYTHON_EXTBUILD_TMP') | ||
26 | |||
9 | perf = Extension('perf', | 27 | perf = Extension('perf', |
10 | sources = ['util/python.c', 'util/ctype.c', 'util/evlist.c', | 28 | sources = ['util/python.c', 'util/ctype.c', 'util/evlist.c', |
11 | 'util/evsel.c', 'util/cpumap.c', 'util/thread_map.c', | 29 | 'util/evsel.c', 'util/cpumap.c', 'util/thread_map.c', |
@@ -21,4 +39,5 @@ setup(name='perf', | |||
21 | author_email='acme@redhat.com', | 39 | author_email='acme@redhat.com', |
22 | license='GPLv2', | 40 | license='GPLv2', |
23 | url='http://perf.wiki.kernel.org', | 41 | url='http://perf.wiki.kernel.org', |
24 | ext_modules=[perf]) | 42 | ext_modules=[perf], |
43 | cmdclass={'build_ext': build_ext, 'install_lib': install_lib}) | ||
diff --git a/tools/perf/util/symbol.c b/tools/perf/util/symbol.c index eec196329fd9..a8b53714542a 100644 --- a/tools/perf/util/symbol.c +++ b/tools/perf/util/symbol.c | |||
@@ -1504,6 +1504,17 @@ int dso__load(struct dso *dso, struct map *map, symbol_filter_t filter) | |||
1504 | dso->adjust_symbols = 0; | 1504 | dso->adjust_symbols = 0; |
1505 | 1505 | ||
1506 | if (strncmp(dso->name, "/tmp/perf-", 10) == 0) { | 1506 | if (strncmp(dso->name, "/tmp/perf-", 10) == 0) { |
1507 | struct stat st; | ||
1508 | |||
1509 | if (stat(dso->name, &st) < 0) | ||
1510 | return -1; | ||
1511 | |||
1512 | if (st.st_uid && (st.st_uid != geteuid())) { | ||
1513 | pr_warning("File %s not owned by current user or root, " | ||
1514 | "ignoring it.\n", dso->name); | ||
1515 | return -1; | ||
1516 | } | ||
1517 | |||
1507 | ret = dso__load_perf_map(dso, map, filter); | 1518 | ret = dso__load_perf_map(dso, map, filter); |
1508 | dso->symtab_type = ret > 0 ? SYMTAB__JAVA_JIT : | 1519 | dso->symtab_type = ret > 0 ? SYMTAB__JAVA_JIT : |
1509 | SYMTAB__NOT_FOUND; | 1520 | SYMTAB__NOT_FOUND; |