struct sbi_trap_info;
struct sbi_ecall_extension {
+ /* head is used by the extension list */
struct sbi_dlist head;
+ /*
+ * extid_start and extid_end specify the range for this extension. As
+ * the initial range may be wider than the valid runtime range, the
+ * register_extensions callback is responsible for narrowing the range
+ * before other callbacks may be invoked.
+ */
unsigned long extid_start;
unsigned long extid_end;
+ /*
+ * register_extensions
+ *
+ * Calls sbi_ecall_register_extension() one or more times to register
+ * extension ID range(s) which should be handled by this extension.
+ * More than one sbi_ecall_extension struct and
+ * sbi_ecall_register_extension() call is necessary when the supported
+ * extension ID ranges have gaps. Additionally, extension availability
+ * must be checked before registering, which means, when this callback
+ * returns, only valid extension IDs from the initial range, which are
+ * also available, have been registered.
+ */
int (* register_extensions)(void);
+ /*
+ * probe
+ *
+ * Implements the Base extension's probe function for the extension. As
+ * the register_extensions callback ensures that no other extension
+ * callbacks will be invoked when the extension is not available, then
+ * probe can never fail. However, an extension may choose to set
+ * out_val to a nonzero value other than one. In those cases, it should
+ * implement this callback.
+ */
int (* probe)(unsigned long extid, unsigned long *out_val);
+ /*
+ * handle
+ *
+ * This is the extension handler. register_extensions ensures it is
+ * never invoked with an invalid or unavailable extension ID.
+ */
int (* handle)(unsigned long extid, unsigned long funcid,
const struct sbi_trap_regs *regs,
unsigned long *out_val,