aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
Diffstat (limited to 'kernel')
0 files changed, 0 insertions, 0 deletions
1b86a5923fad5f3fbb6192f767f410241ba27'>bc31b86a5923
09cbfeaf1a5a
bc31b86a5923
cc395d7f1f7b



bc31b86a5923
c4a77a6c7dcf

83ba7b071f30
c4a77a6c7dcf

0dc83bd30b0b
c4a77a6c7dcf
6e6938b6d313
52957fe1c709


7747bd4bceb3
ac7b19a34f33
0e175a1835ff
c4a77a6c7dcf
8010c3b6349b
cc395d7f1f7b
03ba3782e8dc

a2f4870697a5
cc395d7f1f7b












a2f4870697a5










7ccf19a8042e

c7f5408493ae
7ccf19a8042e

15eb77a07c71







774016b2d455

d6c10f1fc862





95a46c65e3c0
766a9d6e6057

d6c10f1fc862






766a9d6e6057
d6c10f1fc862
95a46c65e3c0

766a9d6e6057
d6c10f1fc862


c7f5408493ae
d6c10f1fc862



c7f5408493ae
d6c10f1fc862


c7f5408493ae
d6c10f1fc862




c7f5408493ae
d6c10f1fc862









c7f5408493ae
d6c10f1fc862





c7f5408493ae
d6c10f1fc862



c7f5408493ae
d6c10f1fc862


f0054bb1e1f3
5acda9d12dcf
f0054bb1e1f3



5acda9d12dcf

f0054bb1e1f3

6585027a5e8c
5634cc2aa9ae
6585027a5e8c
f0054bb1e1f3
8a1270cda7b4
5acda9d12dcf
cc395d7f1f7b

f0054bb1e1f3

5acda9d12dcf
f0054bb1e1f3
1da177e4c3f4

cc395d7f1f7b

















703c270887bb

2a81490811d0













a1a0e23e4903


21c6321fbb3a





























703c270887bb
87e1d789bf55























87e1d789bf55
aaa2cacf8184
614a4e377314



87e1d789bf55

614a4e377314
87e1d789bf55


















682aa8e1a6a1












d10c80955265

682aa8e1a6a1
d10c80955265


682aa8e1a6a1





d10c80955265



682aa8e1a6a1
d10c80955265






682aa8e1a6a1
d10c80955265



c7f5408493ae
d10c80955265





































c7f5408493ae
d10c80955265

c7f5408493ae
d10c80955265
c7f5408493ae
d10c80955265


c7f5408493ae
d10c80955265


682aa8e1a6a1
d10c80955265
682aa8e1a6a1


d10c80955265

682aa8e1a6a1





d10c80955265
682aa8e1a6a1
d10c80955265

682aa8e1a6a1
d10c80955265



682aa8e1a6a1
d10c80955265

682aa8e1a6a1
a1a0e23e4903

682aa8e1a6a1








a1a0e23e4903
682aa8e1a6a1


































a1a0e23e4903





682aa8e1a6a1
745249555560
682aa8e1a6a1

682aa8e1a6a1

a1a0e23e4903

682aa8e1a6a1














87e1d789bf55
b16b1deb553a











dd73e4b7df95




b16b1deb553a
2a81490811d0








b16b1deb553a

e8a7abf5a5bd






b16b1deb553a


2a81490811d0

b16b1deb553a


2a81490811d0





























b16b1deb553a


2a81490811d0

dd73e4b7df95

2a81490811d0

dd73e4b7df95





2a81490811d0



















































682aa8e1a6a1

2a81490811d0









b16b1deb553a




2a81490811d0






















2a81490811d0
2a81490811d0
















5aa2a96b3407
2a81490811d0

703c270887bb
60292bcc1b24
703c270887bb








60292bcc1b24


703c270887bb


5cb8b8241e61



aaa2cacf8184
5cb8b8241e61






703c270887bb





f2b651216076



























db125360409f
db125360409f













b817525a4a80
b33e18f61bd1

db125360409f

db125360409f

b817525a4a80
8a1270cda7b4




b817525a4a80




006a0973ed02





db125360409f

8a1270cda7b4








db125360409f
8a1270cda7b4









b817525a4a80







8a1270cda7b4


db125360409f

b817525a4a80


db125360409f

a1a0e23e4903


























f2b651216076

87e1d789bf55




















f2b651216076




db125360409f





006a0973ed02
db125360409f
db125360409f



703c270887bb

c00ddad39f51

b6e51316daed
c00ddad39f51








78ebc2f71461

c00ddad39f51
5634cc2aa9ae
c00ddad39f51







ac7b19a34f33
c00ddad39f51

c5444198ca21
d3ddec7635b6
c5444198ca21
9ecf4866c018

c5444198ca21

6585027a5e8c
9ecf4866c018
6585027a5e8c

c5444198ca21
9ecf4866c018
c5444198ca21
6585027a5e8c



5634cc2aa9ae
9ecf4866c018
1da177e4c3f4


a66979abad09

c7f5408493ae
a66979abad09
87e1d789bf55
f758eeabeb96
87e1d789bf55
c7f5408493ae
52ebea749aae
a66979abad09

a66979abad09
6c60d2b5746c








9a46b04f16a0
6c60d2b5746c
9a46b04f16a0

6c60d2b5746c













9a46b04f16a0



6c60d2b5746c




6610a0bc8dcc



66f3b8e2e103
6610a0bc8dcc


f758eeabeb96
6610a0bc8dcc
03ba3782e8dc
66f3b8e2e103
6610a0bc8dcc
7ccf19a8042e
66f3b8e2e103
6610a0bc8dcc

c7f5408493ae
6610a0bc8dcc


66f3b8e2e103
c986d1e2a460
f758eeabeb96
c986d1e2a460
c7f5408493ae
c986d1e2a460

1c0eeaf56985

365b94ae67d2
4eff96dd5283

365b94ae67d2
1c0eeaf56985



d2caa3c549c7







5b0830cb9085
d2caa3c549c7





0ae45f63d4ef

c986d1e2a460
0e2f2b236720
697e6fed9fc6
2c1365791048
e84d0a4f8e39
2c1365791048
0ae45f63d4ef
ad4e38dd6a33
2c1365791048
0ae45f63d4ef

5c03449d34de

cf137307cd98
5c03449d34de
cf137307cd98
e84d0a4f8e39
5c03449d34de
0ae45f63d4ef

a2f4870697a5

0ae45f63d4ef

2c1365791048
7ccf19a8042e
0ae45f63d4ef

2c1365791048
c7f5408493ae
a8855990e382
0ae45f63d4ef

a8855990e382

cf137307cd98


5c03449d34de

cf137307cd98


e84d0a4f8e39
cf137307cd98

5c03449d34de

7ccf19a8042e
5c03449d34de
7ccf19a8042e
5c03449d34de
c7f5408493ae
5c03449d34de
2c1365791048
e84d0a4f8e39

2c1365791048



4ea879b96d43







2c1365791048
ad4e38dd6a33
66f3b8e2e103
e84d0a4f8e39
0ae45f63d4ef
f758eeabeb96
4ea879b96d43
0ae45f63d4ef


d6c10f1fc862

ad4e38dd6a33
66f3b8e2e103

a9185b41a4f8
08d8e9749e7f
9fb0a7da0c52







03ba3782e8dc
08d8e9749e7f
08d8e9749e7f
2c1365791048
169ebd90131b

01c031945f27
169ebd90131b


01c031945f27




250df6ed274d

743162013d40

250df6ed274d
58a9d3d8db06
01c031945f27


169ebd90131b





























ccb26b5a6586





















4f8ad655dbc8








ccb26b5a6586
























