aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/buffer_head.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/linux/buffer_head.h')
0 files changed, 0 insertions, 0 deletions
0920f84ee06977165ebf32431fc2d2'>6193a2ff180
10cef602950

95b35127f13
10cef602950

1f0532eb617
10cef602950


afc0cedbe91
95b35127f13
02af61bb50f
4374e616d28
95b35127f13

95b35127f13







553948491c1
95b35127f13




10cef602950
95b35127f13
553948491c1
10cef602950

95b35127f13






























20cecbae445
95b35127f13
20cecbae445




95b35127f13

6e9ed0cc4b9
95b35127f13
6e9ed0cc4b9
95b35127f13
7303f240981
95b35127f13



7303f240981
95b35127f13



7303f240981
95b35127f13

6e9ed0cc4b9




95b35127f13




9023cb7e856
95b35127f13

20cecbae445
95b35127f13
20cecbae445
9023cb7e856
95b35127f13




9023cb7e856
95b35127f13

10cef602950



afc0cedbe91









95b35127f13


10cef602950
10cef602950
95b35127f13






bcb4ddb46a4
95b35127f13





10cef602950
95b35127f13
































6e9ed0cc4b9
6193a2ff180




6484eb3e2a8
6193a2ff180









6e9ed0cc4b9

1f0532eb617

6e9ed0cc4b9


95b35127f13



10cef602950
6e9ed0cc4b9
10cef602950
10cef602950
95b35127f13


10cef602950



95b35127f13


10cef602950
95b35127f13


10cef602950

95b35127f13
10cef602950

95b35127f13











10cef602950

95b35127f13


10cef602950

95b35127f13



10cef602950
95b35127f13


6193a2ff180
95b35127f13

d6269543ef2
20cecbae445
95b35127f13

10cef602950
20cecbae445






95b35127f13

20cecbae445
6193a2ff180







d6269543ef2


6193a2ff180
d6269543ef2








20cecbae445


d6269543ef2
10cef602950
95b35127f13



6e9ed0cc4b9
95b35127f13
6e9ed0cc4b9

95b35127f13






20cecbae445
95b35127f13



d07dbea4640

95b35127f13
10cef602950

95b35127f13


10cef602950

95b35127f13


10cef602950

2408c55037c
10cef602950
95b35127f13
10cef602950
6e9ed0cc4b9
95b35127f13
10cef602950
10cef602950
10cef602950
95b35127f13



6fb8f424393
95b35127f13

1f0532eb617
6fb8f424393
95b35127f13
10cef602950
95b35127f13






20cecbae445
95b35127f13







10cef602950
95b35127f13
679299b32db



95b35127f13








10cef602950
95b35127f13












10cef602950


95b35127f13



553948491c1







6193a2ff180
10cef602950
6cb8f91320d
553948491c1
3eae2cb24a9
553948491c1
19cefdffbfe
cf40bd16fda
553948491c1
6cb8f91320d


6193a2ff180
3eae2cb24a9
239f49c0800


3eae2cb24a9

ca2b84cb3c4

d87a133fc21
3eae2cb24a9
d87a133fc21
6e9ed0cc4b9
d87a133fc21




3eae2cb24a9
ca2b84cb3c4

10cef602950
3eae2cb24a9
4374e616d28
3eae2cb24a9
10cef602950
6193a2ff180
10cef602950


95b35127f13
10cef602950
2121db74ba0

2408c55037c
10cef602950
4374e616d28
10cef602950
6e9ed0cc4b9

553948491c1


d87a133fc21

10cef602950
10cef602950

d87a133fc21
fd76bab2fa6
10cef602950
95b35127f13
10cef602950
ef8b4520bd9

10cef602950

6e9ed0cc4b9

70096a561d1



d87a133fc21
10cef602950
b1aabecd559
10cef602950


afc0cedbe91
10cef602950
51cc50685a4
10cef602950


51cc50685a4
10cef602950


0701a9e649b
5e18e2b8b3d
10cef602950



afc0cedbe91
afc0cedbe91



10cef602950
10cef602950
5af60839909
553948491c1

10cef602950

bc0055aee40

10cef602950
4374e616d28
10cef602950



133d205a18b
10cef602950
4374e616d28
7ed9f7e5db5

