Split solana_sdk.h (#19172)
This commit is contained in:
66
sdk/bpf/c/inc/sol/entrypoint.h
Normal file
66
sdk/bpf/c/inc/sol/entrypoint.h
Normal file
@ -0,0 +1,66 @@
|
||||
#pragma once
|
||||
/**
|
||||
* @brief Solana program entrypoint
|
||||
*/
|
||||
|
||||
#include <sol/types.h>
|
||||
#include <sol/pubkey.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/**
|
||||
* Keyed Account
|
||||
*/
|
||||
typedef struct {
|
||||
SolPubkey *key; /** Public key of the account */
|
||||
uint64_t *lamports; /** Number of lamports owned by this account */
|
||||
uint64_t data_len; /** Length of data in bytes */
|
||||
uint8_t *data; /** On-chain data within this account */
|
||||
SolPubkey *owner; /** Program that owns this account */
|
||||
uint64_t rent_epoch; /** The epoch at which this account will next owe rent */
|
||||
bool is_signer; /** Transaction was signed by this account's key? */
|
||||
bool is_writable; /** Is the account writable? */
|
||||
bool executable; /** This account's data contains a loaded program (and is now read-only) */
|
||||
} SolAccountInfo;
|
||||
|
||||
/**
|
||||
* The Solana runtime provides a memory region that is available to programs at
|
||||
* a fixed virtual address and length. The builtin functions `sol_calloc` and
|
||||
* `sol_free` call into the Solana runtime to allocate from this memory region
|
||||
* for heap operations. Because the memory region is directly available to
|
||||
* programs another option is a program can implement their own heap directly on
|
||||
* top of that region. If a program chooses to implement their own heap they
|
||||
* should not call the builtin heap functions because they will conflict.
|
||||
* `HEAP_START_ADDRESS` and `HEAP_LENGTH` specify the memory region's start
|
||||
* virtual address and length.
|
||||
*/
|
||||
#define HEAP_START_ADDRESS (uint64_t)0x300000000
|
||||
#define HEAP_LENGTH (uint64_t)(32 * 1024)
|
||||
|
||||
/**
|
||||
* Structure that the program's entrypoint input data is deserialized into.
|
||||
*/
|
||||
typedef struct {
|
||||
SolAccountInfo* ka; /** Pointer to an array of SolAccountInfo, must already
|
||||
point to an array of SolAccountInfos */
|
||||
uint64_t ka_num; /** Number of SolAccountInfo entries in `ka` */
|
||||
const uint8_t *data; /** pointer to the instruction data */
|
||||
uint64_t data_len; /** Length in bytes of the instruction data */
|
||||
const SolPubkey *program_id; /** program_id of the currently executing program */
|
||||
} SolParameters;
|
||||
|
||||
/**
|
||||
* Program instruction entrypoint
|
||||
*
|
||||
* @param input Buffer of serialized input parameters. Use sol_deserialize() to decode
|
||||
* @return 0 if the instruction executed successfully
|
||||
*/
|
||||
uint64_t entrypoint(const uint8_t *input);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
/**@}*/
|
Reference in New Issue
Block a user