Skip to main content
Skip table of contents

MAC36 - Platform - Unable to log in to the controller's platform

Issue

The user is unable to log in to the MAC36 controller.

Possible causes and solutions

Too fast attempt to connect to the controller

A possible cause here is that the Niagara deamon has not started on the controller yet. The Niagara platform takes about 2 minutes to start after powering on the controller. At the same time, the TCP/IP communication of the Ethernet interface starts considerably quicker, which is why it may be possible to ping the IP address of the controller from a command line (cmd) just after a few seconds. The platform takes longer to fully launch.

CODE
javax.baja.naming.UnresolvedException: platformssl:
   at com.tridium.platcrypto.daemon.wb.BDaemonSecureScheme.resolve(BDaemonSecureScheme.java:127)
   at javax.baja.naming.BOrd.resolve(BOrd.java:278)
   at com.tridium.workbench.shell.BNiagaraWbShell.resolve(BNiagaraWbShell.java:669)
   at com.tridium.workbench.shell.NHyperlinkInfo.resolve(NHyperlinkInfo.java:279)
   at com.tridium.workbench.shell.NHyperlinkInfo.hyperlink(NHyperlinkInfo.java:131)
   at com.tridium.workbench.shell.BNiagaraWbShell.doHyperlink(BNiagaraWbShell.java:528)
   at com.tridium.workbench.shell.BNiagaraWbShell.hyperlink(BNiagaraWbShell.java:486)
   at javax.baja.workbench.nav.tree.NavTreeController.nodeDoubleClicked(NavTreeController.java:119)
   at javax.baja.ui.tree.TreeController.mousePressed(TreeController.java:234)
   at javax.baja.workbench.nav.tree.NavTreeController.mousePressed(NavTreeController.java:65)
   at javax.baja.ui.tree.BTree.mousePressed(BTree.java:611)
   at javax.baja.ui.BWidget.fireMouseEvent(BWidget.java:1365)
   at com.tridium.ui.awt.MouseManager.fire(MouseManager.java:373)
   at com.tridium.ui.awt.MouseManager.fire(MouseManager.java:304)
   at com.tridium.ui.awt.MouseManager.pressed(MouseManager.java:126)
   at com.tridium.ui.awt.MouseManager.process(MouseManager.java:107)
   at com.tridium.ui.awt.AwtShellManager.processMouseEvent(AwtShellManager.java:509)
   at com.tridium.ui.swing.BSwingWidget$GlassMouseListener.redispatchMouseEvent(BSwingWidget.java:642)
   at com.tridium.ui.swing.BSwingWidget$GlassMouseListener.mousePressed(BSwingWidget.java:510)
  java.net.ConnectException: Connection refused: connect
     at java.net.DualStackPlainSocketImpl.waitForConnect(Native Method)
     at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:81)
     at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:476)
     at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:218)
     at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:200)
     at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:162)
     at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:394)
     at java.net.Socket.connect(Socket.java:606)
     at org.bouncycastle.jsse.provider.ProvSSLSocketDirect.connect(Unknown Source)
     at com.tridium.crypto.core.io.CryptoCoreSecureSocket.connect(CryptoCoreSecureSocket.java:64)
     at com.tridium.crypto.core.io.CryptoCoreClientSocketFactory.createSocket(CryptoCoreClientSocketFactory.java:101)
     at javax.baja.net.HttpsConnection.createSocket(HttpsConnection.java:210)
     at javax.baja.net.HttpsConnection.connect(HttpsConnection.java:149)
     at javax.baja.net.HttpsConnection.newRequest(HttpsConnection.java:293)
     at javax.baja.net.HttpConnection.newRequest(HttpConnection.java:373)
     at com.tridium.platform.daemon.BDaemonSession.sendNewRequest(BDaemonSession.java:3587)
     at com.tridium.platform.daemon.BDaemonSession.getConnection(BDaemonSession.java:2529)
     at com.tridium.platform.daemon.BDaemonSession.initHostProperties(BDaemonSession.java:969)
     at com.tridium.platform.daemon.BDaemonSession.connect(BDaemonSession.java:307)

Solution

To avoid the problem, wait until the RUN diode on the controller starts blinking quickly (which means the platform has started) or slowly (which means the station has started). The RUN diode lit continuously means that the controller is only starting FW or the Linux system.

If the RUN diode is hidden from sight or the controller is placed in a remote location, it is recommended to wait at least 2 minutes before attempting to connect to the platform.

Connecting to the controller is not possible after a long time of operation

Occasionally, when the controller is working for some time with no interruptions, it is no longer possible to log in to the platform and the Workbench logs indicate the following error:

