Shop OBEX P1 Docs P2 Docs Learn Events
PC-to-Prop Serial Communication — Parallax Forums

PC-to-Prop Serial Communication

GrendelTGrendelT Posts: 23
edited 2012-08-06 12:00 in Propeller 1
I recently acquired a PropBOE and absolutely love it. I put atop my BOEBot and found it very easy to integrate. I decided to dive off into a project with the Prop and I'm a bit hung up.

Is it possible to read data from the USB serial port on the PropBOE using something like SERIN from the BS2?
(I understand it's prob a bit more involved than the BS2, but the SERIN and WAIT really made life easy for reading data from the computer.)

Also, I understand P31 is the Rx pin on boot. After bootup, is P31 reset as a plain I/O pin or is it still useful as a serial input from the USB connection?

I'm wanting to listen to a stream of serial data coming from the computer and just at a loss on how to proceed. Thanks for any assistance!

Comments

  • Duane DegnDuane Degn Posts: 10,588
    edited 2012-08-05 15:12
    The Propeller needs a serial driver to communicate with the PC such as "FullDuplexSerial.spin" or "Parallax Serial Terminal.spin".

    You can then use a serial terminal program like "Parallax Serial Terminal.exe" as a debug window.

    These serial drivers often use pin 31 to 30 to communicate with the PC since they're wired to the USB interface. But the program needs to configure these pins before they can be used to communicate with the PC.

    Make sure and check out Parallax's new "Learn" section about the PropBOE. It has lots of useful information on getting started using the Propeller.

    The Propeller Tool's "Help" section also has a pdf of the Propeller Education Kit which also has lessons on how to do these type of things.
  • Mike GreenMike Green Posts: 23,101
    edited 2012-08-05 15:19
    You can use other serial drivers as well, depending on what you need. For speeds up to 9600 Baud, you could use the Simple_Serial object which is written all in Spin. For higher speeds or to get buffering, you'll probably have to use FullDuplexSerial or one of its variants. All of these can be configured to use I/O pin 31 for receiving and I/O pin 30 for transmitting. You might want to put a check in your program to see if I/O Pin 31 is initially high (1) before initializing or otherwise using one of these serial drivers. If I/O Pin 31 is low, you probably don't have the USB serial port connected and you can sometimes have problems with unexpected resets if you try to transmit out I/O pin 30 without a USB port powered up.
  • Cluso99Cluso99 Posts: 18,069
    edited 2012-08-05 15:25
    GrendelT: Yes. It's really simple...
    Take a look at the FullDuplexSerial object that came with proptool. You should find a sample program that uses it. Use 115200 baud (easiest default) and use the Parallax Serial Terminal (PST) (windows terminal program) that came with proptool for the PC end.

    Now. Before you download, open PST and ensure it has 115200 baud set. Then switch (click) PropTool and do the download. While this is downloading you can click on PST and it will check the COM port for availability (counts down ~10secs) and when the port is released by PropTool it will take the port. It is best to use a waitcnt instruction of 23 seconds before outputting any messages from your prop. Otherwise, just repeat outputting a character so you can see it on PST on your PC.

    If you have problems, check back here for more help. Once you have this working, it is a great debugging aid - I cannot stress this enough !!!
  • GrendelTGrendelT Posts: 23
    edited 2012-08-05 15:45
    Yeah, I walked through the http://learn.parallax.com when I got the PropBOE - good stuff. That's what helped get me started! (Hats off to Andy and Stephanie for that venture!)

    I got PST working and I can send characters to it from Putty. Fine business.

    Is there a WAIT directive like that used for SERIN in PBASIC? Or do I need to read in the whole string directly and then parse accordingly?
  • Bob Lawrence (VE1RLL)Bob Lawrence (VE1RLL) Posts: 1,720
    edited 2012-08-05 19:06
    [h=1]AN018: Communication with a PC Application[/h]
    Keywords:
    VB.NET, Visual BASIC, Communication, Serial, Protocol, Packet, PC, QuickStart, P8X32A


    Abstract:
    Abstract: Many embedded applications share information with external devices, and the preferred connection between devices is asynchronous serial communications. The multi-core architecture of the P8X32A enables the designer to create and deploy device-to-device communications strategies with no impact on the primary application code. In this example a deployed communications support cog manages data between the main application and the serial I/O firmware, usingVB.NET and the P8X32A QuickStart board.

    http://www.parallaxsemiconductor.com/an018







  • GrendelTGrendelT Posts: 23
    edited 2012-08-05 19:49
    Right. I came across that PDF too. The application is already made though and is known to work with other devices.

    I'm just wondering if it's possible to pick only pieces from the data coming in.

    Suppose the serial line is receiving this data: P45 V13.6 C0.200 T78.6F U12:05 LAT94.6 LON32.5

    How would I pull out just the LAT and LON fields using PST? With PBASIC you could do a WAIT on the SERIN command. Do I need to receive the whole string then parse it out or is there an object that provides this sort of functionality?
  • Cluso99Cluso99 Posts: 18,069
    edited 2012-08-05 23:28
    There is a waitcnt command. In PropTools under help there is a link to the Propeller Manual. Lookup waitcnt (the spin version, not pasm) for an explanation.

    If you use the fdx.rx command, just look at each character coming in until you reach the ones you want and assemble them as required. IIRC the rx call waits for a character.
  • AribaAriba Posts: 2,690
    edited 2012-08-06 12:00
    GrendelT wrote: »
    ...
    Suppose the serial line is receiving this data: P45 V13.6 C0.200 T78.6F U12:05 LAT94.6 LON32.5

    How would I pull out just the LAT and LON fields using PST? With PBASIC you could do a WAIT on the SERIN command. Do I need to receive the whole string then parse it out or is there an object that provides this sort of functionality?

    Spin has not such built in functions like PBASIC. Either you find an object that has this functions or you do it by yourself. Here is a possible way to decode the characters while you receive them:
    CON
      _clkmode  = xtal1 + pll16x
      _xinfreq  = 5_000_000
    
    OBJ
      ser :  "FullDuplexSerial"
    
    VAR
      byte c1,c2,c3
      long lon,lat,vers
             
    PUB Main
      ser.start(31,30,0, 115200)   '<-- pins and baudrate
      repeat
        c1 := c2
        c2 := c3
        c3 := ser.rx                ' read a char and shift in
        if c1=="L" and c2=="A" and c3=="T"
          lat := rxDec
          ser.str(string(13,"LAT*10 = "))
          ser.dec(lat)
        elseif c1=="L" and c2=="O" and c3=="N"
          lon := rxDec
          ser.str(string(13,"LON*10 = "))
          ser.dec(lon)
        elseif c3=="V"
          vers := rxDec
          ser.str(string(13,"Vers*10 = "))
          ser.dec(vers)
    
    PRI rxDec : val | c             'receive dec chars
     repeat
       c := ser.rx
       case c
         "0".."9": val := val*10 + c-"0"
         ".",":" : 'ignore
         other   : return val
    
    Just load this code and start PST (with 115kBaud), then type your example string or parts of it.

    Andy
Sign In or Register to comment.