/[rdesktop]/sourceforge.net/trunk/rdesktop/pstcache.c
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Annotation of /sourceforge.net/trunk/rdesktop/pstcache.c

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1042 - (hide annotations)
Tue Jan 24 12:40:24 2006 UTC (18 years, 3 months ago) by astrand
File MIME type: text/plain
File size: 5331 byte(s)
Applied patch #1390148 from Ilya Konstantinov: Refactoring of color depth code.

1 astrand 963 /* -*- c-basic-offset: 8 -*-
2 jsorg71 725 rdesktop: A Remote Desktop Protocol client.
3     Persistent Bitmap Cache routines
4 jdmeijer 830 Copyright (C) Jeroen Meijer 2004-2005
5 jsorg71 725
6     This program is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10    
11     This program is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14     GNU General Public License for more details.
15    
16     You should have received a copy of the GNU General Public License
17     along with this program; if not, write to the Free Software
18     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19     */
20    
21     #include "rdesktop.h"
22    
23 astrand 738 #define MAX_CELL_SIZE 0x1000 /* pixels */
24 jsorg71 725
25 jdmeijer 808 #define IS_PERSISTENT(id) (id < 8 && g_pstcache_fd[id] > 0)
26 jsorg71 725
27 astrand 1042 extern int g_server_depth;
28 jsorg71 725 extern BOOL g_bitmap_cache;
29     extern BOOL g_bitmap_cache_persist_enable;
30     extern BOOL g_bitmap_cache_precache;
31    
32     int g_pstcache_fd[8];
33     int g_pstcache_Bpp;
34     BOOL g_pstcache_enumerated = False;
35 jdmeijer 830 uint8 zero_key[] = { 0, 0, 0, 0, 0, 0, 0, 0 };
36 jsorg71 725
37    
38 jdmeijer 830 /* Update mru stamp/index for a bitmap */
39 jsorg71 725 void
40     pstcache_touch_bitmap(uint8 cache_id, uint16 cache_idx, uint32 stamp)
41     {
42     int fd;
43    
44 jdmeijer 808 if (!IS_PERSISTENT(cache_id) || cache_idx >= BMPCACHE2_NUM_PSTCELLS)
45 jsorg71 725 return;
46    
47     fd = g_pstcache_fd[cache_id];
48     rd_lseek_file(fd, 12 + cache_idx * (g_pstcache_Bpp * MAX_CELL_SIZE + sizeof(CELLHEADER)));
49     rd_write_file(fd, &stamp, sizeof(stamp));
50     }
51    
52     /* Load a bitmap from the persistent cache */
53     BOOL
54     pstcache_load_bitmap(uint8 cache_id, uint16 cache_idx)
55     {
56     uint8 *celldata;
57     int fd;
58     CELLHEADER cellhdr;
59     HBITMAP bitmap;
60    
61 jdmeijer 808 if (!g_bitmap_cache_persist_enable)
62 jsorg71 725 return False;
63    
64 jdmeijer 808 if (!IS_PERSISTENT(cache_id) || cache_idx >= BMPCACHE2_NUM_PSTCELLS)
65     return False;
66    
67 jsorg71 725 fd = g_pstcache_fd[cache_id];
68     rd_lseek_file(fd, cache_idx * (g_pstcache_Bpp * MAX_CELL_SIZE + sizeof(CELLHEADER)));
69     rd_read_file(fd, &cellhdr, sizeof(CELLHEADER));
70 astrand 738 celldata = (uint8 *) xmalloc(cellhdr.length);
71 jsorg71 725 rd_read_file(fd, celldata, cellhdr.length);
72    
73     bitmap = ui_create_bitmap(cellhdr.width, cellhdr.height, celldata);
74 jdmeijer 830 DEBUG(("Load bitmap from disk: id=%d, idx=%d, bmp=0x%x)\n", cache_id, cache_idx, bitmap));
75     cache_put_bitmap(cache_id, cache_idx, bitmap);
76 jsorg71 725
77     xfree(celldata);
78     return True;
79     }
80    
81     /* Store a bitmap in the persistent cache */
82     BOOL
83 jdmeijer 830 pstcache_save_bitmap(uint8 cache_id, uint16 cache_idx, uint8 * key,
84     uint16 width, uint16 height, uint16 length, uint8 * data)
85 jsorg71 725 {
86     int fd;
87     CELLHEADER cellhdr;
88    
89 jdmeijer 808 if (!IS_PERSISTENT(cache_id) || cache_idx >= BMPCACHE2_NUM_PSTCELLS)
90 jsorg71 725 return False;
91    
92 jdmeijer 830 memcpy(cellhdr.key, key, sizeof(HASH_KEY));
93 jsorg71 725 cellhdr.width = width;
94     cellhdr.height = height;
95     cellhdr.length = length;
96     cellhdr.stamp = 0;
97    
98     fd = g_pstcache_fd[cache_id];
99     rd_lseek_file(fd, cache_idx * (g_pstcache_Bpp * MAX_CELL_SIZE + sizeof(CELLHEADER)));
100     rd_write_file(fd, &cellhdr, sizeof(CELLHEADER));
101     rd_write_file(fd, data, length);
102    
103     return True;
104     }
105    
106 jdmeijer 830 /* List the bitmap keys from the persistent cache file */
107 jsorg71 725 int
108 jdmeijer 830 pstcache_enumerate(uint8 id, HASH_KEY * keylist)
109 jsorg71 725 {
110 jdmeijer 830 int fd, idx, n;
111     sint16 mru_idx[0xa00];
112     uint32 mru_stamp[0xa00];
113 jsorg71 725 CELLHEADER cellhdr;
114    
115 jdmeijer 830 if (!(g_bitmap_cache && g_bitmap_cache_persist_enable && IS_PERSISTENT(id)))
116 jsorg71 725 return 0;
117    
118     /* The server disconnects if the bitmap cache content is sent more than once */
119     if (g_pstcache_enumerated)
120     return 0;
121    
122 jdmeijer 830 DEBUG_RDP5(("Persistent bitmap cache enumeration... "));
123     for (idx = 0; idx < BMPCACHE2_NUM_PSTCELLS; idx++)
124 jsorg71 725 {
125 jdmeijer 830 fd = g_pstcache_fd[id];
126     rd_lseek_file(fd, idx * (g_pstcache_Bpp * MAX_CELL_SIZE + sizeof(CELLHEADER)));
127 jsorg71 725 if (rd_read_file(fd, &cellhdr, sizeof(CELLHEADER)) <= 0)
128     break;
129    
130 jdmeijer 830 if (memcmp(cellhdr.key, zero_key, sizeof(HASH_KEY)) != 0)
131 jsorg71 725 {
132 jdmeijer 830 memcpy(keylist[idx], cellhdr.key, sizeof(HASH_KEY));
133 jsorg71 725
134 astrand 1042 /* Pre-cache (not possible for 8 bit colour depth cause it needs a colourmap) */
135     if (g_bitmap_cache_precache && cellhdr.stamp && g_server_depth > 8)
136 jdmeijer 830 pstcache_load_bitmap(id, idx);
137    
138     /* Sort by stamp */
139     for (n = idx; n > 0 && cellhdr.stamp < mru_stamp[n - 1]; n--)
140 jsorg71 725 {
141 jdmeijer 830 mru_idx[n] = mru_idx[n - 1];
142     mru_stamp[n] = mru_stamp[n - 1];
143     }
144 jsorg71 725
145 jdmeijer 830 mru_idx[n] = idx;
146     mru_stamp[n] = cellhdr.stamp;
147 jsorg71 725 }
148     else
149     {
150     break;
151     }
152     }
153    
154 jdmeijer 830 DEBUG_RDP5(("%d cached bitmaps.\n", idx));
155    
156     cache_rebuild_bmpcache_linked_list(id, mru_idx, idx);
157 jsorg71 725 g_pstcache_enumerated = True;
158 jdmeijer 830 return idx;
159 jsorg71 725 }
160    
161     /* initialise the persistent bitmap cache */
162     BOOL
163     pstcache_init(uint8 cache_id)
164     {
165     int fd;
166     char filename[256];
167    
168     if (g_pstcache_enumerated)
169     return True;
170    
171     g_pstcache_fd[cache_id] = 0;
172    
173     if (!(g_bitmap_cache && g_bitmap_cache_persist_enable))
174     return False;
175    
176     if (!rd_pstcache_mkdir())
177     {
178     DEBUG(("failed to get/make cache directory!\n"));
179     return False;
180     }
181    
182 astrand 1042 g_pstcache_Bpp = (g_server_depth + 7) / 8;
183 jsorg71 725 sprintf(filename, "cache/pstcache_%d_%d", cache_id, g_pstcache_Bpp);
184     DEBUG(("persistent bitmap cache file: %s\n", filename));
185    
186     fd = rd_open_file(filename);
187     if (fd == -1)
188     return False;
189    
190     if (!rd_lock_file(fd, 0, 0))
191     {
192     warning("Persistent bitmap caching is disabled. (The file is already in use)\n");
193     rd_close_file(fd);
194     return False;
195     }
196    
197     g_pstcache_fd[cache_id] = fd;
198     return True;
199     }

  ViewVC Help
Powered by ViewVC 1.1.26