CODE
javax.baja.naming.UnresolvedException: platformssl:
   at com.tridium.platcrypto.daemon.wb.BDaemonSecureScheme.resolve(BDaemonSecureScheme.java:103)
   at javax.baja.naming.BOrd.resolve(BOrd.java:274)
   at com.tridium.workbench.shell.BNiagaraWbShell.resolve(BNiagaraWbShell.java:656)
   at com.tridium.workbench.shell.NHyperlinkInfo.resolve(NHyperlinkInfo.java:279)
   at com.tridium.workbench.shell.NHyperlinkInfo.hyperlink(NHyperlinkInfo.java:131)
   at com.tridium.workbench.shell.BNiagaraWbShell.doHyperlink(BNiagaraWbShell.java:515)
   at com.tridium.workbench.shell.BNiagaraWbShell.hyperlink(BNiagaraWbShell.java:473)
   at javax.baja.workbench.nav.tree.NavTreeController.nodeDoubleClicked(NavTreeController.java:119)
   at javax.baja.ui.tree.TreeController.mousePressed(TreeController.java:234)
   at javax.baja.workbench.nav.tree.NavTreeController.mousePressed(NavTreeController.java:65)
   at javax.baja.ui.tree.BTree.mousePressed(BTree.java:591)
   at javax.baja.ui.BWidget.fireMouseEvent(BWidget.java:1227)
   at com.tridium.ui.awt.MouseManager.fire(MouseManager.java:325)
   at com.tridium.ui.awt.MouseManager.fire(MouseManager.java:299)
   at com.tridium.ui.awt.MouseManager.pressed(MouseManager.java:122)
   at com.tridium.ui.awt.MouseManager.process(MouseManager.java:103)
   at com.tridium.ui.awt.AwtShellManager.processMouseEvent(AwtShellManager.java:509)
   at com.tridium.ui.swing.BSwingWidget$GlassMouseListener.redispatchMouseEvent(BSwingWidget.java:641)
   at com.tridium.ui.swing.BSwingWidget$GlassMouseListener.mousePressed(BSwingWidget.java:509)
  DaemonConnectException: javax.net.ssl.SSLHandshakeException: Remote host terminated the handshake
     at com.tridium.platform.daemon.BDaemonSession.processException(BDaemonSession.java:831)
     at com.tridium.platform.daemon.BDaemonSession.processException(BDaemonSession.java:782)
     at com.tridium.platform.daemon.BDaemonSession.processException(BDaemonSession.java:794)
     at com.tridium.platform.daemon.BDaemonSession.processException(BDaemonSession.java:782)
     at com.tridium.platform.daemon.BDaemonSession.connect(BDaemonSession.java:3608)
     at com.tridium.platcrypto.daemon.wb.BDaemonSecureSession.connect(BDaemonSecureSession.java:231)
     at com.tridium.platform.daemon.BDaemonSession.getConnection(BDaemonSession.java:2432)
     at com.tridium.platform.daemon.BDaemonSession.initHostProperties(BDaemonSession.java:948)
     at com.tridium.platform.daemon.BDaemonSession.connect(BDaemonSession.java:287)
     at com.tridium.platform.daemon.BDaemonSession.connect(BDaemonSession.java:275)
     at com.tridium.platcrypto.daemon.wb.BDaemonSecureScheme.resolve(BDaemonSecureScheme.java:91)
     at javax.baja.naming.BOrd.resolve(BOrd.java:274)
     at com.tridium.workbench.shell.BNiagaraWbShell.resolve(BNiagaraWbShell.java:656)
     at com.tridium.workbench.shell.NHyperlinkInfo.resolve(NHyperlinkInfo.java:279)
     at com.tridium.workbench.shell.NHyperlinkInfo.hyperlink(NHyperlinkInfo.java:131)
     at com.tridium.workbench.shell.BNiagaraWbShell.doHyperlink(BNiagaraWbShell.java:515)
     at com.tridium.workbench.shell.BNiagaraWbShell.hyperlink(BNiagaraWbShell.java:473)
     at javax.baja.workbench.nav.tree.NavTreeController.nodeDoubleClicked(NavTreeController.java:119)
     at javax.baja.ui.tree.TreeController.mousePressed(TreeController.java:234)

There are known cases of MAC36 controllers so overloaded with logic, files, and historic data that there was no more memory available to start a TCP/IP socket.

Solution

To solve this problem, reboot the controller. It should bring back access to the platform. To make sure the problem does not recur, go to the File Transfer Client in platform and remove the sw folder contents (if the folder is not present in the controller, the described case is not the reason of being unable to connect to the platform).

image-20231102-083817.png

The sw folder stores data from past commissionings and is not always visible. If the folder is unavailable or empty, it means that the station needs to be reduced.

Unable to connect just after commissioning - the controller responds to ping

In the process of establishing new users on first commissioning of the platform, an error occurred while removing a default user (niagara -> tridium). Despite the error, the commissioning process was finished and it was possible to begin operations. However, after restarting the controller, it was no longer possible to log in and the following logs appeared:

CODE
javax.baja.naming.UnresolvedException: platform:
   at com.tridium.platcrypto.daemon.BDaemonScheme.resolve(BDaemonScheme.java:111)
   at javax.baja.naming.BOrd.resolve(BOrd.java:274)
   at com.tridium.workbench.shell.BNiagaraWbShell.resolve(BNiagaraWbShell.java:656)
   at com.tridium.workbench.shell.NHyperlinkInfo.resolve(NHyperlinkInfo.java:279)
   at com.tridium.workbench.shell.NHyperlinkInfo.hyperlink(NHyperlinkInfo.java:131)
   at com.tridium.workbench.shell.BNiagaraWbShell.doHyperlink(BNiagaraWbShell.java:515)
   at com.tridium.workbench.shell.BNiagaraWbShell.hyperlink(BNiagaraWbShell.java:473)
   at javax.baja.workbench.nav.tree.NavTreeController.nodeDoubleClicked(NavTreeController.java:119)
   at javax.baja.ui.tree.TreeController.mousePressed(TreeController.java:234)
   at javax.baja.workbench.nav.tree.NavTreeController.mousePressed(NavTreeController.java:65)
   at javax.baja.ui.tree.BTree.mousePressed(BTree.java:591)
   at javax.baja.ui.BWidget.fireMouseEvent(BWidget.java:1227)
   at com.tridium.ui.awt.MouseManager.fire(MouseManager.java:325)
   at com.tridium.ui.awt.MouseManager.fire(MouseManager.java:299)
   at com.tridium.ui.awt.MouseManager.pressed(MouseManager.java:122)
   at com.tridium.ui.awt.MouseManager.process(MouseManager.java:103)
   at com.tridium.ui.awt.AwtShellManager.processMouseEvent(AwtShellManager.java:509)
   at com.tridium.ui.swing.BSwingWidget$GlassMouseListener.redispatchMouseEvent(BSwingWidget.java:641)
   at com.tridium.ui.swing.BSwingWidget$GlassMouseListener.mousePressed(BSwingWidget.java:509)
  java.net.ConnectException: Connection timed out: connect
     at java.net.DualStackPlainSocketImpl.connect0(Native Method)
     at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:75)
     at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:476)
     at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:218)
     at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:200)
     at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:162)
     at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:394)
     at java.net.Socket.connect(Socket.java:606)
     at javax.baja.naming.BIpHost.openSocket(BIpHost.java:170)
     at javax.baja.net.HttpConnection.createSocket(HttpConnection.java:303)
     at javax.baja.net.HttpConnection.connect(HttpConnection.java:337)
     at javax.baja.net.HttpConnection.newRequest(HttpConnection.java:416)
     at javax.baja.net.HttpConnection.newRequest(HttpConnection.java:373)
     at com.tridium.platform.daemon.BDaemonSession.sendNewRequest(BDaemonSession.java:3547)
     at com.tridium.platform.daemon.BDaemonSession.getConnection(BDaemonSession.java:2489)
     at com.tridium.platform.daemon.BDaemonSession.initHostProperties(BDaemonSession.java:952)
     at com.tridium.platform.daemon.BDaemonSession.connect(BDaemonSession.java:290)
     at com.tridium.platform.daemon.BDaemonSession.connect(BDaemonSession.java:278)
     at com.tridium.platform.daemon.BDaemonScheme.resolve(BDaemonScheme.java:90)

