Skip to content

Commit

Permalink
Moved more of the plugins main.c code to the SDK + updated SDK script
Browse files Browse the repository at this point in the history
Also fixed flake8 warnings
  • Loading branch information
apaillier-ledger committed Oct 10, 2023
1 parent 49da32a commit 3e09ee0
Show file tree
Hide file tree
Showing 3 changed files with 78 additions and 37 deletions.
51 changes: 47 additions & 4 deletions src_plugins_sdk/plugin_main.c → src_plugin_sdk/main.c
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
/*****************************************************************************
* Ledger Plugins SDK.
* (c) 2023 Ledger SAS.
* Ledger Plugin SDK
* (c) 2023 Ledger SAS
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand All @@ -15,6 +15,17 @@
* limitations under the License.
*****************************************************************************/

#include "eth_internals.h"
#include "eth_plugin_interface.h"

// Functions implemented by the plugin
void handle_init_contract(ethPluginInitContract_t *parameters);
void handle_provide_parameter(ethPluginProvideParameter_t *parameters);
void handle_finalize(ethPluginFinalize_t *parameters);
void handle_provide_token(ethPluginProvideInfo_t *parameters);
void handle_query_contract_id(ethQueryContractID_t *parameters);
void handle_query_contract_ui(ethQueryContractUI_t *parameters);

// Calls the ethereum app.
void call_app_ethereum() {
unsigned int libcall_params[5];
Expand All @@ -40,6 +51,33 @@ void call_app_ethereum() {
os_lib_call((unsigned int *) &libcall_params);
}

// Function to dispatch calls from the ethereum app.
static void dispatch_call(int message, void *parameters) {
switch (message) {
case ETH_PLUGIN_INIT_CONTRACT:
handle_init_contract(parameters);
break;
case ETH_PLUGIN_PROVIDE_PARAMETER:
handle_provide_parameter(parameters);
break;
case ETH_PLUGIN_FINALIZE:
handle_finalize(parameters);
break;
case ETH_PLUGIN_PROVIDE_INFO:
handle_provide_token(parameters);
break;
case ETH_PLUGIN_QUERY_CONTRACT_ID:
handle_query_contract_id(parameters);
break;
case ETH_PLUGIN_QUERY_CONTRACT_UI:
handle_query_contract_ui(parameters);
break;
default:
PRINTF("Unhandled message %d\n", message);
break;
}
}

// Low-level main for plugins.
__attribute__((section(".boot"))) int main(int arg0) {
// Exit critical section
Expand All @@ -61,8 +99,13 @@ __attribute__((section(".boot"))) int main(int arg0) {

} else {
// Not called from dashboard: called from the ethereum app!
// launch plugin main
plugin_main(arg0);
const unsigned int *args = (unsigned int *) arg0;

// If `ETH_PLUGIN_CHECK_PRESENCE` is set, this means the caller is just trying to
// know whether this app exists or not. We can skip `paraswap_plugin_call`.
if (args[0] != ETH_PLUGIN_CHECK_PRESENCE) {
dispatch_call(args[0], (void *) args[1]);
}
}

// Call `os_lib_end`, go back to the ethereum app.
Expand Down
19 changes: 0 additions & 19 deletions src_plugins_sdk/plugin_main.h

This file was deleted.

45 changes: 31 additions & 14 deletions tools/build_sdk.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
'''

import os
import shutil


def extract_from_headers(sources, nodes_to_extract):
Expand All @@ -28,12 +29,12 @@ def extract_from_headers(sources, nodes_to_extract):
if key in line and value in line:
node += [line]
unclosed_curvy_brackets = line.count('{') - line.count('}')
if unclosed_curvy_brackets == False:
if not unclosed_curvy_brackets:
break
elif (key == "fn" and value in line) or unclosed_parantheses:
node += [line]
unclosed_parantheses = line.find(")") == -1
if unclosed_parantheses == False:
if not unclosed_parantheses:
break
elif unclosed_curvy_brackets:
node += [line]
Expand Down Expand Up @@ -150,7 +151,8 @@ def merge_c_files(sources, nodes_to_extract):

if __name__ == "__main__":

# some nodes will be extracted from these headers and merged into a new one, copied to sdk
# some nodes will be extracted from these headers and merged into a new
# one, copied to sdk
headers_to_merge = [
"src/tokens.h",
"src/chainConfig.h",
Expand All @@ -160,13 +162,23 @@ def merge_c_files(sources, nodes_to_extract):
"src/shared_context.h",
"src/eth_plugin_internal.h",
"src/nft.h",
"src/swap_lib_calls.h",
"src_plugins_sdk/plugin_main.h"
"src/swap_lib_calls.h",
]
nodes_to_extract = {
"#define": ["MAX_TICKER_LEN", "ADDRESS_LENGTH", "INT256_LENGTH", "WEI_TO_ETHER", "SELECTOR_SIZE", "PARAMETER_LENGTH", "RUN_APPLICATION", "COLLECTION_NAME_MAX_LEN"],
"#define": ["MAX_TICKER_LEN",
"ADDRESS_LENGTH",
"INT256_LENGTH",
"WEI_TO_ETHER",
"SELECTOR_SIZE",
"PARAMETER_LENGTH",
"RUN_APPLICATION",
"COLLECTION_NAME_MAX_LEN"],
"typedef enum": [],
"typedef struct": ["tokenDefinition_t", "txInt256_t", "txContent_t", "nftInfo_t", "caller_app_t"],
"typedef struct": ["tokenDefinition_t",
"txInt256_t",
"txContent_t",
"nftInfo_t",
"caller_app_t"],
"typedef union": ["extraInfo_t"],
"__attribute__((no_instrument_function)) inline": ["int allzeroes"],
"const": ["HEXDIGITS"],
Expand All @@ -180,21 +192,26 @@ def merge_c_files(sources, nodes_to_extract):
"void copy_address",
"void copy_parameter",
"bool U2BE_from_parameter",
"bool U4BE_from_parameter",
"void plugin_main",
"void call_app_ethereum",
"int main"]
"bool U4BE_from_parameter"]
}
merge_headers(headers_to_merge, nodes_to_extract)

# this header will be stripped from all #include related to previously merged headers, then copied to sdk
# this header will be stripped from all #include related to previously
# merged headers, then copied to sdk
copy_header("src/eth_plugin_interface.h", headers_to_merge)

# extract and merge function bodies
c_files_to_merge = [
"src/utils.c",
"src_common/ethUtils.c",
"src/eth_plugin_internal.c",
"src_plugins_sdk/plugin_main.c"
"src/eth_plugin_internal.c",
]
merge_c_files(c_files_to_merge, nodes_to_extract["fn"])

files_to_copy = [
"main.c",
]

for file in files_to_copy:
shutil.copyfile("src_plugin_sdk/" + file,
"ethereum-plugin-sdk/include/" + file)

0 comments on commit 3e09ee0

Please sign in to comment.