blob: 9fae61473b375ffc2c3a9c6ab4242a47b8370f10 [file] [log] [blame]
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +09001/*
2 * (C) Copyright 2007
3 * Nobuhiro Iwamatsu <iwamatsu@nigauri.org>
4 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02005 * SPDX-License-Identifier: GPL-2.0+
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +09006 */
7
8#include <common.h>
9#include <command.h>
Nobuhiro Iwamatsufe771152009-02-27 18:35:41 +090010#include <netdev.h>
Nobuhiro Iwamatsu547b67f2007-09-23 02:12:30 +090011#include <asm/processor.h>
Nobuhiro Iwamatsu65335f82008-03-12 12:15:29 +090012#include <asm/cache.h>
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090013
14int checkcpu(void)
15{
Yoshihiro Shimoda1d013192012-07-23 14:53:42 +000016#ifdef CONFIG_SH4A
17 puts("CPU: SH-4A\n");
18#else
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090019 puts("CPU: SH4\n");
Yoshihiro Shimoda1d013192012-07-23 14:53:42 +000020#endif
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090021 return 0;
22}
23
24int cpu_init (void)
25{
26 return 0;
27}
28
29int cleanup_before_linux (void)
30{
31 disable_interrupts();
32 return 0;
33}
34
Wolfgang Denk6262d0212010-06-28 22:00:46 +020035int do_reset (cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090036{
37 disable_interrupts();
38 reset_cpu (0);
39 return 0;
40}
41
Nobuhiro Iwamatsu547b67f2007-09-23 02:12:30 +090042void flush_cache (unsigned long addr, unsigned long size)
43{
Nobuhiro Iwamatsu65335f82008-03-12 12:15:29 +090044 dcache_invalid_range( addr , addr + size );
Nobuhiro Iwamatsu547b67f2007-09-23 02:12:30 +090045}
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090046
47void icache_enable (void)
48{
Nobuhiro Iwamatsu547b67f2007-09-23 02:12:30 +090049 cache_control(0);
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090050}
51
52void icache_disable (void)
53{
Nobuhiro Iwamatsu547b67f2007-09-23 02:12:30 +090054 cache_control(1);
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090055}
56
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090057int icache_status (void)
58{
Wolfgang Denk0a5c2142007-12-27 01:52:50 +010059 return 0;
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090060}
Nobuhiro Iwamatsu547b67f2007-09-23 02:12:30 +090061
62void dcache_enable (void)
63{
64}
65
66void dcache_disable (void)
67{
68}
69
70int dcache_status (void)
71{
72 return 0;
73}
Nobuhiro Iwamatsud8f5d502008-11-21 12:04:18 +090074
75int cpu_eth_init(bd_t *bis)
76{
77#ifdef CONFIG_SH_ETHER
78 sh_eth_initialize(bis);
79#endif
80 return 0;
81}