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