MOXA IoThinx 4530 Series Advanced Controllers User Manual
- June 5, 2024
- MOXA
Table of Contents
MOXA IoThinx 4530 Series Advanced Controllers User Manual
Introduction
This user’s manual applies to the ioThinx 4530 Series models listed below:
ioThinx 4530 Series
ioThinx 4533-LX Series
Detailed instructions on configuring advanced settings are covered in Chapters
3 and 4.
Getting Started
Connecting to the ioThinx 4530 Controller
You will need to use a computer to connect to the ioThinx 4530 controller and to log in through the command line interface. There are two ways to connect: through the serial console port or through the Ethernet port. Refer to the ioThinx 4530 Series Hardware Manual to see how to set up the physical connections.
The default login username and password are:
Username: moxa
Password: moxa
The username and password are the same for all serial console and SSH remote log in actions. Root account login is disabled until you manually create a password for the account. The user moxa is in the sudo group so that you can operate system level commands with this user using the sudo command. For additional details, see the Sudo Mechanism section in chapter 5
ATTENTION
For security reasons, we recommend that you disable the default user account
and create your own user accounts.
Connecting Through the Serial Console
This method is particularly useful when using the computer for the first time. The signal is transmitted over a direct serial connection so you do not need to know either of its two IP addresses in order to connect to the ioThinx 4530 controller. To connect through the serial console, configure your PC’s terminal software using the following settings.
Serial Console Port Settings
Baudrate| 115200 bps
Parity| None
Data bits| 8
Stop bits| 1
Flow control| None
Terminal| VT100
Below we show how to use the terminal software to connect to the ioThinx 4530 controller in a Linux environment and in a Windows environment.
Linux Users
NOTE These steps apply to the Linux PC you are using to connect to the ioThinx 4530 controller. Do NOT apply these steps to the ioThinx 4530 controller itself.
Take the following steps to connect to the ioThinx 4530 controller from your Linux PC.
-
Install minicom from the package repository of your operating system. For Centos and Fedora:
user@PC1:~# yum -y install minicom
For Ubuntu and Debian:
user@PC2:~# apt-get install minicom -
Use the minicom –s command to enter the configuration menu and set up the serial port settings.
user@PC1:~# minicom –s -
Select Serial port setup
-
Select A to change the serial device. Note that you need to know which device node is connected to the ioThinx 4530 controller.
-
Select E to configure the port settings according to the Serial Console Port Settings table provided.
-
Select Save setup as dfl (from the main configuration menu) to use default values.
-
Select Exit from minicom (from the configuration menu) to leave the configuration menu.
-
Execute minicom after completing the above configurations.
Windows Users
NOTE These steps apply to the Windows PC you are using to connect to the ioThinx 4530 controller. Do NOT apply these steps to the ioThinx 4530 controller itself.
Take the following steps to connect to the ioThinx 4530 controller from your Windows PC.
-
Download PuTTY http://www.chiark.greenend.org.uk/~sgtatham/putty/download.html to set up a serial connection with the ioThinx 4530 controller in a Windows environment.
-
Once the connection is established, the following window will open.
-
Select the Serial connection type and choose settings
Connecting Through the SSH Console
The ioThinx 4530 controller supports SSH connections over an Ethernet network. Use the following default IP addresses to connect to the ioThinx 4530 controller.
Port | Default IP |
---|---|
LAN 1 | 192.168.127.254 |
LAN 2 | 192.168.126.254 |
Linux Users
NOTE These steps apply to the Linux PC you are using to connect to the ioThinx 4530 controller. Do NOT apply these steps to the ioThinx 4530 controller itself. Before you run the ssh command, be sure to configure the IP address of your notebook/PC’s Ethernet interface in the range of 192.168.127.0/24 for LAN1 and 192.168.126.0/24 for LAN2.
Use the ssh command from a Linux computer to access the ioThinx 4530 controller’s LAN1 port.
Type yes to complete the connection.
ATTENTION
Rekey SSH regularly
In order to secure your system, we suggest doing a regular SSH-rekey, as shown
in the following steps:
When prompted for a passphrase, leave the passphrase empty and press enter.
For more information about SSH, refer to the following link.
Windows Users
NOTE These steps apply to the Windows PC you are using to connect to the ioThinx 4530 controller. Do NOT apply these steps to the ioThinx 4530 controller itself.
Take the following steps from your Windows PC. Click on the link http://www.chiark.greenend.org.uk/~sgtatham/putty/download.html to download PuTTY (free software) to set up an SSH console for the ioThinx 4530 controller in a Windows environment. The following figure shows a simple example of the configuration that is required.
NOTE The ioThinx 4530 Series only supports SSH connections.
User Account Management
Switching to the Root Account
You can switch to root using sudo -i (or sudo su). For security reasons, do not operate the all commands from the root account.
NOTE Click the following link for more information on the sudo command. https://wiki.debian.org/sudo
ATTENTION
You might get the permission denied message when using pipe or redirect
behavior with a non-root account. You must use ‘sudo su –c’ to run the command
instead of using >, <, >>, <<, etc.
Note: The single quotes around the full command are required.
Creating and Deleting User Accounts
You can use the useradd and userdel commands to create and delete user accounts. Be sure to reference the main page of these commands to set relevant access privileges for the account. The following example shows how to create a test1 user in the sudo group whose default login shell is bash and has home directory at /home/test1:
To change the password for test1, use the password option along with the new password. Retype the password to confirm the change.
To delete user test1, use the userdel command.
Disabling the Default User Account
ATTENTION
You should first create a user account before you disable the default account.
Use the passwd command to lock the default user account so the user moxa
cannot log in.
Type the following command to unlock the user moxa:
Network Settings
Configuring Ethernet Interfaces
After the first login, you can configure the ioThinx 4530 controller’s network settings to fit your application better. Note that it is more convenient to manipulate the network interface settings from the serial console than from an SSH login because an SSH connection can disconnect when there are network issues and the connection must be reestablished.
Modifying Network Settings via the Serial Console
In this section, we use the serial console to configure the ioThinx 4530 controller’s network settings. Follow the instructions in the Connecting to the ioThinx 4530 controller section under Getting Started to access the Console Utility of the target computer via the serial Console port and then type cd /etc/network to change directories.
Type sudo vi interfaces to edit the network configuration file in the vi editor. You can configure the ioThinx 4530 controller’s Ethernet ports to use either static or dynamic (DHCP) IP addresses.
Setting a Static IP address
To set a static IP address for the ioThinx 4530 controller, use the iface command to modify the default gateway, address, network, netmask, and broadcast parameters of the Ethernet interface.
Setting Dynamic IP Addresses:
To configure one or both LAN ports to request an IP address dynamically use the dhcp option in place of static in the iface command, as follows:
Default Setting for LAN1 | Dynamic Setting using DHCP |
---|
iface eth0 inet static
address 192.168.127.254
network 192.168.127.0
netmask 255.255.255.0
broadcast 192.168.127.255
| interface Ethernet dhcp
System Administration
Querying the Firmware Version
To check the ioThinx 4530 controller’s firmware version, type:
Add the –a option to create a full build version:
Adjusting the Time
The ioThinx 4530 controller has two time settings. One is the system time, and the other is the RTC (Real Time Clock) time kept by the ioThinx 4530 controller’s hardware. Use the date command to query the current system time or set a new system time. Use the hwclock command to query the current RTC time or set a new RTC time.
Use the date MMDDhhmmYYYY command to set the system time:
MM = Month
DD = Date
hhmm = hour and minute
Use the following command to set the RTC time to system time:
NOTE Click the following links for more information on date and time:
https://www.debian.org/doc/manuals/system-administrator/ch-sysadmin-
time.html https://wiki.debian.org/DateTime
Setting the Time Zone
There are two ways to configure the Moxa embedded computer’s timezone. One is using the TZ variable. The other is using the /etc/localtime file.
Using the TZ Variable
The format of the TZ environment variable looks like this: TZ=HH[:MM[:SS] [daylight[HH[:MM[:SS]]][,start date[/starttime], enddate[/endtime]]] Here are some possible settings for the North American Eastern time zone:
- TZ=EST5EDT
- TZ=EST0EDT
- TZ=EST0
In the first case, the reference time is GMT and the stored time values are correct worldwide. A simple change of the TZ variable can print the local time correctly in any time zone.
In the second case, the reference time is Eastern Standard Time and the only conversion performed is for Daylight Saving Time. Therefore, there is no need to adjust the hardware clock for Daylight Saving Time twice per year.
In the third case, the reference time is always the time reported. You can use this option if the hardware clock on your machine automatically adjusts for Daylight Saving Time or you would like to manually adjust the hardware time twice a year.
You must include the TZ setting in the /etc/rc.local file. The timezone
setting will be activated when you restart the computer.
The following table lists other possible values for the TZ environment
variable:
Hours From Greenwich Mean Time (GMT) | Value | Description |
---|---|---|
0 | GMT | Greenwich Mean Time |
+1 | ECT | European Central Time |
+2 | EET | European Eastern Time |
+2 | ART | |
+3 | EAT | Saudi Arabia |
+3.5 | MET | Iran |
+4 | NET | |
+5 | PLT | West Asia |
+5.5 | IST | India |
+6 | BST | Central Asia |
+7 | VST | Bangkok |
+8 | CTT | China |
+9 | JST | Japan |
+9.5 | ACT | Central Australia |
+10 | AET | Eastern Australia |
+11 | SST | Central Pacific |
+12 | NST | New Zealand |
-11 | MIT | Samoa |
-10 | HST | Hawaii |
-9 | AST | Alaska |
-8 | PST | Pacific Standard Time |
Hours From Greenwich Mean Time (GMT) | Value | Description |
--- | --- | --- |
-7 | PNT | Arizona |
-7 | MST | Mountain Standard Time |
-6 | CST | Central Standard Time |
-5 | EST | Eastern Standard Time |
-5 | IET | Indiana East |
-4 | PRT | Atlantic Standard Time |
-3.5 | CNT | Newfoundland |
-3 | AGT | Eastern South America |
-3 | BET | Eastern South America |
-1 | CAT | Azores |
160BUsing the Localtime File
The local timezone is stored in the /etc/localtime and is used by GNU Library for C (glibc) if no value has been set for the TZ environment variable. This file is either a copy of the /usr/share/zoneinfo/ file or a symbolic link to it. The ioThinx 4530 controller does not provide /usr/share/zoneinfo/ files. You should find a suitable time zone information file and write over the original local time file in the ioThinx 4530 controller
Determining Available Drive Space
To determine the amount of available drive space, use the df command with the –h tag. The system will return the amount of drive space broken down by file system. Here is an example:
Shutting Down the Device
To shut down the device, disconnect the power source to the computer. When the
computer is powered off, main components such as the CPU, RAM, and storage
devices are powered off, although an internal clock powered by a super
capacitor may keep running. You can use the Linux shutdown command to close
all software running on the device and halt the system. However, main
components such as the CPU, RAM, and storage devices will continue to be
powered after you run this command.
moxa@Moxa:~$ sudo shutdown -h now
Firmware Update and System Recovery
Firmware Update and Set-to-Default Functions
Set-to-Default
-
Power off the device.
-
Press and hold the reset button; while holding the reset button:
a. Power on the device; the RDY LED will blink green while the device is booting up.
b. After the device has booted up, the RDY LED will blink red; continue holding the reset button until the RDY LED stops blinking. -
Release the reset button to load the factory default settings.
For additional details on the LEDs, refer to the quick installation guide or the user’s manual for your ioThinx 4530 controller.
NOTE It should take about 20 seconds from the time the RDY LED starts blinking green until it stops blinking red.
ATTENTION
Reset-to-default will erase all the data stored on the boot storage
Back up your files before resetting the system to factory defaults. All the
data stored in the ioThinx 4530 controller’s boot storage will be destroyed
after resetting to factory defaults
You can also use the mx-set-def command to restore the ioThinx 4530 controller to factory defaults:
moxa@Moxa:~$ sudo mx-set-def
Firmware Update Using an SFTP Server or microSD Card
Updating the Firmware Under OS Mode
-
To update the firmware, log in to the product through the serial console. Instructions on how to connect to the serial console can be found in the ioThinx 4530 Hardware User’s Manual.
-
Put the firmware (*.sh) file to the ioThinx 4530 device via an SFTP server or MicroSD card.
-
Use the following commands to update the firmware.
-
After the firmware update is complete, the ioThinx 4530 will restart automatically. Use the kversion command to check the firmware version.
Updating the Firmware Under BIOS Mode
-
To update the firmware, log in through the serial console. Instructions on how to connect to the serial console can be found in the Hardware User’s Manual for the ioThinx 4533.
-
After powering up the computer, press Delete to enter the bootloader configuration settings.
-
Enter 1 to update the firmware through the microSD card. Key in the file name of the firmware
-
After updating the firmware, select Go to Linux to open the OS command-line console.
Programming Guide
Click the following link to download the ioThinx 4530 Programming Guide:
https://www.moxa.com/en/products/industrial-edge connectivity/controllers-
and-ios/advanced-controllersand-i-os/iothinx-4530
series#resources The ioThinx 4530 Programming Guide
includes the following sections:
Cycle Time Calculation
The controller’s cycle time is defined as how much time the CPU needs to poll the status of all IO modules. This information is important since it allows users to make sure the controller can control their application within a designated time period. The cycle time calculation is based on the following table. A cycle time is calculated for each group of eight appended 45M modules. The cycle time of a group is the sum of the cycle time of the first module in the group (the times in column 1) plus the cycle times of the 2nd through 8th modules (the times in column 2) in the group. To calculate the cycle time of ioThinx 4530 Series CPU, simply add up the cycle times of all of the groups connected to the ioThinx, and then round the time up to the nearest millisecond.
| Cycle time as 1st module in one
group (µs)
| Cycle time as 2nd to 8th module of the one
group (µs)
---|---|---
45MR-1600| 1200| 100
45MR-1601| 1200| 100
45MR-2404| 1300| 100
45MR-2600| 1200| 100
45MR-2601| 1200| 100
45MR-2606| 1200| 100
45MR-3800| 1300| 200
45MR-3810| 1300| 200
45MR-6600| 1500| 300
45MR-6810| 1500| 300
We provide two examples to illustrate cycle time calculations.
Case 1. 4-piece 45MR-1600 and 4-piece 45MR-2601.
1st module: 45MR-1600| 2nd module: 45MR-1600| 3rd module: 45MR-1600| 4th
module: 45MR-1600| 5th module: 45MR-2601| 6th module: 45MR-2601| 7th module:
45MR-2601| 8th module: 45MR-2601
---|---|---|---|---|---|---|---
In this case, the eight modules form one group. The cycle time of this combination is 1900 µs = 1200 µs + 7 x 100 µs. The ioThinx 4530 Series will round up the cycle time to the ms level, and consequently the cycle time of this combination is 2 ms.
Case 2. 4 x 45MR-1600, 4 x 45MR-2601, 2 x 45MR-3800.
1st module: 45MR-1600| 2nd module: 45MR-1600| 3rd module: 45MR-1600| 4th
module: 45MR-1600| 5th module: 45MR-2601| 6th module: 45MR-2601| 7th module:
45MR-2601| 8th module: 45MR-2601| 9th module: 45MR-3800| 10th module:
45MR-3800
---|---|---|---|---|---|---|---|---|---
In this case, the 10 modules are separated in two groups. The first group is outlined in red above, whereas the second group is outlined in orange. The combination of modules in the first group is the same as in Case 1, which was shown to have a cycle time = 1900 µs. For the second group, the cycle time is 1500 µs = 1300 µs + 200 µs. Therefore, the total cycle time of the two groups is 3400 µs = 1900 µs + 1500 µs, which when rounded up to the nearest ms results in a total cycle time = 4 ms.
References
- Download PuTTY: latest release (0.81)
- Moxa - Support
- DateTime - Debian Wiki
- SSH - Debian Wiki
- sudo - Debian Wiki