ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/gvpe/src/util.h
Revision: 1.11
Committed: Wed Oct 22 01:05:23 2003 UTC (20 years, 7 months ago) by pcg
Content type: text/plain
Branch: MAIN
CVS Tags: poll-based-iom, VPE_1_4
Changes since 1.10: +26 -0 lines
Log Message:
*** empty log message ***

File Contents

# User Rev Content
1 pcg 1.1 /*
2     util.h -- process management and other utility functions
3     Copyright (C) 1998-2002 Ivo Timmermans <ivo@o2w.nl>
4     2000-2002 Guus Sliepen <guus@sliepen.eu.org>
5 pcg 1.9 2003 Marc Lehmann <pcg@goof.com>
6 pcg 1.1
7     This program is free software; you can redistribute it and/or modify
8     it under the terms of the GNU General Public License as published by
9     the Free Software Foundation; either version 2 of the License, or
10     (at your option) any later version.
11    
12     This program is distributed in the hope that it will be useful,
13     but WITHOUT ANY WARRANTY; without even the implied warranty of
14     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15     GNU General Public License for more details.
16    
17     You should have received a copy of the GNU General Public License
18     along with this program; if not, write to the Free Software
19     Foundation, Inc. 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20     */
21    
22     #ifndef UTIL_H__
23     #define UTIL_H__
24    
25 pcg 1.11 #include <openssl/rsa.h>
26    
27 pcg 1.10 #include "gettext.h"
28    
29     #include "slog.h"
30 pcg 1.3 #include "iom.h"
31 pcg 1.1
32     /*
33     * check for an existing vped for this net, and write pid to pidfile
34     */
35     extern int write_pidfile (void);
36    
37     /*
38     * kill older vped
39     */
40     extern int kill_other (int signal);
41    
42     /*
43     * Detach from current terminal, write pidfile, kill parent
44     */
45     extern int detach (int do_detach);
46    
47     /*
48     * Set all files and paths according to netname
49     */
50     extern void make_names (void);
51    
52     /*
53     * check wether the given path is an absolute pathname
54     */
55     #define ABSOLUTE_PATH(c) ((c)[0] == '/')
56 pcg 1.10
57 pcg 1.11 /*****************************************************************************/
58    
59 pcg 1.10 typedef u8 mac[6];
60 pcg 1.1
61 pcg 1.8 extern void id2mac (unsigned int id, void *m);
62 pcg 1.1
63 pcg 1.8 #define mac2id(p) ((p)[0] & 0x01 ? 0 : ((p)[4] << 8) | (p)[5])
64 pcg 1.1
65 pcg 1.2 struct sliding_window {
66     u32 v[(WINDOWSIZE + 31) / 32];
67     u32 seq;
68    
69     void reset (u32 seqno)
70     {
71     memset (v, -1, sizeof v);
72     seq = seqno;
73     }
74    
75     bool recv_ok (u32 seqno)
76     {
77     if (seqno <= seq - WINDOWSIZE)
78     slog (L_ERR, _("received duplicate or outdated packet (received %08lx, expected %08lx)\n"
79     "possible replay attack, or just massive packet reordering"), seqno, seq + 1);//D
80     else if (seqno > seq + WINDOWSIZE)
81     slog (L_ERR, _("received duplicate or out-of-sync packet (received %08lx, expected %08lx)\n"
82     "possible replay attack, or just massive packet loss"), seqno, seq + 1);//D
83     else
84     {
85     while (seqno > seq)
86     {
87     seq++;
88    
89     u32 s = seq % WINDOWSIZE;
90     u32 *cell = v + (s >> 5);
91     u32 mask = 1 << (s & 31);
92    
93     *cell &= ~mask;
94     }
95    
96     u32 s = seqno % WINDOWSIZE;
97     u32 *cell = v + (s >> 5);
98     u32 mask = 1 << (s & 31);
99    
100     if (*cell & mask)
101     {
102     slog (L_ERR, _("received duplicate packet (received %08lx, expected %08lx)\n"
103     "possible replay attack, or just packet duplication"), seqno, seq + 1);//D
104     return false;
105     }
106     else
107     {
108     *cell |= mask;
109     return true;
110     }
111     }
112     }
113     };
114    
115 pcg 1.6 typedef callback0<const char *> run_script_cb;
116 pcg 1.5
117     // run a shell script (or actually an external program).
118     void run_script (const run_script_cb &cb, bool wait);
119    
120 pcg 1.7 #if ENABLE_HTTP_PROXY
121     u8 *base64_encode (const u8 *data, unsigned int len);
122     #endif
123 pcg 1.11
124     /*****************************************************************************/
125    
126     typedef u8 rsaclear[RSA_KEYLEN - RSA_OVERHEAD]; // challenge data;
127     typedef u8 rsacrypt[RSA_KEYLEN]; // encrypted challenge
128    
129     static inline void
130     rsa_encrypt (RSA *key, const rsaclear &chg, rsacrypt &encr)
131     {
132     if (RSA_public_encrypt (sizeof chg,
133     (unsigned char *)&chg, (unsigned char *)&encr,
134     key, RSA_PKCS1_OAEP_PADDING) < 0)
135     fatal ("RSA_public_encrypt error");
136     }
137    
138     static inline bool
139     rsa_decrypt (RSA *key, const rsacrypt &encr, rsaclear &chg)
140     {
141     return RSA_private_decrypt (sizeof encr,
142     (unsigned char *)&encr, (unsigned char *)&chg,
143     key, RSA_PKCS1_OAEP_PADDING) > 0;
144     }
145 pcg 1.7
146 pcg 1.1 #endif
147