The reason is that the default user was not successfully removed, which is possible when the Putty console with the default user (niagara -> tridium) logged in was simultaneously started (for example, to check the IP address). During the first commissioning of the platform, the error of removing the default user occurred because there was an active session open for that user. Ultimately, logging in with a new user could not be possible. To avoid the issue, make sure to perform all works with the Defaults Settings Wizard with the Putty console shut down.

Solution

To solve the problem, reload the SD card image according to the following instructions: iSMA CONTROLLI Download Center.

Unable to connect just after commissioning - the controller does not respond to ping

After performing a commissioning process (with changing the IP address) of the MAC36-family controller, it is not possible to log in. The controller does not respond to a ping command.

image-20240603-112928.png

Most probably, due to a mistake while configuring the IP address, the controller saved a DHCP option active or saved an IP address different than intended.

In such a situation, check the actual IP address of the controller and try to connect. Unfortunately, if the controller is part of a larger network, it is possible that it shares the IP address with another device and may be unreachable.

Solutions

  • Connect the controller directly to the PC (in the PC network configuration, set the IP address in the same subnet as the expected address of the controller) and scan the network with a software like Advanced IP Scanner to check whether a different address was mistakenly assigned in the last octet.

  • In any case different than a mistake in the last octet of the IP address, it is required, first, to connect to the controller using the serial console MAC36 - Console - Serial connection. Then, use the following command:

CODE
cat /etc/network/interfaces

The command returns a full configuration of both Ethernet interfaces saved in the controller. If a specific IP address has been set, it is sufficient to set on the computer the IP address in the same subnet and connect to the controller’s platform to reset the IP address to the intended one.

If the configuration is set to DHCP, it is required to use the below command to check the IP address in use (the Ethernet cable must be plugged into the specified interface of the controller and connected on the other side to the computer):

CODE
/sbin/ifconfig

The returned IP address may seem unusual but it is still required to set on the computer the IP address in the same subnet and log into the controller’s platform to reset the IP address to the intended one.

  • If no mini USB cable, necessary for a serial console connection, is available, it is required to connect the controller to a router with DHCP active. Using a diagnostic tool, verify whether the device has been found and what IP address it is. Alternatively, use a 6th DIP switch restore function or reload the SD card to restore a default IP address.
    WARNING: Depending on the method, other settings will be restored to default too.

Controller is after launching a first step of restoring factory settings

In case an S3 6th DIP switch is set to the ON position and the controller is then powered up, it will go into a phase of waiting for a factory reset process to complete, and the platform of the controller cannot be started.

IMG_20240703_083954.jpg

The ALARM diode on the controller blinks quickly and the logs show stopping the startup process:

CODE
U-Boot SPL 2017.03-mx6+g3b5f889 (Jul 23 2018 - 18:04:11)

Part number: VSM-DUAL-239A
Assembly: AS1811142076
Date of production: 2018 Dec 10
Trying to boot from MMC1
MMC Boot Device: mmc0 (SD)

Authenticate image from DDR location 0x177fffc0...
Check CSF for Write Data command before authenticating image

(...) 260 lines more

imx_thermal 2000000.aips-bus:tempmon: Commercial CPU temperature grade - max:95C critical:90C passive:85C
rtc-pcf8563 0-0051: setting system clock to 2024-07-01 09:44:12 UTC (1719827052)
Freeing unused kernel memory: 27648K
hub 2-1:1.0: USB hub found
hub 2-1:1.0: 5 ports detected
rorootfs-overlay: Could not mount , bind mounting...
usb 2-1.1: new high-speed USB device number 3 using ci_hdrc
EXT4-fs (mmcblk1p2): warning: maximal mount count reached, running e2fsck is recommended
EXT4-fs (mmcblk1p2): recovery complete
EXT4-fs (mmcblk1p2): mounted filesystem with ordered data mode. Opts: (null)
EXT4-fs (mmcblk1p3): warning: maximal mount count reached, running e2fsck is recommended
EXT4-fs (mmcblk1p3): recovery complete
EXT4-fs (mmcblk1p3): mounted filesystem with ordered data mode. Opts: (null)
random: crng init done

Solution

To solve the problem, follow the below steps:

  • disconnect the controller’s power supply,

  • set the S3 6th DIP switch to OFF,

  • power the controller back on.

WARNING: This sequence cannot be changed - setting the S3 6th DIP switch to the OFF position when the controller is powered causes it to go into a second phase of restoring factory setting, which is a final overwriting of the current settings with the factory settings.

