1. Components
Most of the commands in the following list have their own dedicated man pages.
Some will have expanded descriptions, some will have limited descriptions.
From this list you know what components exist, and you can use man
name on your UNIX command line to get additional information.
To view the information in the man page, in a terminal window type:
man axis
The one or other setup of a UNIX system may require to explicitly specify the section of the man page.
If you do not find the man page or the name of the man page is already taken by another UNIX tool with the LinuxCNC man page residing in another section,
then try to explicitly specify the section, as in man _sectionno_ axis
, with sectionno = 1 for non-realtime and 9 for realtime components.
Note
|
See also the Man Pages section of the docs main page or the directory listing.
To search in the man pages, use the UNIX tool apropos . |
1.1. User Interfaces (non-realtime)
1.1.1. Machine Control
AXIS LinuxCNC (The Enhanced Machine Controller) GUI |
|||
AXIS Remote Interface |
|||
Touchy LinuxCNC Graphical User Interface |
|||
Touchy LinuxCNC Graphical User Interface |
|||
Observe HAL pins and command LinuxCNC through NML |
|||
manual only Digital Read Out (DRO) |
|||
Framework for conversational G-code generation on the controller |
|||
Short description |
|||
Python implementation of NGCGUI |
|||
AXIS - TOUCHY LinuxCNC Graphical User Interface |
1.1.2. Virtual Control Panels (VCP)
Virtual Control Panel for LinuxCNC based on Glade, Gtk and HAL widgets |
|||
GladeVCP - used by sample configs to deonstrate Glade Virtual_demo |
|||
G-code graphical preview |
|||
GUI for the moveoff component |
|||
Utility for panelui |
|||
Virtual Control Panel for LinuxCNC |
|||
Python Virtual Control Panel demonstration component |
|||
Qt based virtual control panel |
1.1.3. Vismach Virtual Machines
Vismach Virtual Machine GUI |
|||
Vismach Virtual Machine GUI |
|||
Vismach Virtual Machine GUI |
|||
Vismach Virtual Machine GUI |
|||
hexagui - Vismach Virtual Machine GUI |
|||
hexagui - Vismach Virtual Machine GUI |
|||
puma560agui - Vismach Virtual Machine GUI |
|||
Vismach Virtual Machine GUI |
|||
Vismach Virtual Machine GUI |
|||
Vismach Virtual Machine GUI |
|||
Vismach Virtual Machine GUI |
|||
Vismach Virtual Machine GUI |
1.2. Motion (non-realtime)
1.3. Hardware Drivers
1.3.1. VFD & Communication Interfaces (non-realtime)
Communicate with Mesa ethernet cards |
|||
HAL non-realtime component for Automation Direct GS2 VFDs |
|||
HAL non-realtime component for Huanyang GT-series VFDs |
|||
HAL non-realtime component for Huanyang VFDs |
|||
MB2HAL is a generic non-realtime HAL component to communicate with one or more Modbus devices. Modbus RTU and Modbus TCP are supported. |
|||
HAL non-realtime component for Mitsubishi A500 F500 E500 A500 D700 E700 F700-series VFDs (others may work) |
|||
Monitors the XHC-HB04 pendant and warns of disconnection |
|||
Powtran PI500 modbus driver |
|||
Modbus communications with a Powermax Plasma Cutter |
|||
Modbus communications testing with a Powermax Plasma Cutter |
|||
control HAL pins with the ShuttleXpress, ShuttlePRO, and ShuttlePRO2 device made by Contour Design |
|||
HAL non-realtime component for SVD-P(S) VFDs |
|||
HAL non-realtime component for Delta VFD-B Variable Frequency Drives |
|||
HAL non-realtime component for Toshiba-Schneider VF-S11 Variable Frequency Drives |
|||
Hitachi wj200 modbus driver |
|||
Non-realtime HAL component for the xhc-hb04 pendant |
|||
Obsolete script for jogging wheel |
|||
Non-realtime jog dial HAL component for the wireless XHC WHB04B-6 USB device |
1.4. Mesa and other I/O Cards (Realtime)
hal_ppmc |
Pico Systems driver for analog servo, PWM and Stepper controller |
||
Driver for beaglebone GPIO pins |
|||
Realtime HAL component to communicate with one or more PC parallel ports |
|||
Mesa Electronics driver for the 7I43 EPP Anything IO board with HostMot2. (See the man page for more information) |
|||
LinuxCNC HAL driver for the Mesa Electronics 7I90 EPP Anything IO board with HostMot2 firmware |
|||
LinuxCNC HAL driver for the Mesa Electronics Ethernet Anything IO boards, with HostMot2 firmware |
|||
Mesa Electronics driver for the 5I20, 5I22, 5I23, 4I65, and 4I68 Anything I/O boards, with HostMot2 firmware. (See the man page for more information) |
|||
LinuxCNC HAL driver for the Mesa Electronics SPI Anything IO boards, with HostMot2 firmware |
|||
LinuxCNC HAL driver for the Mesa Electronics SPI Anything IO boards, with HostMot2 firmware |
|||
Mesa Electronics driver for the HostMot2 firmware. |
|||
Support for the MAX31855 Thermocouple-to-Digital converter using bitbanged SPI |
|||
Mesa Electronics driver for the 7I65 eight-axis servo card. (See the man page for more information) |
|||
PktUART simple test with Microstrain 3DM-GX3-15 gyro |
|||
Realtime driver for opto22 PCI-AC5 cards |
|||
pluto_servo |
Pluto-P driver and firmware for the parallel port FPGA, for servos |
||
pluto_step |
Pluto-P driver for the parallel port FPGA, for steppers |
||
Hardware driver for the digital I/O bits of the 8250 and 16550 serial port |
|||
hostmot2 - Smart Serial LinuxCNC HAL driver for the Mesa Electronics HostMot2 Smart-Serial remote cards |
|||
Torch Height Control using a Mesa THC card or any analog to velocity input |
1.5. Utilities (non-realtime)
Plots the value of a HAL pin as a histogram |
|||
Build, compile and install LinuxCNC HAL components |
|||
Observe HAL pins, signals, and parameters |
|||
Manipulate the LinuxCNC HAL from the command line |
|||
Short description |
|||
Creates a report on the status of the HAL |
|||
Short description |
|||
Manipulate the LinuxCNC HAL from the command line |
|||
Sample data from HAL in realtime |
|||
Software oscilloscope for viewing real time waveforms of HAL pins and signals |
|||
Show HAL parameters, pins and signals |
|||
Stream file data into HAL in real time |
|||
Manipulates the LinuxCNC HAL from the command line using Tcl |
|||
Converts bitmap images to G-code |
|||
Plots histogram of machine latency |
|||
Another way to view latency numbers |
|||
Tests the realtime system latency |
|||
Configuration wizard for Mesa cards |
|||
Utility for setting Smart Serial NVRAM parameters. NOTE: This rather clunky utility is no longer needed except for flashing new smart-serial remote firmware. Smart-serial remote parameters can now be set in the HAL file in the normal way. |
|||
GUI for displaying and setting one or more HAL inputs |
|||
Configuration wizard for parallel-port based machines |
1.6. Signal processing (Realtime)
1.6.1. Logic and Bitwise
Two-input AND gate. For out to be true both inputs must be true. (and2) |
|||
Computes various bitwise operations on the two input values |
|||
Filter noisy digital inputs Details |
|||
Filter noisy digital inputs Details Description |
|||
Select one of several output pins by integer and/or or individual bits |
|||
Edge detector |
|||
E-stop latch |
|||
D-type flip-flop |
|||
General logic function component |
|||
5-input logic function based on a look-up table Description |
|||
8-bit binary match detector |
|||
Single-, double-, triple-, and quadruple-click detector |
|||
Toggles between a specified number of output bits |
|||
Inverter |
|||
One-shot pulse generator |
|||
Two-input OR gate |
|||
8-bit binary match detector. |
|||
IEC TOF timer - delay falling edge on a signal |
|||
Push-on, push-off from momentary pushbuttons |
|||
Toggle button to nist logic |
|||
IEC TON timer - delay rising edge on a signal |
|||
Equivalent of a time-delay relay. |
|||
IEC TP timer - generate a high pulse of defined duration on rising edge |
|||
Places signal on an I/O pin only when enabled, similar to a tristate buffer in electronics |
|||
Places signal on an I/O pin only when enabled, similar to a tristate buffer in electronics |
|||
Two-input XOR (exclusive OR) gate |
1.6.2. Arithmetic and float
Computes the absolute value and sign of the input signal |
|||
Computes the absolute value and sign of the input signal |
|||
Biquad IIR filter |
|||
Perform linear interpolation between two values |
|||
Two input comparator with hysteresis |
|||
Uses parameter to set the value of a pin |
|||
Counts input pulses (deprecated). Use the encoder component. |
|||
Computes the derivative of the input function. |
|||
Returns the center if within the threshold. |
|||
Quotient of two floating point inputs. |
|||
Three-input hypotenuse (Euclidean distance) calculator. |
|||
Low-pass filter with integer inputs and outputs |
|||
Integrator |
|||
Computes the inverse of the input signal. |
|||
Unidimensional Kalman filter, also known as linear quadratic estimation (LQE) |
|||
Converts counts (probably from an encoder) to a float value. |
|||
Low-pass filter |
|||
Limits the output signal to fall between min and max. |
|||
Limits the output signal to fall between min and max. Limit its slew rate to less than maxv per second.
|
|||
Limit the output signal to fall between min and max.
Limit its slew rate to less than maxv per second. Limit its second derivative to less than MaxA per second squared |
|||
One-dimensional lookup table |
|||
Compute the majority of 3 inputs |
|||
Tracks the minimum and maximum values of the input to the outputs. |
|||
Product of two inputs. |
|||
Select from one of 16 input values (multiplexer). |
|||
Select from one of two input values (multiplexer). |
|||
Select from one of four input values (multiplexer). |
|||
Select from one of eight input values (multiplexer). |
|||
Select one from several input values (multiplexer). |
|||
Determine whether two values are roughly equal. |
|||
Adds an offset to an input, and subtracts it from the feedback value. |
|||
Sample and Hold. |
|||
Applies a scale and offset to its input. |
|||
Sum of two inputs (each with a gain) and an offset. |
|||
Component that measures thread scheduling timing behavior. |
|||
Counts up or down, with optional limits and wraparound behavior. |
|||
Window comparator. |
|||
Convert a group of bits to an integer. |
|||
xhc-hb04 convenience utility |
1.6.3. Type conversion
Converts a number to the gray-code representation |
|||
Converts an unsigned-32 input into individual bits |
|||
Converts from bit to float |
|||
Converts from bit to s32 |
|||
Converts from bit to u32 |
|||
Converts from float to s32 |
|||
Converts from float to u32 |
|||
Converts from s32 to bit |
|||
Converts from s32 to float |
|||
Converts from s32 to u32 |
|||
Converts from u32 to bit |
|||
Converts from u32 to float |
|||
Converts from u32 to s32 |
|||
Converts gray-code input to binary |
1.7. Kinematics (Realtime)
CoreXY kinematics |
|||
Kinematics for a differential transmission |
|||
LinuxCNC HAL component for driving multiple joints from a single axis |
|||
Kinematics module that maps one axis to multiple joints. |
|||
Gives six degrees of freedom in position and orientation (XYZABC). The location of the motors is defined at compile time. |
|||
Kinematics that can model a general serial-link manipulator with up to 6 angular joints. |
|||
See trivkins |
|||
Kinematics definitions for LinuxCNC. |
|||
Kinematics for a linear delta robot |
|||
Kinematics for a tabletop 5 axis mill named max with tilting head (B axis) and horizontal rotary mounted to the table (C axis). Provides UVW motion in the rotated coordinate system. The source file, maxkins.c, may be a useful starting point for other 5-axis systems. |
|||
Switchable kinematics for a mill-turn machine |
|||
Kinematics for PUMA-style robots. |
|||
Kinematics for a rose engine |
|||
The X and Y axes are rotated 45 degrees compared to the joints 0 and 1. |
|||
Kinematics for SCARA-type robots. |
|||
The joints represent the distance of the controlled point from three predefined locations (the motors), giving three degrees of freedom in position (XYZ). |
|||
1:1 correspondence between joints and axes. Most standard milling machines and lathes use the trivial kinematics module. |
|||
Template for user-built kinematics |
1.8. Motion control (Realtime)
Accepts NML motion commands, interacts with HAL in realtime |
1.9. Motor control (Realtime)
Proportional/integral/derivative controller with auto tuning. |
|||
BLDC and AC-servo control component |
|||
Two input version of Clarke transform |
|||
Clarke (3 phase to cartesian) transform |
|||
Inverse Clarke transform |
|||
Software counting of quadrature encoder signals, see Description. |
|||
Proportional/integral/derivative controller, Description. |
|||
Software PWM/PDM generation, see Description. |
|||
Software step pulse generation, see Description. |
1.10. Other (Realtime)
Build, compile and install LinuxCNC HAL components. |
|||
Realtime software PLC based on ladder logic. See ClassicLadder chapter for more information. |
|||
Creates hard realtime HAL threads. |
|||
Creates a square-wave for the charge pump input of some controller boards. The Charge Pump should be added to the base thread function. When enabled, the output is on for one period and off for one period. To calculate the frequency [Hz] of the output: 1/(period time in seconds x 2). For example, if you have a base period of 100,000 ns that is 0.0001 seconds and the formula would be 1/(0.0001 x 2) = 5,000 Hz or 5 kHz. |
|||
Electronic gear to synchronize two axes. |
|||
Multiply the input by the ratio of current velocity to the feed rate. |
|||
displays Virtual control Panels built with GTK / GLADE |
|||
Select from one of two speed ranges. |
|||
Sets nonlinear joypad movements, deadbands and scales. |
|||
Sample data from HAL in real time. |
|||
Signal generator, see Description. |
|||
Simulated quadrature encoder, see Description. |
|||
Probe a pretend hemisphere. |
|||
Used by StepConf to allow testing of acceleration and velocity values for an axis. |
|||
Stream file data into HAL in real time. |
|||
Set output pins with values from parameters (deprecated). |
|||
Component for testing thread behavior. |
|||
Accumulated run-time timer counts HH:MM:SS of active input. |
|||
Monitor one to thirty-two inputs for a heartbeat. |
1.11. Not categorized (auto generated from man pages)
Jog two axes (or joints) at an angle |
|||
Used to allow testing of an axis. Used IN PnCconf. |
|||
Orient a toolchanger carousel using various encoding schemes |
|||
sets the debug level for the non-realtime part of LinuxCNC |
|||
Adjust ini tuning variables on the fly with save option |
|||
enumerate integer values into bits |
|||
Compute External Offset Per Angle |
|||
control HAL pins with any Linux input device, including USB HID devices |
|||
HAL non-realtime component to enable manual tool changes. |
|||
histogram bins utility for scripts/hal-histogram |
|||
homing module template |
|||
Query an INI file |
|||
comp utility for scripts/latency-histogram |
|||
Stream HAL data to an LCD screen |
|||
Dynamic range based axis limits |
|||
LinuxCNC (The Enhanced Machine Controller) |
|||
collects information about the LinuxCNC version and the host |
|||
controls root access for system hardware |
|||
retrieves LinuxCNC variables |
|||
LinuxCNC Graphical User Interface for LCD character display |
|||
create a desktop icon for LinuxCNC |
|||
text-mode interface for commanding LinuxCNC over the network |
|||
Allows network access to LinuxCNC internals via NML |
|||
live LinuxCNC status description |
|||
Convert integers to HAL pins. Optionally scan a matrix of IO ports to create those integers. |
|||
Vismach Virtual Machine GUI |
|||
An example component demonstrating how to access the Hostmot2 UART |
|||
Display a message |
|||
millturngui - Vismach Virtual Machine GUI |
|||
Utility for compiling Modbus drivers |
|||
log motion commands sent from LinuxCNC’s Task module |
|||
Component for HAL-only offsets |
|||
send HAL pin data to MQTT broker periodically |
|||
LinuxCNC HAL component that uses a Mesa THCAD for ohmic sensing |
|||
Provide a PID command input for orientation mode based on current spindle position, target angle and orient mode |
|||
A plasma cutter controller |
|||
Convert plasma parameters. |
|||
Create a plasma materials file. |
|||
Migrate a PlasmaC configuration. |
|||
Switch a QtPlasmaC installation type. |
|||
A python script that is part of Plasmac, a Plasma cutting system. |
|||
standalone G-code interpreter |
|||
creates a simulated real time environment |
|||
Sum of four inputs (each with a scale) |
|||
telnet based scheduler for LinuxCNC |
|||
to link the Intellitek Scorbot educational robot to LinuxCNC |
|||
send input events based on pins or scancodes from HAL |
|||
A script to configure the system for use of QTdesigner |
|||
A simulated plasma torch |
|||
A component to simulate home and limit switches |
|||
Home switch simulator |
|||
convert HAL pin inputs to keycodes |
|||
A component to simulate the pins of the hal_parport component |
|||
Simulated spindle with index pulse |
|||
This component is a single axis simple trajectory planner, same as used for jogging in LinuxCNC. |
|||
simulate a probe input |
|||
Control a spindle with different acceleration and deceleration and optional gear change scaling |
|||
spindle at-speed and underspeed detection |
|||
jog the machine to a position, and record the state |
|||
Torch Height Control Up/Down Input |
|||
compute temperature indicated by a thermistor |
|||
A component of the tool database system (an alternative to the classic tooltable) |
|||
A component of the tool database system (an alternative to the classic tooltable) |
|||
tool table editor |
|||
Trajectory Planning (tp) module skeleton |
|||
converts 2.7 format INI files to 2.8 format |
|||
Vismach Virtual Machine GUI |
|||
Switchable kinematics for 5 axis machine with rotary table A and B |
1.12. Without man page or broken link (auto generated from component list)
hal_ppmc |
|||
pluto_servo |
|||
pluto_step |
2. HAL API calls
hal_add_funct_to_thread.3hal
hal_bit_t.3hal
hal_create_thread.3hal
hal_del_funct_from_thread.3hal
hal_exit.3hal
hal_export_funct.3hal
hal_float_t.3hal
hal_get_lock.3hal
hal_init.3hal
hal_link.3hal
hal_malloc.3hal
hal_param_bit_new.3hal
hal_param_bit_newf.3hal
hal_param_float_new.3hal
hal_param_float_newf.3hal
hal_param_new.3hal
hal_param_s32_new.3hal
hal_param_s32_newf.3hal
hal_param_u32_new.3hal
hal_param_u32_newf.3hal
hal_parport.3hal
hal_pin_bit_new.3hal
hal_pin_bit_newf.3hal
hal_pin_float_new.3hal
hal_pin_float_newf.3hal
hal_pin_new.3hal
hal_pin_s32_new.3hal
hal_pin_s32_newf.3hal
hal_pin_u32_new.3hal
hal_pin_u32_newf.3hal
hal_ready.3hal
hal_s32_t.3hal
hal_set_constructor.3hal
hal_set_lock.3hal
hal_signal_delete.3hal
hal_signal_new.3hal
hal_start_threads.3hal
hal_type_t.3hal
hal_u32_t.3hal
hal_unlink.3hal
intro.3hal
undocumented.3hal
3. RTAPI calls
EXPORT_FUNCTION.3rtapi
MODULE_AUTHOR.3rtapi
MODULE_DESCRIPTION.3rtapi
MODULE_LICENSE.3rtapi
RTAPI_MP_ARRAY_INT.3rtapi
RTAPI_MP_ARRAY_LONG.3rtapi
RTAPI_MP_ARRAY_STRING.3rtapi
RTAPI_MP_INT.3rtapi
RTAPI_MP_LONG.3rtapi
RTAPI_MP_STRING.3rtapi
intro.3rtapi
rtapi_app_exit.3rtapi
rtapi_app_main.3rtapi
rtapi_clock_set_period.3rtapi
rtapi_delay.3rtapi
rtapi_delay_max.3rtapi
rtapi_exit.3rtapi
rtapi_get_clocks.3rtapi
rtapi_get_msg_level.3rtapi
rtapi_get_time.3rtapi
rtapi_inb.3rtapi
rtapi_init.3rtapi
rtapi_module_param.3rtapi
RTAPI_MP_ARRAY_INT.3rtapi
RTAPI_MP_ARRAY_LONG.3rtapi
RTAPI_MP_ARRAY_STRING.3rtapi
RTAPI_MP_INT.3rtapi
RTAPI_MP_LONG.3rtapi
RTAPI_MP_STRING.3rtapi
rtapi_mutex.3rtapi
rtapi_outb.3rtapi
rtapi_print.3rtap
rtapi_prio.3rtapi
rtapi_prio_highest.3rtapi
rtapi_prio_lowest.3rtapi
rtapi_prio_next_higher.3rtapi
rtapi_prio_next_lower.3rtapi
rtapi_region.3rtapi
rtapi_release_region.3rtapi
rtapi_request_region.3rtapi
rtapi_set_msg_level.3rtapi
rtapi_shmem.3rtapi
rtapi_shmem_delete.3rtapi
rtapi_shmem_getptr.3rtapi
rtapi_shmem_new.3rtapi
rtapi_snprintf.3rtapi
rtapi_task_delete.3rtpi
rtapi_task_new.3rtapi
rtapi_task_pause.3rtapi
rtapi_task_resume.3rtapi
rtapi_task_start.3rtapi
rtapi_task_wait.3rtapi