blob: 11747ca4a4ebc037e3be876d3894d84bb5f4b335 [file] [log] [blame]
roy zang4978adf2006-11-02 18:59:15 +08001/*
2 * (C) Copyright 2005 Freescale Semiconductor, Inc.
3 *
4 * Roy Zang <tie-fei.zang@freescale.com>
5 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02006 * SPDX-License-Identifier: GPL-2.0+
roy zang4978adf2006-11-02 18:59:15 +08007 *
8 * modifications for the Tsi108 Emul Board by avb@Tundra
9 */
10
11/*
roy zang92dda872006-12-01 11:47:36 +080012 * board support/init functions for the
roy zang4978adf2006-11-02 18:59:15 +080013 * Freescale MPC7448 HPC2 (High-Performance Computing 2 Platform).
14 */
15
16#include <common.h>
17#include <74xx_7xx.h>
Gerald Van Barenfcd91bb2008-06-03 20:34:45 -040018#include <fdt_support.h>
Ben Warren04e97e02008-08-31 09:59:33 -070019#include <netdev.h>
roy zang4978adf2006-11-02 18:59:15 +080020
21#undef DEBUG
22
Wolfgang Denkd112a2c2007-09-15 20:48:41 +020023DECLARE_GLOBAL_DATA_PTR;
24
roy zang92dda872006-12-01 11:47:36 +080025extern void tsi108_init_f (void);
roy zang4978adf2006-11-02 18:59:15 +080026
roy zang92dda872006-12-01 11:47:36 +080027int display_mem_map (void);
roy zang4978adf2006-11-02 18:59:15 +080028
roy zang92dda872006-12-01 11:47:36 +080029void after_reloc (ulong dest_addr)
roy zang4978adf2006-11-02 18:59:15 +080030{
roy zang4978adf2006-11-02 18:59:15 +080031 /*
32 * Jump to the main U-Boot board init code
33 */
roy zang92dda872006-12-01 11:47:36 +080034 board_init_r ((gd_t *) gd, dest_addr);
roy zang4978adf2006-11-02 18:59:15 +080035 /* NOTREACHED */
36}
37
38/*
39 * Check Board Identity:
roy zang4978adf2006-11-02 18:59:15 +080040 * report board type
41 */
42
roy zang92dda872006-12-01 11:47:36 +080043int checkboard (void)
roy zang4978adf2006-11-02 18:59:15 +080044{
45 int l_type = 0;
46
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020047 printf ("BOARD: %s\n", CONFIG_SYS_BOARD_NAME);
roy zang4978adf2006-11-02 18:59:15 +080048 return (l_type);
49}
50
51/*
52 * Read Processor ID:
53 *
54 * report calling processor number
55 */
56
roy zang92dda872006-12-01 11:47:36 +080057int read_pid (void)
roy zang4978adf2006-11-02 18:59:15 +080058{
59 return 0; /* we are on single CPU platform for a while */
60}
61
roy zang92dda872006-12-01 11:47:36 +080062long int dram_size (int board_type)
roy zang4978adf2006-11-02 18:59:15 +080063{
64 return 0x20000000; /* 256M bytes */
65}
66
Becky Brucebd99ae72008-06-09 16:03:40 -050067phys_size_t initdram (int board_type)
roy zang4978adf2006-11-02 18:59:15 +080068{
roy zang92dda872006-12-01 11:47:36 +080069 return dram_size (board_type);
roy zang4978adf2006-11-02 18:59:15 +080070}
71
Gerald Van Baren84714ba2008-06-03 20:24:58 -040072#if defined(CONFIG_OF_BOARD_SETUP)
Simon Glass2aec3cc2014-10-23 18:58:47 -060073int ft_board_setup(void *blob, bd_t *bd)
Gerald Van Baren84714ba2008-06-03 20:24:58 -040074{
75 ft_cpu_setup(blob, bd);
76 fdt_fixup_memory(blob, (u64)bd->bi_memstart, (u64)bd->bi_memsize);
Simon Glass2aec3cc2014-10-23 18:58:47 -060077
78 return 0;
Gerald Van Baren84714ba2008-06-03 20:24:58 -040079}
80#endif
Ben Warren04e97e02008-08-31 09:59:33 -070081
82int board_eth_init(bd_t *bis)
83{
84 int rc = 0;
85#if defined(CONFIG_TSI108_ETH)
86 rc = tsi108_eth_initialize(bis);
87#endif
88 return rc;
89}