powerpc/p5040: enable NAND, SD, SPI boot support
[platform/kernel/u-boot.git] / common / cmd_cache.c
1 /*
2  * (C) Copyright 2000
3  * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4  *
5  * See file CREDITS for list of people who contributed to this
6  * project.
7  *
8  * This program is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU General Public License as
10  * published by the Free Software Foundation; either version 2 of
11  * the License, or (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21  * MA 02111-1307 USA
22  */
23
24 /*
25  * Cache support: switch on or off, get status
26  */
27 #include <common.h>
28 #include <command.h>
29 #include <linux/compiler.h>
30
31 static int parse_argv(const char *);
32
33 void __weak invalidate_icache_all(void)
34 {
35         /* please define arch specific invalidate_icache_all */
36         puts("No arch specific invalidate_icache_all available!\n");
37 }
38
39 int do_icache(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
40 {
41         switch (argc) {
42         case 2:                 /* on / off     */
43                 switch (parse_argv(argv[1])) {
44                 case 0:
45                         icache_disable();
46                         break;
47                 case 1:
48                         icache_enable();
49                         break;
50                 case 2:
51                         invalidate_icache_all();
52                         break;
53                 }
54                 break;
55         case 1:                 /* get status */
56                 printf("Instruction Cache is %s\n",
57                         icache_status() ? "ON" : "OFF");
58                 return 0;
59         default:
60                 return CMD_RET_USAGE;
61         }
62         return 0;
63 }
64
65 void __weak flush_dcache_all(void)
66 {
67         puts("No arch specific flush_dcache_all available!\n");
68         /* please define arch specific flush_dcache_all */
69 }
70
71 int do_dcache(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
72 {
73         switch (argc) {
74         case 2:                 /* on / off */
75                 switch (parse_argv(argv[1])) {
76                 case 0:
77                         dcache_disable();
78                         break;
79                 case 1:
80                         dcache_enable();
81                         break;
82                 case 2:
83                         flush_dcache_all();
84                         break;
85                 }
86                 break;
87         case 1:                 /* get status */
88                 printf("Data (writethrough) Cache is %s\n",
89                         dcache_status() ? "ON" : "OFF");
90                 return 0;
91         default:
92                 return CMD_RET_USAGE;
93         }
94         return 0;
95 }
96
97 static int parse_argv(const char *s)
98 {
99         if (strcmp(s, "flush") == 0)
100                 return 2;
101         else if (strcmp(s, "on") == 0)
102                 return 1;
103         else if (strcmp(s, "off") == 0)
104                 return 0;
105
106         return -1;
107 }
108
109
110 U_BOOT_CMD(
111         icache,   2,   1,     do_icache,
112         "enable or disable instruction cache",
113         "[on, off, flush]\n"
114         "    - enable, disable, or flush instruction cache"
115 );
116
117 U_BOOT_CMD(
118         dcache,   2,   1,     do_dcache,
119         "enable or disable data cache",
120         "[on, off, flush]\n"
121         "    - enable, disable, or flush data (writethrough) cache"
122 );