0ae45f63d4ef
a2f4870697a5
c7f5408493ae
ccb26b5a6586

c7f5408493ae
ccb26b5a6586



4f8ad655dbc8


1da177e4c3f4

cd8ed2a45a40
1da177e4c3f4
1da177e4c3f4
251d6a471c83
01c031945f27
1da177e4c3f4

4f8ad655dbc8
1da177e4c3f4
9fb0a7da0c52

1da177e4c3f4

26821ed40b42


7747bd4bceb3


26821ed40b42
7747bd4bceb3
26821ed40b42
1da177e4c3f4



5547e8aac6f7




250df6ed274d
9c6ac78eb352
5547e8aac6f7
a2f4870697a5

dc5ff2b1d66f
a2f4870697a5








0ae45f63d4ef
9c6ac78eb352
















250df6ed274d
9c6ac78eb352
0ae45f63d4ef

26821ed40b42
0ae45f63d4ef
a9185b41a4f8
1da177e4c3f4


4f8ad655dbc8











aaf2559332ba

4f8ad655dbc8
aaf2559332ba
4f8ad655dbc8











169ebd90131b


4f8ad655dbc8
169ebd90131b
4f8ad655dbc8


f9b0e058cbd0





4f8ad655dbc8
0ae45f63d4ef
f9b0e058cbd0

4f8ad655dbc8

b16b1deb553a
4f8ad655dbc8
cd8ed2a45a40
1da177e4c3f4
b16b1deb553a
aaf2559332ba

250df6ed274d
4f8ad655dbc8



0ae45f63d4ef
c7f5408493ae
4f8ad655dbc8
1c0eeaf56985
4f8ad655dbc8

1da177e4c3f4


a88a341a73be
1a12d8bd7b29
d46db3d58233

















1a12d8bd7b29
a88a341a73be
dcc25ae76eb7
1a12d8bd7b29



d46db3d58233



03ba3782e8dc
f11c9c5c259c
edadfb10ba35
d46db3d58233
0ba13fd19d39



f11c9c5c259c
d46db3d58233


1da177e4c3f4
d46db3d58233




7747bd4bceb3
d46db3d58233







03ba3782e8dc
7ccf19a8042e
aaf2559332ba
edadfb10ba35

d46db3d58233
edadfb10ba35




f758eeabeb96
edadfb10ba35







d46db3d58233
edadfb10ba35

9843b76aae80
331cbdeedeb2

9843b76aae80

250df6ed274d
9843b76aae80
250df6ed274d
fcc5c22218a1
7ef0d7377cb2

cc1676d917f3














f0d07b7ffde7

4f8ad655dbc8




169ebd90131b



ead188f9f930
169ebd90131b

4f8ad655dbc8
b16b1deb553a
169ebd90131b
a88a341a73be
d46db3d58233

250df6ed274d
169ebd90131b



cd8ed2a45a40
250df6ed274d
b16b1deb553a
d46db3d58233

590dca3a7187













aaf2559332ba




4f8ad655dbc8
0ae45f63d4ef
d46db3d58233
aaf2559332ba
4f8ad655dbc8
0f1b1fd86f6f
590dca3a7187
aaf2559332ba




d46db3d58233








8bc3be2751b4
1da177e4c3f4
d46db3d58233
f11c9c5c259c

d46db3d58233

f11c9c5c259c
d46db3d58233

38f219776631
f11c9c5c259c
7ccf19a8042e
f11c9c5c259c
9ecc2738ac23
eb6ef3df4faa
0e995816f4fb
eb6ef3df4faa
0e995816f4fb



edadfb10ba35
f11c9c5c259c
d46db3d58233
eb6ef3df4faa
f11c9c5c259c
d46db3d58233






f11c9c5c259c
66f3b8e2e103
d46db3d58233
66f3b8e2e103

7d9f073b8da4
0e175a1835ff
edadfb10ba35
d46db3d58233



0e175a1835ff
d46db3d58233
505a666ee3fc
edadfb10ba35
505a666ee3fc
f758eeabeb96
424b351fe190
ad4e38dd6a33
d46db3d58233
f758eeabeb96
505a666ee3fc
edadfb10ba35
d46db3d58233

03ba3782e8dc
03ba3782e8dc

66f3b8e2e103
03ba3782e8dc



66f3b8e2e103
03ba3782e8dc


66f3b8e2e103
03ba3782e8dc

66f3b8e2e103
c4a77a6c7dcf
83ba7b071f30
66f3b8e2e103
e98be2d59920
d46db3d58233
0dc83bd30b0b
a5989bdc981e
d46db3d58233
505a666ee3fc
66f3b8e2e103
0dc83bd30b0b

38f219776631
505a666ee3fc
e8dfc3058299
03ba3782e8dc

d3ddec7635b6
03ba3782e8dc
83ba7b071f30
03ba3782e8dc
66f3b8e2e103
38f219776631
aa373cf55099





f0054bb1e1f3
aa373cf55099


d3ddec7635b6

38f219776631
aa661bbe1e61
03ba3782e8dc
38f219776631
1bc36b6426ae





ba9aa8399fda
0dc83bd30b0b
ba9aa8399fda
1bc36b6426ae
0dc83bd30b0b
028c2dd184c0
5634cc2aa9ae
e8dfc3058299
ad4e38dd6a33
83ba7b071f30
d46db3d58233
edadfb10ba35
d46db3d58233
5634cc2aa9ae
028c2dd184c0
e98be2d59920
03ba3782e8dc

e6fb6da2e106





03ba3782e8dc
d46db3d58233
71fd05a887e0

e6fb6da2e106
71fd05a887e0
b7a2441f9966
03ba3782e8dc
71fd05a887e0
71fd05a887e0



71fd05a887e0
5634cc2aa9ae
7ccf19a8042e
250df6ed274d
f0d07b7ffde7
169ebd90131b

f0d07b7ffde7
03ba3782e8dc

e8dfc3058299
505a666ee3fc
03ba3782e8dc
d46db3d58233
03ba3782e8dc


83ba7b071f30
03ba3782e8dc
f0054bb1e1f3
03ba3782e8dc
83ba7b071f30
03ba3782e8dc
f0054bb1e1f3


83ba7b071f30

03ba3782e8dc
f0054bb1e1f3
83ba7b071f30
03ba3782e8dc

cdf01dd5443d





11fb998986a7

cdf01dd5443d


6585027a5e8c

aa661bbe1e61
6585027a5e8c





0e175a1835ff
6585027a5e8c







03ba3782e8dc




69b62d01ec44





03ba3782e8dc





cdf01dd5443d
03ba3782e8dc
c4a77a6c7dcf
83ba7b071f30
c4a77a6c7dcf



0e175a1835ff
c4a77a6c7dcf

83ba7b071f30
c4a77a6c7dcf
03ba3782e8dc






25d130ba2236
03ba3782e8dc
83ba7b071f30
c4a77a6c7dcf
03ba3782e8dc
4452226ea276
f0054bb1e1f3
cc395d7f1f7b
03ba3782e8dc
5634cc2aa9ae
455b2864686d
83ba7b071f30
03ba3782e8dc
8a1270cda7b4
83ba7b071f30
cc395d7f1f7b

03ba3782e8dc





6585027a5e8c
4452226ea276
03ba3782e8dc





839a8e8660b6
03ba3782e8dc
f0054bb1e1f3
03ba3782e8dc
839a8e8660b6

03ba3782e8dc

f0054bb1e1f3
766f9164193f
455b2864686d
839a8e8660b6
4452226ea276
6467716a3767
f0054bb1e1f3
839a8e8660b6
f0054bb1e1f3
839a8e8660b6
6467716a3767
839a8e8660b6
25d130ba2236
839a8e8660b6
f0054bb1e1f3
839a8e8660b6