10cef602950
10cef602950


6193a2ff180
10cef602950


3eae2cb24a9
6193a2ff180
ca2b84cb3c4


3eae2cb24a9
6e9ed0cc4b9
ca2b84cb3c4


3eae2cb24a9
10cef602950

51cc50685a4
10cef602950
4374e616d28
10cef602950

6193a2ff180
10cef602950
afc0cedbe91
10cef602950
afc0cedbe91

10cef602950
6e9ed0cc4b9
afc0cedbe91











4374e616d28
afc0cedbe91






afc0cedbe91

3eae2cb24a9
ca2b84cb3c4
10cef602950














2e892f43ccb





55935a34a42
2e892f43ccb



84a01c2f8ea






bcb4ddb46a4

84a01c2f8ea
10cef602950
bbff2e433e8




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




                                          

                                    



                                                                   

                                                                          
  










                                                                      

                                                                    
                                                                         
                                                                   
                                                                      



                                                                             

                                                                     



                                                                         
                                                                      
                                                                       

                                                                  



                                                                         
                                                                        







                                                                           

   
                         

                       
                                                  


                         
                           
                       
                            
                           

                       







                                                                          
                            




                      
                   
                        
  

                                 






























                                                                               
                                                   
   




                                   

  
                                                                   
   
                                                    
 
                                           



                                                      
                                         



                                                        
                                           

 




                                                           




                                                          
                                               

 
                                                                            
 
                                  
                                             




                                                             
                                               

 



                                                             









                                                                          


                                                    
                                  
 






                                                                
 





                                     
 
































                                                                
                                                           




                       
                                                                









                                               

                                               

                                                                     


                                            



                                                                          
 
                                            
                                                
 


                                                                               



                                                                             


                                                                
                                                                          


                                                                       

                                              
                                                        

                         











                                                                                      

                         


                                                         

                                   



                                    
 


                                                   
                                                                    

                             
                               
                                    

                            
 






                                              

                                                                        
                                                  







                                                                        


                                                 
 








                                                                       


                                                              
                      
         



                                                        
                                                               
                       

                                    






                                                                              
                                                  



                                                          

                                              
                 

 


                                                  

                                            


                                                  

                            
                                              
                       
                      
 
                              
                                 
 
                                             
 



                                                                               
                                                          

                                    
                                      
                       
         
 






                                                                             
                                                         







                                                                            
 
                           



                                                       








                                               
 












                                                                 


                                                  



                                                                             







                                                        
                                                      
 
                        
                                                                   
                  
 
                                 
 
                                       


                                             
                                                               
 


                                    

                                        

                                                                  
                
                                                     
 
                                                                              




                                                 
 

                                                                        
         
 
                                          
                   
 
                              


                             
                             
 

                                     
                                              
                       
                             
 

                               


                                                                           

                                    
 

                     
                                                               
                               
 
                             
 

                                             

                         

                               



                                                                           
                                        
 
                     


                                 
                            
                         
                             


                                                                   
                                                                


                             
                                                 
                                                       



                               
                                                  



                                                                            
                               
                                                         
                                                                         

                                                      

                                         

                                                             
 
                                                                    



                                 
                                             
 
                         

                                           
                                                


                                  
                                                                        


                
                                  
                                                               


                                                                            
                
                                                                    


                                                                            
         

                    
                           
 
                                                                 

                 
                                     
 
                                                
 

                                   
            
                                                    











                                                                                
                                             






                                                                   

                                              
 
                                           














                                                  





                                           
                                                          



                 






                                             

                                 
                       
 




                                      
/*
 * SLOB Allocator: Simple List Of Blocks
 *
 * Matt Mackall <mpm@selenic.com> 12/30/03
 *
 * NUMA support by Paul Mundt, 2007.
 *
 * How SLOB works:
 *
 * The core of SLOB is a traditional K&R style heap allocator, with
 * support for returning aligned objects. The granularity of this
 * allocator is as little as 2 bytes, however typically most architectures
 * will require 4 bytes on 32-bit and 8 bytes on 64-bit.
 *
 * The slob heap is a set of linked list of pages from alloc_pages(),
 * and within each page, there is a singly-linked list of free blocks
 * (slob_t). The heap is grown on demand. To reduce fragmentation,
 * heap pages are segregated into three lists, with objects less than
 * 256 bytes, objects less than 1024 bytes, and all other objects.
 *
 * Allocation from heap involves first searching for a page with
 * sufficient free blocks (using a next-fit-like approach) followed by
 * a first-fit scan of the page. Deallocation inserts objects back
 * into the free list in address order, so this is effectively an
 * address-ordered first fit.
 *
 * Above this is an implementation of kmalloc/kfree. Blocks returned
 * from kmalloc are prepended with a 4-byte header with the kmalloc size.
 * If kmalloc is asked for objects of PAGE_SIZE or larger, it calls
 * alloc_pages() directly, allocating compound pages so the page order
 * does not have to be separately tracked, and also stores the exact
 * allocation size in page->private so that it can be used to accurately
 * provide ksize(). These objects are detected in kfree() because slob_page()
 * is false for them.
 *
 * SLAB is emulated on top of SLOB by simply calling constructors and
 * destructors for every SLAB allocation. Objects are returned with the
 * 4-byte alignment unless the SLAB_HWCACHE_ALIGN flag is set, in which
 * case the low-level allocator will fragment blocks to create the proper
 * alignment. Again, objects of page-size or greater are allocated by
 * calling alloc_pages(). As SLAB objects know their size, no separate
 * size bookkeeping is necessary and there is essentially no allocation
 * space overhead, and compound pages aren't needed for multi-page
 * allocations.
 *
 * NUMA support in SLOB is fairly simplistic, pushing most of the real
 * logic down to the page allocator, and simply doing the node accounting
 * on the upper levels. In the event that a node id is explicitly
 * provided, alloc_pages_exact_node() with the specified node id is used
 * instead. The common case (or when the node id isn't explicitly provided)
 * will default to the current node, as per numa_node_id().
 *
 * Node aware pages are still inserted in to the global freelist, and
 * these are scanned for by matching against the node id encoded in the
 * page flags. As a result, block allocations that can be satisfied from
 * the freelist will only be done so on pages residing on the same node,
 * in order to prevent random node placement.
 */

