summaryrefslogtreecommitdiff
path: root/os-patches/linux-patches.html
blob: ed2fda6cd9aab1436741ff5ec2ee0638b30e623c (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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
<html><head>
  <title>Linux patches to support ACE</title>
</head>

<BODY text = "#000000"
link="#000fff"
vlink="#ff0f0f"
bgcolor="#ffffff">

With RedHat 5.0 distributions of Linux, it's best to upgrade the
distribution with these:
<ul>
  <li>egcs 1.0.2
  <li>glibc-2.0.7-7 (from ftp://sunsite.unc.edu/pub/gnu)
</ul>

Thanks to James CE Johnson &lt;jjohnson@lads.com&gt;, Torbjörn
Lindgren &lt;tl@funcom.com&gt;, and Oleg Krivosheev
&lt;kriol@fnal.gov&gt; for this information.  With the above
configuration, ACE compiles and runs cleanly on Intel platforms.  It
compiles and runs cleanly on Alpha platforms with the patches listed
below.<p>

<strong><blink><font color="#ff0000">WARNING:</font></blink></strong>
There is a bug in <code>getsockname ()</code> on versions of Linux
through 2.0.30, at least.  <code>getsockname ()</code> returns an
Internet host address of 127.0.0.1 (localhost) instead of 0.0.0.0 for
sockets that aren't connected.  This bug prevents TAO servers from
working correctly.  To fix it, comment out these two lines in function
<code>inet_getname ()</code> in
<code>/usr/src/linux/net/ipv4/af_inet.c</code>:

<pre>
	} else {
		__u32 addr = sk-&gt;rcv_saddr;
		if (!addr) {
			addr = sk-&gt;saddr;
/* comment out this line:  if (!addr) */
/* comment out this line:  	addr = ip_my_addr(); */
		}
		sin-&gt;sin_port = sk-&gt;dummy_th.source;
		sin-&gt;sin_addr.s_addr = addr;
	}
</pre>

and rebuild your kernel.  This fix has been implemented in 2.1.x
versions of the kernel.<p>

Without the following patch from Scott Snyder &lt;sss@d0linux01.fnal.gov&gt;,
egcs 1.0.1 on Linux won't be able to compile
netsvcs/lib/Server_Logging_Handler.cpp:

<pre>
1997-12-10  scott snyder  &lt;sss@d0linux01.fnal.gov&gt;

	* method.c (make_thunk): Avoid name buffer overflow.


Index: gcc/cp/method.c
===================================================================
RCS file: /d0sgi0/usr0/snyder/CVSROOT/egcs/gcc/cp/method.c,v
retrieving revision 1.1.1.5
diff -c -r1.1.1.5 method.c
*** method.c    1997/12/08 21:06:03     1.1.1.5
--- method.c    1997/12/11 05:40:37
***************
*** 1811,1817 ****
       tree function;
       int delta;
  {
!   char buffer[250];
    tree thunk_id;
    tree thunk;
    char *func_name;
--- 1811,1817 ----
       tree function;
       int delta;
  {
!   char *buffer;
    tree thunk_id;
    tree thunk;
    char *func_name;
***************
*** 1822,1827 ****
--- 1822,1828 ----
    if (TREE_CODE (func_decl) != FUNCTION_DECL)
      abort ();
    func_name = IDENTIFIER_POINTER (DECL_ASSEMBLER_NAME (func_decl));
+   buffer = (char *)alloca (strlen (func_name) + 32);
    if (delta&lt;=0)
      sprintf (buffer, "__thunk_%d_%s", -delta, func_name);
    else
</pre>

With RedHat 5.0 on Alpha CPUs, two system patches and one
glibc-2.0.6/linuxthreads patch are necessary in addition to the above.
The first patch is for the GNU assembler, gas.  It is only necessary
on Alphas, and only when <code>-g</code> is used.  If you don't want
to patch the assembler, you can enable the SUPPRESS_DASH_G option in
the <code>platform_linux.GNu</code>.  Otherwise, this patch can be
applied to the binutils gas source.  Then, rebuild and install as.
The file to be patched is binutils-2.8.1/gas/config/tc-alpha.h:<p>

<pre>
--- tc-alpha.h.orig	Mon May 26 12:32:38 1997
+++ tc-alpha.h	Sat Feb 28 06:45:41 1998
@@ -25,6 +25,8 @@

 #define TARGET_ARCH			bfd_arch_alpha

+#define PAGE_SIZE 8192
+
 #define TARGET_FORMAT (OUTPUT_FLAVOR == bfd_target_ecoff_flavour	\
 		       ? "ecoff-littlealpha"				\
 		       : OUTPUT_FLAVOR == bfd_target_elf_flavour	\
</pre><p>

In addition, you'll need to patch
<code>/usr/src/linux/include/linux/posix_types.h</code> as follows
to avoid compilation errors:<p>

<pre>
--- posix_types.h.ORIGINAL	Wed Nov 12 12:01:56 1997
+++ posix_types.h	Fri Feb 27 14:13:16 1998
@@ -41,9 +41,14 @@
 #undef __FDMASK
 #define	__FDMASK(d)	(1UL &lt;&lt; ((d) % __NFDBITS))

+#if defined (__KERNEL__)
 typedef struct fd_set {
 	unsigned long fds_bits [__FDSET_LONGS];
 } __kernel_fd_set;
+#else  /* ! __KERNEL__ */
+#include &lt;gnu/types.h&gt;
+typedef __fd_set __kernel_fd_set;
+#endif /* ! __KERNEL__ */

 /* Type of a signal handler.  */
 typedef void (*__kernel_sighandler_t)(int);
</pre><p>

Finally, on Alpha only, I removed wrapsyscall from the LinuxThreads
library by patching linuxthreads/Makefile:

<pre>
36c36
&lt;                      semaphore wrapsyscall
---
&gt;                      semaphore # wrapsyscall
</pre>

With that and the above configuration/pathes, all ACE tests run
perfectly cleanly on Alpha!<p>

<hr>
<h3>Old patches</h3>

If you use glibc-2.0.6, you'll need to apply Torbjörn Lindgren's
&lt;tl@funcom.com&gt; patch to glibc-2.0.6's LinuxThreads:<p>

<pre>
--- signals.c.old	Wed Jan 14 01:09:02 1998
+++ signals.c	Wed Jan 14 01:11:37 1998
@@ -82,7 +82,7 @@
   pthread_mutex_lock(&sigwaited_mut);
   /* Make sure no other thread is waiting on our signals */
 test_again:
-  for (s = 0; s &lt; NSIG; s++) {
+  for (s = 1; s &lt; NSIG; s++) {
     if (sigismember(set, s) && sigismember(&sigwaited, s)) {
       pthread_cond_wait(&sigwaited_changed, &sigwaited_mut);
       goto test_again;
@@ -96,7 +96,7 @@
   /* Install our signal handler on all signals in set,
      and unblock them in mask.
      Also mark those signals as being sigwaited on */
-  for (s = 1; s &lt;= NSIG; s++) {
+  for (s = 1; s &lt; NSIG; s++) {
     if (sigismember(set, s) && s != PTHREAD_SIG_CANCEL) {
       sigdelset(&mask, s);
       action.sa_handler = __pthread_sighandler;
@@ -121,7 +121,7 @@
   self-&gt;p_cancel_jmp = NULL;
   /* The signals are now reblocked. Restore the sighandlers. */
   pthread_mutex_lock(&sigwaited_mut);
-  for (s = 1; s &lt;= NSIG; s++) {
+  for (s = 1; s &lt; NSIG; s++) {
     if (sigismember(set, s) && s != PTHREAD_SIG_CANCEL) {
       sigaction(s, &(saved_signals[s]), NULL);
       sigdelset(&sigwaited, s);
</pre>

</body> </html>