Contiki 3.x
rs232.c
1 /*
2  * Copyright (c) 2006, Swedish Institute of Computer Science.
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  * notice, this list of conditions and the following disclaimer in the
12  * documentation and/or other materials provided with the distribution.
13  * 3. Neither the name of the Institute nor the names of its contributors
14  * may be used to endorse or promote products derived from this software
15  * without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
18  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20  * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
21  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27  * SUCH DAMAGE.
28  *
29  */
30 
31 #include "lib/sensors.h"
32 #include "dev/rs232.h"
33 #include "dev/serial-line.h"
34 #include "lib/simEnvChange.h"
35 #include <string.h>
36 #include <stdio.h>
37 
38 const struct simInterface rs232_interface;
39 
40 #define SERIAL_BUF_SIZE 1024
41 
42 // COOJA variables
43 char simSerialReceivingData[SERIAL_BUF_SIZE];
44 int simSerialReceivingLength;
45 char simSerialReceivingFlag;
46 
47 static int (* input_handler)(unsigned char) = NULL;
48 
49 /*-----------------------------------------------------------------------------------*/
50 void rs232_init(void) { }
51 /*-----------------------------------------------------------------------------------*/
52 void rs232_set_speed(unsigned char speed) { }
53 /*-----------------------------------------------------------------------------------*/
54 void
55 rs232_set_input(int (*f)(unsigned char))
56 {
57  input_handler = f;
58 }
59 /*-----------------------------------------------------------------------------------*/
60 void rs232_send(char c) {
61  printf("%c", c);
62 }
63 /*-----------------------------------------------------------------------------------*/
64 void
65 rs232_print(char *message)
66 {
67  printf("%s", message);
68 }
69 /*-----------------------------------------------------------------------------------*/
70 void
71 slip_arch_writeb(unsigned char c)
72 {
73  simlog_char(c);
74 }
75 /*-----------------------------------------------------------------------------------*/
76 static void
77 doInterfaceActionsBeforeTick(void)
78 {
79  int i;
80 
81  if (!simSerialReceivingFlag) {
82  return;
83  }
84 
85  if (simSerialReceivingLength == 0) {
86  /* Error, should not be zero */
87  simSerialReceivingFlag = 0;
88  return;
89  }
90 
91  /* Notify specified rs232 handler */
92  if(input_handler != NULL) {
93  for (i=0; i < simSerialReceivingLength; i++) {
94  input_handler(simSerialReceivingData[i]);
95  }
96  } else {
97  /* Notify serial process */
98  for (i=0; i < simSerialReceivingLength; i++) {
99  serial_line_input_byte(simSerialReceivingData[i]);
100  }
102  }
103 
104  simSerialReceivingLength = 0;
105  simSerialReceivingFlag = 0;
106 }
107 /*-----------------------------------------------------------------------------------*/
108 static void
109 doInterfaceActionsAfterTick(void)
110 {
111 }
112 /*-----------------------------------------------------------------------------------*/
113 
114 SIM_INTERFACE(rs232_interface,
115  doInterfaceActionsBeforeTick,
116  doInterfaceActionsAfterTick);
void rs232_init(void)
Initialize the RS232 module.
Definition: rs232.c:50
void slip_arch_writeb(unsigned char c)
Copyright (c) 2014, Analog Devices, Inc.
Definition: slip-arch.c:46
int serial_line_input_byte(unsigned char c)
Get one byte of input from the serial driver.
Definition: serial-line.c:60
void rs232_set_speed(unsigned char speed)
Configure the speed of the RS232 hardware.
Definition: rs232.c:52
void rs232_set_input(int(*f)(unsigned char))
Set an input handler for incoming RS232 data.
Definition: rs232.c:55
#define NULL
The null pointer.
Generic serial I/O process header filer.
void rs232_print(char *text)
Print a text string on RS232.
Definition: rs232.c:65
void rs232_send(uint8_t port, unsigned char c)
Print a character on RS232.
Definition: rs232.c:325