xref: /rk3399_rockchip-uboot/drivers/dfu/dfu_ram.c (revision 3517de6d26de7baeddb2c9e9bf145456c35885e1)
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 
440e285b50SStephen Warren long dfu_get_medium_size_ram(struct dfu_entity *dfu)
450e285b50SStephen Warren {
460e285b50SStephen Warren 	return dfu->data.ram.size;
470e285b50SStephen Warren }
480e285b50SStephen 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 
55dd64827eSStephen Warren int dfu_fill_entity_ram(struct dfu_entity *dfu, char *devstr, char *s)
56a9479f04SAfzal Mohammed {
57e1b0f6feSMugunthan V N 	const char *argv[3];
58e1b0f6feSMugunthan V N 	const char **parg = argv;
59e1b0f6feSMugunthan V N 
60e1b0f6feSMugunthan V N 	for (; parg < argv + sizeof(argv) / sizeof(*argv); ++parg) {
61e1b0f6feSMugunthan V N 		*parg = strsep(&s, " ");
62e1b0f6feSMugunthan V N 		if (*parg == NULL) {
63e1b0f6feSMugunthan V N 			error("Invalid number of arguments.\n");
64e1b0f6feSMugunthan V N 			return -ENODEV;
65e1b0f6feSMugunthan V N 		}
66e1b0f6feSMugunthan V N 	}
67a9479f04SAfzal Mohammed 
68a9479f04SAfzal Mohammed 	dfu->dev_type = DFU_DEV_RAM;
69e1b0f6feSMugunthan V N 	if (strcmp(argv[0], "ram")) {
70e1b0f6feSMugunthan V N 		error("unsupported device: %s\n", argv[0]);
71a9479f04SAfzal Mohammed 		return -ENODEV;
72a9479f04SAfzal Mohammed 	}
73a9479f04SAfzal Mohammed 
74a9479f04SAfzal Mohammed 	dfu->layout = DFU_RAM_ADDR;
75*3517de6dSStephen Warren 	dfu->data.ram.start = (void *)simple_strtoul(argv[1], NULL, 16);
76*3517de6dSStephen Warren 	dfu->data.ram.size = simple_strtoul(argv[2], NULL, 16);
77a9479f04SAfzal Mohammed 
78a9479f04SAfzal Mohammed 	dfu->write_medium = dfu_write_medium_ram;
790e285b50SStephen Warren 	dfu->get_medium_size = dfu_get_medium_size_ram;
80a9479f04SAfzal Mohammed 	dfu->read_medium = dfu_read_medium_ram;
81a9479f04SAfzal Mohammed 
82a9479f04SAfzal Mohammed 	dfu->inited = 0;
83a9479f04SAfzal Mohammed 
84a9479f04SAfzal Mohammed 	return 0;
85a9479f04SAfzal Mohammed }
86