State of DIP and rotary switches forces the controller into a bootloader mode

When all S3 6 DIP switches are set to ON and both rotary switches (S1 and S2) are set to 0, the controller after the next reboot or voltage power restart will automatically go to the bootloader and wait for uploading new firmware. Unfortunately, it cannot be done as the MAC36-family controllers transfer files during commissioning.

IMG_20231216_125135 (2).jpg

In such a case, the controller will light a red ALARM diode and stop the platform from starting, which will prevent the possibility to log in.

Solution

To solve the problem, set the DIP and rotary switches to a different state.

WARNING: Leaving the S3 6th DIP switch set to ON will commence the procedure of restoring factory settings!

No SD card inserted

Out-of-the-box MAC36 controller does not have an SD card inserted. In some cases, it is provided in the box, but sometimes it is required to purchase the SD card separately.

In any case, first, check if the SD card is places in an SD card slot on the side of the controller. If the SD card is missing from the slot, no diodes other than ON will be lit.

The following log will also be generated in the Putty console (serial connection):

CODE
U-Boot SPL 2017.03-mx6+g3b5f889 (Oct 08 2018 - 14:35:15)

Part number: VSM-DUAL-239B
Assembly: AS2112173828
Date of production: 2022 Jul 17
Trying to boot from MMC1
MMC Boot Device: mmc0 (SD)
MMC: no card present
mmc_init: -123, time 2
spl: mmc init failed with error: -123
SPL: failed to boot from all boot devices
### ERROR ### Please RESET the board ###

Solution

Place the iSMA-B-SD-NL card in the SD card slot on the side of the controller while the controller is powered off and then switch on the power supply.

Incorrectly inserted SD card

It may happen that the SD card is placed incorrectly in the MAC36 controller’s SD card slot. It will be signaled with a red ALARM diode. It may not necessarily mean that the SD card is placed upside down; occasionally, it happens that the copper pads do not fully contact and the SD card is read incorrectly.

Solution

Remove the SD card when the controller is powered off. Check if the SD card is being inserted a correct side up, place it in the SD card slot and power on the controller.

Damaged image or files on the SD card

Sporadically, the SD card of the MAC36-family controller (especially, a brand new one) has an incorrectly uploaded file image or a single file has been corrupted while writing. It prevents logging in to the platform and may cause one of the following:

  • no diode other than ON is lit,

  • the red ALARM diode is lit,

  • the green RUN diode is lit continuously.

Solution

Remove the SD card when the controller is powered off and reload the card’s image according to the following instructions: iSMA CONTROLLI Download Center.

Then, insert the SD card to the controller and power it on.

Damaged partitions on the SD card

Seldom, a partition system on the SD card gets damaged, which causes that the SD card is incorrectly read by the MAC36 controller, at the same time being recognized by the PC but it is impossible to copy its image.

The reason to this may be a damaged partition system. Such a damage can occur when the SD card is inserted to the PC. In this moment, the Windows system automatically discovers all partitions on the card and cannot recognize the files format. Pop-up windows appear with a suggestion to format the partitions. The correct approach is to obligatorily reject formatting. However, if, by mistake or out of inexperience, the SD card does get formatted, it will be no longer possible to load a new image to the card.

Solution

The solution is to remove all volumes from the SD card using a Windows' built-in tool, Disk Management.

image-20220712-063644.png

Open the Disk Management tool and select the Delete volume option from the context menu.

WARNING: Make absolutely sure that the removed volume is from the SD card and NOT the HDD disk or a phone connected to the PC.

image-20220712-063713.png

Having removed all volumes from the SD card, it is ready to load a new image according to the following instructions: iSMA CONTROLLI Download Center.

Finally, insert the SD card to the controller and power it on.

Mechanical micro-crack or visible damage to the SD card

The iSMA-B-SD-NL card, dedicated to the MAC36-family controllers, needs to be cautiously inserted to the SD card slot; especially, it is not allowed to use any tools to insert it, such as a screwdriver. Using hardware tools instead of fingers increases an amount of pressure on the card when it is pressed against the end of the slot. Due to the resulting stress, the SD card may be slightly bent in the slot, which in effect may lead to micro-cracks on the surface of the card. Such a micro-crack can cause damage to the microcontroller or copper tracks embedded in the plastic. The SD card damaged this way may (but does not have to, depending on the location of the damage) overheat. A micro-crack resembles a damage pictured below:

broken SD card using screwdriver (2).jpg

On the other hand, when the damage is clearly visible, as below, a very strong mechanical force had to be applied to bring the card to such a state:

image-20240603-094021.png

Solution

In this case, the only solution is to exchange the SD card. If the damaged card is overheating and left in the powered on controller for a too long time, it can also cause a damage to the card slot.

Windows system in Turkish

This is a known issue that it is not possible to log in to the MAC36 controller from the Workbench installed on the Windows system in Turkish language version. The problem is rooted in a specific coding of letters using in this language.

