dist_nifs.c

Include dependency graph for dist_nifs.c:

digraph { graph [bgcolor="#00000000"] node [shape=rectangle style=filled fillcolor="#FFFFFF" font=Helvetica padding=2] edge [color="#1414CE"] "6" [label="stdbool.h" tooltip="stdbool.h"] "32" [label="erl_nif_priv.h" tooltip="erl_nif_priv.h"] "19" [label="refc_binary.h" tooltip="refc_binary.h"] "35" [label="nifs.h" tooltip="nifs.h"] "30" [label="defaultatoms.h" tooltip="defaultatoms.h"] "26" [label="atom.h" tooltip="atom.h"] "14" [label="assert.h" tooltip="assert.h"] "17" [label="utils.h" tooltip="utils.h"] "23" [label="synclist.h" tooltip="synclist.h"] "20" [label="list.h" tooltip="list.h"] "7" [label="stdint.h" tooltip="stdint.h"] "9" [label="stdlib.h" tooltip="stdlib.h"] "33" [label="context.h" tooltip="context.h"] "11" [label="memory.h" tooltip="memory.h"] "1" [label="/__w/AtomVM/AtomVM/src/libAtomVM/dist_nifs.c" tooltip="/__w/AtomVM/AtomVM/src/libAtomVM/dist_nifs.c" fillcolor="#BFBFBF"] "2" [label="dist_nifs.h" tooltip="dist_nifs.h"] "21" [label="resources.h" tooltip="resources.h"] "4" [label="term.h" tooltip="term.h"] "18" [label="stddef.h" tooltip="stddef.h"] "12" [label="erl_nif.h" tooltip="erl_nif.h"] "3" [label="exportedfunction.h" tooltip="exportedfunction.h"] "31" [label="defaultatoms.def" tooltip="defaultatoms.def"] "15" [label="limits.h" tooltip="limits.h"] "27" [label="atom_table.h" tooltip="atom_table.h"] "34" [label="externalterm.h" tooltip="externalterm.h"] "5" [label="sys/types.h" tooltip="sys/types.h"] "10" [label="string.h" tooltip="string.h"] "13" [label="term_typedef.h" tooltip="term_typedef.h"] "25" [label="globalcontext.h" tooltip="globalcontext.h"] "24" [label="smp.h" tooltip="smp.h"] "29" [label="timer_list.h" tooltip="timer_list.h"] "22" [label="mailbox.h" tooltip="mailbox.h"] "8" [label="stdio.h" tooltip="stdio.h"] "28" [label="ets.h" tooltip="ets.h"] "16" [label="inttypes.h" tooltip="inttypes.h"] "32" -> "33" [dir=forward tooltip="include"] "32" -> "11" [dir=forward tooltip="include"] "32" -> "21" [dir=forward tooltip="include"] "19" -> "6" [dir=forward tooltip="include"] "19" -> "9" [dir=forward tooltip="include"] "19" -> "20" [dir=forward tooltip="include"] "19" -> "21" [dir=forward tooltip="include"] "35" -> "26" [dir=forward tooltip="include"] "35" -> "33" [dir=forward tooltip="include"] "35" -> "3" [dir=forward tooltip="include"] "30" -> "25" [dir=forward tooltip="include"] "30" -> "31" [dir=forward tooltip="include"] "26" -> "7" [dir=forward tooltip="include"] "26" -> "9" [dir=forward tooltip="include"] "17" -> "18" [dir=forward tooltip="include"] "17" -> "8" [dir=forward tooltip="include"] "17" -> "9" [dir=forward tooltip="include"] "23" -> "8" [dir=forward tooltip="include"] "23" -> "20" [dir=forward tooltip="include"] "23" -> "24" [dir=forward tooltip="include"] "20" -> "6" [dir=forward tooltip="include"] "33" -> "25" [dir=forward tooltip="include"] "33" -> "20" [dir=forward tooltip="include"] "33" -> "22" [dir=forward tooltip="include"] "33" -> "24" [dir=forward tooltip="include"] "33" -> "4" [dir=forward tooltip="include"] "33" -> "29" [dir=forward tooltip="include"] "11" -> "7" [dir=forward tooltip="include"] "11" -> "9" [dir=forward tooltip="include"] "11" -> "12" [dir=forward tooltip="include"] "11" -> "13" [dir=forward tooltip="include"] "11" -> "17" [dir=forward tooltip="include"] "1" -> "2" [dir=forward tooltip="include"] "1" -> "30" [dir=forward tooltip="include"] "1" -> "12" [dir=forward tooltip="include"] "1" -> "32" [dir=forward tooltip="include"] "1" -> "34" [dir=forward tooltip="include"] "1" -> "25" [dir=forward tooltip="include"] "1" -> "20" [dir=forward tooltip="include"] "1" -> "11" [dir=forward tooltip="include"] "1" -> "35" [dir=forward tooltip="include"] "1" -> "23" [dir=forward tooltip="include"] "1" -> "4" [dir=forward tooltip="include"] "1" -> "17" [dir=forward tooltip="include"] "2" -> "3" [dir=forward tooltip="include"] "2" -> "25" [dir=forward tooltip="include"] "2" -> "4" [dir=forward tooltip="include"] "21" -> "9" [dir=forward tooltip="include"] "21" -> "12" [dir=forward tooltip="include"] "21" -> "20" [dir=forward tooltip="include"] "21" -> "22" [dir=forward tooltip="include"] "21" -> "11" [dir=forward tooltip="include"] "21" -> "23" [dir=forward tooltip="include"] "4" -> "5" [dir=forward tooltip="include"] "4" -> "6" [dir=forward tooltip="include"] "4" -> "7" [dir=forward tooltip="include"] "4" -> "8" [dir=forward tooltip="include"] "4" -> "9" [dir=forward tooltip="include"] "4" -> "10" [dir=forward tooltip="include"] "4" -> "11" [dir=forward tooltip="include"] "4" -> "19" [dir=forward tooltip="include"] "4" -> "17" [dir=forward tooltip="include"] "4" -> "13" [dir=forward tooltip="include"] "12" -> "13" [dir=forward tooltip="include"] "3" -> "4" [dir=forward tooltip="include"] "27" -> "6" [dir=forward tooltip="include"] "27" -> "26" [dir=forward tooltip="include"] "34" -> "4" [dir=forward tooltip="include"] "13" -> "14" [dir=forward tooltip="include"] "13" -> "15" [dir=forward tooltip="include"] "13" -> "16" [dir=forward tooltip="include"] "13" -> "7" [dir=forward tooltip="include"] "25" -> "7" [dir=forward tooltip="include"] "25" -> "26" [dir=forward tooltip="include"] "25" -> "27" [dir=forward tooltip="include"] "25" -> "12" [dir=forward tooltip="include"] "25" -> "28" [dir=forward tooltip="include"] "25" -> "20" [dir=forward tooltip="include"] "25" -> "22" [dir=forward tooltip="include"] "25" -> "24" [dir=forward tooltip="include"] "25" -> "23" [dir=forward tooltip="include"] "25" -> "4" [dir=forward tooltip="include"] "25" -> "29" [dir=forward tooltip="include"] "24" -> "6" [dir=forward tooltip="include"] "29" -> "6" [dir=forward tooltip="include"] "29" -> "7" [dir=forward tooltip="include"] "29" -> "20" [dir=forward tooltip="include"] "22" -> "6" [dir=forward tooltip="include"] "22" -> "20" [dir=forward tooltip="include"] "22" -> "13" [dir=forward tooltip="include"] "22" -> "17" [dir=forward tooltip="include"] "28" -> "20" [dir=forward tooltip="include"] "28" -> "23" [dir=forward tooltip="include"] "28" -> "4" [dir=forward tooltip="include"] }