f0054bb1e1f3
839a8e8660b6
455b2864686d
03ba3782e8dc

f0054bb1e1f3
6ca738d60c56

f0054bb1e1f3
455b2864686d
839a8e8660b6
03ba3782e8dc


b8c2f3474f10

03ba3782e8dc
0e175a1835ff
03ba3782e8dc
b8c2f3474f10
03ba3782e8dc
51350ea0d7f3





47df3ddedd22

03ba3782e8dc
b8c2f3474f10
f2b651216076

f2b651216076



b817525a4a80
f2b651216076


cfc4ba536544
1da177e4c3f4

a2f4870697a5























001fe6f617b1
001fe6f617b1
b817525a4a80
6fdf860f15d4

a2f4870697a5











1efff914afac










03ba3782e8dc



























1da177e4c3f4
03ba3782e8dc








1da177e4c3f4
03ba3782e8dc





1da177e4c3f4
03ba3782e8dc
1da177e4c3f4
dbce03b9e3e6
03ba3782e8dc
0ae45f63d4ef


1da177e4c3f4
03ba3782e8dc



0ae45f63d4ef
9fb0a7da0c52

03ba3782e8dc
aa38572954ad
9fb0a7da0c52

03ba3782e8dc
0ae45f63d4ef


03ba3782e8dc

9c6ac78eb352

03ba3782e8dc


0ae45f63d4ef

03ba3782e8dc




250df6ed274d
0ae45f63d4ef

03ba3782e8dc


52ebea749aae

0ae45f63d4ef

03ba3782e8dc







250df6ed274d
03ba3782e8dc





1d3382cbf029
250df6ed274d
03ba3782e8dc
a4ffdde6e56f
250df6ed274d
03ba3782e8dc





87e1d789bf55
d6c10f1fc862
a66979abad09
253c34e9b10c
87e1d789bf55
253c34e9b10c
0747259d13fe


03ba3782e8dc

a2f4870697a5

d6c10f1fc862
a2f4870697a5
0747259d13fe
a2f4870697a5
0747259d13fe
d6c10f1fc862
c7f5408493ae
d6c10f1fc862

0747259d13fe
0ae45f63d4ef
a66979abad09
d6c10f1fc862





0747259d13fe

a66979abad09
1da177e4c3f4
1da177e4c3f4
250df6ed274d

253c34e9b10c
dbce03b9e3e6
03ba3782e8dc


e97fedb9ef98








b6e51316daed
03ba3782e8dc
6c60d2b5746c
03ba3782e8dc




b6e51316daed
03ba3782e8dc
e97fedb9ef98
03ba3782e8dc

6c60d2b5746c

















03ba3782e8dc
6c60d2b5746c


250df6ed274d
03ba3782e8dc
6c60d2b5746c

















250df6ed274d
6c60d2b5746c
250df6ed274d
6c60d2b5746c

03ba3782e8dc
250df6ed274d
03ba3782e8dc
250df6ed274d
6c60d2b5746c
03ba3782e8dc
aa750fd71c24





03ba3782e8dc


6c60d2b5746c



03ba3782e8dc
6c60d2b5746c

e97fedb9ef98
1da177e4c3f4

f30a7d0cc8d9

1da177e4c3f4
cc395d7f1f7b
83ba7b071f30
6e6938b6d313




0e175a1835ff
3c4d716538f3
e79729123f63
d8a8559cd7a9
e79729123f63
6eedc70150d5
cf37e972478e
f30a7d0cc8d9
db125360409f
cc395d7f1f7b
e913fc825dc6
f30a7d0cc8d9
















3259f8bed2f0




786228ab3095
3259f8bed2f0




0e175a1835ff
3259f8bed2f0
0e175a1835ff
3259f8bed2f0
0e3c9a2284f5
e913fc825dc6

10ee27a06cc8
17bd55d037a0
10ee27a06cc8

17bd55d037a0
10ee27a06cc8
17bd55d037a0

f30a7d0cc8d9

17bd55d037a0
10ee27a06cc8
f30a7d0cc8d9
10ee27a06cc8
f30a7d0cc8d9
10ee27a06cc8
f30a7d0cc8d9
17bd55d037a0
10ee27a06cc8
17bd55d037a0

10ee27a06cc8
3259f8bed2f0
786228ab3095
3259f8bed2f0
10ee27a06cc8
3259f8bed2f0

f30a7d0cc8d9
3259f8bed2f0
10ee27a06cc8
3259f8bed2f0
10ee27a06cc8
3259f8bed2f0

d8a8559cd7a9
0dc83bd30b0b
d8a8559cd7a9

0dc83bd30b0b
d8a8559cd7a9
0dc83bd30b0b
d8a8559cd7a9
cc395d7f1f7b
83ba7b071f30
3c4d716538f3



83ba7b071f30
0e175a1835ff
7747bd4bceb3
3c4d716538f3
e79729123f63
3c4d716538f3
006a0973ed02





6eedc70150d5
cf37e972478e

db125360409f
cc395d7f1f7b
83ba7b071f30
b6e51316daed
1da177e4c3f4
d8a8559cd7a9
1da177e4c3f4
1da177e4c3f4
7f04c26d715a





1da177e4c3f4
7f04c26d715a
1da177e4c3f4
1da177e4c3f4

1da177e4c3f4

18914b1884eb
111ebb6e6f7b

1da177e4c3f4


49364ce25344
1da177e4c3f4

aaf2559332ba
1da177e4c3f4















aaf2559332ba
1da177e4c3f4

c37650161a53

c691b9d983d7
c37650161a53


c691b9d983d7
c37650161a53