CODE
javax.baja.naming.UnresolvedException: platform:
   at com.tridium.platform.daemon.BDaemonScheme.resolve(BDaemonScheme.java:111)
   at javax.baja.naming.BOrd.resolve(BOrd.java:274)
   at com.tridium.workbench.shell.BNiagaraWbShell.resolve(BNiagaraWbShell.java:656)
   at com.tridium.workbench.shell.NHyperlinkInfo.resolve(NHyperlinkInfo.java:279)
   at com.tridium.workbench.shell.NHyperlinkInfo.hyperlink(NHyperlinkInfo.java:131)
   at com.tridium.workbench.shell.BNiagaraWbShell.doHyperlink(BNiagaraWbShell.java:515)
   at com.tridium.workbench.shell.BNiagaraWbShell.hyperlink(BNiagaraWbShell.java:473)
   at javax.baja.workbench.nav.tree.NavTreeController.nodeDoubleClicked(NavTreeController.java:119)
   at javax.baja.ui.tree.TreeController.mousePressed(TreeController.java:234)
   at javax.baja.workbench.nav.tree.NavTreeController.mousePressed(NavTreeController.java:65)
   at javax.baja.ui.tree.BTree.mousePressed(BTree.java:591)
   at javax.baja.ui.BWidget.fireMouseEvent(BWidget.java:1227)
   at com.tridium.ui.awt.MouseManager.fire(MouseManager.java:325)
   at com.tridium.ui.awt.MouseManager.fire(MouseManager.java:299)
   at com.tridium.ui.awt.MouseManager.pressed(MouseManager.java:122)
   at com.tridium.ui.awt.MouseManager.process(MouseManager.java:103)
   at com.tridium.ui.awt.AwtShellManager.processMouseEvent(AwtShellManager.java:509)
   at com.tridium.ui.swing.BSwingWidget$GlassMouseListener.redispatchMouseEvent(BSwingWidget.java:641)
   at com.tridium.ui.swing.BSwingWidget$GlassMouseListener.mousePressed(BSwingWidget.java:509)
  javax.baja.sys.LocalizableRuntimeException: Error connecting to platform daemon at 192.168.1.123:
  GET /platformInfo
     at com.tridium.platform.daemon.BDaemonSession.handleConnectionException(BDaemonSession.java:3288)
     at com.tridium.platform.daemon.BDaemonSession.getConnection(BDaemonSession.java:2513)
     at com.tridium.platform.daemon.BDaemonSession.initHostProperties(BDaemonSession.java:948)
     at com.tridium.platform.daemon.BDaemonSession.connect(BDaemonSession.java:287)
     at com.tridium.platform.daemon.BDaemonSession.connect(BDaemonSession.java:275)
     at com.tridium.platform.daemon.BDaemonScheme.resolve(BDaemonScheme.java:90)
     at javax.baja.naming.BOrd.resolve(BOrd.java:274)
     at com.tridium.workbench.shell.BNiagaraWbShell.resolve(BNiagaraWbShell.java:656)
     at com.tridium.workbench.shell.NHyperlinkInfo.resolve(NHyperlinkInfo.java:279)
     at com.tridium.workbench.shell.NHyperlinkInfo.hyperlink(NHyperlinkInfo.java:131)
     at com.tridium.workbench.shell.BNiagaraWbShell.doHyperlink(BNiagaraWbShell.java:515)
     at com.tridium.workbench.shell.BNiagaraWbShell.hyperlink(BNiagaraWbShell.java:473)
     at javax.baja.workbench.nav.tree.NavTreeController.nodeDoubleClicked(NavTreeController.java:119)
     at javax.baja.ui.tree.TreeController.mousePressed(TreeController.java:234)
     at javax.baja.workbench.nav.tree.NavTreeController.mousePressed(NavTreeController.java:65)
     at javax.baja.ui.tree.BTree.mousePressed(BTree.java:591)
     at javax.baja.ui.BWidget.fireMouseEvent(BWidget.java:1227)
     at com.tridium.ui.awt.MouseManager.fire(MouseManager.java:325)
    java.lang.UnsupportedOperationException: Unknown SCRAM type "SCRAM-GLİBC-SHA512"
       at com.tridium.platform.daemon.ScramAuthenticator.setAuthorization(ScramAuthenticator.java:101)
       at com.tridium.platform.daemon.ScramAuthenticator.setAuthorization(ScramAuthenticator.java:63)
       at com.tridium.platform.daemon.BDaemonSession.setAuthOnConnection(BDaemonSession.java:3590)
       at com.tridium.platform.daemon.BDaemonSession.getConnection(BDaemonSession.java:2445)
       at com.tridium.platform.daemon.BDaemonSession.initHostProperties(BDaemonSession.java:948)
       at com.tridium.platform.daemon.BDaemonSession.connect(BDaemonSession.java:287)
       at com.tridium.platform.daemon.BDaemonSession.connect(BDaemonSession.java:275)
       at com.tridium.platform.daemon.BDaemonScheme.resolve(BDaemonScheme.java:90)
       at javax.baja.naming.BOrd.resolve(BOrd.java:274)
       at com.tridium.workbench.shell.BNiagaraWbShell.resolve(BNiagaraWbShell.java:656)
       at com.tridium.workbench.shell.NHyperlinkInfo.resolve(NHyperlinkInfo.java:279)
       at com.tridium.workbench.shell.NHyperlinkInfo.hyperlink(NHyperlinkInfo.java:131)
       at com.tridium.workbench.shell.BNiagaraWbShell.doHyperlink(BNiagaraWbShell.java:515)
       at com.tridium.workbench.shell.BNiagaraWbShell.hyperlink(BNiagaraWbShell.java:473)
       at javax.baja.workbench.nav.tree.NavTreeController.nodeDoubleClicked(NavTreeController.java:119)
       at javax.baja.ui.tree.TreeController.mousePressed(TreeController.java:234)
       at javax.baja.workbench.nav.tree.NavTreeController.mousePressed(NavTreeController.java:65)
       at javax.baja.ui.tree.BTree.mousePressed(BTree.java:591)
       at javax.baja.ui.BWidget.fireMouseEvent(BWidget.java:1227)

Solution

To avoid this issue, install the Windows system in English and install the Workbench instance there.

Damage to the KeyMaterial file

In older Niagara distributions (4.4, 4.6, or 4.7), supported by the MAC36-family controllers, right after cleanDist is executed, there may be a problem with the keyMaterial file that stores login data for the controller station or its services.