Implementation of distribution NIFs and resources.

Enums

enum [anonymous]

Values:

enumerator OPERATION_REG_SEND = 6
enumerator OPERATION_GROUP_LEADER = 7
enumerator OPERATION_REG_SEND_TT = 16
enumerator OPERATION_MONITOR_P = 19
enumerator OPERATION_DEMONITOR_P = 20
enumerator OPERATION_SEND_SENDER = 22
enumerator OPERATION_SEND_SENDER_TT = 23
enumerator OPERATION_PAYLOAD_EXIT = 24
enumerator OPERATION_PAYLOAD_EXIT_TT = 25
enumerator OPERATION_PAYLOAD_EXIT2 = 26
enumerator OPERATION_PAYLOAD_EXIT2_TT = 27
enumerator OPERATION_PAYLOAD_MONITOR_P_EXIT = 28
enumerator OPERATION_SPAWN_REQUEST = 29
enumerator OPERATION_SPAWN_REQUEST_TT = 30
enumerator OPERATION_SPAWN_REPLY = 31
enumerator OPERATION_SPAWN_REPLY_TT = 32
enumerator OPERATION_ALIAS_SEND = 33
enumerator OPERATION_ALIAS_SEND_TT = 34
enum [anonymous]

Values:

enumerator SPAWN_REPLY_FLAGS_MONITOR_CREATED = 2