1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
1339
1340
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
1460
1461
1462
1463
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475
1476
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
1489
1490
1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
1599
1600
1601
1602
1603
1604
1605
1606
1607
1608
1609
1610
1611
1612
1613
1614
1615
1616
1617
1618
1619
1620
1621
1622
1623
1624
1625
1626
1627
1628
1629
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658
1659
1660
1661
1662
1663
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
1675
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
1690
1691
1692
1693
1694
1695
1696
1697
1698
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715
1716
1717
1718
1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
1750
1751
1752
1753
1754
1755
1756
1757
1758
1759
1760
1761
1762
1763
1764
1765
1766
1767
1768
1769
1770
1771
1772
1773
1774
1775
1776
1777
1778
1779
1780
1781
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798
1799
1800
1801
1802
1803
1804
1805
1806
1807
1808
1809
1810
1811
1812
1813
1814
1815
1816
1817
1818
1819
1820
1821
1822
1823
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
1855
1856
1857
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
1903
1904
1905
1906
1907
1908
1909
1910
1911
1912
1913
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951
1952
1953
1954
1955
1956
1957
1958
1959
1960
1961
1962
1963
1964
1965
1966
1967
1968
1969
1970
1971
1972
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
2060
2061
2062
2063
2064
2065
2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
2078
2079
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101
2102
2103
2104
2105
2106
2107
2108
2109
2110
2111
2112
2113
2114
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
2125
2126
2127
2128
2129
2130
2131
2132
2133
2134
2135
2136
2137
2138
2139
2140
2141
2142
2143
2144
2145
2146
2147
2148
2149
2150
2151
2152
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
2163
2164
2165
2166
2167
2168
2169
2170
2171
2172
2173
2174
2175
2176
2177
2178
2179
2180
2181
2182
2183
2184
2185
2186
2187
2188
2189
2190
2191
2192
2193
2194
2195
2196
2197
2198
2199
2200
2201
2202
2203
2204
2205
2206
2207
2208
2209
2210
2211
2212
2213
2214
2215
2216
2217
2218
2219
2220
2221
2222
2223
2224
2225
2226
2227
2228
2229
2230
2231
2232
2233
2234
2235
2236
2237
2238
2239
2240
2241
2242
2243
2244
2245
2246
2247
2248
2249
2250
2251
2252
2253
2254
2255
2256
2257
2258
2259
2260
2261
2262
2263
2264
2265
2266
2267
2268
2269
2270
2271
2272
2273
2274
2275
2276
2277
2278
2279
2280
2281
2282
2283
2284
2285
2286
2287
2288
2289
2290
2291
2292
2293
2294
2295
2296
2297
2298
2299
2300
2301
2302
2303
2304
2305
2306
2307
2308
2309
2310
2311
2312
2313
2314
2315
2316
2317
2318
2319
2320
2321
2322
2323
2324
2325
2326
2327
2328
2329
2330
2331
2332
2333
2334
2335
2336
2337
2338
2339
2340
2341
2342
2343
2344
2345
2346
2347
2348
2349
2350
2351
2352
2353
2354
2355
2356
2357
2358
2359
2360
2361
2362
2363
2364
2365
2366
2367
2368
2369
2370
2371
2372
2373
2374
2375
2376
2377
2378
2379
2380
2381
2382
2383
2384
2385
2386
2387
2388
2389
2390
2391
2392
2393
2394
2395
2396
2397
2398
2399
2400
2401
2402
2403
2404
2405
2406
2407
2408
2409
2410
2411
2412
2413
2414
2415
2416
2417
2418
2419
2420
2421
2422
2423
2424
2425
2426
2427
2428
2429
2430
2431
2432
2433
2434
2435
2436
2437
2438
2439
2440
2441
2442
2443
2444
2445
2446
2447
2448
2449
2450
2451
2452
2453
2454
2455
2456
2457
2458
2459
2460
2461
2462
2463
2464
2465
2466
2467
2468
2469
2470
2471
2472









                                                                 
                             




                                                           
                         
                           
                       


                        
                          
                          


                              
                             
                         
                             
                     
 
  

                               
                                                             
 



                                    
  

                                                                        
                          

                               
                                       
                                            
                                         


                                      
                                                                           
                                                                
                                                                          
 
                                                               
                                                                     

  
  












                                                                           










                                                                     

                                                            
                                                         

 







                                                                          

                                            





                                                           
                                                       

                                                               






                                                              
                                                                  
                                                       

                                                                            
         


   
                                                                         



                                          
                                                                   


                                                                      
                                                          




                                                               
                                           









                                                                   
                                                                            





                                                                           
                                                         



                                                              
                                         


                                    
                                               
 



                                                        

 

                                                         
 
                                        
 
                                     
                                                 
                                

                                             

                                                   
           
                                       

 

















                                                                           

                              













                                                                               


                                                  





























                                                                          
   























                                                                               
 
                                                                              



                                                                    

                                            
                           


















                                                                           












                                                                          

                                                         
                                                   


                                    





                                                                          



                                                                           
           






                                                                           
                                  



                                                                         
                                                         





































                                                                             
                                             

                                  
                                                        
                                     
                                                                     


                                                              
                                                                              


                                     
 
                                                                               


                                     

                        





                                                                          
                                             
                                    

                                        
 



                                  
                       

                    
                   

                                      








                                                                           
                                       


































                                                                               





                                                         
                                      
                      

                                    

                           

                                      














                                                                          
   











                                                                              




                                            
                                     








                                                  

                                    






                                                                          


   

                                                                               


                                                                         





























                                                                           


                                                    

                                           

                                                    

                   





                                            



















































                                                                               

                                                               









                                                                         




                        






















                                                                           
                                                
















                                                                       
                                  

   
                                                       
                                                     








                                                                           


                                                                   


                                                       



                                                                        
                                                   






                                                                





                                                                 



























                                                                               
   













                                                                         
                                             

                                                                              

                      

                        
                                                                       




                                                                 




                                        





                                                              

                                 








                                                                       
                 









                                                                                 







                                                                          


                                                                 

                          


                                

 


























                                                                           

                                     




















                                                                           




                                                                       





                                                                      
                                                                
                                         



                                                   

                                     

                                                                 
 








                                                                      

                                                                     
                    
                                           







                                          
                            

                                
 
 
   

                                                             

               
                                                                    
                                                                   

                                                                    
   
                                                            
 



                                                                         
                                            
                      


  

                                                     
                                           
 
                                 
 
                                              
                                            
                                    

 
  








                                                                   
                                                    
                                                                           

                                                             













                                                                        



                                                              




                                                                        



                                                                             
                                                                           


                                                                              
                                                                       
 
                                        
                                   
 
                                                  
                                                                         

                                                      
                                                           


  
                                                                   
   
                                                                     
 
                                                             

 

                                                    
                                  

                                                                 
                                                                   



                                               







                                                                               
                                                             





                                                                  

                                 
  
                                                                        
                                      
   
                                                                
                                                                
                                         
                                                              
 

                                              

                                     
                                      
                            
                           
                      
 

                                                        

                                                                         

                                               
                                             
                                                       

                                                                 
                              
                                                   
                        

                                                                         

                                                 


                                            

         


                                                                          
                         

         

                                                      
                                              
                                                          
                                              
                                              
                                                                             
                 
         

                     



                                                       







                                                                
   
                                                                              
 
                  
 
                                           
                                                    


                                                                      

                                          
                                                  

 
                                                                          
 







                                                                     
                 
 
 
  

                                                                       
   


                                                           




                                                       

                                            

                                                    
                                          
         


  





























                                                                             





















                                                                               








                                                                 
























                                                                               
                                                   
                                              
                                                                        

                                                                      
                                                    



         


                                                                           

          
                                                                            
 
                                                         
                                            
                       

                
                                            
 

                                                                    

                                          


                                                                         


                                                                                
           
                                                              
                                                     



                                  




                                                                      
                                  
 
                                         

                                                                  
                                                    








                                                                             
                                 
















                                                                           
                                    
 

                                             
                                                                 
                                     
                                                  


                                  











                                                                              

                                                                
 
                                 











                                                                     


                                                                               
                   
                                                  


                                         





                                                                               
           
                                              

                                                                         

                                 
                                                
 
                                                   
 
                              

                                              
                                  



                                                                             
                                            
                                                    
                                    
                                   

                                    


                   
                                                          
                                                                

















                                                                              
              
                                                        
                                                                        



                                                               



                     
  
                                                      
  
                                                    



                                                         
   


                                                               
 




                                                                  
                                                         







                                                             
                                        
                                                              
                                             

                                        
                                       




                                                                            
                                                        







                                                                       
                              

                 
                  

                                                                               

                                                         
                                          
                                                                         
                                                    
                                                

                                 














                                                                                

                                            




                                                                             



                                                                            
                                                  

                                 
                                         
                                                         
 
                                                             

                                              
 



                                                                            
                                                      
 
                                       

                                                                













                                                                              




                                                                           
                                          
                                                    
                                
                                                   
                                           
                                            
 




                                                        








                                                                           
                 
         
                     

 

                                                                 
 

                                           
 
                                        
                                                              
                                                     
 
                                         
                          
                                                                       



                                                                            
                                 
                 
                                                           
                                       
 






                                                                               
         
                                                
                     

 
                                                                        
                                                      
 



                                               
                                         
          
                             
 
                              
                                  
                                  
                                    
                                         
                                    
                               
 

                                        
 

                                                         
  



                                                                               
  


                                                                          
  

                                                                               
   
                                                  
                                                        
 
                                         
                                       
                                 
                            
                      
                             
 

                                            
 
                              
                                  

                  
                                                                 
                   
                                        
                              
 
                  





                                                                      
                                                


                              

                                                                      
                   
                                                                   
                              
 





                                                                              
                                        
                                              
                                                                             
                                                
                                             
 
                                                
                                          
                                           
                             
                                                                           
                    
                                                                   
                                                  
 
                                                  

                  





                                                                            
                   
                             

                                 
                                              
                   
                                               
                              
                  



                                                            
                                                   
                                                       
                                                             
                                                  
                                                    

                                                           
                                                  

                 
                                    
                               
 
                                         


  
                                                                           
   
                                                                             
 
                                              
 


                                                     

                                                                  
         
                                       
                    

 





                                                                    

                                                         


                                      

                                                               
                                    





                                                       
                                                               







                                               




                                                             





                                                       





                                                                        
                                        
 
                       
                                                 



                                                       
                                                             

                  
                                               
         






                                                         
                                                     
 
                                       
                       
 
                                                  
                                                         
                                                        
 
                                               
 
                                                
 
                                    
                                    

                                                            





                                                         
                                               
                                                    





                                                                         
                                                             
   
                                        
 

                                                                             

                           
                                                            
                                       
 
                                                     
                                                           
                  
                                                                    
                                                                         
                                                                          
                                                            
                   
                    
                                                            
                                                                     
                                                      





                                                                           
                                                             
                                                                             
                                                             

         
                                        

                                                                 
                                      
 
                                        


  

                                                                          
   
                                                                 
 
                                     
 





                                                                            

                                                
 
                        

                                                           



                                           
                                                                    


                                                                                
                          

 























                                                                        
                                         
 
                                                                    

                                                           











                                                                               










                                                                               



























                                                                         
  








                                                                         
  





                                                                               
   
                                                       
 
                                                       
                                             


                                                       
 



                                                                  
                                                                       

                                                                
                                          
                                                            

                                                          
         


                                         

          

                                                                     


                 

                                                            




                                                     
                                  

                                                          


                                                               

                                             

                                                        







                                                                             
                                              





                                                                     
                                                  
                                                      
                 
                                               
                                              





                                                                            
                                                 
                                                     
                                                
 
                                                                     
 


                                                                       

                                                      

                                                                   
 
                                                                             
                                                          
                            
                                                               
 
                                                                         

                                                                           
                                                    
                                                                   
 





                                                                          

                                                                           
                               
                 
         

                                    
 
                    


                                  








                                                                                
                                                  
 
                             




                                                                    
                                                 
 
                                     

          

















                                                                                
           


                                                                                
                                                                 
 

















                                                                                
                                          
                                                                     
                                                    

                                                                
                                 
                 
                              
                                            
                                  
 





                                                                             


                               



                                                        
         

                                                  
                                       

 

                                                                              
 
                                           
                                         




                                                       
                                                 
          
                                                 
 
                                                                    
                       
                                                 
 
                                                              
                                           
 
















                                                                             




                                                                             
                                                        




                                                                             
                                                                       
 
                                                                        
 
                                   

   
                                                                          
                      

                                    
  
                                                                       

                                                

                                                                            
 
                                              
                             
 
                                                       
                               
                    
 
                                             

   
                                                                       
                      
                                                        
  
                                               

                                                
                                                                              
 
                                                                               
 
                                          

   
                                                   
                      

                                                                      
               
   
                                           
 
                                           
                                         



                                              
                                        
                                                 
                                    
          
                                                 
 





                                                                           
                       

                                                 
                                                 
                                           
 
                           
 
                              
 
   





                                                                             
  
                                                                               
   

                                                  

                                        
                                                               

                                       


                                                           
                                    

                      
                                                   















                                                                            
                                                  

                          

   
                                               


                                   
                                                                      












                                                                            
/*
 * fs/fs-writeback.c
 *
 * Copyright (C) 2002, Linus Torvalds.
 *
 * Contains all the functions related to writing back and waiting
 * upon dirty inodes against superblocks, and writing back dirty
 * pages against inodes.  ie: data writeback.  Writeout of the
 * inode itself is not handled here.
 *
 * 10Apr2002	Andrew Morton
 *		Split out of fs/inode.c
 *		Additions for address_space-based writeback
 */

