I'm getting tired of fighting this every so often. PCs in question are industrial touchscreen models that should never change. This one is Windows 10 while I believe it has also happened on Windows 7. While in the past sometimes this error dealt with emulated com ports (i.e., USB connector) in this case it is a true com port so I can't just plug it into another one since I'm using both 232 connectors. The PC will work fine for months and then one day something goes amiss with a COM port and I'll have to shuffle them around, trying to figure out which ones work now. This is a major pain when I must do it remotely (1000 miles away) with a tech sometimes having to plug cables into different positions.
To eliminate anything with my original program, I have created a very simple test app as follows:
Imports System.IO.Ports
Public Class Form1
Private Sub Form1_Load(sender As Object, e As EventArgs) Handles Me.Load
Try
Dim tempList As List(Of String) = SerialPort.GetPortNames.ToList
ListBox1.DataSource = tempList
Catch ex As Exception
MessageBox.Show(ex.Message)
End Try
End Sub
Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
Dim tempPort As New SerialPort
tempPort.PortName = "COM1"
Try
tempPort.Close()
Catch ex As Exception
MessageBox.Show("Closing error: " & ex.ToString)
End Try
Try
tempPort.Open()
MessageBox.Show("COM1 Opened")
Catch ex As Exception
MessageBox.Show("Open error: " & ex.ToString)
End Try
End Sub
End Class
Even after a fresh reboot, I get no error on the Close attempt but the traditional access denied when I attempt to open it. It does show up in ListBox1, of course.
System.UnauthorizedAccessException: Access to the port 'COM1' is denied. at System.IO.Ports.InternalResources.WinIOError(Int32 errorCode, String str) at System.IO.Ports.SerialStream..ctor(String portName, Int32 baudRate, Parity parity, Int32 dataBits, StopBits stopBits, Int32 readTimeout, Int32 writeTimeout, Handshake handshake, Boolean dtrEnable, Boolean rtsEnable, Boolean discardNull, Byte parityReplace) at System.IO.Ports.SerialPort.Open()
Touchscreens are always supposed to be on COM4 and when I look at the provided config utility that is what always shows up. Going into Device Manager shows no conflicts that I can see on IRQ or memory location for COM1. What is preventing this little test app from opening the port on this PC after a reboot?!?!?
UPDATE: For now at least, it magically "fixed" itself somehow (my bet is gremlins). After a couple more hours of research I remoted back in to see if a reboot into Safe Mode would help and lo and behold my normal program was running! WTH?!?!? I asked the tech what he did to fix it, and he thought I had done something to fix it. Argh!!! I still need to find an answer so a production PC isn't down for 16 hours the next time this happens while we beat our heads against the wall.
Not really an answer (yet at least), but next the time this happens, aside from trying Safe Mode, I'll try finding a serial handle using Process Explorer as detailed in this thread. That seems promising.
UPDATE (Apr 10 '17) - finally found the issue thanks to Clone's answer (not the accepted one) in this thread. Windows sometimes identifies devices with a constant data stream connected to a serial port as a serial mouse (e.g., Microsoft Serial Ballpoint), and tries to install them, TAKING CONTROL OVER THE PORT WITHOUT ANY PROCESS USING IT. Indeed, Process Explorer could not see anything using COM1. The solution is to DISABLE (not uninstall) the device using Device Manager under Mice And Other Pointing Devices.