Ladderlib is a C library designed for implementing ladder logic programming, a method widely used in Programmable Logic Controllers (PLCs) for industrial automation. It provides a robust framework to define, execute, and manage ladder logic programs, supporting hardware interactions and custom function extensions.
Ladderlib enables developers to create ladder logic programs, which are graphical representations of control logic resembling electrical relay circuits. These programs are executed cyclically by PLCs to automate industrial processes, such as controlling machinery in manufacturing or chemical processing. The library supports defining logic through cells and networks, managing execution states, handling hardware inputs/outputs, and integrating custom functions for enhanced flexibility.
Key features include:
- Instruction Set: 39 instructions for defining logic operations.
- State Management: 6 states to control program execution.
- Error Handling: 8 error codes for robust operation.
- Hardware Integration: Function pointers for reading inputs and writing outputs.
- Custom Extensions: Support for adding user-defined functions.
The library is likely optimized for embedded systems.
Ladder logic programming stands as the fundamental programming language for Programmable Logic Controllers (PLCs), powering approximately 80% of industrial automation systems worldwide.
It’s a visual programming methodology that evolved from traditional relay-based control systems, provides an intuitive approach to implementing complex control logic in manufacturing processes. The purpose of ladder logic programming is to simplify the process of programming and controlling complex machinery, such as assembly lines and manufacturing equipment. The transition from physical relay panels to digital programming has maintained the familiar ladder diagram format while incorporating advanced digital capabilities, making it the preferred choice for automation engineers and technicians.
Ladder logic is a fast and simple way of creating logic expressions for a PLC in order to automate repetitive machine tasks and sequences. It is used in a multitude of industrial automation applications.
- Basic Logic Instructions
- API Documentation
- Enums and Structures
- Callback Prototypes
- Basic Usage
- Contributing
- License
- Contact
The following table summarizes the instructions, their codes, categories, and symbols.
Basic instructions manage Input/Output functions
- Instruction Code: LADDER_INS_NO(3)
- Description: The Normally Open contact allows logic flow when its associated input is true, acting like a switch that closes when activated. It is used to check if an input condition (e.g., a sensor) is met.
- Example Use: Checking if a pushbutton is pressed to activate a motor.
- Instruction Code: LADDER_INS_NC(4)
- Description: The Normally Closed contact allows logic flow when its associated input is false, acting like a switch that opens when activated. It is used to proceed when a condition is not met.
- Example Use: Ensuring a safety switch is not triggered before starting a process.
- Instruction Code: LADDER_INS_COIL(7)
- Description: The Coil instruction sets an output to true when the rung's logic is true, controlling devices like motors or lights. It represents the action taken when conditions are satisfied.
- Example Use: Turning on a conveyor belt when all conditions are met.
- Instruction Code: LADDER_INS_COILL(8)
- Description: The Coil Latch sets an output to true and maintains it (latches) even if the input conditions change, until unlatched. It is used for memory functions in control systems.
- Example Use: Keeping a pump running after a start button is released.
- Instruction Code: LADDER_INS_COILU(9)
- Description: The Coil Unlatch resets a latched output to false, releasing the latched state. It is paired with COILLfor set/reset operations.
- Example Use: Stopping a latched pump when a stop button is pressed.
Timer instructions manage time-based operations, delaying or pulsing outputs.
- Instruction Code: LADDER_INS_TON(10)
- Description: The Timer On Delay starts timing when its input is true. After a preset time, the output becomes true. It is used to delay actions, such as waiting before starting a motor.
- Example Use: Delaying a fan activation for 10 seconds after a heater starts.
- Instruction Code: LADDER_INS_TOFF(11)
- Description: The Timer Off Delay starts timing when its input goes false. After a preset time, the output becomes false. It is used to extend the duration of an output.
- Example Use: Keeping a light on for 5 seconds after a switch is turned off.
- Instruction Code: LADDER_INS_TP(12)
- Description: The Timer Pulse generates a pulse of a specified duration when triggered by a true input. It is used for creating timed signals, such as a brief alarm.
- Example Use: Activating a buzzer for 2 seconds when a fault is detected.
Counter instructions track the number of events or occurrences.
- Instruction Code: LADDER_INS_CTU(13)
- Description: The Count Up counter increments its count each time the input transitions from false to true, up to a preset value. It is used to count items or events.
- Example Use: Counting the number of boxes on a conveyor belt.
- Instruction Code: LADDER_INS_CTD(14)
- Description: The Count Down counter decrements its count each time the input transitions from false to true, down to zero. It is used for countdown tasks.
- Example Use: Tracking remaining items in a batch process.
These instructions perform mathematical operations on data.
- Instruction Code: LADDER_INS_ADD(17)
- Description: Adds two values and stores the result in a specified location. It is used for calculations like summing sensor readings.
- Example Use: Adding the outputs of two flow sensors.
- Instruction Code: LADDER_INS_SUB(16)
- Description: Subtracts one value from another and stores the result. It is used for differential calculations.
- Example Use: Calculating the difference in pressure between two points.
- Instruction Code: LADDER_INS_MUL(18)
- Description: Multiplies two values and stores the result. It is used for scaling or area calculations.
- Example Use: Calculating power by multiplying voltage and current.
- Instruction Code: LADDER_INS_DIV(19)
- Description: Divides one value by another and stores the result. It is used for ratio calculations.
- Example Use: Determining speed by dividing distance by time.
- Instruction Code: LADDER_INS_MOD(20)
- Description: Computes the remainder of dividing one value by another. It is used for cyclic operations or remainder checks.
- Example Use: Checking if a counter value is even or odd.
These instructions manipulate bits within data values.
- Instruction Code: LADDER_INS_SHL(21)
- Description: Shifts the bits of a value to the left by a specified number of positions, filling with zeros. It is used for bit manipulation or scaling.
- Example Use: Doubling a binary value by shifting left.
- Instruction Code: LADDER_INS_SHR(22)
- Description: Shifts the bits of a value to the right by a specified number of positions, filling with zeros or sign bits. It is used for division or bit extraction.
- Example Use: Halving a binary value by shifting right.
- Instruction Code: LADDER_INS_ROL(23)
- Description: Rotates the bits of a value to the left, with the most significant bit wrapping around to the least significant position. It is used for circular shifts.
- Example Use: Rotating status flags in a control word.
- Instruction Code: LADDER_INS_ROR(24)
- Description: Rotates the bits of a value to the right, with the least significant bit wrapping around to the most significant position. It is used for circular shifts.
- Example Use: Cycling through a set of control bits.
- Instruction Code: LADDER_INS_AND(25)
- Description: Performs a bitwise AND operation on two values, setting output bits to 1 only where both inputs are 1. It is used for masking or condition checks.
- Example Use: Masking specific bits in a status register.
- Instruction Code: LADDER_INS_OR(26)
- Description: Performs a bitwise OR operation on two values, setting output bits to 1 where either input is 1. It is used for combining conditions.
- Example Use: Combining multiple fault flags.
- Instruction Code: LADDER_INS_XOR(27)
- Description: Performs a bitwise XOR operation on two values, setting output bits to 1 where inputs differ. It is used for toggling or comparison.
- Example Use: Detecting changes in bit patterns.
- Instruction Code: LADDER_INS_NOT(28)
- Description: Performs a bitwise NOT operation, inverting all bits of a value. It is used for logical negation.
- Example Use: Inverting a control signal.
These instructions compare values and produce boolean outputs.
- Instruction Code: LADDER_INS_EQ(29)
- Description: Checks if two values are equal, outputting true if they are. It is used for equality checks in control logic.
- Example Use: Verifying if a temperature reading matches a setpoint.
- Instruction Code: LADDER_INS_GT(30)
- Description: Checks if one value is greater than another, outputting true if so. It is used for threshold checks.
- Example Use: Checking if pressure exceeds a safe limit.
- Instruction Code: LADDER_INS_GE(31)
- Description: Checks if one value is greater than or equal to another, outputting true if so. It is used for inclusive threshold checks.
- Example Use: Ensuring a tank level is at or above a minimum.
- Instruction Code: LADDER_INS_LT(32)
- Description: Checks if one value is less than another, outputting true if so. It is used for lower-bound checks.
- Example Use: Detecting if a speed is below a target.
- Instruction Code: LADDER_INS_LE(33)
- Description: Checks if one value is less than or equal to another, outputting true if so. It is used for inclusive lower-bound checks.
- Example Use: Verifying a flow rate is at or below a maximum.
- Instruction Code: LADDER_INS_NE(34)
- Description: Checks if two values are not equal, outputting true if they differ. It is used for change detection.
- Example Use: Detecting a change in a sensor value.
These instructions provide additional functionality, some of which may be specific to ladderlib.
- Instruction Code: LADDER_INS_NOP(0)
- Description: Performs no operation, acting as a placeholder or for timing purposes. It does not affect the program state.
- Example Use: Reserving space for future instructions.
- Instruction Code: LADDER_INS_CONN(1)
- Description: Likely used to connect different parts of the ladder diagram, such as branching or joining rungs. It facilitates complex logic structures.
- Example Use: Linking parallel branches in a rung.
- Instruction Code: LADDER_INS_NEG(2)
- Description: Inverts the logic state of an input, turning true to false or vice versa. It is used to reverse conditions.
- Example Use: Inverting a stop signal to enable a process.
- Instruction Code: LADDER_INS_RE(5)
- Description: Detects a rising edge, triggering when an input transitions from false to true. It is used for event-driven actions.
- Example Use: Starting a counter when a button is pressed.
- Instruction Code: LADDER_INS_FE(6)
- Description: Detects a falling edge, triggering when an input transitions from true to false. It is used for event-driven actions.
- Example Use: Resetting a system when a sensor deactivates.
- Instruction Code: LADDER_INS_MOVE(15)
- Description: Copies data from one memory location to another without modification. It is used for data transfer.
- Example Use: Transferring a sensor value to a display register.
- Instruction Code: LADDER_INS_TMOVE(36)
- Description: Likely used for moving data within tables or arrays, possibly for batch processing or data manipulation. The exact functionality may depend a lot on ladderlib's implementation.
- Example Use: Moving a set of values to a new memory block.
- Instruction Code: LADDER_INS_FOREIGN(35)
- Description: Allows calling external or user-defined functions not natively supported by ladder logic. It enables integration with custom code.
- Example Use: Calling a custom algorithm for complex calculations.
- Instruction Code: LADDER_INS_INV(37)
- Description: Marks the beginning of invalid instruction codes, not intended for use in programs. It serves as a boundary for valid instructions.
- Example Use: None, as it is not used in programming.
- Instruction Code: LADDER_INS_MULTI(255, 0xff)
- Description: Indicates that the cell is part of a larger instruction spanning multiple cells, used for complex operations requiring additional data.
- Example Use: Implementing a multi-step operation like a sequence control.
This section provides detailed documentation for the core API functions of LadderLib, extracted from the header files ladder.h, ladder_instructions.h, and ladder_internals.h.
Initializes the ladder context with specified parameters for networks, memory, inputs, outputs, timers, counters, and blocks.
bool ladder_ctx_init(ladder_ctx_t *ladder_ctx, uint8_t net_columns_qty, uint8_t net_rows_qty, uint32_t networks_qty, uint32_t qty_m, uint32_t qty_c, uint32_t qty_t, uint32_t qty_d, uint32_t qty_r, bool init_netwok)  Parameters:
| Parameter | Description | 
|---|---|
| net_columns_qty | Number of columns in networks (max 32). Defines the width of each network grid. | 
| net_rows_qty | Number of rows in networks. Defines the height of each network grid. | 
| networks_qty | Number of networks. Specifies how many ladder networks the context will manage. | 
| qty_m | Quantity of memory bits. Number of general-purpose memory bits available. | 
| qty_c | Quantity of counters. Number of counter instances available for counting events | 
| qty_t | Quantity of timers. Number of timer instances available for timing operations. | 
| qty_d | Quantity of memory areas quantities. | 
| qty_r | Quantity of nemory areas quantities. Float or Real registers.. | 
| init_netwok | If false not initialize Networks. | 
Returns: Pointer to the initialized ladder_ctx_t structure, or NULL if initialization fails.
Deinitializes the ladder context, freeing all associated resources.
void ladder_deinit(ladder_ctx_t* ladder_ctx)  Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context to be deinitialized. | 
Returns: None.
Registers a callback function for reading input values from hardware.
bool ladder_add_read_fn(ladder_ctx_t *ladder_ctx, _io_read read, _io_init read_init)  Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context. | 
| read | Pointer to the read callback function. | 
| read_init | Initialize/deinitialize read function. | 
Returns: None.
Registers a callback function for writing output values to hardware.
bool ladder_add_write_fn(ladder_ctx_t *ladder_ctx, _io_write write, _io_init write_init);Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context. | 
| write | Pointer to the write callback function. | 
| write_init | Initialize/deinitialize write function. | 
Returns: None.
Add a foreign function
bool ladder_add_foreign(ladder_ctx_t *ladder_ctx, _foreign_fn_init fn_init, void *init_data, uint32_t qty);Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Ladder context. | 
| fn_init | Initialize internal foreign function. | 
| init_data | Generic foreign function data. | 
| qty | Quantity. | 
This section documents utility functions from the header files ladder_print.h, ladder_program_json.h, and ladder_program_check.h.
Prints the entire ladder program to the console for debugging purposes.
void ladder_print_program(ladder_ctx_t* ladder_ctx)  Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context. | 
Returns: None.
Print networks in ascii graphical format.
void ladder_print(ladder_ctx_t ladder_ctx)Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context. | 
Returns: None.
Save ladder program to a JSON file.
ladder_json_error_t ladder_program_to_json(const char *prg, ladder_ctx_t *ladder_ctx) Parameters:
| Parameter | Description | 
|---|---|
| prg | File name. | 
| ladder_ctx | Pointer to the ladder context. | 
Returns: Status.
Load ladder program from a JSON file.
ladder_json_error_t ladder_json_to_program(const char *prg, ladder_ctx_t *ladder_ctx) Parameters:
| Parameter | Description | 
|---|---|
| prg | File name. | 
| ladder_ctx | Pointer to the ladder context. | 
Returns: Status.
Checks the integrity and validity of the ladder program.
bool ladder_program_check(ladder_ctx_t* ladder_ctx)  Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context. | 
Returns: true if the program is valid, false otherwise.
This section documents all enums and structures from the header files.
Defines the types of instructions supported by LadderLib.
typedef enum LADDER_INSTRUCTIONS {
    LADDER_INS_NOP,     /**< Instruction NOP */
    LADDER_INS_CONN,    /**< Instruction CONN */
    LADDER_INS_NEG,     /**< Instruction NEG */
    LADDER_INS_NO,      /**< Instruction NO */
    LADDER_INS_NC,      /**< Instruction NC */
    LADDER_INS_RE,      /**< Instruction RE */
    LADDER_INS_FE,      /**< Instruction FE */
    LADDER_INS_COIL,    /**< Instruction COIL */
    LADDER_INS_COILL,   /**< Instruction COILL */
    LADDER_INS_COILU,   /**< Instruction COILU */
    LADDER_INS_TON,     /**< Instruction TON */
    LADDER_INS_TOFF,    /**< Instruction TOFF */
    LADDER_INS_TP,      /**< Instruction TP */
    LADDER_INS_CTU,     /**< Instruction CTU */
    LADDER_INS_CTD,     /**< Instruction CTD */
    LADDER_INS_MOVE,    /**< Instruction MOVE */
    LADDER_INS_SUB,     /**< Instruction SUB */
    LADDER_INS_ADD,     /**< Instruction ADD */
    LADDER_INS_MUL,     /**< Instruction MUL */
    LADDER_INS_DIV,     /**< Instruction DIV */
    LADDER_INS_MOD,     /**< Instruction MOD */
    LADDER_INS_SHL,     /**< Instruction SHL */
    LADDER_INS_SHR,     /**< Instruction SHR */
    LADDER_INS_ROL,     /**< Instruction ROL */
    LADDER_INS_ROR,     /**< Instruction ROR */
    LADDER_INS_AND,     /**< Instruction AND */
    LADDER_INS_OR,      /**< Instruction OR */
    LADDER_INS_XOR,     /**< Instruction XOR */
    LADDER_INS_NOT,     /**< Instruction NOT */
    LADDER_INS_EQ,      /**< Instruction EQ */
    LADDER_INS_GT,      /**< Instruction GT */
    LADDER_INS_GE,      /**< Instruction GE */
    LADDER_INS_LT,      /**< Instruction LT */
    LADDER_INS_LE,      /**< Instruction LE */
    LADDER_INS_NE,      /**< Instruction NE */
    LADDER_INS_FOREIGN, /**< Instruction FOREIGN */
    LADDER_INS_TMOVE,   /**< Instruction TMOVE */
    ///////////////////
    LADDER_INS_INV,     /**< First invalid */
    LADDER_INS_MULTI,   /**< cell is a part of multi cell instruction */
} ladder_instruction_t;General state
typedef enum LADDER_STATE {
    LADDER_ST_STOPPED,  /**< Stopped */
    LADDER_ST_RUNNING,  /**< Running */
    LADDER_ST_ERROR,    /**< Error */
    LADDER_ST_EXIT_TSK, /**< Exit task */
    LADDER_ST_NULLFN,   /**< pointer to NULL function */
    LADDER_ST_INV,      /**< Invalid */
} ladder_state_t;Instruction status
typedef enum LADDER_INS_ERROR {
    LADDER_INS_ERR_OK,         /**< OK */
    LADDER_INS_ERR_GETPREVVAL, /**< Error get previous value */
    LADDER_INS_ERR_GETDATAVAL, /**< Error get data value */
    LADDER_INS_ERR_SETDATAVAL, /**< Error set data value */
    LADDER_INS_ERR_NOFOREIGN,  /**< Error foreign function not exist */
    LADDER_INS_ERR_NOTABLE,    /**< Table not exist or net not disabled */
    LADDER_INS_ERR_OUTOFRANGE, /**< Value out of range */
    //...//
    LADDER_INS_ERR_FAIL,       /**< Generic fail */
} ladder_ins_err_t;Data types
typedef enum LADDER_DATA_TYPE {
    LADDER_DATATYPE_U8,       /**< Unsigned 8 bits */
    LADDER_DATATYPE_U16,      /**< Unsigned 16 bits */
    LADDER_DATATYPE_U32,      /**< Unsigned 32 bits */
    LADDER_DATATYPE_I8,       /**< Signed 8 bits */
    LADDER_DATATYPE_I16,      /**< Signed 16 bits */
    LADDER_DATATYPE_I32,      /**< Signed 32 bits */
    LADDER_DATATYPE_REAL,     /**< Float 32 bits */
    LADDER_DATATYPE_CSTR,     /**< Constant string */
    LADDER_DATATYPE_MOD_PORT, /**< Module.port format */
} ladder_data_type_t;typedef enum LADDER_BASETIME {
    LADDER_BASETIME_MS,    /**< Basetime ms */
    LADDER_BASETIME_10MS,  /**< Basetime 10 ms */
    LADDER_BASETIME_100MS, /**< Basetime 100 ms */
    LADDER_BASETIME_SEC,   /**< Basetime seconds */
    LADDER_BASETIME_MIN,   /**< Basetime minutes */
} ladder_basetime_t;typedef enum LADDER_REGISTERS {
    LADDER_REGISTER_NONE, /**< Register None */
    LADDER_REGISTER_M,    /**< Register M */
    LADDER_REGISTER_Q,    /**< Register Q */
    LADDER_REGISTER_I,    /**< Register I */
    LADDER_REGISTER_Cd,   /**< Register Cd */
    LADDER_REGISTER_Cr,   /**< Register Cr */
    LADDER_REGISTER_Td,   /**< Register Td */
    LADDER_REGISTER_Tr,   /**< Register Tr */
    LADDER_REGISTER_IW,   /**< Register IW */
    LADDER_REGISTER_QW,   /**< Register QW */
    LADDER_REGISTER_C,    /**< Register C */
    LADDER_REGISTER_T,    /**< Register T */
    LADDER_REGISTER_D,    /**< Register D */
    LADDER_REGISTER_S,    /**< Register string */
    LADDER_REGISTER_R,    /**< Register real (float) */
    //...//
    LADDER_REGISTER_INV,  /**< Register invalid */
} ladder_register_t;Describes an instruction's input/output configuration and cell occupancy.
typedef struct ladder_instructions_ioc_s {
    uint8_t inputs;   /**< Inputs quantity */
    uint8_t outputs;  /**< Outputs quantity */
    uint8_t cells;    /**< Cells quantity */
    uint8_t data_qty; /**< Quantity */
} ladder_instructions_iocd_t;- Fields:
- inputs: Number of input connections to the instruction.
- outputs: Number of output connections from the instruction.
- cells: Number of cells occupied by the instruction in the ladder diagram.
- data_qty: Quantity of data elements associated with the instruction.
 
