38 #include <sys/select.h>
39 #include <IOKit/serial/ioss.h>
41 namespace rp{
namespace arch{
namespace net{
44 :
rp::hal::serial_rxtx()
52 raw_serial::~raw_serial()
58 bool raw_serial::open()
60 return open(_portName, _baudrate, _flags);
63 bool raw_serial::bind(
const char * portname, uint32_t baudrate, uint32_t flags)
65 strncpy(_portName, portname,
sizeof(_portName));
71 bool raw_serial::open(
const char * portname, uint32_t baudrate, uint32_t flags)
73 if (isOpened()) close();
75 serial_fd = ::open(portname, O_RDWR | O_NOCTTY | O_NDELAY);
77 if (serial_fd == -1)
return false;
79 struct termios options, oldopt;
80 tcgetattr(serial_fd, &oldopt);
81 bzero(&options,
sizeof(
struct termios));
83 cfsetspeed(&options, B19200);
86 options.c_cflag |= (CLOCAL | CREAD);
89 options.c_cflag &= ~PARENB;
90 options.c_cflag &= ~CSTOPB;
92 options.c_cflag &= ~CSIZE;
93 options.c_cflag |= CS8;
96 options.c_cflag &= ~CNEW_RTSCTS;
99 options.c_iflag &= ~(IXON | IXOFF | IXANY);
102 options.c_lflag &= ~(ICANON | ECHO | ECHOE | ISIG);
104 options.c_oflag &= ~OPOST;
106 tcflush(serial_fd,TCIFLUSH);
108 if (tcsetattr(serial_fd, TCSANOW, &options))
114 printf(
"Setting serial port baudrate...\n");
116 speed_t speed = (speed_t)baudrate;
117 if (ioctl(serial_fd, IOSSIOSPEED, &speed)== -1) {
118 printf(
"Error calling ioctl(..., IOSSIOSPEED, ...) %s - %s(%d).\n",
119 portname, strerror(errno), errno);
124 _is_serial_opened =
true;
132 void raw_serial::close()
138 _is_serial_opened =
false;
141 int raw_serial::senddata(
const unsigned char *
data,
size_t size)
144 if (!isOpened())
return 0;
146 if (
data == NULL ||
size ==0)
return 0;
151 int ans = ::write(serial_fd,
data + tx_len,
size-tx_len);
153 if (ans == -1)
return tx_len;
156 required_tx_cnt = tx_len;
157 }
while (tx_len<
size);
164 int raw_serial::recvdata(
unsigned char *
data,
size_t size)
166 if (!isOpened())
return 0;
168 int ans = ::read(serial_fd,
data,
size);
170 if (ans == -1) ans=0;
171 required_rx_cnt = ans;
176 void raw_serial::flush(
_u32 flags)
178 tcflush(serial_fd,TCIFLUSH);
181 int raw_serial::waitforsent(
_u32 timeout,
size_t * returned_size)
183 if (returned_size) *returned_size = required_tx_cnt;
187 int raw_serial::waitforrecv(
_u32 timeout,
size_t * returned_size)
189 if (!isOpened() )
return -1;
191 if (returned_size) *returned_size = required_rx_cnt;
195 int raw_serial::waitfordata(
size_t data_count,
_u32 timeout,
size_t * returned_size)
198 if (returned_size==NULL) returned_size=(
size_t *)&length;
203 struct timeval timeout_val;
207 FD_SET(serial_fd, &input_set);
208 max_fd = serial_fd + 1;
211 timeout_val.tv_sec = timeout / 1000;
212 timeout_val.tv_usec = (timeout % 1000) * 1000;
218 if ( ioctl(serial_fd, FIONREAD, &nread) == -1)
return ANS_DEV_ERR;
220 *returned_size = nread;
222 if (*returned_size >= data_count)
231 int n = ::select(max_fd, &input_set, NULL, NULL, &timeout_val);
248 assert (FD_ISSET(serial_fd, &input_set));
251 if ( ioctl(serial_fd, FIONREAD, returned_size) == -1)
return ANS_DEV_ERR;
252 if (*returned_size >= data_count)
264 size_t raw_serial::rxqueue_count()
266 if ( !isOpened() )
return 0;
269 if (::ioctl(serial_fd, FIONREAD, &remaining) == -1)
return 0;
273 void raw_serial::setDTR()
275 if ( !isOpened() )
return;
277 uint32_t dtr_bit = TIOCM_DTR;
278 ioctl(serial_fd, TIOCMBIS, &dtr_bit);
281 void raw_serial::clearDTR()
283 if ( !isOpened() )
return;
285 uint32_t dtr_bit = TIOCM_DTR;
286 ioctl(serial_fd, TIOCMBIC, &dtr_bit);
289 void raw_serial::_init()
293 required_tx_cnt = required_rx_cnt = 0;
298 _u32 raw_serial::getTermBaudBitmap(
_u32 baud)
300 #define BAUD_CONV(_baud_) case _baud_: return _baud_
334 namespace rp{
namespace hal{