xref: /rk3399_rockchip-uboot/drivers/dfu/dfu_ram.c (revision 0e285b503c41bb53f6ef962e6f9c942c1ca47cc6)
1a9479f04SAfzal Mohammed /*
2a9479f04SAfzal Mohammed  * (C) Copyright 2013
3a9479f04SAfzal Mohammed  * Afzal Mohammed <afzal.mohd.ma@gmail.com>
4a9479f04SAfzal Mohammed  *
5a9479f04SAfzal Mohammed  * Reference: dfu_mmc.c
6a9479f04SAfzal Mohammed  * Copyright (C) 2012 Samsung Electronics
7a9479f04SAfzal Mohammed  * author: Lukasz Majewski <l.majewski@samsung.com>
8a9479f04SAfzal Mohammed  *
9a9479f04SAfzal Mohammed  * SPDX-License-Identifier:	GPL-2.0+
10a9479f04SAfzal Mohammed  */
11a9479f04SAfzal Mohammed 
12a9479f04SAfzal Mohammed #include <common.h>
13a9479f04SAfzal Mohammed #include <malloc.h>
14a9479f04SAfzal Mohammed #include <errno.h>
15a9479f04SAfzal Mohammed #include <dfu.h>
16a9479f04SAfzal Mohammed 
17a9479f04SAfzal Mohammed static int dfu_transfer_medium_ram(enum dfu_op op, struct dfu_entity *dfu,
18a9479f04SAfzal Mohammed 				   u64 offset, void *buf, long *len)
19a9479f04SAfzal Mohammed {
20a9479f04SAfzal Mohammed 	if (dfu->layout != DFU_RAM_ADDR) {
21a9479f04SAfzal Mohammed 		error("unsupported layout: %s\n", dfu_get_layout(dfu->layout));
22a9479f04SAfzal Mohammed 		return  -EINVAL;
23a9479f04SAfzal Mohammed 	}
24a9479f04SAfzal Mohammed 
25a9479f04SAfzal Mohammed 	if (offset > dfu->data.ram.size) {
26a9479f04SAfzal Mohammed 		error("request exceeds allowed area\n");
27a9479f04SAfzal Mohammed 		return -EINVAL;
28a9479f04SAfzal Mohammed 	}
29a9479f04SAfzal Mohammed 
30a9479f04SAfzal Mohammed 	if (op == DFU_OP_WRITE)
31a9479f04SAfzal Mohammed 		memcpy(dfu->data.ram.start + offset, buf, *len);
32a9479f04SAfzal Mohammed 	else
33a9479f04SAfzal Mohammed 		memcpy(buf, dfu->data.ram.start + offset, *len);
34a9479f04SAfzal Mohammed 
35a9479f04SAfzal Mohammed 	return 0;
36a9479f04SAfzal Mohammed }
37a9479f04SAfzal Mohammed 
38a9479f04SAfzal Mohammed static int dfu_write_medium_ram(struct dfu_entity *dfu, u64 offset,
39a9479f04SAfzal Mohammed 				void *buf, long *len)
40a9479f04SAfzal Mohammed {
41a9479f04SAfzal Mohammed 	return dfu_transfer_medium_ram(DFU_OP_WRITE, dfu, offset, buf, len);
42a9479f04SAfzal Mohammed }
43a9479f04SAfzal Mohammed 
44*0e285b50SStephen Warren long dfu_get_medium_size_ram(struct dfu_entity *dfu)
45*0e285b50SStephen Warren {
46*0e285b50SStephen Warren 	return dfu->data.ram.size;
47*0e285b50SStephen Warren }
48*0e285b50SStephen Warren 
49a9479f04SAfzal Mohammed static int dfu_read_medium_ram(struct dfu_entity *dfu, u64 offset,
50a9479f04SAfzal Mohammed 			       void *buf, long *len)
51a9479f04SAfzal Mohammed {
52a9479f04SAfzal Mohammed 	return dfu_transfer_medium_ram(DFU_OP_READ, dfu, offset, buf, len);
53a9479f04SAfzal Mohammed }
54a9479f04SAfzal Mohammed 
55a9479f04SAfzal Mohammed int dfu_fill_entity_ram(struct dfu_entity *dfu, char *s)
56a9479f04SAfzal Mohammed {
57a9479f04SAfzal Mohammed 	char *st;
58a9479f04SAfzal Mohammed 
59a9479f04SAfzal Mohammed 	dfu->dev_type = DFU_DEV_RAM;
60a9479f04SAfzal Mohammed 	st = strsep(&s, " ");
61a9479f04SAfzal Mohammed 	if (strcmp(st, "ram")) {
62a9479f04SAfzal Mohammed 		error("unsupported device: %s\n", st);
63a9479f04SAfzal Mohammed 		return -ENODEV;
64a9479f04SAfzal Mohammed 	}
65a9479f04SAfzal Mohammed 
66a9479f04SAfzal Mohammed 	dfu->layout = DFU_RAM_ADDR;
67a9479f04SAfzal Mohammed 	dfu->data.ram.start = (void *)simple_strtoul(s, &s, 16);
68a9479f04SAfzal Mohammed 	s++;
69a9479f04SAfzal Mohammed 	dfu->data.ram.size = simple_strtoul(s, &s, 16);
70a9479f04SAfzal Mohammed 
71a9479f04SAfzal Mohammed 	dfu->write_medium = dfu_write_medium_ram;
72*0e285b50SStephen Warren 	dfu->get_medium_size = dfu_get_medium_size_ram;
73a9479f04SAfzal Mohammed 	dfu->read_medium = dfu_read_medium_ram;
74a9479f04SAfzal Mohammed 
75a9479f04SAfzal Mohammed 	dfu->inited = 0;
76a9479f04SAfzal Mohammed 
77a9479f04SAfzal Mohammed 	return 0;
78a9479f04SAfzal Mohammed }
79