Represents a value tied to a specific module and port, typically for I/O operations.
typedef struct ladder_moduleportvalue_s {
    uint8_t module; /**< Module */
    uint8_t port;   /**< Port */
} ladder_moduleportvalue_t;- Fields:
- module: Identifier of the module.
- port: Identifier of the port within the module.
 
A versatile container for values of different types used in ladder logic.
typedef struct ladder_value_s {
    ladder_register_t type; /**< Data type */
    union {
             uint8_t u8;    /**< Unsigned integer 8 bits */
            uint16_t u16;   /**< Unsigned integer 16 bits */
            uint32_t u32;   /**< Unsigned integer 32 bits */
              int8_t i8;    /**< Signed integer 8 bits */
             int16_t i16;   /**< Signed integer 16 bits */
             int32_t i32;   /**< Signed integer 32 bits */
          const char *cstr; /**< Constant string */
               float real;  /**< Float */
        moduleport_t mp;    /**< Module.port value */
    } value; /**< Data */
} ladder_value_t;- Fields:
- type: Specifies the value's data type (e.g.,- u32,- i32,- cstr,- real,- mp).
- value: Union containing the actual value, interpreted based on- type. Supports:- Unsigned integer 8 bits  (u8).
- Unsigned integer 16 bits  (u16).
- Unsigned integer 32 bits  (u32).
- Signed integer 8 bits  (i8).
- Signed integer 16 bits  (i16).
- Signed integer 32 bits  (i32).
- Constant string  (cstr).
- Float  (real).
- Module.port value  (mp).
 