Functions

static void dist_connection_dtor(ErlNifEnv *caller_env, void *obj)
static void dist_enqueue_message(term control_message, term payload, struct DistConnection *connection, GlobalContext *global)
static void dist_enqueue_reg_send_message(int32_t local_process_id, term remote_process_name, term payload, struct DistConnection *connection, GlobalContext *global)
static void dist_enqueue_send_sender_message(int32_t local_process_id, term remote_process_id, term payload, struct DistConnection *connection, GlobalContext *global)
static void dist_enqueue_monitor_exit_message(struct RemoteMonitor *monitor, term reason, struct DistConnection *connection, GlobalContext *global)
static void dist_connection_down(ErlNifEnv *caller_env, void *obj, ErlNifPid *pid, ErlNifMonitor *mon)
static term nif_erlang_setnode_3(Context *ctx, int argc, term argv[])
static term nif_erlang_dist_ctrl_get_data_notification(Context *ctx, int argc, term argv[])
static term nif_erlang_dist_ctrl_get_data(Context *ctx, int argc, term argv[])
term dist_monitor(struct DistConnection *conn_obj, term from_pid, term target_proc, term monitor_ref, Context *ctx)

@doc Setup a monitor on a local process for a distributed process. @end

Parameters:
  • conn_obj – object of the connection

  • from_pid – remote pid setting up the monitor

  • target_proc – atom (for registered process) or pid of the local process to monitor

  • monitor_ref – reference used for monitor

  • ctx – context for memory allocation

static term nif_erlang_dist_ctrl_put_data(Context *ctx, int argc, term argv[])
term dist_send_message(term target, term payload, Context *ctx)

@doc Enqueue a message to be sent to a remote process. This function may raise a badarg error following OTP if target is incorrect.

Parameters:
  • target – external pid or a tuple {atom(), node()} to refer to a remote registered process

  • payload – message to send

  • ctx – process that sends the message.

Returns:

the payload if the message was sent or term_invalid if there was a badarg error

void dist_spawn_reply(term req_id, term to_pid, bool link, bool monitor, term result, struct DistConnection *connection, GlobalContext *global)

@doc Send a spawn reply signal to a node @end

Parameters:
  • conn_obj – object of the connection

  • req_id – reference identifying the request

  • to_pid – (remote) process id identifying the caller

  • link – if a link was created

  • monitor – if a monitor was created

  • result – pid of the spawned process or atom for an error

  • ctx – context for memory allocation

Variables

const ErlNifResourceTypeInit dist_connection_resource_type_init = {.members = 3, .dtor = dist_connection_dtor, .stop = NULL, .down = dist_connection_down,}
const struct Nif setnode_3_nif = {.base.type = NIFFunctionType, .nif_ptr = nif_erlang_setnode_3}
const struct Nif dist_ctrl_get_data_notification_nif = {.base.type = NIFFunctionType, .nif_ptr = nif_erlang_dist_ctrl_get_data_notification}
const struct Nif dist_ctrl_get_data_nif = {.base.type = NIFFunctionType, .nif_ptr = nif_erlang_dist_ctrl_get_data}
const struct Nif dist_ctrl_put_data_nif = {.base.type = NIFFunctionType, .nif_ptr = nif_erlang_dist_ctrl_put_data}
struct DistributionPacket

Collaboration diagram for DistributionPacket:

digraph { graph [bgcolor="#00000000"] node [shape=rectangle style=filled fillcolor="#FFFFFF" font=Helvetica padding=2] edge [color="#1414CE"] "2" [label="ListHead" tooltip="ListHead"] "1" [label="DistributionPacket" tooltip="DistributionPacket" fillcolor="#BFBFBF"] "2" -> "2" [dir=forward tooltip="usage"] "1" -> "2" [dir=forward tooltip="usage"] }

