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