Comm ports and IDE crashes
Jonathan
Posts: 1,023
Hi All,
I am having problems with the Propeller IDE and a bluetooth device. I use the bluetooth device for communicating with my project, so I can't un-install or disable the device.
What happens is that the when programming, the IDE hard crashes when it scans the port that the bluetooth device is on. I have to reboot, force quit doesn't work.
I found a thread discussing this problem, but didn't see a fix. I am using the Prop tool 1.05.5, winXP with SP2 on a Dell 5150 laptop. Is there any way to specify which port for the IDE to use so it skips the scan? I am travelling and nees to get it all working on my laptop. The same issue appears on my desktop. To work around I have been using the desktop for programming and the laptop for communicating with the project, but on the road this won't work.
Thanks!
Jonathan
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
www.madlabs.info - Home of the Hydrogen Fuel Cell Robot
I am having problems with the Propeller IDE and a bluetooth device. I use the bluetooth device for communicating with my project, so I can't un-install or disable the device.
What happens is that the when programming, the IDE hard crashes when it scans the port that the bluetooth device is on. I have to reboot, force quit doesn't work.
I found a thread discussing this problem, but didn't see a fix. I am using the Prop tool 1.05.5, winXP with SP2 on a Dell 5150 laptop. Is there any way to specify which port for the IDE to use so it skips the scan? I am travelling and nees to get it all working on my laptop. The same issue appears on my desktop. To work around I have been using the desktop for programming and the laptop for communicating with the project, but on the road this won't work.
Thanks!
Jonathan
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
www.madlabs.info - Home of the Hydrogen Fuel Cell Robot
Comments
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Paul Baker
Propeller Applications Engineer
Parallax, Inc.
Yes, the bluetooth does have two com ports when I look under the device manager, COM7 and COM8. I am using a Linksys USBBT100 adapter. I am using the latest driver from Linksys, 1.4.2.8 .
Thanks!
Jonathan
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
www.madlabs.info - Home of the Hydrogen Fuel Cell Robot
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Paul Baker
Propeller Applications Engineer
Parallax, Inc.
Thanks for giving me the skinny. I may try picking up another Bluetooth adapter while I'm on the road. Do you know of one which does not cause this problem? Right now I am going to have to unplug/program/quit IDE/ plug. Eeew. Dang Windows...
Thanks!
Jonathan
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
www.madlabs.info - Home of the Hydrogen Fuel Cell Robot
This problem occurs on many brands of bluetooth devices. Personally, I haven't found any brands that don't have some problem with the Prop Tool's autoscan feature.
Paul, I don't think it has to do with "read only" or "write only" ports. These bluetooth ports are virtual com ports that windows just simply enumerates as an available physical port. I've usually found the problem to occur when
1. the bluetooth device is plugged into the computer and the driver/manager is running and
2. the serial port connection isn't actually paired with a bluetooth device.
It's not that it is the PropTool causing the crash. If any other program tries to "open" the port at this time then it'll lockup the system too. BUT, most programs don't go around opening every available com port either. So it doesn't come up too often.
Here's the workaround I've found for BT devices.
1. don't plug it in (not usually·very usefull)
2. move the serial port #s that the bluetooth is using to something high like the 20s
3. make sure there is actually a propeller connected on a low com port so it doesn't get to scan the upper ones
of course after 10-15 minutes of development in this scenario and I ALWAYS forget to turn on the propeller before hitting F10 and my system is lockup up. No blue screen, no CTRL-ALT-DELETE,... nothing just unplug and go to bed.
Oh and its not just limited to bluetooth devices. TCP/IP redirect drivers (ie. Lantronix) have the same problem if the target port isn't available (as in its off). And even loop-back virtual serial ports have a problem.
Really, there are just too many scenarios to try to "fix" the problem. I don't think it can be fixed. There's nothing wrong except maybe trying to open·ports that shouldn't be opened. I know this is a small percentage of the user base's setups, but it isn't that uncommon.
The solution is just let us disable the autoscan feature when we know that it'll lock things up.
·
That presents a stopgap solution for some cases - Run an application which keeps the ports open so the Propeller Tool cannot. It wouldn't help in the situation where simply opening the port leads to a system crash or hang.
It's better to fix the problem rather than the symptoms [noparse]:)[/noparse]
Gr,
Mightor
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
| What the world needs is more geniuses with humility, there are so few of us left.
| "Wait...if that was a compliment, why is my fist of death tingling?"
| - Alice from Dilbert
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Paul Baker
Propeller Applications Engineer
Parallax, Inc.
solution to handle this, with the PropellerTool.
So, this evening I made a little Upload Tool for the Propeller IDE.
It can also be a solution for the Bluethooth and oder COM-problems,
because it does'nt search on the COMs. You can define 4 COM-ports for
code upload to 4 different Propellers.
I used the same technic as for the PreSpin Preprocessor to control the
IDE, and I reused the Loader routines from the PropTerminal.
Installation and Usage:
Copy the PropUp.exe in the PropellerTool directory. Start it before or
after the PropellerTool. The little window will stay in foreground.
Click on Compile to compile a spin code (this is the same as pressing F8).
If not done, enable the Hex-Dump view in the Object info window.
Then set the desired COM number in a line and click on the Upload button,
after the compilation has finished. The code will automatically be saved
as "compiled.binary" file and then uploaded to the Propeller.
With Save, you save all 4 COM numbers and the window position for future
starts.
Don't click on Upload when no Hexdump of the compiled code is visible,
this will write some text lines in the source code.
The Upload button on the first of the 4 COM-port lines will also control
a PropTerminal window, if one is started. You no longer have to minimize
and restore it manually.
Have fun
Andy
I Like it !
Regards,
········· John Twomey
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
'Necessity is the mother of invention'
Gr,
Mightor
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
| What the world needs is more geniuses with humility, there are so few of us left.
| "Wait...if that was a compliment, why is my fist of death tingling?"
| - Alice from Dilbert
I hope Parallax will implement something similar in the IDE, that would be still a little bit more comfortable.
Andy
Post Edited (Ariba) : 8/7/2007 11:35:21 PM GMT
Its an absolutely brilliant hack.
I have a feeling how you did it but I'd love to hear the details so I'll ask...
How DO you get the compiled.binary file? This was a feature I had asked them to add the IDE but it seems like you worked around it anyway.
Once you get the compiled.binary I understand the upload bit as I helped work though that little issue a while ago.
-Chad
There is some explanation in the PreSpin Thread:
http://forums.parallax.com/showthread.php?p=655470
There are some Windows API functions that let you select any activ window and send some key-events to it.
To compile, I activate the IDE, then I send key <F8>. To produce the binary, I send ALT-B (the File-Dialog Opens) then I send the filename as ASCII characters and then <RETURN> - the binary will be saved.
You can cotrol all what is doable with Keyboard-Shortcuts, the problem is you get no feedback, when something is done, so you have to time this with delays and a lot of trying.
Fred
That was my first attempt, but it does'nt easy fit in the PreSpin concept, so I decided to make a new application for now. I hope it is necessary only for short time, until Parallax include something similar into the IDE. If not I will include it in PreSpin later...
Andy
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