Blame view

arch/mips/power/cpu.c 863 Bytes
363c55cae   Wu Zhangjin   MIPS: Add hiberna...
1
2
3
4
5
  /*
   * Suspend support specific for mips.
   *
   * Licensed under the GPLv2
   *
f7a904dff   Wu Zhangjin   MIPS: Loongson: C...
6
   * Copyright (C) 2009 Lemote Inc.
363c55cae   Wu Zhangjin   MIPS: Add hiberna...
7
   * Author: Hu Hongbing <huhb@lemote.com>
f7a904dff   Wu Zhangjin   MIPS: Loongson: C...
8
   *         Wu Zhangjin <wuzhangjin@gmail.com>
363c55cae   Wu Zhangjin   MIPS: Add hiberna...
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
   */
  #include <asm/suspend.h>
  #include <asm/fpu.h>
  #include <asm/dsp.h>
  
  static u32 saved_status;
  struct pt_regs saved_regs;
  
  void save_processor_state(void)
  {
  	saved_status = read_c0_status();
  
  	if (is_fpu_owner())
  		save_fp(current);
  	if (cpu_has_dsp)
  		save_dsp(current);
  }
  
  void restore_processor_state(void)
  {
  	write_c0_status(saved_status);
  
  	if (is_fpu_owner())
  		restore_fp(current);
  	if (cpu_has_dsp)
  		restore_dsp(current);
  }
  
  int pfn_is_nosave(unsigned long pfn)
  {
  	unsigned long nosave_begin_pfn = PFN_DOWN(__pa(&__nosave_begin));
  	unsigned long nosave_end_pfn = PFN_UP(__pa(&__nosave_end));
  
  	return	(pfn >= nosave_begin_pfn) && (pfn < nosave_end_pfn);
  }