xref: /rk3399_rockchip-uboot/drivers/dfu/dfu_ram.c (revision 90aa625c9a9e1fb7a2f001fd8e50099bacaf92b8)
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 
dfu_transfer_medium_ram(enum dfu_op op,struct dfu_entity * dfu,u64 offset,void * buf,long * len)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) {
21*90aa625cSMasahiro Yamada 		pr_err("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) {
26*90aa625cSMasahiro Yamada 		pr_err("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 
dfu_write_medium_ram(struct dfu_entity * dfu,u64 offset,void * buf,long * len)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 
dfu_get_medium_size_ram(struct dfu_entity * dfu,u64 * size)4415970d87SPatrick Delaunay int dfu_get_medium_size_ram(struct dfu_entity *dfu, u64 *size)
450e285b50SStephen Warren {
464de51201SPatrick Delaunay 	*size = dfu->data.ram.size;
474de51201SPatrick Delaunay 
484de51201SPatrick Delaunay 	return 0;
490e285b50SStephen Warren }
500e285b50SStephen Warren 
dfu_read_medium_ram(struct dfu_entity * dfu,u64 offset,void * buf,long * len)51a9479f04SAfzal Mohammed static int dfu_read_medium_ram(struct dfu_entity *dfu, u64 offset,
52a9479f04SAfzal Mohammed 			       void *buf, long *len)
53a9479f04SAfzal Mohammed {
54a9479f04SAfzal Mohammed 	return dfu_transfer_medium_ram(DFU_OP_READ, dfu, offset, buf, len);
55a9479f04SAfzal Mohammed }
56a9479f04SAfzal Mohammed 
dfu_fill_entity_ram(struct dfu_entity * dfu,char * devstr,char * s)57dd64827eSStephen Warren int dfu_fill_entity_ram(struct dfu_entity *dfu, char *devstr, char *s)
58a9479f04SAfzal Mohammed {
59e1b0f6feSMugunthan V N 	const char *argv[3];
60e1b0f6feSMugunthan V N 	const char **parg = argv;
61e1b0f6feSMugunthan V N 
62e1b0f6feSMugunthan V N 	for (; parg < argv + sizeof(argv) / sizeof(*argv); ++parg) {
63e1b0f6feSMugunthan V N 		*parg = strsep(&s, " ");
64e1b0f6feSMugunthan V N 		if (*parg == NULL) {
65*90aa625cSMasahiro Yamada 			pr_err("Invalid number of arguments.\n");
66e1b0f6feSMugunthan V N 			return -ENODEV;
67e1b0f6feSMugunthan V N 		}
68e1b0f6feSMugunthan V N 	}
69a9479f04SAfzal Mohammed 
70a9479f04SAfzal Mohammed 	dfu->dev_type = DFU_DEV_RAM;
71e1b0f6feSMugunthan V N 	if (strcmp(argv[0], "ram")) {
72*90aa625cSMasahiro Yamada 		pr_err("unsupported device: %s\n", argv[0]);
73a9479f04SAfzal Mohammed 		return -ENODEV;
74a9479f04SAfzal Mohammed 	}
75a9479f04SAfzal Mohammed 
76a9479f04SAfzal Mohammed 	dfu->layout = DFU_RAM_ADDR;
773517de6dSStephen Warren 	dfu->data.ram.start = (void *)simple_strtoul(argv[1], NULL, 16);
783517de6dSStephen Warren 	dfu->data.ram.size = simple_strtoul(argv[2], NULL, 16);
79a9479f04SAfzal Mohammed 
80a9479f04SAfzal Mohammed 	dfu->write_medium = dfu_write_medium_ram;
810e285b50SStephen Warren 	dfu->get_medium_size = dfu_get_medium_size_ram;
82a9479f04SAfzal Mohammed 	dfu->read_medium = dfu_read_medium_ram;
83a9479f04SAfzal Mohammed 
84a9479f04SAfzal Mohammed 	dfu->inited = 0;
85a9479f04SAfzal Mohammed 
86a9479f04SAfzal Mohammed 	return 0;
87a9479f04SAfzal Mohammed }
88