]>
Commit | Line | Data |
---|---|---|
a9479f04 AM |
1 | /* |
2 | * (C) Copyright 2013 | |
3 | * Afzal Mohammed <[email protected]> | |
4 | * | |
5 | * Reference: dfu_mmc.c | |
6 | * Copyright (C) 2012 Samsung Electronics | |
7 | * author: Lukasz Majewski <[email protected]> | |
8 | * | |
9 | * SPDX-License-Identifier: GPL-2.0+ | |
10 | */ | |
11 | ||
12 | #include <common.h> | |
13 | #include <malloc.h> | |
14 | #include <errno.h> | |
15 | #include <dfu.h> | |
16 | ||
17 | static int dfu_transfer_medium_ram(enum dfu_op op, struct dfu_entity *dfu, | |
18 | u64 offset, void *buf, long *len) | |
19 | { | |
20 | if (dfu->layout != DFU_RAM_ADDR) { | |
9b643e31 | 21 | pr_err("unsupported layout: %s\n", dfu_get_layout(dfu->layout)); |
a9479f04 AM |
22 | return -EINVAL; |
23 | } | |
24 | ||
25 | if (offset > dfu->data.ram.size) { | |
9b643e31 | 26 | pr_err("request exceeds allowed area\n"); |
a9479f04 AM |
27 | return -EINVAL; |
28 | } | |
29 | ||
30 | if (op == DFU_OP_WRITE) | |
31 | memcpy(dfu->data.ram.start + offset, buf, *len); | |
32 | else | |
33 | memcpy(buf, dfu->data.ram.start + offset, *len); | |
34 | ||
35 | return 0; | |
36 | } | |
37 | ||
38 | static int dfu_write_medium_ram(struct dfu_entity *dfu, u64 offset, | |
39 | void *buf, long *len) | |
40 | { | |
41 | return dfu_transfer_medium_ram(DFU_OP_WRITE, dfu, offset, buf, len); | |
42 | } | |
43 | ||
15970d87 | 44 | int dfu_get_medium_size_ram(struct dfu_entity *dfu, u64 *size) |
0e285b50 | 45 | { |
4de51201 PD |
46 | *size = dfu->data.ram.size; |
47 | ||
48 | return 0; | |
0e285b50 SW |
49 | } |
50 | ||
a9479f04 AM |
51 | static int dfu_read_medium_ram(struct dfu_entity *dfu, u64 offset, |
52 | void *buf, long *len) | |
53 | { | |
a9479f04 AM |
54 | return dfu_transfer_medium_ram(DFU_OP_READ, dfu, offset, buf, len); |
55 | } | |
56 | ||
dd64827e | 57 | int dfu_fill_entity_ram(struct dfu_entity *dfu, char *devstr, char *s) |
a9479f04 | 58 | { |
e1b0f6fe M |
59 | const char *argv[3]; |
60 | const char **parg = argv; | |
61 | ||
62 | for (; parg < argv + sizeof(argv) / sizeof(*argv); ++parg) { | |
63 | *parg = strsep(&s, " "); | |
64 | if (*parg == NULL) { | |
9b643e31 | 65 | pr_err("Invalid number of arguments.\n"); |
e1b0f6fe M |
66 | return -ENODEV; |
67 | } | |
68 | } | |
a9479f04 AM |
69 | |
70 | dfu->dev_type = DFU_DEV_RAM; | |
e1b0f6fe | 71 | if (strcmp(argv[0], "ram")) { |
9b643e31 | 72 | pr_err("unsupported device: %s\n", argv[0]); |
a9479f04 AM |
73 | return -ENODEV; |
74 | } | |
75 | ||
76 | dfu->layout = DFU_RAM_ADDR; | |
3517de6d SW |
77 | dfu->data.ram.start = (void *)simple_strtoul(argv[1], NULL, 16); |
78 | dfu->data.ram.size = simple_strtoul(argv[2], NULL, 16); | |
a9479f04 AM |
79 | |
80 | dfu->write_medium = dfu_write_medium_ram; | |
0e285b50 | 81 | dfu->get_medium_size = dfu_get_medium_size_ram; |
a9479f04 AM |
82 | dfu->read_medium = dfu_read_medium_ram; |
83 | ||
84 | dfu->inited = 0; | |
85 | ||
86 | return 0; | |
87 | } |