Blame view

kernel/linux-rt-4.4.41/arch/powerpc/platforms/cell/spufs/lscsa_alloc.c 1.59 KB
5113f6f70   김현기   kernel add
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
  /*
   * SPU local store allocation routines
   *
   * Copyright 2007 Benjamin Herrenschmidt, IBM Corp.
   *
   * This program is free software; you can redistribute it and/or modify
   * it under the terms of the GNU General Public License as published by
   * the Free Software Foundation; either version 2, or (at your option)
   * any later version.
   *
   * This program is distributed in the hope that it will be useful,
   * but WITHOUT ANY WARRANTY; without even the implied warranty of
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   * GNU General Public License for more details.
   *
   * You should have received a copy of the GNU General Public License
   * along with this program; if not, write to the Free Software
   * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
   */
  
  #undef DEBUG
  
  #include <linux/kernel.h>
  #include <linux/mm.h>
  #include <linux/slab.h>
  #include <linux/vmalloc.h>
  
  #include <asm/spu.h>
  #include <asm/spu_csa.h>
  #include <asm/mmu.h>
  
  #include "spufs.h"
  
  int spu_alloc_lscsa(struct spu_state *csa)
  {
  	struct spu_lscsa *lscsa;
  	unsigned char *p;
  
  	lscsa = vzalloc(sizeof(struct spu_lscsa));
  	if (!lscsa)
  		return -ENOMEM;
  	csa->lscsa = lscsa;
  
  	/* Set LS pages reserved to allow for user-space mapping. */
  	for (p = lscsa->ls; p < lscsa->ls + LS_SIZE; p += PAGE_SIZE)
  		SetPageReserved(vmalloc_to_page(p));
  
  	return 0;
  }
  
  void spu_free_lscsa(struct spu_state *csa)
  {
  	/* Clear reserved bit before vfree. */
  	unsigned char *p;
  
  	if (csa->lscsa == NULL)
  		return;
  
  	for (p = csa->lscsa->ls; p < csa->lscsa->ls + LS_SIZE; p += PAGE_SIZE)
  		ClearPageReserved(vmalloc_to_page(p));
  
  	vfree(csa->lscsa);
  }