aboutsummaryrefslogtreecommitdiffstats
path: root/meta-oe/recipes-support/picocom/picocom/0001-Fix-building-with-musl.patch
blob: 5b344b9e83ab2ef59c36674c5048821fb3bdf632 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
From 9664809da36bd7bada3e44f50cfc042539fb61ee Mon Sep 17 00:00:00 2001
From: Paul Eggleton <paul.eggleton@linux.intel.com>
Date: Sun, 14 Jul 2019 19:13:21 -0700
Subject: [PATCH] Fix building with musl

Upstream-status: Pending

Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
---
 termios2.c | 27 +++++++++++++++++++++++++++
 termios2.h |  5 +++++
 2 files changed, 32 insertions(+)

diff --git a/termios2.c b/termios2.c
index 97c3be0..88ff6fc 100644
--- a/termios2.c
+++ b/termios2.c
@@ -37,6 +37,7 @@
 #include <errno.h>
 #include <termios.h>
 #include <sys/ioctl.h>
+#include <asm/ioctls.h>
 
 /* Contains the definition of the termios2 structure and some related
    constants that we should normally include from system
@@ -53,6 +54,10 @@
 */
 #define IBAUD0 020000000000
 
+#if !defined(__GLIBC__)
+#define __MAX_BAUD B4000000
+#endif
+
 int
 tc2setattr(int fd, int optional_actions, const struct termios *tios)
 {
@@ -79,8 +84,13 @@ tc2setattr(int fd, int optional_actions, const struct termios *tios)
     t2.c_cflag = tios->c_cflag;
     t2.c_lflag = tios->c_lflag;
     t2.c_line = tios->c_line;
+#if !defined(__GLIBC__)
+    t2.c_ispeed = tios->__c_ispeed;
+    t2.c_ospeed = tios->__c_ospeed;
+#else
     t2.c_ispeed = tios->c_ispeed;
     t2.c_ospeed = tios->c_ospeed;
+#endif
     memcpy(&t2.c_cc[0], &tios->c_cc[0], K_NCCS * sizeof (cc_t));
 
     return ioctl(fd, cmd, &t2);
@@ -101,8 +111,13 @@ tc2getattr(int fd, struct termios *tios)
     tios->c_cflag = t2.c_cflag;
     tios->c_lflag = t2.c_lflag;
     tios->c_line = t2.c_line;
+#if !defined(__GLIBC__)
+    tios->__c_ispeed = t2.c_ispeed;
+    tios->__c_ospeed = t2.c_ospeed;
+#else
     tios->c_ispeed = t2.c_ispeed;
     tios->c_ospeed = t2.c_ospeed;
+#endif
     memcpy(&tios->c_cc[0], &t2.c_cc[0], K_NCCS * sizeof (cc_t));
 
     for (i = K_NCCS; i < NCCS; i++)
@@ -131,7 +146,11 @@ cf2setispeed(struct termios *tios, speed_t speed)
         errno = EINVAL;
         return -1;
     }
+#if !defined(__GLIBC__)
+    tios->__c_ispeed = speed;
+#else
     tios->c_ispeed = speed;
+#endif
     tios->c_cflag &= ~((CBAUD | CBAUDEX) << IBSHIFT);
     tios->c_cflag |= (speed << IBSHIFT);
 
@@ -156,7 +175,11 @@ cf2setospeed_custom(struct termios *tios, int speed)
     }
     tios->c_cflag &= ~(CBAUD | CBAUDEX);
     tios->c_cflag |= BOTHER;
+#if !defined(__GLIBC__)
+    tios->__c_ospeed = speed;
+#else
     tios->c_ospeed = speed;
+#endif
 
     return 0;
 }
@@ -177,7 +200,11 @@ cf2setispeed_custom(struct termios *tios, int speed)
     } else {
         tios->c_cflag &= ~((CBAUD | CBAUDEX) << IBSHIFT);
         tios->c_cflag |= (BOTHER << IBSHIFT);
+#if !defined(__GLIBC__)
+        tios->__c_ispeed = speed;
+#else
         tios->c_ispeed = speed;
+#endif
     }
 
     return 0;
diff --git a/termios2.h b/termios2.h
index e13b0e3..63dd0ce 100644
--- a/termios2.h
+++ b/termios2.h
@@ -37,8 +37,13 @@
 /* And define these new ones */
 #define cfsetospeed_custom cf2setospeed_custom
 #define cfsetispeed_custom cf2setispeed_custom
+#if defined(__linux__) && !defined(__GLIBC__)
+#define cfgetospeed_custom(tiop) ((tiop)->__c_ospeed)
+#define cfgetispeed_custom(tiop) ((tiop)->__c_ispeed)
+#else
 #define cfgetospeed_custom(tiop) ((tiop)->c_ospeed)
 #define cfgetispeed_custom(tiop) ((tiop)->c_ispeed)
+#endif
 
 /* Replacements for the standard tcsetattr(3), tcgetattr(3)
  * functions. Same user interface, but these use the new termios2