Skip to content

Latest commit

 

History

History
143 lines (112 loc) · 2.72 KB

README.md

File metadata and controls

143 lines (112 loc) · 2.72 KB

femtocom

femtocom is a simple shell-based wrapper-like scripting app for picocom terminal emulator app.

Prerequirements

  • modern GNU/Linux distro;
  • picocom;
  • configuration line for every device of interest in custom rules file for udev;
  • femtocom script;
  • configuration file for femtocom.

picocom

Install picocom:

  • using package manager of your distribution like:
$ sudo  apt  install  picocom

or

$ sudo  dnf  install  picocom

(or something similar)

  • using sources:
$ git  clone  https://github.com/npat-efault/picocom
$ cd  picocom
$ make

udev rule

  • add custom rule for a compatible device:
SUBSYSTEM=="tty", ATTRS{bcdDevice}=="____", ATTRS{idProduct}=="____", ATTRS{idVendor}=="____", MODE="0664", GROUP="plugdev", SYMLINK+="CUSTOM_NAME"
  • restart udev to apply changes:
$ sudo  udevadm  control --reload-rules  &&  sudo  udevadm  trigger

femtocom

$ wget  https://github.com/ia/femtocom/raw/main/femtocom
  • set executable bit for the downloaded script:
$ chmod  a+x  femtocom
  • put the downloaded script to the directory like /usr/local/bin or a similar one which is in PATH shell variable:
$ mv  femtocom  DIRECTORY_WITH_BINS_INCLUDED_IN_PATH_VARIABLE

femtocom config

  • create file ~/.femtocomrc:
$ touch ~/.femtocomrc
  • add default section to the config:
[default]
	baud=115200
	databits=8
	parity=n
	flow=n
	stopbits=1
	omap=crlf
	port=/dev/ttyUSB0
  • add per-device section for a compatible device, i.e.:
[CUSTOM_NAME]
	baud=115200
	databits=8
	parity=n
	flow=n
	stopbits=1

Testing a setup

  • connect a device;
  • just run:
    • to use default settings:
      $ femtocom default
    • to use a device specific settings:
      $ femtocom CUSTOM_NAME
  • if everything is configured properly, then shell to a target device will be initialized:
$ femtocom hw

====>>>> exit: hold CTRL and press: A X

====>>>> picocom --baud 115200 --databits 8 --parity n --flow n --stopbits 1 /dev/hw

picocom v3.2a

port is        : /dev/hw
flowcontrol    : none
baudrate is    : 115200
parity is      : none
databits are   : 8
stopbits are   : 1
escape is      : C-a
local echo is  : no
noinit is      : no
noreset is     : no
hangup is      : no
nolock is      : no
send_cmd is    : sz -vv
receive_cmd is : rz -vv -E
imap is        : 
omap is        : 
emap is        : crcrlf,delbs,
logfile is     : none
initstring     : none
exit_after is  : not set
exit is        : no

Type [C-a] [C-h] to see available commands
Terminal ready

> help
Available commands
...