Ohad Ben-Cohen | 400e64d | 2011-10-20 16:52:46 +0200 | [diff] [blame] | 1 | /* |
| 2 | * Remote processor framework |
| 3 | * |
| 4 | * Copyright (C) 2011 Texas Instruments, Inc. |
| 5 | * Copyright (C) 2011 Google, Inc. |
| 6 | * |
| 7 | * Ohad Ben-Cohen <ohad@wizery.com> |
| 8 | * Brian Swetland <swetland@google.com> |
| 9 | * |
| 10 | * This software is licensed under the terms of the GNU General Public |
| 11 | * License version 2, as published by the Free Software Foundation, and |
| 12 | * may be copied, distributed, and modified under those terms. |
| 13 | * |
| 14 | * This program is distributed in the hope that it will be useful, |
| 15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 17 | * GNU General Public License for more details. |
| 18 | */ |
| 19 | |
| 20 | #ifndef REMOTEPROC_INTERNAL_H |
| 21 | #define REMOTEPROC_INTERNAL_H |
| 22 | |
| 23 | #include <linux/irqreturn.h> |
Sjur Brændeland | 72854fb | 2012-07-15 11:25:27 +0300 | [diff] [blame] | 24 | #include <linux/firmware.h> |
Ohad Ben-Cohen | 400e64d | 2011-10-20 16:52:46 +0200 | [diff] [blame] | 25 | |
| 26 | struct rproc; |
| 27 | |
Sjur Brændeland | 4afc89d | 2012-06-19 10:08:18 +0300 | [diff] [blame] | 28 | /** |
| 29 | * struct rproc_fw_ops - firmware format specific operations. |
Sjur Brændeland | 95f9578 | 2013-02-21 18:15:34 +0100 | [diff] [blame] | 30 | * @find_rsc_table: find the resource table inside the firmware image |
| 31 | * @find_loaded_rsc_table: find the loaded resouce table |
Sjur Brændeland | 4afc89d | 2012-06-19 10:08:18 +0300 | [diff] [blame] | 32 | * @load: load firmeware to memory, where the remote processor |
| 33 | * expects to find it |
| 34 | * @sanity_check: sanity check the fw image |
| 35 | * @get_boot_addr: get boot address to entry point specified in firmware |
| 36 | */ |
| 37 | struct rproc_fw_ops { |
Suman Anna | 172e6ab | 2015-02-27 17:18:23 -0600 | [diff] [blame] | 38 | struct resource_table *(*find_rsc_table)(struct rproc *rproc, |
Sjur Brændeland | 4afc89d | 2012-06-19 10:08:18 +0300 | [diff] [blame] | 39 | const struct firmware *fw, |
| 40 | int *tablesz); |
Sjur Brændeland | 95f9578 | 2013-02-21 18:15:34 +0100 | [diff] [blame] | 41 | struct resource_table *(*find_loaded_rsc_table)(struct rproc *rproc, |
| 42 | const struct firmware *fw); |
Sjur Brændeland | 4afc89d | 2012-06-19 10:08:18 +0300 | [diff] [blame] | 43 | int (*load)(struct rproc *rproc, const struct firmware *fw); |
| 44 | int (*sanity_check)(struct rproc *rproc, const struct firmware *fw); |
| 45 | u32 (*get_boot_addr)(struct rproc *rproc, const struct firmware *fw); |
| 46 | }; |
| 47 | |
Ohad Ben-Cohen | 400e64d | 2011-10-20 16:52:46 +0200 | [diff] [blame] | 48 | /* from remoteproc_core.c */ |
| 49 | void rproc_release(struct kref *kref); |
| 50 | irqreturn_t rproc_vq_interrupt(struct rproc *rproc, int vq_id); |
| 51 | |
Ohad Ben-Cohen | 7a18694 | 2012-02-13 22:30:39 +0100 | [diff] [blame] | 52 | /* from remoteproc_virtio.c */ |
| 53 | int rproc_add_virtio_dev(struct rproc_vdev *rvdev, int id); |
| 54 | void rproc_remove_virtio_dev(struct rproc_vdev *rvdev); |
Ohad Ben-Cohen | 400e64d | 2011-10-20 16:52:46 +0200 | [diff] [blame] | 55 | |
| 56 | /* from remoteproc_debugfs.c */ |
| 57 | void rproc_remove_trace_file(struct dentry *tfile); |
| 58 | struct dentry *rproc_create_trace_file(const char *name, struct rproc *rproc, |
| 59 | struct rproc_mem_entry *trace); |
| 60 | void rproc_delete_debug_dir(struct rproc *rproc); |
| 61 | void rproc_create_debug_dir(struct rproc *rproc); |
| 62 | void rproc_init_debugfs(void); |
| 63 | void rproc_exit_debugfs(void); |
| 64 | |
Ohad Ben-Cohen | 6db20ea | 2012-05-17 14:23:59 +0300 | [diff] [blame] | 65 | void rproc_free_vring(struct rproc_vring *rvring); |
| 66 | int rproc_alloc_vring(struct rproc_vdev *rvdev, int i); |
Sjur Brændeland | 72854fb | 2012-07-15 11:25:27 +0300 | [diff] [blame] | 67 | |
| 68 | void *rproc_da_to_va(struct rproc *rproc, u64 da, int len); |
Fernando Guzman Lugo | 70b85ef | 2012-08-30 13:26:13 -0500 | [diff] [blame] | 69 | int rproc_trigger_recovery(struct rproc *rproc); |
Sjur Brændeland | 72854fb | 2012-07-15 11:25:27 +0300 | [diff] [blame] | 70 | |
Sjur Brændeland | 4afc89d | 2012-06-19 10:08:18 +0300 | [diff] [blame] | 71 | static inline |
| 72 | int rproc_fw_sanity_check(struct rproc *rproc, const struct firmware *fw) |
| 73 | { |
| 74 | if (rproc->fw_ops->sanity_check) |
| 75 | return rproc->fw_ops->sanity_check(rproc, fw); |
| 76 | |
| 77 | return 0; |
| 78 | } |
| 79 | |
| 80 | static inline |
| 81 | u32 rproc_get_boot_addr(struct rproc *rproc, const struct firmware *fw) |
| 82 | { |
| 83 | if (rproc->fw_ops->get_boot_addr) |
| 84 | return rproc->fw_ops->get_boot_addr(rproc, fw); |
| 85 | |
| 86 | return 0; |
| 87 | } |
| 88 | |
| 89 | static inline |
| 90 | int rproc_load_segments(struct rproc *rproc, const struct firmware *fw) |
| 91 | { |
| 92 | if (rproc->fw_ops->load) |
| 93 | return rproc->fw_ops->load(rproc, fw); |
| 94 | |
| 95 | return -EINVAL; |
| 96 | } |
| 97 | |
| 98 | static inline |
Sjur Brændeland | 72854fb | 2012-07-15 11:25:27 +0300 | [diff] [blame] | 99 | struct resource_table *rproc_find_rsc_table(struct rproc *rproc, |
Sjur Brændeland | 4afc89d | 2012-06-19 10:08:18 +0300 | [diff] [blame] | 100 | const struct firmware *fw, int *tablesz) |
| 101 | { |
| 102 | if (rproc->fw_ops->find_rsc_table) |
| 103 | return rproc->fw_ops->find_rsc_table(rproc, fw, tablesz); |
| 104 | |
| 105 | return NULL; |
| 106 | } |
| 107 | |
Sjur Brændeland | 95f9578 | 2013-02-21 18:15:34 +0100 | [diff] [blame] | 108 | static inline |
| 109 | struct resource_table *rproc_find_loaded_rsc_table(struct rproc *rproc, |
Suman Anna | 5797115 | 2013-06-30 11:33:05 +0300 | [diff] [blame] | 110 | const struct firmware *fw) |
Sjur Brændeland | 95f9578 | 2013-02-21 18:15:34 +0100 | [diff] [blame] | 111 | { |
| 112 | if (rproc->fw_ops->find_loaded_rsc_table) |
| 113 | return rproc->fw_ops->find_loaded_rsc_table(rproc, fw); |
| 114 | |
Suman Anna | 5797115 | 2013-06-30 11:33:05 +0300 | [diff] [blame] | 115 | return NULL; |
Sjur Brændeland | 95f9578 | 2013-02-21 18:15:34 +0100 | [diff] [blame] | 116 | } |
| 117 | |
Sjur Brændeland | 4afc89d | 2012-06-19 10:08:18 +0300 | [diff] [blame] | 118 | extern const struct rproc_fw_ops rproc_elf_fw_ops; |
Sjur Brændeland | 72854fb | 2012-07-15 11:25:27 +0300 | [diff] [blame] | 119 | |
Ohad Ben-Cohen | 400e64d | 2011-10-20 16:52:46 +0200 | [diff] [blame] | 120 | #endif /* REMOTEPROC_INTERNAL_H */ |