(PHP 4 >= 4.3.0, PHP 5 < 5.1.0)

dio_tcsetattr Imposta gli attributi terminale e la velocità per una porta seriale


voiddio_tcsetattr(resource $fd, array $options)

La funzione dio_tcsetattr() imposta gli attributi di terminale e la velocità della porta aperta fd.

Nota: Questa funzione non è implementata sulle piattaforme Windows.

Elenco dei parametri


Descrittore di file restituito da dio_open().


Attualmente le opzioni disponibili sono:

  • 'baud' - velocità della porta - può essere 38400,19200,9600,4800,2400,1800,1200,600,300,200,150,134,110,75 oppure 50, il valore di default è 9600

  • 'bits' - bit di dati - può essere 8,7,6 oppure 5 il valore di default è 8.

  • 'stop' - bit di stop - può essere 1 o 2 il valore di default è 1.

  • 'parity' - può essere 0,1 o 2 il valore di default è 0.

Valori restituiti

Nessun valore viene restituito.


Example #1 Esempio di impostazione della velocità di una porta seriale


dio_open('/dev/ttyS0'O_RDWR O_NOCTTY O_NONBLOCK);


dio_tcsetattr($fd, array(
'baud' => 9600,
'bits' => 8,
'stop'  => 1,
'parity' => 0

while (
1) {

$data dio_read($fd256);

  if (
$data) {


add a note add a note

User Contributed Notes 3 notes

daniel widyanto (kunilkuda at gmail dot com)
16 years ago
I'm using PHP to interface my AVR microcontroller in /dev/ttyS0. I bet someone else does the same.

Here's some hint :
- dio_tcsetattr -> is set to enable :
            - RTS / CTS hardware control
            - ICANON mode
              (means that dio_read will wait until 0x0A/LF or other control character is entered in /dev/ttyS0 before it returns reading result, when you use dio_write it will also send 0x0A/LF automatically in the end of the message to your device).

For those who dont need RTS/CTS and/or ICANON, you can use linux command : stty.

Here's mine :

('stty -F /dev/ttyS0 4800 raw');

$fd=dio_open('/dev/ttyS0',O_RDWR | O_NOCTTY | O_NDELAY);

dio_write($fd,"\x41",1);  // write 0x41 or 'A' to /dev/ttyS0
        // Replace result_length with your expected command result length
for ($i=0;$i < result_length;$i++) {
$result .=dio_read($fd, 1);

Refer to :
- Serial Programming Guide for POSIX Operating Systems, http://www.easysw.com/~mike/serial/
- stty man pages
fherrero at noticiasdenavarra dot com
17 years ago
For Windows the Example 1 looks same this one:


('mode com1: baud=9600 data=8 stop=1 parity=n xon=on');
// execute 'help mode' in command line of Windows for help

$fd = dio_open('com1:', O_RDWR);

while (
1) {

$data = dio_read($fd, 256);

  if (
$data) {

healer at colorado dot edu
18 years ago
It was frustrating at first because I was trying to get my Linux box to talk to an external serial device (a PIC18F452 programmable chip) and the example provided here refers to fcntl() and open() parameters that aren't in the PHP documentation.

I finally found out what does what through the man pages:

man open
man fcntl

still haven't gotten it to work, or how to reset the ttySx, but thought it may help someone...
To Top