#include <linux/kernel.h>
#include <linux/export.h>
#include <linux/spinlock.h>
#include <linux/slab.h>
#include <linux/sched.h>
#include <linux/fs.h>
#include <linux/mm.h>
#include <linux/pagemap.h>
#include <linux/kthread.h>
#include <linux/writeback.h>
#include <linux/blkdev.h>
#include <linux/backing-dev.h>
#include <linux/tracepoint.h>
#include <linux/device.h>
#include <linux/memcontrol.h>
#include "internal.h"

/*
 * 4MB minimal write chunk size
 */
#define MIN_WRITEBACK_PAGES	(4096UL >> (PAGE_SHIFT - 10))

struct wb_completion {
	atomic_t		cnt;
};

/*
 * Passed into wb_writeback(), essentially a subset of writeback_control
 */
struct wb_writeback_work {
	long nr_pages;
	struct super_block *sb;
	unsigned long *older_than_this;
	enum writeback_sync_modes sync_mode;
	unsigned int tagged_writepages:1;
	unsigned int for_kupdate:1;
	unsigned int range_cyclic:1;
	unsigned int for_background:1;
	unsigned int for_sync:1;	/* sync(2) WB_SYNC_ALL writeback */
	unsigned int auto_free:1;	/* free on completion */
	enum wb_reason reason;		/* why was writeback initiated? */

	struct list_head list;		/* pending work list */
	struct wb_completion *done;	/* set if the caller waits */
};

/*
 * If one wants to wait for one or more wb_writeback_works, each work's
 * ->done should be set to a wb_completion defined using the following
 * macro.  Once all work items are issued with wb_queue_work(), the caller
 * can wait for the completion of all using wb_wait_for_completion().  Work
 * items which are waited upon aren't freed automatically on completion.
 */
#define DEFINE_WB_COMPLETION_ONSTACK(cmpl)				\
	struct wb_completion cmpl = {					\
		.cnt		= ATOMIC_INIT(1),			\
	}


/*
 * If an inode is constantly having its pages dirtied, but then the
 * updates stop dirtytime_expire_interval seconds in the past, it's
 * possible for the worst case time between when an inode has its
 * timestamps updated and when they finally get written out to be two
 * dirtytime_expire_intervals.  We set the default to 12 hours (in
 * seconds), which means most of the time inodes will have their
 * timestamps written to disk after 12 hours, but in the worst case a
 * few inodes might not their timestamps updated for 24 hours.
 */
unsigned int dirtytime_expire_interval = 12 * 60 * 60;

static inline struct inode *wb_inode(struct list_head *head)
{
	return list_entry(head, struct inode, i_io_list);
}

/*
 * Include the creation of the trace points after defining the
 * wb_writeback_work structure and inline functions so that the definition
 * remains local to this file.
 */
#define CREATE_TRACE_POINTS
#include <trace/events/writeback.h>

EXPORT_TRACEPOINT_SYMBOL_GPL(wbc_writepage);

static bool wb_io_lists_populated(struct bdi_writeback *wb)
{
	if (wb_has_dirty_io(wb)) {
		return false;
	} else {
		set_bit(WB_has_dirty_io, &wb->state);
		WARN_ON_ONCE(!wb->avg_write_bandwidth);
		atomic_long_add(wb->avg_write_bandwidth,
				&wb->bdi->tot_write_bandwidth);
		return true;
	}
}

static void wb_io_lists_depopulated(struct bdi_writeback *wb)
{
	if (wb_has_dirty_io(wb) && list_empty(&wb->b_dirty) &&
	    list_empty(&wb->b_io) && list_empty(&wb->b_more_io)) {
		clear_bit(WB_has_dirty_io, &wb->state);
		WARN_ON_ONCE(atomic_long_sub_return(wb->avg_write_bandwidth,
					&wb->bdi->tot_write_bandwidth) < 0);
	}
}

