dfu_ram.c 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. /*
  2. * (C) Copyright 2013
  3. * Afzal Mohammed <afzal.mohd.ma@gmail.com>
  4. *
  5. * Reference: dfu_mmc.c
  6. * Copyright (C) 2012 Samsung Electronics
  7. * author: Lukasz Majewski <l.majewski@samsung.com>
  8. *
  9. * SPDX-License-Identifier: GPL-2.0+
  10. */
  11. #include <common.h>
  12. #include <malloc.h>
  13. #include <errno.h>
  14. #include <dfu.h>
  15. static int dfu_transfer_medium_ram(enum dfu_op op, struct dfu_entity *dfu,
  16. u64 offset, void *buf, long *len)
  17. {
  18. if (dfu->layout != DFU_RAM_ADDR) {
  19. error("unsupported layout: %s\n", dfu_get_layout(dfu->layout));
  20. return -EINVAL;
  21. }
  22. if (offset > dfu->data.ram.size) {
  23. error("request exceeds allowed area\n");
  24. return -EINVAL;
  25. }
  26. if (op == DFU_OP_WRITE)
  27. memcpy(dfu->data.ram.start + offset, buf, *len);
  28. else
  29. memcpy(buf, dfu->data.ram.start + offset, *len);
  30. return 0;
  31. }
  32. static int dfu_write_medium_ram(struct dfu_entity *dfu, u64 offset,
  33. void *buf, long *len)
  34. {
  35. return dfu_transfer_medium_ram(DFU_OP_WRITE, dfu, offset, buf, len);
  36. }
  37. long dfu_get_medium_size_ram(struct dfu_entity *dfu)
  38. {
  39. return dfu->data.ram.size;
  40. }
  41. static int dfu_read_medium_ram(struct dfu_entity *dfu, u64 offset,
  42. void *buf, long *len)
  43. {
  44. return dfu_transfer_medium_ram(DFU_OP_READ, dfu, offset, buf, len);
  45. }
  46. int dfu_fill_entity_ram(struct dfu_entity *dfu, char *devstr, char *s)
  47. {
  48. const char *argv[3];
  49. const char **parg = argv;
  50. for (; parg < argv + sizeof(argv) / sizeof(*argv); ++parg) {
  51. *parg = strsep(&s, " ");
  52. if (*parg == NULL) {
  53. error("Invalid number of arguments.\n");
  54. return -ENODEV;
  55. }
  56. }
  57. dfu->dev_type = DFU_DEV_RAM;
  58. if (strcmp(argv[0], "ram")) {
  59. error("unsupported device: %s\n", argv[0]);
  60. return -ENODEV;
  61. }
  62. dfu->layout = DFU_RAM_ADDR;
  63. dfu->data.ram.start = (void *)simple_strtoul(argv[1], NULL, 16);
  64. dfu->data.ram.size = simple_strtoul(argv[2], NULL, 16);
  65. dfu->write_medium = dfu_write_medium_ram;
  66. dfu->get_medium_size = dfu_get_medium_size_ram;
  67. dfu->read_medium = dfu_read_medium_ram;
  68. dfu->inited = 0;
  69. return 0;
  70. }