core: Changed WS from being a flag on a TCP/TLS connection to a protocol in its own...
[sip-router] / fix_lumps.h
1 /*
2  * $Id$
3  *
4  * here, we delete message lumps which are generated in
5  * core functions using pkg_malloc and applied to shmem
6  * requests; not doing so would result ugly memory problems
7  *
8  * I admit it is not a nice hack; -jiri 
9  *
10  * Copyright (C) 2001-2003 FhG Fokus
11  *
12  * This file is part of ser, a free SIP server.
13  *
14  * ser is free software; you can redistribute it and/or modify
15  * it under the terms of the GNU General Public License as published by
16  * the Free Software Foundation; either version 2 of the License, or
17  * (at your option) any later version
18  *
19  * ser is distributed in the hope that it will be useful,
20  * but WITHOUT ANY WARRANTY; without even the implied warranty of
21  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
22  * GNU General Public License for more details.
23  *
24  * You should have received a copy of the GNU General Public License 
25  * along with this program; if not, write to the Free Software 
26  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
27  */
28 /*
29  * History:
30  * -------
31  *  2003-11-24  changed free_via_lump to free_via_clen_lump and make it
32  *              handle CONTENTLENGTH lumps also (andrei)
33  *  2005-07-04  lumps in SHM or dup'ed lumps are not freed and an warning
34  *               message is logged (temporary fix) (andrei)
35  */
36
37
38
39 #ifndef _FIX_LUMPS_H
40 #define _FIX_LUMPS_H
41
42
43
44 /** @brief used to delete attached via lumps from msg;
45
46    msg can be either an original pkg msg, whose Via lump I want
47    to delete before generating next branch, or a shmem-stored
48    message processed during on_reply -- then I want to
49    delete the Via lump for the same reason
50
51    the other case when I want to delete them is when a message
52    is stored in shmem for branch picking, forwarded lated and
53    Via removal is applied to the shmem-ed message
54
55    the same thing for Content-Length lumps (FIXME: this
56    should be done in a nicer way)
57 */
58 inline static void free_via_clen_lump( struct lump **list )
59 {
60         struct lump *prev_lump, *lump, *a, *foo, *next;
61
62         next=0;
63         prev_lump=0;
64         for(lump=*list;lump;lump=next) {
65                 next=lump->next;
66                 if (lump->type==HDR_VIA_T||lump->type==HDR_CONTENTLENGTH_T) {
67                         if (lump->flags & (LUMPFLAG_DUPED|LUMPFLAG_SHMEM)){
68                                 LOG(L_CRIT, "BUG: free_via_clen_lmp: lump %p, flags %x\n",
69                                                 lump, lump->flags);
70                                 /* ty to continue */
71                         }
72                         a=lump->before;
73                         while(a) {
74                                 foo=a; a=a->before;
75                                 if (!(foo->flags&(LUMPFLAG_DUPED|LUMPFLAG_SHMEM)))
76                                         free_lump(foo);
77                                 if (!(foo->flags&LUMPFLAG_SHMEM))
78                                         pkg_free(foo);
79                         }
80                         a=lump->after;
81                         while(a) {
82                                 foo=a; a=a->after;
83                                 if (!(foo->flags&(LUMPFLAG_DUPED|LUMPFLAG_SHMEM)))
84                                         free_lump(foo);
85                                 if (!(foo->flags&LUMPFLAG_SHMEM))
86                                         pkg_free(foo);
87                         }
88                         if (prev_lump) prev_lump->next = lump->next;
89                         else *list = lump->next;
90                         if (!(lump->flags&(LUMPFLAG_DUPED|LUMPFLAG_SHMEM)))
91                                 free_lump(lump);
92                         if (!(lump->flags&LUMPFLAG_SHMEM))
93                                 pkg_free(lump);
94                 } else {
95                         /* store previous position */
96                         prev_lump=lump;
97                 }
98         }
99 }
100
101 #endif