blob: 7d89665dca66340ae17cbc50197c72256b016cae [file] [log] [blame]
Angel Ponsf5627e82020-04-05 15:46:52 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Lijian Zhaoae565462017-10-02 19:18:16 -07002
3#include <soc/gpe.h>
Lijian Zhaoae565462017-10-02 19:18:16 -07004
Edward O'Callaghan81128412020-06-24 09:45:49 +10005#define PORTSCN_OFFSET 0x480
6#define PORTSCXUSB3_OFFSET 0x540
7
8#define WAKE_ON_CONNECT_DISCONNECT_ENABLE 0x6000000
9#define RO_BITS_OFF_MASK ~0x80FE0012
10
11/*
12 * USB Port Wake Enable (UPWE) on usb attach/detach
13 * Arg0 - Port Number
14 * Arg1 - Port 1 Status and control offset
15 * Arg2 - xHCI Memory-mapped address
16 */
17Method (UPWE, 3, Serialized)
18{
19 Local0 = Arg1 + ((Arg0 - 1) * 0x10)
20
21 /* Map ((XMEM << 16) + Local0 in PSCR */
22 OperationRegion (PSCR, SystemMemory,
23 Add (ShiftLeft (Arg2, 16), Local0), 0x10)
24 Field (PSCR, DWordAcc, NoLock, Preserve)
25 {
26 PSCT, 32,
27 }
28 Local0 = PSCT
29 /*
30 * And port status/control reg with RO and RWS bits
31 * RO bits: 0, 2:3, 10:13, 24, 28:30
32 * RWS bits: 5:9, 14:16, 25:27
33 */
34 Local0 = Local0 & RO_BITS_OFF_MASK
35 /* Set WCE and WDE bits */
36 Local0 = Local0 | WAKE_ON_CONNECT_DISCONNECT_ENABLE
37 PSCT = Local0
38}
39
40/*
41 * USB Wake Enable Setup (UWES)
42 * Arg0 - Port enable bitmap
43 * Arg1 - Port 1 Status and control offset
44 * Arg2 - xHCI Memory-mapped address
45 */
46Method (UWES, 3, Serialized)
47{
48 Local0 = Arg0
49
50 While (One) {
51 FindSetRightBit (Local0, Local1)
52 If (Local1 == Zero) {
53 Break
54 }
55 UPWE (Local1, Arg1, Arg2)
56 /*
57 * Clear the lowest set bit in Local0 since it was
58 * processed.
59 */
60 Local0 = Local0 & (Local0 - 1)
61 }
62}
63
Lijian Zhaoae565462017-10-02 19:18:16 -070064/* XHCI Controller 0:14.0 */
65
66Device (XHCI)
67{
68 Name (_ADR, 0x00140000)
69
70 Name (_PRW, Package () { GPE0_PME_B0, 3 })
71
Edward O'Callaghan81128412020-06-24 09:45:49 +100072 Method (_DSW, 3)
73 {
74 UWES ((\U2WE & 0xFFF), PORTSCN_OFFSET, XMEM)
75 UWES ((\U3WE & 0x3F ), PORTSCXUSB3_OFFSET, XMEM)
76 }
77
Lijian Zhaoae565462017-10-02 19:18:16 -070078 Name (_S3D, 3) /* D3 supported in S3 */
Lijian Zhaoae565462017-10-02 19:18:16 -070079 Name (_S0W, 3) /* D3 can wake device in S0 */
80 Name (_S3W, 3) /* D3 can wake system from S3 */
Lijian Zhaoae565462017-10-02 19:18:16 -070081
Edward O'Callaghan81128412020-06-24 09:45:49 +100082 OperationRegion (XPRT, PCI_Config, 0x00, 0x100)
83 Field (XPRT, AnyAcc, NoLock, Preserve)
84 {
85 Offset (0x10),
86 , 16,
87 XMEM, 16, /* MEM_BASE */
88 }
89
Lijian Zhaoae565462017-10-02 19:18:16 -070090 Method (_PS0, 0, Serialized)
91 {
Lijian Zhaoae565462017-10-02 19:18:16 -070092
Lijian Zhaoae565462017-10-02 19:18:16 -070093 }
94
95 Method (_PS3, 0, Serialized)
96 {
Lijian Zhaoae565462017-10-02 19:18:16 -070097
Lijian Zhaoae565462017-10-02 19:18:16 -070098 }
99
100 /* Root Hub for Cannonlake-LP PCH */
101 Device (RHUB)
102 {
103 Name (_ADR, Zero)
104
105 /* USB2 */
106 Device (HS01) { Name (_ADR, 1) }
107 Device (HS02) { Name (_ADR, 2) }
108 Device (HS03) { Name (_ADR, 3) }
109 Device (HS04) { Name (_ADR, 4) }
110 Device (HS05) { Name (_ADR, 5) }
111 Device (HS06) { Name (_ADR, 6) }
112 Device (HS07) { Name (_ADR, 7) }
113 Device (HS08) { Name (_ADR, 8) }
114 Device (HS09) { Name (_ADR, 9) }
115 Device (HS10) { Name (_ADR, 10) }
116 Device (HS11) { Name (_ADR, 11) }
117 Device (HS12) { Name (_ADR, 12) }
118
119 /* USBr */
120 Device (USR1) { Name (_ADR, 11) }
121 Device (USR2) { Name (_ADR, 12) }
122
123 /* USB3 */
124 Device (SS01) { Name (_ADR, 13) }
125 Device (SS02) { Name (_ADR, 14) }
126 Device (SS03) { Name (_ADR, 15) }
127 Device (SS04) { Name (_ADR, 16) }
128 Device (SS05) { Name (_ADR, 17) }
129 Device (SS06) { Name (_ADR, 18) }
130 }
131}