You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

88 lines
3.6 KiB

3 years ago
  1. \documentclass[11pt]{article}
  2. %Gummi|065|=)
  3. \usepackage{graphicx}
  4. \usepackage{caption}
  5. \usepackage{xcolor}
  6. \usepackage[vcentering,dvips]{geometry}
  7. \geometry{papersize={6in,9in},total={4.5in,6.8in}}
  8. \title{\textbf{UserSpace IO via uLisp and Arduino Uno}}
  9. \author{Steak Electronics}
  10. \date{}
  11. \begin{document}
  12. \maketitle
  13. %\tableofcontents
  14. \textcolor{green!60!blue!70}{
  15. \section{UserSpace IO via uLisp and Arduino Uno}}
  16. Overview: Goal is to get an easy way to echo "command" > /dev/ARDUINO from GnuLinux userspace.
  17. Then I can 3D print a box, throw some LEDs in there, and get a hardware interface for anything from my distro.
  18. \subsection{Setup}
  19. First off, I installed the stable uLisp from ulisp.com (AVR version 3.4).
  20. \subsubsection{Trouble with interfacing directly to ttyACM0 / ttyUSB0}
  21. The Arduino Uno uses an FTDI USB to Serial chip. It also has more than just RX/TX connected (I think). This means that when you echo "something" to
  22. arduino, this command will open the serial connection, send the command, then close the command and possibly reset the board via one of the
  23. UART reset pins (DTS perhaps). This won't work. First thing to do, get an FTDI board, and connect it to the computer, the connect
  24. it to digital pins 0,1 (for UART). Then test sending a command. This works. This will be the final setup. Computer -> FTDI -> Arduino.
  25. It should be possible to get it to work without the FTDI chip, but not without some debugging. Have at it, if you wish. I don't have time to troubleshoot this now.
  26. I tried a few things (exec 3<>, and the stty) neither worked. You could also use Python, but then that's more dependencies. Bad idea. This
  27. should be simple.
  28. Ref:
  29. https://forum.arduino.cc/index.php?topic=61127.0
  30. https://arduino.stackexchange.com/questions/16776/how-to-connect-arduino-device-to-linux
  31. https://stackoverflow.com/questions/3918032/bash-serial-i-o-and-arduino
  32. \subsubsection{Troubleshooting Code}
  33. The first thing you will want to do is prove that you can echo or cat "code" > /dev/ARDUINO.
  34. This code works:
  35. \begin{verbatim}
  36. (defun b (&optional x)
  37. (pinmode 13 :output)
  38. (digitalwrite 13 x)
  39. (delay 1000)
  40. (b (not x)))
  41. (b)
  42. \end{verbatim}
  43. Save it as a text file, then cat the file into /dev/ttyUSB0 or /dev/ARDUINO. Problem is, that code runs indefinitely. You can't tell it to do anything else. Hit the reset button to restart the Uno back to square one. So instead, you want a loop that runs and then stops. Here's one of those:
  44. \begin{verbatim}
  45. (defun b ()
  46. (pinmode 13 :output)
  47. (digitalwrite 13 nil)
  48. (delay 500)
  49. (digitalwrite 13 t)
  50. (delay 200)
  51. (digitalwrite 13 nil)
  52. (delay 500)
  53. (digitalwrite 13 t)
  54. (delay 200)
  55. (digitalwrite 13 nil)
  56. (delay 500)
  57. (digitalwrite 13 t)
  58. (delay 200)
  59. (digitalwrite 13 nil)
  60. (delay 500)
  61. (digitalwrite 13 t)
  62. (delay 200))
  63. (b)
  64. \end{verbatim}
  65. This works. Save it as a .dat or .txt (whatever) and cat file.txt > /dev/ARDUINO. It will run a few times, then stop. You can echo it again, if you wish.
  66. There, now we have an interface, and we have proven we can switch an IO high. With a couple of functions, it's trivial to go from there.\footnote{i.e. have one function set IO high for a given pin. Have one function set IO low. Have one function blink IO some amount of times. This can be used for counters or shift registers.}
  67. Tip: When building code, copy and paste into the Arduino Serial Monitor first. This way, if there's an error, it will tell you what's wrong. After
  68. you've tested the code, then you can put it in a text file. As we are keeping this simple, we don't have logging setup, or anything else. This is
  69. meant to be for basic IO from user space, not C compiled programs. Think lightweight.
  70. \end{document}