/**
 * inode_io_list_move_locked - move an inode onto a bdi_writeback IO list
 * @inode: inode to be moved
 * @wb: target bdi_writeback
 * @head: one of @wb->b_{dirty|io|more_io}
 *
 * Move @inode->i_io_list to @list of @wb and set %WB_has_dirty_io.
 * Returns %true if @inode is the first occupant of the !dirty_time IO
 * lists; otherwise, %false.
 */
static bool inode_io_list_move_locked(struct inode *inode,
				      struct bdi_writeback *wb,
				      struct list_head *head)
{
	assert_spin_locked(&wb->list_lock);

	list_move(&inode->i_io_list, head);

	/* dirty_time doesn't count as dirty_io until expiration */
	if (head != &wb->b_dirty_time)
		return wb_io_lists_populated(wb);

	wb_io_lists_depopulated(wb);
	return false;
}

/**
 * inode_io_list_del_locked - remove an inode from its bdi_writeback IO list
 * @inode: inode to be removed
 * @wb: bdi_writeback @inode is being removed from
 *
 * Remove @inode which may be on one of @wb->b_{dirty|io|more_io} lists and
 * clear %WB_has_dirty_io if all are empty afterwards.
 */
static void inode_io_list_del_locked(struct inode *inode,
				     struct bdi_writeback *wb)
{
	assert_spin_locked(&wb->list_lock);

	list_del_init(&inode->i_io_list);
	wb_io_lists_depopulated(wb);
}

static void wb_wakeup(struct bdi_writeback *wb)
{
	spin_lock_bh(&wb->work_lock);
	if (test_bit(WB_registered, &wb->state))
		mod_delayed_work(bdi_wq, &wb->dwork, 0);
	spin_unlock_bh(&wb->work_lock);
}

static void wb_queue_work(struct bdi_writeback *wb,
			  struct wb_writeback_work *work)
{
	trace_writeback_queue(wb, work);

	spin_lock_bh(&wb->work_lock);
	if (!test_bit(WB_registered, &wb->state))
		goto out_unlock;
	if (work->done)
		atomic_inc(&work->done->cnt);
	list_add_tail(&work->list, &wb->work_list);
	mod_delayed_work(bdi_wq, &wb->dwork, 0);
out_unlock:
	spin_unlock_bh(&wb->work_lock);
}

/**
 * wb_wait_for_completion - wait for completion of bdi_writeback_works
 * @bdi: bdi work items were issued to
 * @done: target wb_completion
 *
 * Wait for one or more work items issued to @bdi with their ->done field
 * set to @done, which should have been defined with
 * DEFINE_WB_COMPLETION_ONSTACK().  This function returns after all such
 * work items are completed.  Work items which are waited upon aren't freed
 * automatically on completion.
 */
static void wb_wait_for_completion(struct backing_dev_info *bdi,
				   struct wb_completion *done)
{
	atomic_dec(&done->cnt);		/* put down the initial count */
	wait_event(bdi->wb_waitq, !atomic_read(&done->cnt));
}

#ifdef CONFIG_CGROUP_WRITEBACK

/* parameters for foreign inode detection, see wb_detach_inode() */
#define WB_FRN_TIME_SHIFT	13	/* 1s = 2^13, upto 8 secs w/ 16bit */
#define WB_FRN_TIME_AVG_SHIFT	3	/* avg = avg * 7/8 + new * 1/8 */
#define WB_FRN_TIME_CUT_DIV	2	/* ignore rounds < avg / 2 */
#define WB_FRN_TIME_PERIOD	(2 * (1 << WB_FRN_TIME_SHIFT))	/* 2s */

#define WB_FRN_HIST_SLOTS	16	/* inode->i_wb_frn_history is 16bit */
#define WB_FRN_HIST_UNIT	(WB_FRN_TIME_PERIOD / WB_FRN_HIST_SLOTS)
					/* each slot's duration is 2s / 16 */
#define WB_FRN_HIST_THR_SLOTS	(WB_FRN_HIST_SLOTS / 2)
					/* if foreign slots >= 8, switch */
#define WB_FRN_HIST_MAX_SLOTS	(WB_FRN_HIST_THR_SLOTS / 2 + 1)
					/* one round can affect upto 5 slots */

static atomic_t isw_nr_in_flight = ATOMIC_INIT(0);
static struct workqueue_struct *isw_wq;

void __inode_attach_wb(struct inode *inode, struct page *page)
{
	struct backing_dev_info *bdi = inode_to_bdi(inode);
	struct bdi_writeback *wb = NULL;

	if (inode_cgwb_enabled(inode)) {
		struct cgroup_subsys_state *memcg_css;

		if (page) {
			memcg_css = mem_cgroup_css_from_page(page);
			wb = wb_get_create(bdi, memcg_css, GFP_ATOMIC);
		} else {
			/* must pin memcg_css, see wb_get_create() */
			memcg_css = task_get_css(current, memory_cgrp_id);
			wb = wb_get_create(bdi, memcg_css, GFP_ATOMIC);
			css_put(memcg_css);
		}
	}

	if (!wb)
		wb = &bdi->wb;

	/*
	 * There may be multiple instances of this function racing to
	 * update the same inode.  Use cmpxchg() to tell the winner.
	 */
	if (unlikely(cmpxchg(&inode->i_wb, NULL, wb)))
		wb_put(wb);
}

/**
 * locked_inode_to_wb_and_lock_list - determine a locked inode's wb and lock it
 * @inode: inode of interest with i_lock held
 *
 * Returns @inode's wb with its list_lock held.  @inode->i_lock must be
 * held on entry and is released on return.  The returned wb is guaranteed
 * to stay @inode's associated wb until its list_lock is released.
 */
static struct bdi_writeback *
locked_inode_to_wb_and_lock_list(struct inode *inode)
	__releases(&inode->i_lock)
	__acquires(&wb->list_lock)
{
	while (true) {
		struct bdi_writeback *wb = inode_to_wb(inode);

		/*
		 * inode_to_wb() association is protected by both
		 * @inode->i_lock and @wb->list_lock but list_lock nests
		 * outside i_lock.  Drop i_lock and verify that the
		 * association hasn't changed after acquiring list_lock.
		 */
		wb_get(wb);
		spin_unlock(&inode->i_lock);
		spin_lock(&wb->list_lock);

		/* i_wb may have changed inbetween, can't use inode_to_wb() */
		if (likely(wb == inode->i_wb)) {
			wb_put(wb);	/* @inode already has ref */
			return wb;
		}

		spin_unlock(&wb->list_lock);
		wb_put(wb);
		cpu_relax();
		spin_lock(&inode->i_lock);
	}
}

/**
 * inode_to_wb_and_lock_list - determine an inode's wb and lock it
 * @inode: inode of interest
 *
 * Same as locked_inode_to_wb_and_lock_list() but @inode->i_lock isn't held
 * on entry.
 */
static struct bdi_writeback *inode_to_wb_and_lock_list(struct inode *inode)
	__acquires(&wb->list_lock)
{
	spin_lock(&inode->i_lock);
	return locked_inode_to_wb_and_lock_list(inode);
}

struct inode_switch_wbs_context {
	struct inode		*inode;
	struct bdi_writeback	*new_wb;

	struct rcu_head		rcu_head;
	struct work_struct	work;
};

