The new callback will be usefull when we will implement the support for Windows. The implementation of native serial set_timeout method uses a HANDLER on Windows and we will use the WinSock2 API which has a socket descriptor. Signed-off-by: Claudiu Olteanu <olteanu.claudiu@ymail.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
81 lines
2.2 KiB
C
81 lines
2.2 KiB
C
/*
|
|
* libdivecomputer
|
|
*
|
|
* Copyright (C) 2015 Claudiu Olteanu
|
|
* base on code that is Copyright (C) 2008 Jef Driesen
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
|
* MA 02110-1301 USA
|
|
*/
|
|
|
|
#include <libdivecomputer/custom_serial.h>
|
|
#include <serial.h>
|
|
|
|
#include "context-private.h"
|
|
|
|
const dc_serial_operations_t native_serial_ops = {
|
|
.open = serial_open,
|
|
.close = serial_close,
|
|
.read = serial_read,
|
|
.write = serial_write,
|
|
.flush = serial_flush,
|
|
.get_received = serial_get_received,
|
|
.get_transmitted = serial_get_transmitted,
|
|
.set_timeout = serial_set_timeout
|
|
};
|
|
|
|
|
|
void
|
|
dc_serial_init(dc_serial_t *device, void *data, const dc_serial_operations_t *ops)
|
|
{
|
|
memset(device, 0, sizeof (*device));
|
|
device->data = data;
|
|
device->ops = ops;
|
|
}
|
|
|
|
|
|
dc_status_t
|
|
dc_serial_native_open(dc_serial_t **out, dc_context_t *context, const char *devname)
|
|
{
|
|
if (out == NULL)
|
|
return DC_STATUS_INVALIDARGS;
|
|
|
|
// Allocate memory.
|
|
dc_serial_t *serial_device = (dc_serial_t *) malloc (sizeof (dc_serial_t));
|
|
|
|
if (serial_device == NULL) {
|
|
ERROR (context, "Failed to allocate memory.");
|
|
return DC_STATUS_NOMEMORY;
|
|
}
|
|
|
|
// Initialize data and function pointers
|
|
dc_serial_init(serial_device, NULL, &native_serial_ops);
|
|
|
|
// Open the serial device.
|
|
int rc = serial_open (&serial_device->port, context, devname);
|
|
if (rc == -1) {
|
|
ERROR (context, "Failed to open the serial port.");
|
|
free (serial_device);
|
|
return DC_STATUS_IO;
|
|
}
|
|
|
|
// Set the type of the device
|
|
serial_device->type = DC_TRANSPORT_SERIAL;
|
|
|
|
*out = serial_device;
|
|
|
|
return DC_STATUS_SUCCESS;
|
|
}
|