#include <linux/kernel.h>
#include <linux/slab.h>
#include <linux/mm.h>
#include <linux/swap.h> /* struct reclaim_state */
#include <linux/cache.h>
#include <linux/init.h>
#include <linux/module.h>
#include <linux/rcupdate.h>
#include <linux/list.h>
#include <linux/kmemtrace.h>
#include <linux/kmemleak.h>
#include <asm/atomic.h>

/*
 * slob_block has a field 'units', which indicates size of block if +ve,
 * or offset of next block if -ve (in SLOB_UNITs).
 *
 * Free blocks of size 1 unit simply contain the offset of the next block.
 * Those with larger size contain their size in the first SLOB_UNIT of
 * memory, and the offset of the next free block in the second SLOB_UNIT.
 */
#if PAGE_SIZE <= (32767 * 2)
typedef s16 slobidx_t;
#else
typedef s32 slobidx_t;
#endif

struct slob_block {
	slobidx_t units;
};
typedef struct slob_block slob_t;

/*
 * We use struct page fields to manage some slob allocation aspects,
 * however to avoid the horrible mess in include/linux/mm_types.h, we'll
 * just define our own struct page type variant here.
 */
struct slob_page {
	union {
		struct {
			unsigned long flags;	/* mandatory */
			atomic_t _count;	/* mandatory */
			slobidx_t units;	/* free units left in page */
			unsigned long pad[2];
			slob_t *free;		/* first free slob_t in page */
			struct list_head list;	/* linked list of free pages */
		};
		struct page page;
	};
};
static inline void struct_slob_page_wrong_size(void)
{ BUILD_BUG_ON(sizeof(struct slob_page) != sizeof(struct page)); }

/*
 * free_slob_page: call before a slob_page is returned to the page allocator.
 */
static inline void free_slob_page(struct slob_page *sp)
{
	reset_page_mapcount(&sp->page);
	sp->page.mapping = NULL;
}

/*
 * All partially free slob pages go on these lists.
 */