CODE
WARNING: Failed to encrypt local session credentials, stationPolfarmexBMS may not start properly
INFO [nre] Launching Niagara Runtime Environment
SEVERE [11:52:29 17-Nov-20 CET][security.keyMaterial] Permission failure when getting key material
java.security.PrivilegedActionException: java.io.IOException: Process can not write to provided directory '/etc/niagara'
 at java.security.AccessController.doPrivileged(Native Method)
 at com.tridium.nre.platform.NativePlatformProvider.getKeyMaterial(NativePlatformProvider.java:1511)
 at com.tridium.nre.security.km.PlatformKeyMaterial.doGetKeyMaterial(PlatformKeyMaterial.java:56)
 at com.tridium.nre.security.km.KeyMaterial.getKeyMaterial(KeyMaterial.java:33)
 at com.tridium.nre.security.km.KeyMaterial.keyExists(KeyMaterial.java:61)
 at com.tridium.nre.security.km.KeyMaterialFactory.getKeyMaterial(KeyMaterialFactory.java:82)
 at com.tridium.nre.security.KeyRingFactory$GetKeyRingPrivilegedAction.run(KeyRingFactory.java:93)
 at com.tridium.nre.security.KeyRingFactory$GetKeyRingPrivilegedAction.run(KeyRingFactory.java:77)
 at java.security.AccessController.doPrivileged(Native Method)
 at com.tridium.nre.security.KeyRingFactory.getKeyRing(KeyRingFactory.java:68)
 at com.tridium.nre.security.SecurityInitializer.initSecurityInfo(SecurityInitializer.java:350)
 at com.tridium.nre.security.SecurityInitializer.configure(SecurityInitializer.java:75)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 at java.lang.reflect.Method.invoke(Method.java:498)
 at com.tridium.nre.di.BaseSupplier.evaluateConfiguration(BaseSupplier.java:99)
 at com.tridium.nre.di.SingletonSupplier.get(SingletonSupplier.java:62)
 at com.tridium.nre.di.NreInstantiator.instance(NreInstantiator.java:123)
 at com.tridium.nre.bootstrap.Bootstrap.Main(Bootstrap.java:87)
Caused by: java.io.IOException: Process can not write to provided directory '/etc/niagara'
 at com.tridium.nre.util.SimpleKeyValueUtil.getInstance(SimpleKeyValueUtil.java:68)
 at com.tridium.nre.platform.NativePlatformProvider.lambda$getKeyMaterial$20(NativePlatformProvider.java:1512)
 ... 20 more
SEVERE [11:52:29 17-Nov-20 CET][security.keyMaterial] Error checking for existence of key material
java.lang.RuntimeException: java.io.IOException: Process can not write to provided directory '/etc/niagara'
 at com.tridium.nre.platform.NativePlatformProvider.getKeyMaterial(NativePlatformProvider.java:1528)
 at com.tridium.nre.security.km.PlatformKeyMaterial.doGetKeyMaterial(PlatformKeyMaterial.java:56)
 at com.tridium.nre.security.km.KeyMaterial.getKeyMaterial(KeyMaterial.java:33)
 at com.tridium.nre.security.km.KeyMaterial.keyExists(KeyMaterial.java:61)
 at com.tridium.nre.security.km.KeyMaterialFactory.getKeyMaterial(KeyMaterialFactory.java:82)
 at com.tridium.nre.security.KeyRingFactory$GetKeyRingPrivilegedAction.run(KeyRingFactory.java:93)
 at com.tridium.nre.security.KeyRingFactory$GetKeyRingPrivilegedAction.run(KeyRingFactory.java:77)
 at java.security.AccessController.doPrivileged(Native Method)
 at com.tridium.nre.security.KeyRingFactory.getKeyRing(KeyRingFactory.java:68)
 at com.tridium.nre.security.SecurityInitializer.initSecurityInfo(SecurityInitializer.java:350)
 at com.tridium.nre.security.SecurityInitializer.configure(SecurityInitializer.java:75)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 at java.lang.reflect.Method.invoke(Method.java:498)
 at com.tridium.nre.di.BaseSupplier.evaluateConfiguration(BaseSupplier.java:99)
 at com.tridium.nre.di.SingletonSupplier.get(SingletonSupplier.java:62)
 at com.tridium.nre.di.NreInstantiator.instance(NreInstantiator.java:123)
 at com.tridium.nre.bootstrap.Bootstrap.Main(Bootstrap.java:87)
Caused by: java.io.IOException: Process can not write to provided directory '/etc/niagara'
 at com.tridium.nre.util.SimpleKeyValueUtil.getInstance(SimpleKeyValueUtil.java:68)
 at com.tridium.nre.platform.NativePlatformProvider.lambda$getKeyMaterial$20(NativePlatformProvider.java:1512)
 at java.security.AccessController.doPrivileged(Native Method)
 at com.tridium.nre.platform.NativePlatformProvider.getKeyMaterial(NativePlatformProvider.java:1511)
 ... 18 more
SEVERE [11:52:29 17-Nov-20 CET][security.keyMaterial] Permission failure when getting key material
java.security.PrivilegedActionException: java.io.IOException: Process can not write to provided directory '/etc/niagara'
 at java.security.AccessController.doPrivileged(Native Method)
 at com.tridium.nre.platform.NativePlatformProvider.getKeyMaterial(NativePlatformProvider.java:1511)
 at com.tridium.nre.security.km.PlatformKeyMaterial.doGetKeyMaterial(PlatformKeyMaterial.java:56)
 at com.tridium.nre.security.km.KeyMaterial.getKeyMaterial(KeyMaterial.java:33)
 at com.tridium.nre.security.km.KeyMaterial.keyExists(KeyMaterial.java:61)
 at com.tridium.nre.security.km.KeyMaterialFactory.getKeyMaterial(KeyMaterialFactory.java:97)
 at com.tridium.nre.security.KeyRingFactory$GetKeyRingPrivilegedAction.run(KeyRingFactory.java:93)
 at com.tridium.nre.security.KeyRingFactory$GetKeyRingPrivilegedAction.run(KeyRingFactory.java:77)
 at java.security.AccessController.doPrivileged(Native Method)
 at com.tridium.nre.security.KeyRingFactory.getKeyRing(KeyRingFactory.java:68)
 at com.tridium.nre.security.SecurityInitializer.initSecurityInfo(SecurityInitializer.java:350)
 at com.tridium.nre.security.SecurityInitializer.configure(SecurityInitializer.java:75)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 at java.lang.reflect.Method.invoke(Method.java:498)
 at com.tridium.nre.di.BaseSupplier.evaluateConfiguration(BaseSupplier.java:99)
 at com.tridium.nre.di.SingletonSupplier.get(SingletonSupplier.java:62)
 at com.tridium.nre.di.NreInstantiator.instance(NreInstantiator.java:123)
 at com.tridium.nre.bootstrap.Bootstrap.Main(Bootstrap.java:87)