Public Members

struct ListHead head
size_t size
uint8_t bytes[]
struct RemoteMonitor

Collaboration diagram for RemoteMonitor:

digraph { graph [bgcolor="#00000000"] node [shape=rectangle style=filled fillcolor="#FFFFFF" font=Helvetica padding=2] edge [color="#1414CE"] "22" [label="SpinLock" tooltip="SpinLock"] "3" [label="ResourceType" tooltip="ResourceType"] "17" [label="Module" tooltip="Module"] "5" [label="ListHead" tooltip="ListHead"] "13" [label="HeapFragment" tooltip="HeapFragment"] "15" [label="RefcBinaryQueueItem" tooltip="RefcBinaryQueueItem"] "6" [label="GlobalContext" tooltip="GlobalContext"] "7" [label="Ets" tooltip="Ets"] "14" [label="HNodeGroup" tooltip="HNodeGroup"] "21" [label="TimerList" tooltip="TimerList"] "19" [label="LiteralEntry" tooltip="LiteralEntry"] "9" [label="MailboxMessage" tooltip="MailboxMessage"] "12" [label="Heap" tooltip="Heap"] "8" [label="MessageQueueItem" tooltip="MessageQueueItem"] "20" [label="AtomsHashTable" tooltip="AtomsHashTable"] "1" [label="RemoteMonitor" tooltip="RemoteMonitor" fillcolor="#BFBFBF"] "16" [label="RefcBinary" tooltip="RefcBinary"] "2" [label="ErlNifMonitor" tooltip="ErlNifMonitor"] "10" [label="AtomTable" tooltip="AtomTable"] "18" [label="ExportedFunction" tooltip="ExportedFunction"] "4" [label="SyncList" tooltip="SyncList"] "11" [label="HNode" tooltip="HNode"] "3" -> "4" [dir=forward tooltip="usage"] "3" -> "6" [dir=forward tooltip="usage"] "3" -> "5" [dir=forward tooltip="usage"] "17" -> "18" [dir=forward tooltip="usage"] "17" -> "19" [dir=forward tooltip="usage"] "17" -> "5" [dir=forward tooltip="usage"] "5" -> "5" [dir=forward tooltip="usage"] "13" -> "13" [dir=forward tooltip="usage"] "15" -> "16" [dir=forward tooltip="usage"] "15" -> "15" [dir=forward tooltip="usage"] "6" -> "3" [dir=forward tooltip="usage"] "6" -> "7" [dir=forward tooltip="usage"] "6" -> "8" [dir=forward tooltip="usage"] "6" -> "10" [dir=forward tooltip="usage"] "6" -> "15" [dir=forward tooltip="usage"] "6" -> "4" [dir=forward tooltip="usage"] "6" -> "17" [dir=forward tooltip="usage"] "6" -> "20" [dir=forward tooltip="usage"] "6" -> "21" [dir=forward tooltip="usage"] "6" -> "22" [dir=forward tooltip="usage"] "6" -> "5" [dir=forward tooltip="usage"] "7" -> "4" [dir=forward tooltip="usage"] "14" -> "11" [dir=forward tooltip="usage"] "14" -> "14" [dir=forward tooltip="usage"] "21" -> "5" [dir=forward tooltip="usage"] "9" -> "9" [dir=forward tooltip="usage"] "12" -> "13" [dir=forward tooltip="usage"] "8" -> "9" [dir=forward tooltip="usage"] "8" -> "8" [dir=forward tooltip="usage"] "20" -> "11" [dir=forward tooltip="usage"] "1" -> "2" [dir=forward tooltip="usage"] "1" -> "5" [dir=forward tooltip="usage"] "16" -> "3" [dir=forward tooltip="usage"] "16" -> "5" [dir=forward tooltip="usage"] "2" -> "3" [dir=forward tooltip="usage"] "10" -> "11" [dir=forward tooltip="usage"] "10" -> "14" [dir=forward tooltip="usage"] "4" -> "5" [dir=forward tooltip="usage"] "11" -> "11" [dir=forward tooltip="usage"] "11" -> "12" [dir=forward tooltip="usage"] }

Public Members

struct ListHead head
term target_proc
uint8_t ref_len
uint32_t ref_words[5]
uint32_t pid_number
uint32_t pid_serial
ErlNifMonitor process_monitor
struct DistConnection

