]> Git Repo - J-u-boot.git/blame - common/cmd_bmp.c
ipu common: reset ipuv3 correctly
[J-u-boot.git] / common / cmd_bmp.c
CommitLineData
059ae173
WD
1/*
2 * (C) Copyright 2002
b37c7e5e 3 * Detlev Zundel, DENX Software Engineering, [email protected].
059ae173
WD
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 * BMP handling routines
26 */
27
28#include <common.h>
6111722a 29#include <lcd.h>
059ae173
WD
30#include <bmp_layout.h>
31#include <command.h>
8655b6f8 32#include <asm/byteorder.h>
c29ab9d7 33#include <malloc.h>
059ae173 34
059ae173 35static int bmp_info (ulong addr);
059ae173 36
43ef1c38
HCE
37/*
38 * Allocate and decompress a BMP image using gunzip().
39 *
40 * Returns a pointer to the decompressed image data. Must be freed by
41 * the caller after use.
42 *
43 * Returns NULL if decompression failed, or if the decompressed data
44 * didn't contain a valid BMP signature.
45 */
46#ifdef CONFIG_VIDEO_BMP_GZIP
c01171ea 47bmp_image_t *gunzip_bmp(unsigned long addr, unsigned long *lenp)
43ef1c38
HCE
48{
49 void *dst;
50 unsigned long len;
51 bmp_image_t *bmp;
52
53 /*
54 * Decompress bmp image
55 */
6d0f6bcf
JCPV
56 len = CONFIG_SYS_VIDEO_LOGO_MAX_SIZE;
57 dst = malloc(CONFIG_SYS_VIDEO_LOGO_MAX_SIZE);
43ef1c38
HCE
58 if (dst == NULL) {
59 puts("Error: malloc in gunzip failed!\n");
60 return NULL;
61 }
6d0f6bcf 62 if (gunzip(dst, CONFIG_SYS_VIDEO_LOGO_MAX_SIZE, (uchar *)addr, &len) != 0) {
43ef1c38
HCE
63 free(dst);
64 return NULL;
65 }
6d0f6bcf 66 if (len == CONFIG_SYS_VIDEO_LOGO_MAX_SIZE)
43ef1c38 67 puts("Image could be truncated"
6d0f6bcf 68 " (increase CONFIG_SYS_VIDEO_LOGO_MAX_SIZE)!\n");
43ef1c38
HCE
69
70 bmp = dst;
71
72 /*
73 * Check for bmp mark 'BM'
74 */
75 if (!((bmp->header.signature[0] == 'B') &&
76 (bmp->header.signature[1] == 'M'))) {
77 free(dst);
78 return NULL;
79 }
80
17f79e45 81 debug("Gzipped BMP image detected!\n");
43ef1c38
HCE
82
83 return bmp;
84}
85#else
c01171ea 86bmp_image_t *gunzip_bmp(unsigned long addr, unsigned long *lenp)
43ef1c38
HCE
87{
88 return NULL;
89}
90#endif
91
54841ab5 92static int do_bmp_info(cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[])
9acd4f0e
FM
93{
94 ulong addr;
43ef1c38 95
9acd4f0e
FM
96 switch (argc) {
97 case 1: /* use load_addr as default address */
98 addr = load_addr;
99 break;
100 case 2: /* use argument */
101 addr = simple_strtoul(argv[1], NULL, 16);
102 break;
103 default:
4c12eeb8 104 return CMD_RET_USAGE;
9acd4f0e
FM
105 }
106
107 return (bmp_info(addr));
108}
109
54841ab5 110static int do_bmp_display(cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[])
059ae173
WD
111{
112 ulong addr;
4b248f3f 113 int x = 0, y = 0;
059ae173
WD
114
115 switch (argc) {
9acd4f0e 116 case 1: /* use load_addr as default address */
059ae173
WD
117 addr = load_addr;
118 break;
9acd4f0e
FM
119 case 2: /* use argument */
120 addr = simple_strtoul(argv[1], NULL, 16);
059ae173 121 break;
9acd4f0e
FM
122 case 4:
123 addr = simple_strtoul(argv[1], NULL, 16);
124 x = simple_strtoul(argv[2], NULL, 10);
125 y = simple_strtoul(argv[3], NULL, 10);
4b248f3f 126 break;
059ae173 127 default:
4c12eeb8 128 return CMD_RET_USAGE;
059ae173
WD
129 }
130
9acd4f0e
FM
131 return (bmp_display(addr, x, y));
132}
133
134static cmd_tbl_t cmd_bmp_sub[] = {
135 U_BOOT_CMD_MKENT(info, 3, 0, do_bmp_info, "", ""),
136 U_BOOT_CMD_MKENT(display, 5, 0, do_bmp_display, "", ""),
137};
138
2e5167cc 139#ifdef CONFIG_NEEDS_MANUAL_RELOC
f1d2b313
HS
140void bmp_reloc(void) {
141 fixup_cmdtable(cmd_bmp_sub, ARRAY_SIZE(cmd_bmp_sub));
142}
143#endif
144
9acd4f0e
FM
145/*
146 * Subroutine: do_bmp
147 *
148 * Description: Handler for 'bmp' command..
149 *
150 * Inputs: argv[1] contains the subcommand
151 *
152 * Return: None
153 *
154 */
54841ab5 155static int do_bmp(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
9acd4f0e
FM
156{
157 cmd_tbl_t *c;
158
159 /* Strip off leading 'bmp' command argument */
160 argc--;
161 argv++;
162
163 c = find_cmd_tbl(argv[0], &cmd_bmp_sub[0], ARRAY_SIZE(cmd_bmp_sub));
164
47e26b1b 165 if (c)
9acd4f0e 166 return c->cmd(cmdtp, flag, argc, argv);
47e26b1b 167 else
4c12eeb8 168 return CMD_RET_USAGE;
059ae173
WD
169}
170
0d498393 171U_BOOT_CMD(
4b248f3f 172 bmp, 5, 1, do_bmp,
2fb2604d 173 "manipulate BMP image data",
4b248f3f 174 "info <imageAddr> - display image info\n"
a89c33db 175 "bmp display <imageAddr> [x y] - display image at x,y"
b0fce99b
WD
176);
177
059ae173
WD
178/*
179 * Subroutine: bmp_info
180 *
181 * Description: Show information about bmp file in memory
182 *
183 * Inputs: addr address of the bmp file
184 *
185 * Return: None
186 *
187 */
188static int bmp_info(ulong addr)
189{
190 bmp_image_t *bmp=(bmp_image_t *)addr;
43ef1c38 191 unsigned long len;
c29ab9d7 192
059ae173 193 if (!((bmp->header.signature[0]=='B') &&
43ef1c38
HCE
194 (bmp->header.signature[1]=='M')))
195 bmp = gunzip_bmp(addr, &len);
c29ab9d7 196
43ef1c38 197 if (bmp == NULL) {
059ae173 198 printf("There is no valid bmp file at the given address\n");
43ef1c38 199 return 1;
059ae173 200 }
43ef1c38 201
059ae173
WD
202 printf("Image size : %d x %d\n", le32_to_cpu(bmp->header.width),
203 le32_to_cpu(bmp->header.height));
204 printf("Bits per pixel: %d\n", le16_to_cpu(bmp->header.bit_count));
205 printf("Compression : %d\n", le32_to_cpu(bmp->header.compression));
c29ab9d7 206
43ef1c38
HCE
207 if ((unsigned long)bmp != addr)
208 free(bmp);
c29ab9d7 209
059ae173
WD
210 return(0);
211}
212
213/*
214 * Subroutine: bmp_display
215 *
216 * Description: Display bmp file located in memory
217 *
218 * Inputs: addr address of the bmp file
219 *
220 * Return: None
221 *
222 */
de3b49c4 223int bmp_display(ulong addr, int x, int y)
059ae173 224{
43ef1c38
HCE
225 int ret;
226 bmp_image_t *bmp = (bmp_image_t *)addr;
227 unsigned long len;
228
229 if (!((bmp->header.signature[0]=='B') &&
230 (bmp->header.signature[1]=='M')))
231 bmp = gunzip_bmp(addr, &len);
232
233 if (!bmp) {
234 printf("There is no valid bmp file at the given address\n");
235 return 1;
236 }
237
281e00a3 238#if defined(CONFIG_LCD)
02110903 239 ret = lcd_display_bitmap((ulong)bmp, x, y);
281e00a3 240#elif defined(CONFIG_VIDEO)
4b248f3f 241 extern int video_display_bitmap (ulong, int, int);
43ef1c38
HCE
242
243 ret = video_display_bitmap ((unsigned long)bmp, x, y);
281e00a3
WD
244#else
245# error bmp_display() requires CONFIG_LCD or CONFIG_VIDEO
4b248f3f 246#endif
43ef1c38
HCE
247
248 if ((unsigned long)bmp != addr)
249 free(bmp);
250
251 return ret;
059ae173 252}
This page took 0.250692 seconds and 4 git commands to generate.