static void inode_switch_wbs_work_fn(struct work_struct *work)
{
	struct inode_switch_wbs_context *isw =
		container_of(work, struct inode_switch_wbs_context, work);
	struct inode *inode = isw->inode;
	struct address_space *mapping = inode->i_mapping;
	struct bdi_writeback *old_wb = inode->i_wb;
	struct bdi_writeback *new_wb = isw->new_wb;
	struct radix_tree_iter iter;
	bool switched = false;
	void **slot;

	/*
	 * By the time control reaches here, RCU grace period has passed
	 * since I_WB_SWITCH assertion and all wb stat update transactions
	 * between unlocked_inode_to_wb_begin/end() are guaranteed to be
	 * synchronizing against mapping->tree_lock.
	 *
	 * Grabbing old_wb->list_lock, inode->i_lock and mapping->tree_lock
	 * gives us exclusion against all wb related operations on @inode
	 * including IO list manipulations and stat updates.
	 */
	if (old_wb < new_wb) {
		spin_lock(&old_wb->list_lock);
		spin_lock_nested(&new_wb->list_lock, SINGLE_DEPTH_NESTING);
	} else {
		spin_lock(&new_wb->list_lock);
		spin_lock_nested(&old_wb->list_lock, SINGLE_DEPTH_NESTING);
	}
	spin_lock(&inode->i_lock);
	spin_lock_irq(&mapping->tree_lock);

	/*
	 * Once I_FREEING is visible under i_lock, the eviction path owns
	 * the inode and we shouldn't modify ->i_io_list.
	 */
	if (unlikely(inode->i_state & I_FREEING))
		goto skip_switch;

	/*
	 * Count and transfer stats.  Note that PAGECACHE_TAG_DIRTY points
	 * to possibly dirty pages while PAGECACHE_TAG_WRITEBACK points to
	 * pages actually under underwriteback.
	 */
	radix_tree_for_each_tagged(slot, &mapping->page_tree, &iter, 0,
				   PAGECACHE_TAG_DIRTY) {
		struct page *page = radix_tree_deref_slot_protected(slot,
							&mapping->tree_lock);
		if (likely(page) && PageDirty(page)) {
			__dec_wb_stat(old_wb, WB_RECLAIMABLE);
			__inc_wb_stat(new_wb, WB_RECLAIMABLE);
		}
	}

	radix_tree_for_each_tagged(slot, &mapping->page_tree, &iter, 0,
				   PAGECACHE_TAG_WRITEBACK) {
		struct page *page = radix_tree_deref_slot_protected(slot,
							&mapping->tree_lock);
		if (likely(page)) {
			WARN_ON_ONCE(!PageWriteback(page));
			__dec_wb_stat(old_wb, WB_WRITEBACK);
			__inc_wb_stat(new_wb, WB_WRITEBACK);
		}
	}

	wb_get(new_wb);

	/*
	 * Transfer to @new_wb's IO list if necessary.  The specific list
	 * @inode was on is ignored and the inode is put on ->b_dirty which
	 * is always correct including from ->b_dirty_time.  The transfer
	 * preserves @inode->dirtied_when ordering.
	 */
	if (!list_empty(&inode->i_io_list)) {
		struct inode *pos;

		inode_io_list_del_locked(inode, old_wb);
		inode->i_wb = new_wb;
		list_for_each_entry(pos, &new_wb->b_dirty, i_io_list)
			if (time_after_eq(inode->dirtied_when,
					  pos->dirtied_when))
				break;
		inode_io_list_move_locked(inode, new_wb, pos->i_io_list.prev);
	} else {
		inode->i_wb = new_wb;
	}

	/* ->i_wb_frn updates may race wbc_detach_inode() but doesn't matter */
	inode->i_wb_frn_winner = 0;
	inode->i_wb_frn_avg_time = 0;
	inode->i_wb_frn_history = 0;
	switched = true;
skip_switch:
	/*
	 * Paired with load_acquire in unlocked_inode_to_wb_begin() and
	 * ensures that the new wb is visible if they see !I_WB_SWITCH.
	 */
	smp_store_release(&inode->i_state, inode->i_state & ~I_WB_SWITCH);

	spin_unlock_irq(&mapping->tree_lock);
	spin_unlock(&inode->i_lock);
	spin_unlock(&new_wb->list_lock);
	spin_unlock(&old_wb->list_lock);

	if (switched) {
		wb_wakeup(new_wb);
		wb_put(old_wb);
	}
	wb_put(new_wb);

	iput(inode);
	kfree(isw);

	atomic_dec(&isw_nr_in_flight);
}

static void inode_switch_wbs_rcu_fn(struct rcu_head *rcu_head)
{
	struct inode_switch_wbs_context *isw = container_of(rcu_head,
				struct inode_switch_wbs_context, rcu_head);

	/* needs to grab bh-unsafe locks, bounce to work item */
	INIT_WORK(&isw->work, inode_switch_wbs_work_fn);
	queue_work(isw_wq, &isw->work);
}

/**
 * inode_switch_wbs - change the wb association of an inode
 * @inode: target inode
 * @new_wb_id: ID of the new wb
 *
 * Switch @inode's wb association to the wb identified by @new_wb_id.  The
 * switching is performed asynchronously and may fail silently.
 */
static void inode_switch_wbs(struct inode *inode, int new_wb_id)
{
	struct backing_dev_info *bdi = inode_to_bdi(inode);
	struct cgroup_subsys_state *memcg_css;
	struct inode_switch_wbs_context *isw;

	/* noop if seems to be already in progress */
	if (inode->i_state & I_WB_SWITCH)
		return;

	isw = kzalloc(sizeof(*isw), GFP_ATOMIC);
	if (!isw)
		return;

	/* find and pin the new wb */
	rcu_read_lock();
	memcg_css = css_from_id(new_wb_id, &memory_cgrp_subsys);
	if (memcg_css)
		isw->new_wb = wb_get_create(bdi, memcg_css, GFP_ATOMIC);
	rcu_read_unlock();
	if (!isw->new_wb)
		goto out_free;

	/* while holding I_WB_SWITCH, no one else can update the association */
	spin_lock(&inode->i_lock);
	if (!(inode->i_sb->s_flags & MS_ACTIVE) ||
	    inode->i_state & (I_WB_SWITCH | I_FREEING) ||
	    inode_to_wb(inode) == isw->new_wb) {
		spin_unlock(&inode->i_lock);
		goto out_free;
	}
	inode->i_state |= I_WB_SWITCH;
	__iget(inode);
	spin_unlock(&inode->i_lock);

	isw->inode = inode;

	atomic_inc(&isw_nr_in_flight);

	/*
	 * In addition to synchronizing among switchers, I_WB_SWITCH tells
	 * the RCU protected stat update paths to grab the mapping's
	 * tree_lock so that stat transfer can synchronize against them.
	 * Let's continue after I_WB_SWITCH is guaranteed to be visible.
	 */
	call_rcu(&isw->rcu_head, inode_switch_wbs_rcu_fn);
	return;

out_free:
	if (isw->new_wb)
		wb_put(isw->new_wb);
	kfree(isw);
}

/**
 * wbc_attach_and_unlock_inode - associate wbc with target inode and unlock it
 * @wbc: writeback_control of interest
 * @inode: target inode
 *
 * @inode is locked and about to be written back under the control of @wbc.
 * Record @inode's writeback context into @wbc and unlock the i_lock.  On
 * writeback completion, wbc_detach_inode() should be called.  This is used
 * to track the cgroup writeback context.
 */
void wbc_attach_and_unlock_inode(struct writeback_control *wbc,
				 struct inode *inode)
{
	if (!inode_cgwb_enabled(inode)) {
		spin_unlock(&inode->i_lock);
		return;
	}

	wbc->wb = inode_to_wb(inode);
	wbc->inode = inode;

	wbc->wb_id = wbc->wb->memcg_css->id;
	wbc->wb_lcand_id = inode->i_wb_frn_winner;
	wbc->wb_tcand_id = 0;
	wbc->wb_bytes = 0;
	wbc->wb_lcand_bytes = 0;
	wbc->wb_tcand_bytes = 0;

