IPC (Inter-Process Communications) allows you to send commands between programs to syncronize operations. It does this by listening on a network IP Port Number for incoming messages via a network router (hard wired or wireless ).
You can send IPC commands (see command list below) from one program to the other (ex. RunScript 123). This allows you to synchronize audio and video programming with split second timing. The program that receives the command will execute the specified Script. If you run both programs on the same computer, you do not need to be connected to a network.
FSPortal
FSPortal (FreeStyler Portal) is an add-on for Video Mill and Sound Mill. Or it can be run as a standalone solution client on a tablet to run DMX lights only. It serves as a controller/adapter app to pass Commands to the FreeStyler program to operate DMX lights. See the FSPortal product page for details. IPC configuration for FSPortal is identical to that of Video Mill and Sound Mill.
Note: FSPortal is NOT required for direct IPC connections between Sound Mill and Video Mill.
IPC Networking Example
As an example (shown in Figure 2a), you could use SoundMill-1 (or VideoMill-2) to pipe media programming (audio/video) to the stage speaker system or video displays. Plus it can send FSPortal Controller commands to the FSPortal controller to syncronize DMX lights with audio/video. You can also drive the FSPortal Controller from a FSPortal client running on a tablet (Figure 2b).
How the system is designed is completely up to you and the IP network available at the venue. There is virtually no limit on the number of systems you can network together.
The following are the basic set-up steps to use IPC.
IPC Client Profiles - The program initially creates the IPC Origin Client Profiles using the factory default settings.
Origin Client - This defines the IP address and Port Number that the program will listen to on the local machine.
Remote Client(s) - These clients define the the IP address and Port Number that each remote program will be listening to. You will create one Remote Client for each program that you will send/receive messages to/from.
Start IPC - After completing the configuration steps above, you will start the programs on both (all) computers, then Start IPC in each program. Then test the configuration.
Start IPC - Starts and initializes IPC network connections. If IPC is currently running, this will Stop then Restart IPC to reinitialize it. IPC must be started on all Client programs before the program can send or receive messages. This will initialize an IPCSender and Receiver for the program based the IPC Client Profiles. You can set it to start on program start-up in the Options dialog.
Stop IPC - Stops IPC and releases network connections and resources.
View IPC Status - Pops up a summary of current status of IPC connections and IPC Client Profile settings. This does some error checking as well.
Send Adhoc IPC Command - See section below.
Edit IPC Origin Client Profile - Opens the IPC Client Profile Editor (see below) to edit the Origin Client profile.
Manage IPC Remote Client Profiles - Allows you to Add, Delete and Edit Remote Client profiles.
IPC Clients Reset - This deletes ALL Client Profiles. Then creates one Origin client and one Remote client set with factory default settings.
View IPC Clients - Shows a summary of all of Clients configurations.
View IPC Log - Shows the running log of IPC commands sent and recieved, plus errors when encountered. Useful debugging tool.
The FSPortal Commands accepted by the FSPortal Controller are listed on the Portal Commands page.
IPC Commands
These two commands can be sent to other IPC Remote Clients via the Send Adhoc IPC Command dialog.
Msg - You can send messages to an operator sitting at another Remote Client computer. Example: Msg We start in 5 minutes.
Ping - Sends a Ping to the Destination Remote Client to confirm that it IPC is started and operational on the remote client. The remote client will return a Msg command back to the Ping sender to report the Ping was received. After starting IPC on all clients, it is a good practice to Ping all clients to confirm all connections are initialized with no errors.
You can manually send an IPC message to a Remote Client. This menu item pops up the Send Adhoc IPC Command dialog (Figure 3a) so you can enter a Command. Sending a message with the MSG command is an easy way to confirm that IPC is started and working on both client programs (you will see an IPC message sent/received on the Media List Editor program status bar). This dialog will stay open to allow you to send multiple commands without having to reopen the dialog each time. Commands tags are case-insensitive (ex. Play, PLAY, play are all accepted) .
Send - Sends the command(s) to the specified Destination Remote Client.
Command Picker - Pops up a pick list of valid IPC commands (Figure 3b). You will need to replace "ItemId" or "ScriptId" with the real Id value of an Item.
Recall Forward - Recalls previously sent commands starting with the most recent sent command. Useful for repetitive operations.
Recall Reverse - Recalls previously sent commands but in the reverse order.
Empty - Empties the Recall Commands list.
Refresh - Updates the Destination Client selection list in the event you have made edits to the Remote Clients.
Destination Client - Selects the Destination Remote Client to receive the command.
You can send multiple commands in one click by separating them with a semicolon (;) as shown in Figure 3a. This is faster and more efficient than sending them separately.
All IPC commands sent and received are logged to the IPC Log.
IPC must be Started on both programs for IPC to work.
Figure 4 shows the basic configuration used to send a command from one program to another program using the Remote Client profile.
All IPC commands sent and received are logged to the IPC Log. You can encrypt the message traffic that goes across the network. If one client uses encryption , then all remote clients must use encryption which is set in the Automation Options.
Origin Client - Defines the network IP address of the computer the program is running on and the chosen Port Number that the program will listen on. The Origin IP Address is always the same as the local computer's Private Network IP address.
Remote Client - Defines the network IP address and Port Number of the remote program that commands will be sent to. There must be one Remote Client profile for each remote program that you want to send/receive commands to/from.
Figure 4. Example: IPC Client Configuration For Two Computers
Figure 5. IPC Client Profile Editor
When Video Mill and/or Sound Mill and FSPortal Reside on the Same Computer
In this case, a network router is not required for IPC. Use the standard Loopback IP Address (ie 127.0.0.1) for setup of the IPC clients.
The IPC Client Profile Editor (Figure 5) allows you to configure the Client Profiles. After edits are made, you need to Restart IPC for edits to take effect (Use Start IPC to restart).
Client Profile Settings
Profile Name - A name that logically identifies the Profile. Used for menu selection so keep it short and descriptive.
IP Address - This is the network IP Address of the computer that the program is running on. See the difference between Private Network IP and Loopback IP below. External Internet IP addresses may also work depending on your firewall settings, but only if you have a special need. The Private Network IP is the far preferred IP to use for security and speed reasons.
Port Number - Sound Mill, Video Mill and FSPortal each "Listen" for IPC incoming commands on a designated network Port Number.
Editor Buttons
Private Network IP - This button gets the computer's Private Network IP (IP assigned by the router). Computer must be connected to the router (cabled or wireless) for this action to work. If this button fails, you can open a Windows Commmand Prompt and enter "ipconfig /all". Look for the IPv4 Address (or IPv6 if you are using IPv6 address mode).
Loopback IP - This will set the IP Address to the standard Loopback IP Address (ie 127.0.0.1). ONLY use this when you the two programs that are communicating are running on the same computer. It eliminates the need to have a network router. In ALL other cases, use the local Private Network IP address. Loopback IP address provides a small performance increase for message transfer because it bypasses the system network transaction layer.
Port Number - Pops up a selection list to pick one of the three Default Port Numbers listed below. Also sets the Profile Name based on the selection.
Validate Client - Checks all inputs for valid syntax and values. Some errors will not be detected until IPC is started.
Router Setup and Network IP Addresses
Some routers allow you to lock the assignment of a specific Private Network IP Address to a specific computer connected to its network. So when the router is restarted, it will assign the same IP address to that computer. This is a good method to prevent your IPC client profiles from breaking. If the Private Network IP Address for a computer changes by router reassignment, you will need to make changes to your IPC clients to reflect the IP address changes.
About Port Number
For simplicity you should be consistent when assigning Port Numbers to clients. Below are the default values, but if these ports should conflict with another program on your computer, pick different numbers. Valid ports are any number between 49152 to 65535. Here is how to see what ports are in use on your computer.
Default Port Number
Video Mill - 52011.
Sound Mill - 52010.
Net Comms - 52001.
FreeStyler Portal - 52012.
See previous section "How IPC Works" for an example of how to configure the Origin and Remote clients.
SendTo_UDP Tool: Sending IPC Commands from a Third Party Tool
You may find a need to send an IPC command from a third party tool to trigger automation based an external event. The SendTo_UDP Tool is available for this purpose. Any third party tool that can execute a Windows command line (exe program), can use this tool to send IPC commands to SoundMill, VideoMill and/or FreeStyler DMX Portal. (SendTo_UDP - More information and download)
You should always test the IPC connections before show time.
The first time you connect to a new network, the network firewall may pop up a challenge dialog asking you to Allow the program to send network messages.
To test the IPC Configuration, first Start IPC on both (all) program instances. Then go to Send Adhoc IPC Command. Send a Ping command to each remote client program and watch for the return message that the Ping was recieved on the remote client. If you don't get a return Msg, IPC on the remote client likely encountered a problem on start up.
There are a few common error messages that may be reported. The Windows error messages may not be obvious in describing the error.
Always check the View IPC Status menu item when errors occur and the program session Log and the IPC Log may also report additional errors that may not show up on the program status bar.
Things to Check
After fixing a Client Profile error, you can usually just restart IPC by clicking the Start IPC menu item.
Is IPC started on both the Origin and Remote Client?
Are the Port Numbers set correctly in the Client Profiles?
Are the IP Addresses set correctly in the Client Profiles?
When using encrypted messages, is the "Encrypt Messages" option set on all clients?
Common Error Messages
Find any errors in the Client Profile and make corrections. Then restart IPC on any client where client changes were made.
IPC: Parm is not a valid command. Message: IPC: Parm is not a valid command: rrM7MR7DBglXosgxPe+nJQA==. Problem: Will occur when IPCEncrypt Messages option is set on the sender client but not on the receiver client. The unreadable string is encrypted data that was not decrypted upon receipt.
Solution: Ensure that the "Encrypt Messages" option set on all clients. Then restart IPC.
Connection was forcibly closed Message: An existing connection was forcibly closed by the remote host. Problem: Will occur when IPC is not Started on the Remote Client.
Solution: Check the Port Number in the Remote Client Profile. And check to see if IPC is Started on the Remote Client.
Invalid pointer address Message: The system detected an invalid pointer address in attempting to use a pointer argument in a call. Problem: Usually occurs when IPC is not started on the Remote Client; Or the port number is not correct.
Solution: Check the Port Number in the Remote Client Profile. And check to see if IPC is Started on the Remote Client.
Address Incompatible Message: An address incompatible with the requested protocol was used. Problem: It's likely that one (or both) Client Profile(s) has an IP Addresses not consistent with the current addressing mode in use (IPV4 vs IPV6).
Solution: See which addressing mode in use (IPV4 or IPV6). Then check the Client Profile to see if they are using correct IP Addresses.
End Point creation failed Message: Remote Receiver End Point creation failed for: 0.0.0.0 Problem: The IP Address for the Remote Client Profile has an invalid value.
Solution: Update the IP Address.
Recommendation: We recommend that you use IPV4 addressing mode unless you have a critical reason to use IPV6. We found no noticible performance difference in our testing of these addressing modes. IPV4 IP Addresses are easier to recognize (fewer characters) so debugging configuation problems will be easier when using IPV4. IPV4 is the default factory setting.
If you change this setting, you will need to edit your clients to set new IP addresses.
IPC will run on both IPV4 and IPV6 networks. You can change the IP addressing mode in the Options (requires a program restart).
IPV4 vs IPV6 - Internet Protocol version 4 (IPV4) and version 6 (IPV6), are different specifications for representing an IP Address.
Example IP Addresses:
IPV4 20.0.0.9
IPV6 2001:0:83e8:3d2b:7a25:95fe:c862:2ea3
Loopback IP Address - This value is based on IP addressing mode:
IPV4 127.0.0.1
IPV6 ::1
Things you don't need to know, but are provided for the extreme techies who want the details.
Terms
IP Address - Internet Protocol address uniquely identifies a computer on a network.
Loopback IP Address - Refers to the routing of messages back to the originating computer.
Port Number - A network communications end point. It must be unique port number for the computer.
Network Address Translation (NAT) - Allows multiple devices to connect to a public network using the same public IPv4 address.
Specifications
IPC sends and receives UTF8 formatted text strings using network UDP (User Datagram Protocol) packets.
NAT Traversal for the UDP Client instance is enabled on Windows 10/8/7/Vista but NOT Windows XP. NAT traversal may be provided using Teredo, 6to4, or an ISATAP tunnel. NAT traversal is not a supported feature (meaning it is not included in our test plan). But it should work based on Microsoft documentation.