Blame view

api/api_platform-powerpc.c 1.22 KB
d41ce506b   Eric Lee   Initial Release, ...
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
  /*
   * (C) Copyright 2007 Semihalf
   *
   * Written by: Rafal Jaworowski <raj@semihalf.com>
   *
   * SPDX-License-Identifier:	GPL-2.0+
   *
   * This file contains routines that fetch data from PowerPC-dependent sources
   * (bd_info etc.)
   */
  
  #include <config.h>
  #include <linux/types.h>
  #include <api_public.h>
  
  #include <asm/u-boot.h>
  #include <asm/global_data.h>
  
  #include "api_private.h"
  
  DECLARE_GLOBAL_DATA_PTR;
  
  /*
   * Important notice: handling of individual fields MUST be kept in sync with
   * include/asm-ppc/u-boot.h and include/asm-ppc/global_data.h, so any changes
   * need to reflect their current state and layout of structures involved!
   */
  int platform_sys_info(struct sys_info *si)
  {
  	si->clk_bus = gd->bus_clk;
  	si->clk_cpu = gd->cpu_clk;
  
  #if defined(CONFIG_8xx) || defined(CONFIG_E500) || defined(CONFIG_MPC86xx)
  #define bi_bar	bi_immr_base
  #elif defined(CONFIG_MPC83xx)
  #define bi_bar	bi_immrbar
  #endif
  
  #if defined(bi_bar)
  	si->bar = gd->bd->bi_bar;
  #undef bi_bar
  #else
  	si->bar = 0;
  #endif
  
  	platform_set_mr(si, gd->bd->bi_memstart, gd->bd->bi_memsize, MR_ATTR_DRAM);
  	platform_set_mr(si, gd->bd->bi_flashstart, gd->bd->bi_flashsize, MR_ATTR_FLASH);
  	platform_set_mr(si, gd->bd->bi_sramstart, gd->bd->bi_sramsize, MR_ATTR_SRAM);
  
  	return 1;
  }