Caused by: java.io.IOException: Process can not write to provided directory '/etc/niagara'
 at com.tridium.nre.util.SimpleKeyValueUtil.getInstance(SimpleKeyValueUtil.java:68)
 at com.tridium.nre.platform.NativePlatformProvider.lambda$getKeyMaterial$20(NativePlatformProvider.java:1512)
 ... 20 more
SEVERE [11:52:29 17-Nov-20 CET][security.keyMaterial] Error attempting to upgrade key material
java.lang.RuntimeException: java.io.IOException: Process can not write to provided directory '/etc/niagara'
 at com.tridium.nre.platform.NativePlatformProvider.getKeyMaterial(NativePlatformProvider.java:1528)
 at com.tridium.nre.security.km.PlatformKeyMaterial.doGetKeyMaterial(PlatformKeyMaterial.java:56)
 at com.tridium.nre.security.km.KeyMaterial.getKeyMaterial(KeyMaterial.java:33)
 at com.tridium.nre.security.km.KeyMaterial.keyExists(KeyMaterial.java:61)
 at com.tridium.nre.security.km.KeyMaterialFactory.getKeyMaterial(KeyMaterialFactory.java:97)
 at com.tridium.nre.security.KeyRingFactory$GetKeyRingPrivilegedAction.run(KeyRingFactory.java:93)
 at com.tridium.nre.security.KeyRingFactory$GetKeyRingPrivilegedAction.run(KeyRingFactory.java:77)
 at java.security.AccessController.doPrivileged(Native Method)
 at com.tridium.nre.security.KeyRingFactory.getKeyRing(KeyRingFactory.java:68)
 at com.tridium.nre.security.SecurityInitializer.initSecurityInfo(SecurityInitializer.java:350)
 at com.tridium.nre.security.SecurityInitializer.configure(SecurityInitializer.java:75)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 at java.lang.reflect.Method.invoke(Method.java:498)
 at com.tridium.nre.di.BaseSupplier.evaluateConfiguration(BaseSupplier.java:99)
 at com.tridium.nre.di.SingletonSupplier.get(SingletonSupplier.java:62)
 at com.tridium.nre.di.NreInstantiator.instance(NreInstantiator.java:123)
 at com.tridium.nre.bootstrap.Bootstrap.Main(Bootstrap.java:87)
Caused by: java.io.IOException: Process can not write to provided directory '/etc/niagara'
 at com.tridium.nre.util.SimpleKeyValueUtil.getInstance(SimpleKeyValueUtil.java:68)
 at com.tridium.nre.platform.NativePlatformProvider.lambda$getKeyMaterial$20(NativePlatformProvider.java:1512)
 at java.security.AccessController.doPrivileged(Native Method)
 at com.tridium.nre.platform.NativePlatformProvider.getKeyMaterial(NativePlatformProvider.java:1511)
 ... 18 more
SEVERE [11:52:29 17-Nov-20 CET][security.keyMaterial] Permission failure when setting key material
java.security.PrivilegedActionException: java.io.IOException: Process can not write to provided directory '/etc/niagara'
 at java.security.AccessController.doPrivileged(Native Method)
 at com.tridium.nre.platform.NativePlatformProvider.setKeyMaterial(NativePlatformProvider.java:1569)
 at com.tridium.nre.security.km.PlatformKeyMaterial.doSetKeyMaterial(PlatformKeyMaterial.java:67)
 at com.tridium.nre.security.km.KeyMaterial.setKeyMaterial(KeyMaterial.java:42)
 at com.tridium.nre.security.km.KeyMaterialFactory.getKeyMaterial(KeyMaterialFactory.java:110)
 at com.tridium.nre.security.KeyRingFactory$GetKeyRingPrivilegedAction.run(KeyRingFactory.java:93)
 at com.tridium.nre.security.KeyRingFactory$GetKeyRingPrivilegedAction.run(KeyRingFactory.java:77)
 at java.security.AccessController.doPrivileged(Native Method)
 at com.tridium.nre.security.KeyRingFactory.getKeyRing(KeyRingFactory.java:68)
 at com.tridium.nre.security.SecurityInitializer.initSecurityInfo(SecurityInitializer.java:350)
 at com.tridium.nre.security.SecurityInitializer.configure(SecurityInitializer.java:75)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 at java.lang.reflect.Method.invoke(Method.java:498)
 at com.tridium.nre.di.BaseSupplier.evaluateConfiguration(BaseSupplier.java:99)
 at com.tridium.nre.di.SingletonSupplier.get(SingletonSupplier.java:62)
 at com.tridium.nre.di.NreInstantiator.instance(NreInstantiator.java:123)
 at com.tridium.nre.bootstrap.Bootstrap.Main(Bootstrap.java:87)
Caused by: java.io.IOException: Process can not write to provided directory '/etc/niagara'
 at com.tridium.nre.util.SimpleKeyValueUtil.getInstance(SimpleKeyValueUtil.java:68)
 at com.tridium.nre.platform.NativePlatformProvider.lambda$setKeyMaterial$23(NativePlatformProvider.java:1570)
 ... 19 more