- Unsigned integer 8 bits  (
 
Represents a single cell in the ladder diagram, encapsulating an instruction and its data.
typedef struct ladder_cell_s {
                    bool state;        /**< Output state */
                    bool vertical_bar; /**< Have vertical bar */
    ladder_instruction_t code;         /**< Code */
                 uint8_t data_qty;     /**< Data quantity */
          ladder_value_t *data;        /**< Data */
} ladder_cell_t;- Fields:
- state: Output state of the cell (- truefor active,- falsefor inactive).
- vertical_bar: Indicates the presence of a vertical bar (for ladder diagram rendering).
- code: Instruction code executed by the cell.
- data_qty: Number of data elements associated with the instruction.
- data: Pointer to an array of- ladder_value_tcontaining instruction data.
 
A network is a grid of cells forming a segment of the ladder logic program.
typedef struct ladder_network_s {
             bool enable;  /**< Enabled for execution */
         uint32_t rows;    /**< Rows qty */
         uint32_t cols;    /**< Columns qty */
    ladder_cell_t **cells; /**< Cells */
} ladder_network_t;- Fields:
- enable: Indicates whether the network is active for execution.
- rows: Number of rows in the network grid.
- cols: Number of columns in the network grid.
- cells: 2D array of pointers to- ladder_cell_t, representing the network's cells.
 
Holds the internal state and configuration of the ladder logic system.
typedef struct ladder_s {
    ladder_state_t state; /**< State */
    struct {
         uint8_t instr;       /**< Last executed instruction */
        uint32_t network;     /**< Last executed network */
        uint32_t cell_column; /**< Last executed cell column */
        uint32_t cell_row;    /**< Last executed cell row */
         uint8_t err;         /**< Last executed error */
    } last;
    struct {
        uint32_t m;        /**< Quantity of regular flags */
        uint32_t c;        /**< Quantity of counters */
        uint32_t t;        /**< Quantity of timers */
        uint32_t d;        /**< Quantity of regular registers */
        uint32_t r;        /**< Quantity of floating point registers */
        uint32_t networks; /**< Quantity of networks */
    } quantity;
} ladder_t;- Fields:
- state: Current operational state of the ladder system.
- last: Substructure tracking the last executed instruction:- instr: Instruction code.
- network: Network index.
- cell_column: Column of the executed cell.
- cell_row: Row of the executed cell.
- err: Error code from the last execution.
 
- quantity: Substructure defining the system's capacity:- m: Number of regular flags.
- c: Number of counters.
- t: Number of timers.
- d: Number of regular registers.
- r: Number of floating-point registers.
- networks: Number of networks.
 
 
Defines hardware-dependent functions for I/O and time management.
typedef struct ladder_hw_s {
    struct {
         uint32_t fn_read_qty;  /**< Quantity of read functions */
         uint32_t fn_write_qty; /**< Quantity of write functions */
         _io_read *read;        /**< Read hardware values */
        _io_write *write;       /**< Write hardware values */
         _io_init *init_read;   /**< Initialize read functions */
         _io_init *init_write;  /**< Initialize write functions */
    } io;
    struct {
        _millis millis; /**< Milliseconds from system start */
         _delay delay;  /**< Delay in milliseconds */
    } time;
} ladder_hw_t;- Fields:
- io: Substructure for I/O operations:- fn_read_qty: Number of read functions.
- fn_write_qty: Number of write functions.
- read: Array of read function pointers.
- write: Array of write function pointers.
- init_read: Array of read initialization functions.
- init_write: Array of write initialization functions.
 
- time: Substructure for time management:- millis: Function to get current time.
- delay: Function to delay execution.
 
 
Stores input values read from hardware.
typedef struct ladder_hw_input_vals_s {
    uint32_t fn_id;  /**< Function id */
    uint32_t i_qty;  /**< Digital inputs quantity */
    uint32_t iw_qty; /**< Analog inputs quantity */
     uint8_t *I;     /**< Digital inputs */
     int32_t *IW;    /**< Analog inputs */
     uint8_t *Ih;    /**< Digital inputs previous */
} ladder_hw_input_vals_t;- Fields:
- fn_id: Identifier of the read function.
- i_qty: Number of digital inputs.
- iw_qty: Number of analog inputs.
- I: Array of digital input values.
- IW: Array of analog input values.
- Ih: Array of previous digital input values (for change detection).
 
Stores output values to be written to hardware.
typedef struct ladder_hw_output_vals_s {
    uint32_t fn_id;  /**< Function id */
    uint32_t q_qty;  /**< Digital outputs quantity */
    uint32_t qw_qty; /**< Analog outputs quantity */
     uint8_t *Q;     /**< Digital outputs */
     int32_t *QW;    /**< Analog outputs */
     uint8_t *Qh;    /**< Digital outputs previous */
} ladder_hw_output_vals_t;- Fields:
- fn_id: Identifier of the write function.
- q_qty: Number of digital outputs.
- qw_qty: Number of analog outputs.
- Q: Array of digital output values.
- QW: Array of analog output values.
- Qh: Array of previous digital output values.
 
Contains memory flags and status bits for counters and timers.
typedef struct ladder_memory_s {
    uint8_t *M;  /**< Regular flags */
       bool *Cr; /**< Counter running */
       bool *Cd; /**< Counter done */
       bool *Tr; /**< Timer running */
       bool *Td; /**< Timer done */
} ladder_memory_t;- Fields:
- M: Array of regular memory flags.
- Cr: Array indicating if counters are running.
- Cd: Array indicating if counters are done.
- Tr: Array indicating if timers are running.
- Td: Array indicating if timers are done.
 
Stores previous scan values for memory flags and status bits.
typedef struct ladder_prev_scan_vals_s {
    uint8_t *Mh;  /**< Regular flags previous */
       bool *Crh; /**< Counter running previous */
       bool *Cdh; /**< Counter done previous */
       bool *Trh; /**< Timer running previous */
       bool *Tdh; /**< Timer done previous */
} ladder_prev_scan_vals_t;- Fields:
- Mh: Previous regular memory flags.
- Crh: Previous counter running states.
- Cdh: Previous counter done states.
- Trh: Previous timer running states.
- Tdh: Previous timer done states.
 
Manages counter, integer, and floating-point registers.
typedef struct ladder_registers_s {
    uint32_t *C; /**< Counter registers */
     int32_t *D; /**< Regular registers */
       float *R; /**< Floating point registers */
} ladder_registers_t;- Fields:
- C: Array of counter register values.
- D: Array of regular integer register values.
- R: Array of floating-point register values.
 
Represents a timer with its timestamp and accumulator.
typedef struct ladder_timer_s {
    uint64_t time_stamp; /**< Time stamp */
    uint32_t acc;        /**< Activated counter */
} ladder_timer_t;- Fields:
- time_stamp: Time when the timer was last updated.
- acc: Accumulated time or count for the timer.
 
Manages timing data for scan cycles.
typedef struct ladder_scan_internals_s {
    uint64_t actual_scan_time; /**< Actual scan time */
    uint64_t start_time;       /**< Start time for calculate scan time */
} ladder_scan_internals_t;- Fields:
- actual_scan_time: Duration of the last scan cycle.
- start_time: Starting time of the current scan cycle.
 
Defines a foreign function with its properties and execution logic.
typedef struct ladder_foreign_function_s {
                      uint32_t id;          /**< Foreign function id */
                          char name[4];     /**< Foreign function name */
    ladder_instructions_iocd_t description; /**< Foreign function description */
                   ladder_fn_t exec;        /**< Foreign functions pointers */
            _foreign_fn_deinit deinit;      /**< Foreign functions deinitializer pointers */
                         void *data;        /**< Internal data for foreign functions */
} ladder_foreign_function_t;- Fields:
- id: Unique identifier for the function.
- name: Short name (up to 3 characters + null terminator).
- description: Input/output configuration (- ladder_instructions_iocd_t).
- exec: Pointer to the execution function.
- deinit: Pointer to the deinitialization function.
- data: Pointer to internal data for the function.
 
Manages a collection of foreign functions.
typedef struct ladder_foreign_s {
                     uint32_t qty; /**< Foreign functions quantity */
    ladder_foreign_function_t *fn; /**< Main foreign function definition */
} ladder_foreign_t;- Fields:
- qty: Number of foreign functions.
- fn: Array of- ladder_foreign_function_tstructures.
 
The central structure tying together all components of the ladder logic system.
typedef struct ladder_ctx_s {
                   ladder_t ladder;         /**< Internals */
                ladder_hw_t hw;             /**< Hardware functions */
            ladder_manage_t on;             /**< Manage functions */
            ladder_memory_t memory;         /**< Memory */
    ladder_prev_scan_vals_t prev_scan_vals; /**< Previous scan values */
    ladder_hw_input_vals_t *input;          /**< Hw inputs */
    ladder_hw_output_vals_t *output;        /**< Hw outputs */
         ladder_registers_t registers;      /**< Registers */
             ladder_timer_t *timers;        /**< Timers */
    ladder_scan_internals_t scan_internals; /**< Scan internals */
           ladder_network_t *network;       /**< Networks */
           ladder_network_t *exec_network;  /**< Network in execution */
           ladder_foreign_t foreign;        /**< Foreign functions */
} ladder_ctx_t;- Fields:
- ladder: Internal state and configuration (- ladder_t).
- hw: Hardware interface functions (- ladder_hw_t).
- on: Management callbacks (- ladder_manage_t):- scan_end: Called at the end of each scan cycle.
- instruction: Called for each instruction.
- task_before: Called before each task cycle.
- task_after: Called after each task cycle.
- panic: Called during panic conditions.
- end_task: Called at task completion.
 
- memory: Memory flags and status bits (- ladder_memory_t).
- prev_scan_vals: Previous scan values (- ladder_prev_scan_vals_t).
- input: Array of hardware input values (- ladder_hw_input_vals_t).
- output: Array of hardware output values (- ladder_hw_output_vals_t).
- registers: Register storage (- ladder_registers_t).
- timers: Array of timers (- ladder_timer_t).
- scan_internals: Scan cycle timing data (- ladder_scan_internals_t).
- network: Array of networks (- ladder_network_t).
- exec_network: Currently executing network (- ladder_network_t).
- foreign: Foreign function definitions (- ladder_foreign_t).
 
This section lists all callback prototypes used by LadderLib, with their exact function signatures and purposes.
void (*_io_read)(ladder_ctx_t* ladder_ctx, uint32_t id)  Description: Reads hardware values and updates the input bits in the ladder context.
Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context. | 
| id | Identifier of the input to read. | 
Returns: None.
void (*_io_write)(ladder_ctx_t* ladder_ctx, uint32_t id)  Description: Writes hardware values based on the output bits in the ladder context.
Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context. | 
| id | Identifier of the output to write. | 
Returns: None.
bool (*_io_init)(ladder_ctx_t* ladder_ctx, uint32_t id, bool init_deinit)  Description: Initializes or deinitializes an I/O function.
Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context. | 
| id | Identifier of the I/O function. | 
| init_deinit | trueto initialize,falseto deinitialize. | 
Returns: true if successful, false otherwise.
bool (*_on_scan_end)(ladder_ctx_t* ladder_ctx)  Description: Called at the end of each scan cycle for custom processing.
Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context. | 
Returns: true to continue execution, false to stop.
bool (*_on_instruction)(ladder_ctx_t* ladder_ctx)  Description: Called for each instruction executed during a scan.
Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context. | 
Returns: true to continue execution, false to stop.
bool (*_on_task_before)(ladder_ctx_t* ladder_ctx)  Description: Called before each task cycle scan begins.
Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context. | 
Returns: true to proceed with the scan, false to skip.
bool (*_on_task_after)(ladder_ctx_t* ladder_ctx)  Description: Called after each task cycle scan completes.
Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context. | 
Returns: true to continue, false to stop.
void (*_on_panic)(ladder_ctx_t* ladder_ctx)  Description: Handles panic situations, such as critical errors.
Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context. | 
Returns: None.
void (*_on_end_task)(ladder_ctx_t* ladder_ctx)  Description: Called when a task ends, for cleanup or final actions.
Parameters:
| Parameter | Description | 
|---|---|
| ladder_ctx | Pointer to the ladder context. | 
Returns: None.
void (*_delay)(long msec)  Description: Implements a delay in milliseconds.
Parameters:
| Parameter | Description | 
|---|---|
| msec | Duration of the delay in milliseconds. | 
Returns: None.
uint64_t (*_millis)(void)  Description: Returns the time elapsed since system start in milliseconds.
Parameters: None.
Returns: Number of milliseconds as a 64-bit unsigned integer.
To use Ladderlib, follow these steps:
- Initialize Context: Call ladder_ctx_initwith appropriate quantities for networks, memory areas, counters, timers, data, and registers.
- Define Program: Populate the ladder_sstructure by defining networks (ladder_network_s) and cells (ladder_cell_s), assigning instructions fromLADDER_INSTRUCTIONSand configuring data or timers as needed.
- Set Hardware Callbacks: Provide functions for hardware interactions in ladder_hw_s, such as_io_readand_io_write, to interface with physical devices.
- Set Event Callbacks: Optionally, assign callbacks in ladder_manage_sfor events like scan end (_on_scan_end) or panic handling (_on_panic).
- Run Task: Execute the ladder logic by calling ladder_taskto process the program and interact with hardware.
- Monitor and Handle Errors: Check ladder.state and ladder.err to monitor execution status and handle errors.
- Deinitialize: Call ladder_ctx_deinitto free resources when the program is no longer needed.
Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.
If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement". Don't forget to give the project a star! Thanks again!
- Fork it (https://github.com/hiperiondev/ladderlib/fork)
- Create your feature branch (git checkout -b feature/fooBar)
- Commit your changes (git commit -am 'Add some fooBar')
- Push to the branch (git push origin feature/fooBar)
- Create a new Pull Request
Distributed under the MIT License. See LICENSE.txt for more information.
Emiliano Augusto Gonzalez - egonzalez.hiperion@gmail.com
 
  

































