Blame view

buildroot/buildroot-2016.08.1/package/netcat/0001-signed-bit-counting.patch 1000 Bytes
6b13f685e   김민수   BSP 최초 추가
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
  # Fix the endian-specific bit-counting code so that it works.
  # SF:1068324 "netcat_flag_count() fix"
  #   http://sourceforge.net/tracker/?func=detail&aid=1205729&group_id=52204&atid=466046
  # SF:1205729 "doen't work on arm linux platform":
  #   http://sourceforge.net/tracker/?func=detail&aid=1068324&group_id=52204&atid=466046
  
  Index: netcat-0.7.1/src/flagset.c
  ===================================================================
  --- netcat-0.7.1.orig/src/flagset.c	2010-07-19 13:51:46.000000000 +0100
  +++ netcat-0.7.1/src/flagset.c	2010-07-19 13:52:27.000000000 +0100
  @@ -134,7 +134,7 @@
   
   int netcat_flag_count(void)
   {
  -  register char c;
  +  register unsigned char c;
     register int i;
     int ret = 0;
   
  @@ -154,8 +154,8 @@
   	Assumed that the bit number 1 is the sign, and that we will shift the
   	bit 1 (or the bit that takes its place later) until the the most right,
   	WHY it has to keep the wrong sign? */
  -      ret -= (c >> 7);
  -      c <<= 1;
  +      ret += c&1;
  +      c>>=1;
       }
     }