#define SLOB_BREAK1 256
#define SLOB_BREAK2 1024
static LIST_HEAD(free_slob_small);
static LIST_HEAD(free_slob_medium);
static LIST_HEAD(free_slob_large);

/*
 * is_slob_page: True for all slob pages (false for bigblock pages)
 */
static inline int is_slob_page(struct slob_page *sp)
{
	return PageSlab((struct page *)sp);
}

static inline void set_slob_page(struct slob_page *sp)
{
	__SetPageSlab((struct page *)sp);
}

static inline void clear_slob_page(struct slob_page *sp)
{
	__ClearPageSlab((struct page *)sp);
}

static inline struct slob_page *slob_page(const void *addr)
{
	return (struct slob_page *)virt_to_page(addr);
}

/*
 * slob_page_free: true for pages on free_slob_pages list.
 */
static inline int slob_page_free(struct slob_page *sp)
{
	return PageSlobFree((struct page *)sp);
}

static void set_slob_page_free(struct slob_page *sp, struct list_head *list)
{
	list_add(&sp->list, list);
	__SetPageSlobFree((struct page *)sp);
}

static inline void clear_slob_page_free(struct slob_page *sp)
{
	list_del(&sp->list);
	__ClearPageSlobFree((struct page *)sp);
}

#define SLOB_UNIT sizeof(slob_t)
#define SLOB_UNITS(size) (((size) + SLOB_UNIT - 1)/SLOB_UNIT)
#define SLOB_ALIGN L1_CACHE_BYTES

/*
 * struct slob_rcu is inserted at the tail of allocated slob blocks, which
 * were created with a SLAB_DESTROY_BY_RCU slab. slob_rcu is used to free
 * the block using call_rcu.
 */
struct slob_rcu {
	struct rcu_head head;
	int size;
};

/*
 * slob_lock protects all slob allocator structures.
 */
static DEFINE_SPINLOCK(slob_lock);

/*
 * Encode the given size and next info into a free slob block s.
 */
static void set_slob(slob_t *s, slobidx_t size, slob_t *next)
{
	slob_t *base = (slob_t *)((unsigned long)s & PAGE_MASK);
	slobidx_t offset = next - base;

	if (size > 1) {
		s[0].units = size;
		s[1].units = offset;
	} else
		s[0].units = -offset;
}

/*
 * Return the size of a slob block.
 */
static slobidx_t slob_units(slob_t *s)
{
	if (s->units > 0)
		return s->units;
	return 1;
}

/*
 * Return the next free slob block pointer after this one.
 */
static slob_t *slob_next(slob_t *s)
{
	slob_t *base = (slob_t *)((unsigned long)s & PAGE_MASK);
	slobidx_t next;

	if (s[0].units < 0)
		next = -s[0].units;
	else
		next = s[1].units;
	return base+next;
}

/*
 * Returns true if s is the last free block in its page.
 */
static int slob_last(slob_t *s)
{
	return !((unsigned long)slob_next(s) & ~PAGE_MASK);
}

static void *slob_new_pages(gfp_t gfp, int order, int node)
{
	void *page;

#ifdef CONFIG_NUMA
	if (node != -1)
		page = alloc_pages_exact_node(node, gfp, order);
	else
#endif
		page = alloc_pages(gfp, order);

	if (!page)
		return NULL;

	return page_address(page);
}

static void slob_free_pages(void *b, int order)
{
	if (current->reclaim_state)
		current->reclaim_state->reclaimed_slab += 1 << order;
	free_pages((unsigned long)b, order);
}

/*
 * Allocate a slob block within a given slob_page sp.
 */
static void *slob_page_alloc(struct slob_page *sp, size_t size, int align)
{
	slob_t *prev, *cur, *aligned = NULL;
	int delta = 0, units = SLOB_UNITS(size);

	for (prev = NULL, cur = sp->free; ; prev = cur, cur = slob_next(cur)) {
		slobidx_t avail = slob_units(cur);

		if (align) {
			aligned = (slob_t *)ALIGN((unsigned long)cur, align);
			delta = aligned - cur;
		}
		if (avail >= units + delta) { /* room enough? */
			slob_t *next;

			if (delta) { /* need to fragment head to align? */
				next = slob_next(cur);
				set_slob(aligned, avail - delta, next);