]> sigrok.org Git - libserialport.git/blame - libserialport.h
Divide sp_set_params into separate helper functions.
[libserialport.git] / libserialport.h
CommitLineData
74510d4b
ML
1/*
2 * This file is part of the libserialport project.
3 *
4 * Copyright (C) 2013 Martin Ling <martin-libserialport@earth.li>
5 *
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU Lesser General Public License as
8 * published by the Free Software Foundation, either version 3 of the
9 * License, or (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU Lesser General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 */
19
e8ffaee9
ML
20#ifndef SERIALPORT_H
21#define SERIALPORT_H
22
74510d4b
ML
23#include <stddef.h>
24#ifdef _WIN32
25#include <windows.h>
26#endif
27
28/* A serial port. */
29struct sp_port {
30 /* Name used to open the port */
31 char *name;
32 /* OS-specific port handle */
33#ifdef _WIN32
34 HANDLE hdl;
35#else
36 int fd;
37#endif
38};
39
40/* Return values. */
41enum {
42 /* Operation completed successfully. */
43 SP_OK = 0,
74510d4b 44 /* Invalid arguments were passed to the function. */
e9a2f9c9
ML
45 SP_ERR_ARG = -1,
46 /* A system error occured while executing the operation. */
47 SP_ERR_FAIL = -2,
48 /* A memory allocation failed while executing the operation. */
49 SP_ERR_MEM = -3
74510d4b
ML
50};
51
52/* Port access modes. */
53enum {
54 /* Open port for read/write access. */
55 SP_MODE_RDWR = 1,
56 /* Open port for read access only. */
57 SP_MODE_RDONLY = 2,
58 /* Open port in non-blocking mode. */
59 SP_MODE_NONBLOCK = 4
60};
61
62/* Parity settings. */
63enum {
64 /* No parity. */
65 SP_PARITY_NONE = 0,
66 /* Even parity. */
67 SP_PARITY_EVEN = 1,
68 /* Odd parity. */
69 SP_PARITY_ODD = 2
70};
71
ac74fdaf
ML
72/* Flow control settings. */
73enum {
74 /* No flow control. */
75 SP_FLOW_NONE = 0,
76 /* Hardware (RTS/CTS) flow control. */
77 SP_FLOW_HARDWARE = 1,
78 /* Software (XON/XOFF) flow control. */
79 SP_FLOW_SOFTWARE = 2
80};
81
77f262c4 82int sp_get_port_by_name(const char *portname, struct sp_port **port_ptr);
e3b2f7a4 83void sp_free_port(struct sp_port *port);
77f262c4 84int sp_list_ports(struct sp_port ***list_ptr);
32b5ac05 85int sp_copy_port(const struct sp_port *port, struct sp_port **copy_ptr);
d54e9004
ML
86void sp_free_port_list(struct sp_port **ports);
87int sp_open(struct sp_port *port, int flags);
74510d4b
ML
88int sp_close(struct sp_port *port);
89int sp_flush(struct sp_port *port);
90int sp_write(struct sp_port *port, const void *buf, size_t count);
91int sp_read(struct sp_port *port, void *buf, size_t count);
92int sp_set_params(struct sp_port *port, int baudrate, int bits, int parity,
93 int stopbits, int flowcontrol, int rts, int dtr);
94int sp_last_error_code(void);
95char *sp_last_error_message(void);
96void sp_free_error_message(char *message);
e8ffaee9
ML
97
98#endif /* SERIALPORT_H */