	wb_get(wbc->wb);
	spin_unlock(&inode->i_lock);

	/*
	 * A dying wb indicates that the memcg-blkcg mapping has changed
	 * and a new wb is already serving the memcg.  Switch immediately.
	 */
	if (unlikely(wb_dying(wbc->wb)))
		inode_switch_wbs(inode, wbc->wb_id);
}

/**
 * wbc_detach_inode - disassociate wbc from inode and perform foreign detection
 * @wbc: writeback_control of the just finished writeback
 *
 * To be called after a writeback attempt of an inode finishes and undoes
 * wbc_attach_and_unlock_inode().  Can be called under any context.
 *
 * As concurrent write sharing of an inode is expected to be very rare and
 * memcg only tracks page ownership on first-use basis severely confining
 * the usefulness of such sharing, cgroup writeback tracks ownership
 * per-inode.  While the support for concurrent write sharing of an inode
 * is deemed unnecessary, an inode being written to by different cgroups at
 * different points in time is a lot more common, and, more importantly,
 * charging only by first-use can too readily lead to grossly incorrect
 * behaviors (single foreign page can lead to gigabytes of writeback to be
 * incorrectly attributed).
 *
 * To resolve this issue, cgroup writeback detects the majority dirtier of
 * an inode and transfers the ownership to it.  To avoid unnnecessary
 * oscillation, the detection mechanism keeps track of history and gives
 * out the switch verdict only if the foreign usage pattern is stable over
 * a certain amount of time and/or writeback attempts.
 *
 * On each writeback attempt, @wbc tries to detect the majority writer
 * using Boyer-Moore majority vote algorithm.  In addition to the byte
 * count from the majority voting, it also counts the bytes written for the
 * current wb and the last round's winner wb (max of last round's current
 * wb, the winner from two rounds ago, and the last round's majority
 * candidate).  Keeping track of the historical winner helps the algorithm
 * to semi-reliably detect the most active writer even when it's not the
 * absolute majority.
 *
 * Once the winner of the round is determined, whether the winner is
 * foreign or not and how much IO time the round consumed is recorded in
 * inode->i_wb_frn_history.  If the amount of recorded foreign IO time is
 * over a certain threshold, the switch verdict is given.
 */
void wbc_detach_inode(struct writeback_control *wbc)
{
	struct bdi_writeback *wb = wbc->wb;
	struct inode *inode = wbc->inode;
	unsigned long avg_time, max_bytes, max_time;
	u16 history;
	int max_id;

	if (!wb)
		return;

	history = inode->i_wb_frn_history;
	avg_time = inode->i_wb_frn_avg_time;

	/* pick the winner of this round */
	if (wbc->wb_bytes >= wbc->wb_lcand_bytes &&
	    wbc->wb_bytes >= wbc->wb_tcand_bytes) {
		max_id = wbc->wb_id;
		max_bytes = wbc->wb_bytes;
	} else if (wbc->wb_lcand_bytes >= wbc->wb_tcand_bytes) {
		max_id = wbc->wb_lcand_id;
		max_bytes = wbc->wb_lcand_bytes;
	} else {
		max_id = wbc->wb_tcand_id;
		max_bytes = wbc->wb_tcand_bytes;
	}

	/*
	 * Calculate the amount of IO time the winner consumed and fold it
	 * into the running average kept per inode.  If the consumed IO
	 * time is lower than avag / WB_FRN_TIME_CUT_DIV, ignore it for
	 * deciding whether to switch or not.  This is to prevent one-off
	 * small dirtiers from skewing the verdict.
	 */
	max_time = DIV_ROUND_UP((max_bytes >> PAGE_SHIFT) << WB_FRN_TIME_SHIFT,
				wb->avg_write_bandwidth);
	if (avg_time)
		avg_time += (max_time >> WB_FRN_TIME_AVG_SHIFT) -
			    (avg_time >> WB_FRN_TIME_AVG_SHIFT);
	else
		avg_time = max_time;	/* immediate catch up on first run */

	if (max_time >= avg_time / WB_FRN_TIME_CUT_DIV) {
		int slots;

		/*
		 * The switch verdict is reached if foreign wb's consume
		 * more than a certain proportion of IO time in a
		 * WB_FRN_TIME_PERIOD.  This is loosely tracked by 16 slot
		 * history mask where each bit represents one sixteenth of
		 * the period.  Determine the number of slots to shift into
		 * history from @max_time.
		 */
		slots = min(DIV_ROUND_UP(max_time, WB_FRN_HIST_UNIT),
			    (unsigned long)WB_FRN_HIST_MAX_SLOTS);
		history <<= slots;
		if (wbc->wb_id != max_id)
			history |= (1U << slots) - 1;

		/*
		 * Switch if the current wb isn't the consistent winner.
		 * If there are multiple closely competing dirtiers, the
		 * inode may switch across them repeatedly over time, which
		 * is okay.  The main goal is avoiding keeping an inode on
		 * the wrong wb for an extended period of time.
		 */
		if (hweight32(history) > WB_FRN_HIST_THR_SLOTS)
			inode_switch_wbs(inode, max_id);
	}

	/*
	 * Multiple instances of this function may race to update the
	 * following fields but we don't mind occassional inaccuracies.
	 */
	inode->i_wb_frn_winner = max_id;
	inode->i_wb_frn_avg_time = min(avg_time, (unsigned long)U16_MAX);
	inode->i_wb_frn_history = history;

	wb_put(wbc->wb);
	wbc->wb = NULL;
}

/**
 * wbc_account_io - account IO issued during writeback
 * @wbc: writeback_control of the writeback in progress
 * @page: page being written out
 * @bytes: number of bytes being written out
 *
 * @bytes from @page are about to written out during the writeback
 * controlled by @wbc.  Keep the book for foreign inode detection.  See
 * wbc_detach_inode().
 */
void wbc_account_io(struct writeback_control *wbc, struct page *page,
		    size_t bytes)
{
	int id;

	/*
	 * pageout() path doesn't attach @wbc to the inode being written
	 * out.  This is intentional as we don't want the function to block
	 * behind a slow cgroup.  Ultimately, we want pageout() to kick off
	 * regular writeback instead of writing things out itself.
	 */
	if (!wbc->wb)
		return;

	id = mem_cgroup_css_from_page(page)->id;

	if (id == wbc->wb_id) {
		wbc->wb_bytes += bytes;
		return;
	}

	if (id == wbc->wb_lcand_id)
		wbc->wb_lcand_bytes += bytes;

	/* Boyer-Moore majority vote algorithm */
	if (!wbc->wb_tcand_bytes)
		wbc->wb_tcand_id = id;
	if (id == wbc->wb_tcand_id)
		wbc->wb_tcand_bytes += bytes;
	else
		wbc->wb_tcand_bytes -= min(bytes, wbc->wb_tcand_bytes);
}
EXPORT_SYMBOL_GPL(wbc_account_io);

/**
 * inode_congested - test whether an inode is congested
 * @inode: inode to test for congestion (may be NULL)
 * @cong_bits: mask of WB_[a]sync_congested bits to test
 *
 * Tests whether @inode is congested.  @cong_bits is the mask of congestion
 * bits to test and the return value is the mask of set bits.
 *
 * If cgroup writeback is enabled for @inode, the congestion state is
 * determined by whether the cgwb (cgroup bdi_writeback) for the blkcg
 * associated with @inode is congested; otherwise, the root wb's congestion
 * state is used.
 *
 * @inode is allowed to be NULL as this function is often called on
 * mapping->host which is NULL for the swapper space.
 */