SEVERE [11:52:29 17-Nov-20 CET][security.keyMaterial] Error generating key material
java.lang.RuntimeException: java.io.IOException: Process can not write to provided directory '/etc/niagara'
 at com.tridium.nre.platform.NativePlatformProvider.setKeyMaterial(NativePlatformProvider.java:1583)
 at com.tridium.nre.security.km.PlatformKeyMaterial.doSetKeyMaterial(PlatformKeyMaterial.java:67)
 at com.tridium.nre.security.km.KeyMaterial.setKeyMaterial(KeyMaterial.java:42)
 at com.tridium.nre.security.km.KeyMaterialFactory.getKeyMaterial(KeyMaterialFactory.java:110)
 at com.tridium.nre.security.KeyRingFactory$GetKeyRingPrivilegedAction.run(KeyRingFactory.java:93)
 at com.tridium.nre.security.KeyRingFactory$GetKeyRingPrivilegedAction.run(KeyRingFactory.java:77)
 at java.security.AccessController.doPrivileged(Native Method)
 at com.tridium.nre.security.KeyRingFactory.getKeyRing(KeyRingFactory.java:68)
 at com.tridium.nre.security.SecurityInitializer.initSecurityInfo(SecurityInitializer.java:350)
 at com.tridium.nre.security.SecurityInitializer.configure(SecurityInitializer.java:75)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 at java.lang.reflect.Method.invoke(Method.java:498)
 at com.tridium.nre.di.BaseSupplier.evaluateConfiguration(BaseSupplier.java:99)
 at com.tridium.nre.di.SingletonSupplier.get(SingletonSupplier.java:62)
 at com.tridium.nre.di.NreInstantiator.instance(NreInstantiator.java:123)
 at com.tridium.nre.bootstrap.Bootstrap.Main(Bootstrap.java:87)
Caused by: java.io.IOException: Process can not write to provided directory '/etc/niagara'
 at com.tridium.nre.util.SimpleKeyValueUtil.getInstance(SimpleKeyValueUtil.java:68)
 at com.tridium.nre.platform.NativePlatformProvider.lambda$setKeyMaterial$23(NativePlatformProvider.java:1570)
 at java.security.AccessController.doPrivileged(Native Method)
 at com.tridium.nre.platform.NativePlatformProvider.setKeyMaterial(NativePlatformProvider.java:1569)
 ... 17 more
Exception in thread "main" com.tridium.nre.di.NreInstantiationException: unable to create instance
 at com.tridium.nre.di.SingletonSupplier.get(SingletonSupplier.java:71)
 at com.tridium.nre.di.NreInstantiator.instance(NreInstantiator.java:123)
 at com.tridium.nre.bootstrap.Bootstrap.Main(Bootstrap.java:87)
Caused by: java.lang.RuntimeException: Unable to initializeSecurityProviders key ring
 at com.tridium.nre.security.SecurityInitializer.initSecurityInfo(SecurityInitializer.java:357)
 at com.tridium.nre.security.SecurityInitializer.configure(SecurityInitializer.java:75)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 at java.lang.reflect.Method.invoke(Method.java:498)
 at com.tridium.nre.di.BaseSupplier.evaluateConfiguration(BaseSupplier.java:99)
 at com.tridium.nre.di.SingletonSupplier.get(SingletonSupplier.java:62)
 ... 2 more
Caused by: java.lang.SecurityException: Could not generate key material
 at com.tridium.nre.security.km.KeyMaterialFactory.getKeyMaterial(KeyMaterialFactory.java:116)
 at com.tridium.nre.security.KeyRingFactory$GetKeyRingPrivilegedAction.run(KeyRingFactory.java:93)
 at com.tridium.nre.security.KeyRingFactory$GetKeyRingPrivilegedAction.run(KeyRingFactory.java:77)
 at java.security.AccessController.doPrivileged(Native Method)
 at com.tridium.nre.security.KeyRingFactory.getKeyRing(KeyRingFactory.java:68)
 at com.tridium.nre.security.SecurityInitializer.initSecurityInfo(SecurityInitializer.java:350)
 ... 9 more
Caused by: java.lang.RuntimeException: java.io.IOException: Process can not write to provided directory '/etc/niagara'
 at com.tridium.nre.platform.NativePlatformProvider.setKeyMaterial(NativePlatformProvider.java:1583)
 at com.tridium.nre.security.km.PlatformKeyMaterial.doSetKeyMaterial(PlatformKeyMaterial.java:67)
 at com.tridium.nre.security.km.KeyMaterial.setKeyMaterial(KeyMaterial.java:42)
 at com.tridium.nre.security.km.KeyMaterialFactory.getKeyMaterial(KeyMaterialFactory.java:110)
 ... 14 more
Caused by: java.io.IOException: Process can not write to provided directory '/etc/niagara'
 at com.tridium.nre.util.SimpleKeyValueUtil.getInstance(SimpleKeyValueUtil.java:68)
 at com.tridium.nre.platform.NativePlatformProvider.lambda$setKeyMaterial$23(NativePlatformProvider.java:1570)
 at java.security.AccessController.doPrivileged(Native Method)
 at com.tridium.nre.platform.NativePlatformProvider.setKeyMaterial(NativePlatformProvider.java:1569)
 ... 17 more
App Failed

It occurred most often when after performing cleanDist, the controller was rebooted too quickly, due to, for example, a loss of power supply, which prevented finishing of the keyMaterial file generation. After the controller restarted, the platform was not able to generate the file again.

Solution

To solve the problem of the damaged keyMaterial file, perform cleanDist again making sure that the controller will be steadily powered during the process.

JavaScript errors detected

Please note, these errors can depend on your browser setup.

If this problem persists, please contact our support.