Collaboration diagram for DistConnection:

digraph { graph [bgcolor="#00000000"] node [shape=rectangle style=filled fillcolor="#FFFFFF" font=Helvetica padding=2] edge [color="#1414CE"] "22" [label="SpinLock" tooltip="SpinLock"] "5" [label="ResourceType" tooltip="ResourceType"] "17" [label="Module" tooltip="Module"] "3" [label="ListHead" tooltip="ListHead"] "13" [label="HeapFragment" tooltip="HeapFragment"] "15" [label="RefcBinaryQueueItem" tooltip="RefcBinaryQueueItem"] "6" [label="GlobalContext" tooltip="GlobalContext"] "7" [label="Ets" tooltip="Ets"] "14" [label="HNodeGroup" tooltip="HNodeGroup"] "21" [label="TimerList" tooltip="TimerList"] "19" [label="LiteralEntry" tooltip="LiteralEntry"] "9" [label="MailboxMessage" tooltip="MailboxMessage"] "12" [label="Heap" tooltip="Heap"] "8" [label="MessageQueueItem" tooltip="MessageQueueItem"] "20" [label="AtomsHashTable" tooltip="AtomsHashTable"] "16" [label="RefcBinary" tooltip="RefcBinary"] "1" [label="DistConnection" tooltip="DistConnection" fillcolor="#BFBFBF"] "4" [label="ErlNifMonitor" tooltip="ErlNifMonitor"] "10" [label="AtomTable" tooltip="AtomTable"] "18" [label="ExportedFunction" tooltip="ExportedFunction"] "2" [label="SyncList" tooltip="SyncList"] "11" [label="HNode" tooltip="HNode"] "5" -> "2" [dir=forward tooltip="usage"] "5" -> "6" [dir=forward tooltip="usage"] "5" -> "3" [dir=forward tooltip="usage"] "17" -> "18" [dir=forward tooltip="usage"] "17" -> "19" [dir=forward tooltip="usage"] "17" -> "3" [dir=forward tooltip="usage"] "3" -> "3" [dir=forward tooltip="usage"] "13" -> "13" [dir=forward tooltip="usage"] "15" -> "16" [dir=forward tooltip="usage"] "15" -> "15" [dir=forward tooltip="usage"] "6" -> "5" [dir=forward tooltip="usage"] "6" -> "7" [dir=forward tooltip="usage"] "6" -> "8" [dir=forward tooltip="usage"] "6" -> "10" [dir=forward tooltip="usage"] "6" -> "15" [dir=forward tooltip="usage"] "6" -> "2" [dir=forward tooltip="usage"] "6" -> "17" [dir=forward tooltip="usage"] "6" -> "20" [dir=forward tooltip="usage"] "6" -> "21" [dir=forward tooltip="usage"] "6" -> "22" [dir=forward tooltip="usage"] "6" -> "3" [dir=forward tooltip="usage"] "7" -> "2" [dir=forward tooltip="usage"] "14" -> "11" [dir=forward tooltip="usage"] "14" -> "14" [dir=forward tooltip="usage"] "21" -> "3" [dir=forward tooltip="usage"] "9" -> "9" [dir=forward tooltip="usage"] "12" -> "13" [dir=forward tooltip="usage"] "8" -> "9" [dir=forward tooltip="usage"] "8" -> "8" [dir=forward tooltip="usage"] "20" -> "11" [dir=forward tooltip="usage"] "16" -> "5" [dir=forward tooltip="usage"] "16" -> "3" [dir=forward tooltip="usage"] "1" -> "2" [dir=forward tooltip="usage"] "1" -> "4" [dir=forward tooltip="usage"] "1" -> "3" [dir=forward tooltip="usage"] "4" -> "5" [dir=forward tooltip="usage"] "10" -> "11" [dir=forward tooltip="usage"] "10" -> "14" [dir=forward tooltip="usage"] "2" -> "3" [dir=forward tooltip="usage"] "11" -> "11" [dir=forward tooltip="usage"] "11" -> "12" [dir=forward tooltip="usage"] }

Public Members

struct ListHead head
int node_atom_index
uint32_t node_creation
int32_t selecting_process_id
int32_t connection_process_id
ErlNifMonitor connection_process_monitor
struct SyncList remote_monitors
struct SyncList pending_packets