Coverage Report

Created: 2026-05-30 06:39

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/vinyl-cache/bin/vinyld/cache/cache_vinyld.h
Line
Count
Source
1
/*-
2
 * Copyright (c) 2006 Verdens Gang AS
3
 * Copyright (c) 2006-2015 Varnish Software AS
4
 * All rights reserved.
5
 *
6
 * Author: Poul-Henning Kamp <phk@phk.freebsd.dk>
7
 *
8
 * SPDX-License-Identifier: BSD-2-Clause
9
 *
10
 * Redistribution and use in source and binary forms, with or without
11
 * modification, are permitted provided that the following conditions
12
 * are met:
13
 * 1. Redistributions of source code must retain the above copyright
14
 *    notice, this list of conditions and the following disclaimer.
15
 * 2. Redistributions in binary form must reproduce the above copyright
16
 *    notice, this list of conditions and the following disclaimer in the
17
 *    documentation and/or other materials provided with the distribution.
18
 *
19
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
20
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22
 * ARE DISCLAIMED.  IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
23
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25
 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28
 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29
 * SUCH DAMAGE.
30
 *
31
 * Stuff that should *never* be exposed to a VMOD
32
 */
33
34
#include "cache.h"
35
36
#include "vsb.h"
37
38
#include <sys/socket.h>
39
40
#include <string.h>
41
#include <limits.h>
42
#include <unistd.h>
43
44
#include "common/common_param.h"
45
46
#ifdef NOT_IN_A_VMOD
47
#  include "VSC_main.h"
48
#endif
49
50
/*--------------------------------------------------------------------*/
51
52
struct vfp;
53
struct vdp;
54
struct cli_proto;
55
struct poolparam;
56
57
/*--------------------------------------------------------------------*/
58
59
typedef enum req_fsm_nxt req_state_f(struct worker *, struct req *);
60
struct req_step {
61
  const char  *name;
62
  req_state_f *func;
63
};
64
65
extern const struct req_step R_STP_TRANSPORT[1];
66
extern const struct req_step R_STP_RECV[1];
67
68
struct vxid_pool {
69
  uint64_t    next;
70
  uint32_t    count;
71
};
72
73
/*--------------------------------------------------------------------
74
 * Private part of worker threads
75
 */
76
77
struct worker_priv {
78
  unsigned    magic;
79
#define WORKER_PRIV_MAGIC 0x3047db99
80
  struct objhead    *nobjhead;
81
  struct objcore    *nobjcore;
82
  void      *nhashpriv;
83
  struct vxid_pool  vxid_pool[1];
84
  struct vcl    *vcl;
85
};
86
87
/*--------------------------------------------------------------------
88
 * HTTP Protocol connection structure
89
 *
90
 * This is the protocol independent object for a HTTP connection, used
91
 * both for backend and client sides.
92
 *
93
 */
94
95
struct http_conn {
96
  unsigned    magic;
97
#define HTTP_CONN_MAGIC   0x3e19edd1
98
99
  int     *rfd;
100
  stream_close_t    doclose;
101
  body_status_t   body_status;
102
  struct ws   *ws;
103
  char      *rxbuf_b;
104
  char      *rxbuf_e;
105
  char      *pipeline_b;
106
  char      *pipeline_e;
107
  ssize_t     content_length;
108
  void      *priv;
109
110
  /* Timeouts */
111
  vtim_dur    first_byte_timeout;
112
  vtim_dur    between_bytes_timeout;
113
};
114
115
enum htc_status_e {
116
#define HTC_STATUS(e, n, s, l) HTC_S_ ## e = n,
117
#include "tbl/htc.h"
118
};
119
120
typedef enum htc_status_e htc_complete_f(struct http_conn *);
121
122
/* -------------------------------------------------------------------*/
123
124
extern volatile struct params * cache_param;
125
126
/* -------------------------------------------------------------------
127
 * The VCF facility is deliberately undocumented, use at your peril.
128
 */
129
130
struct vcf_return {
131
  const char    *name;
132
};
133
134
#define VCF_RETURNS() \
135
    VCF_RETURN(CONTINUE) \
136
    VCF_RETURN(DEFAULT) \
137
    VCF_RETURN(MISS) \
138
    VCF_RETURN(HIT)
139
140
#define VCF_RETURN(x) extern const struct vcf_return VCF_##x[1];
141
VCF_RETURNS()
142
#undef VCF_RETURN
143
144
typedef const struct vcf_return *vcf_func_f(
145
  struct req *req,
146
  struct objcore **oc,
147
  struct objcore **oc_exp,
148
  int state);
149
150
struct vcf {
151
  unsigned    magic;
152
#define VCF_MAGIC   0x183285d1
153
  vcf_func_f    *func;
154
  void      *priv;
155
};
156
157
/* Prototypes etc ----------------------------------------------------*/
158
159
/* cache_backend_cfg.c */
160
void VBE_InitCfg(void);
161
162
/* cache_ban.c */
163
164
/* for stevedoes resurrecting bans */
165
void BAN_Hold(void);
166
void BAN_Release(void);
167
void BAN_Reload(const uint8_t *ban, unsigned len);
168
struct ban *BAN_FindBan(vtim_real t0);
169
void BAN_RefBan(struct objcore *oc, struct ban *);
170
vtim_real BAN_Time(const struct ban *ban);
171
172
/* cache_busyobj.c */
173
struct busyobj *VBO_GetBusyObj(const struct worker *, const struct req *);
174
void VBO_ReleaseBusyObj(struct worker *wrk, struct busyobj **busyobj);
175
void VBO_SetState(struct worker *wrk, struct busyobj *bo,
176
    enum boc_state_e next);
177
178
/* cache_director.c */
179
int VDI_GetHdr(struct busyobj *);
180
VCL_IP VDI_GetIP(struct busyobj *);
181
void VDI_Finish(struct busyobj *bo);
182
stream_close_t VDI_Http1Pipe(struct req *, struct busyobj *);
183
void VDI_Panic(const struct director *, struct vsb *, const char *nm);
184
void VDI_Event(const struct director *d, enum vcl_event_e ev);
185
void VDI_Init(void);
186
187
/* cache_deliver_proc.c */
188
void VDP_Fini(const struct vdp_ctx *vdc);
189
void VDP_Init(struct vdp_ctx *vdc, struct worker *wrk, struct vsl_log *vsl,
190
    const struct req *req, const struct busyobj *bo, intmax_t *cl);
191
uint64_t VDP_Close(struct vdp_ctx *, struct objcore *, struct boc *);
192
void VDP_Panic(struct vsb *vsb, const struct vdp_ctx *vdc);
193
int VDP_Push(VRT_CTX, struct vdp_ctx *, struct ws *, const struct vdp *,
194
    void *priv);
195
int VDP_ObjIterate(void *priv, unsigned flush, const void *ptr, ssize_t len);
196
int VDP_DeliverObj(struct vdp_ctx *vdc, struct objcore *oc);
197
extern const struct vdp VDP_gunzip;
198
extern const struct vdp VDP_esi;
199
extern const struct vdp VDP_range;
200
201
uint64_t VDPIO_Close(struct vdp_ctx *, struct objcore *, struct boc *);
202
int VDPIO_Upgrade(VRT_CTX, struct vdp_ctx *vdc);
203
int VDPIO_Push(VRT_CTX, struct vdp_ctx *, struct ws *, const struct vdp *,
204
    void *priv);
205
206
207
/* cache_exp.c */
208
vtim_real EXP_Ttl(const struct req *, const struct objcore *);
209
vtim_real EXP_Ttl_grace(const struct req *, const struct objcore *oc);
210
void EXP_RefNewObjcore(struct objcore *);
211
void EXP_Insert(struct worker *wrk, struct objcore *oc);
212
void EXP_Remove(struct objcore *, const struct objcore *);
213
214
#define EXP_Dttl(req, oc) (oc->ttl - (req->t_req - oc->t_origin))
215
216
/* cache_expire.c */
217
218
/*
219
 * The set of variables which control object expiry are inconveniently
220
 * 24 bytes long (double+3*float) and this causes alignment waste if
221
 * we put then in a struct.
222
 * These three macros operate on the struct we don't use.
223
 */
224
225
#define EXP_ZERO(xx)              \
226
  do {                \
227
    (xx)->t_origin = 0.0;         \
228
    (xx)->ttl = 0.0;          \
229
    (xx)->grace = 0.0;          \
230
    (xx)->keep = 0.0;         \
231
  } while (0)
232
233
#define EXP_COPY(to,fm)             \
234
  do {                \
235
    (to)->t_origin = (fm)->t_origin;      \
236
    (to)->ttl = (fm)->ttl;          \
237
    (to)->grace = (fm)->grace;        \
238
    (to)->keep = (fm)->keep;        \
239
  } while (0)
240
241
#define EXP_WHEN(to)              \
242
  ((to)->t_origin + (to)->ttl + (to)->grace + (to)->keep)
243
244
/* cache_exp.c */
245
void EXP_Rearm(struct objcore *oc, vtim_real now,
246
    vtim_dur ttl, vtim_dur grace, vtim_dur keep);
247
void EXP_Reduce(struct objcore *oc, vtim_real now,
248
    vtim_dur ttl, vtim_dur grace, vtim_dur keep);
249
250
/* From cache_main.c */
251
void BAN_Init(void);
252
void BAN_Compile(void);
253
void BAN_Shutdown(void);
254
255
/* From cache_hash.c */
256
void BAN_NewObjCore(struct objcore *oc);
257
void BAN_DestroyObj(struct objcore *oc);
258
int BAN_CheckObject(struct worker *, struct objcore *, struct req *);
259
260
/* cache_busyobj.c */
261
void VBO_Init(void);
262
263
/* cache_cli.c [CLI] */
264
void CLI_Init(void);
265
void CLI_Run(void);
266
void CLI_AddFuncs(struct cli_proto *p);
267
268
/* cache_expire.c */
269
void EXP_Init(void);
270
void EXP_Shutdown(void);
271
272
/* cache_fetch.c */
273
enum vbf_fetch_mode_e {
274
  VBF_NORMAL = 0,
275
  VBF_PASS = 1,
276
  VBF_BACKGROUND = 2,
277
};
278
void VBF_Fetch(struct worker *wrk, struct req *req,
279
    struct objcore *oc, struct objcore *oldoc, enum vbf_fetch_mode_e);
280
const char *VBF_Get_Filter_List(struct busyobj *);
281
void Bereq_Rollback(VRT_CTX);
282
283
/* cache_fetch_proc.c */
284
void VFP_Init(void);
285
struct vfp_entry *VFP_Push(struct vfp_ctx *, const struct vfp *);
286
enum vfp_status VFP_GetStorage(struct vfp_ctx *, ssize_t *sz, uint8_t **ptr);
287
void VFP_Extend(const struct vfp_ctx *, ssize_t sz, enum vfp_status);
288
void VFP_Setup(struct vfp_ctx *vc, struct worker *wrk);
289
int VFP_Open(VRT_CTX, struct vfp_ctx *);
290
uint64_t VFP_Close(struct vfp_ctx *);
291
292
extern const struct vfp VFP_gunzip;
293
extern const struct vfp VFP_gzip;
294
extern const struct vfp VFP_testgunzip;
295
extern const struct vfp VFP_esi;
296
extern const struct vfp VFP_esi_gzip;
297
298
/* cache_http.c */
299
void HTTP_Init(void);
300
301
/* cache_http1_proto.c */
302
303
htc_complete_f HTTP1_Complete;
304
uint16_t HTTP1_DissectRequest(struct http_conn *, struct http *);
305
uint16_t HTTP1_DissectResponse(struct http_conn *, struct http *resp,
306
    const struct http *req);
307
struct v1l;
308
unsigned HTTP1_Write(struct v1l *v1l, const struct http *hp, const int*);
309
310
/* cache_main.c */
311
vxid_t VXID_Get(const struct worker *, uint64_t marker);
312
extern pthread_key_t panic_key;
313
extern pthread_key_t witness_key;
314
315
void THR_SetName(const char *name);
316
const char* THR_GetName(void);
317
void THR_SetBusyobj(const struct busyobj *);
318
struct busyobj * THR_GetBusyobj(void);
319
void THR_SetRequest(const struct req *);
320
struct req * THR_GetRequest(void);
321
void THR_SetWorker(const struct worker *);
322
struct worker * THR_GetWorker(void);
323
void THR_Init(void);
324
325
/* cache_lck.c */
326
void LCK_Init(void);
327
328
/* cache_mempool.c */
329
void MPL_AssertSane(const void *item);
330
struct mempool * MPL_New(const char *name, volatile struct poolparam *pp,
331
    volatile unsigned *cur_size);
332
void MPL_Destroy(struct mempool **mpp);
333
void *MPL_Get(struct mempool *mpl, unsigned *size);
334
void MPL_Free(struct mempool *mpl, void *item);
335
336
/* cache_obj.c */
337
void ObjInit(void);
338
struct objcore * ObjNew(const struct worker *);
339
void ObjDestroy(const struct worker *, struct objcore **);
340
int ObjGetSpace(struct worker *, struct objcore *, ssize_t *sz, uint8_t **ptr);
341
void ObjExtend(struct worker *, struct objcore *, ssize_t l, int final);
342
uint64_t ObjWaitExtend(const struct worker *, const struct objcore *,
343
    uint64_t l, enum boc_state_e *statep);
344
void ObjSetState(struct worker *, struct objcore *, enum boc_state_e next,
345
    unsigned broadcast);
346
enum boc_state_e ObjWaitState(const struct objcore *, enum boc_state_e want);
347
void ObjTouch(struct worker *, struct objcore *, vtim_real now);
348
void ObjFreeObj(struct worker *, struct objcore *);
349
void ObjSlim(struct worker *, struct objcore *);
350
void *ObjSetAttr(struct worker *, struct objcore *, enum obj_attr,
351
    ssize_t len, const void *);
352
int ObjCopyAttr(struct worker *, struct objcore *, struct objcore *,
353
    enum obj_attr attr);
354
void ObjBocDone(struct worker *, struct objcore *, struct boc **);
355
// VAI
356
uint64_t ObjVAIGetExtend(struct worker *, const struct objcore *, uint64_t,
357
    enum boc_state_e *, struct vai_qe *);
358
void ObjVAICancel(struct worker *, struct boc *, struct vai_qe *);
359
360
int ObjSetDouble(struct worker *, struct objcore *, enum obj_attr, double);
361
int ObjSetU64(struct worker *, struct objcore *, enum obj_attr, uint64_t);
362
int ObjSetXID(struct worker *, struct objcore *, vxid_t);
363
364
void ObjSetFlag(struct worker *, struct objcore *, enum obj_flags of, int val);
365
366
void ObjSendEvent(struct worker *, struct objcore *oc, unsigned event);
367
368
#define OEV_INSERT  (1U<<1)
369
#define OEV_BANCHG  (1U<<2)
370
#define OEV_TTLCHG  (1U<<3)
371
#define OEV_EXPIRE  (1U<<4)
372
373
#define OEV_MASK (OEV_INSERT|OEV_BANCHG|OEV_TTLCHG|OEV_EXPIRE)
374
375
typedef void obj_event_f(struct worker *, void *priv, struct objcore *,
376
    unsigned);
377
378
uintptr_t ObjSubscribeEvents(obj_event_f *, void *, unsigned mask);
379
void ObjUnsubscribeEvents(uintptr_t *);
380
381
/* cache_panic.c */
382
void PAN_Init(void);
383
int PAN__DumpStruct(struct vsb *vsb, int block, int track, const void *ptr,
384
    const char *smagic, unsigned magic, const char *fmt, ...)
385
    v_printflike_(7,8);
386
387
#define PAN_CheckMagic(vsb, ptr, exp)         \
388
  do {                \
389
    if ((ptr)->magic != (exp))        \
390
      VSB_printf((vsb),       \
391
          "MAGIC at %p is 0x%08x (Should be: %s/0x%08x)\n", \
392
          ptr, (ptr)->magic, #exp, exp);    \
393
  } while(0)
394
395
#define PAN_dump_struct(vsb, ptr, magic, ...)   \
396
0
    PAN__DumpStruct(vsb, 1, 1, ptr, #magic, magic, __VA_ARGS__)
397
398
#define PAN_dump_oneline(vsb, ptr, magic, ...)    \
399
    PAN__DumpStruct(vsb, 0, 1, ptr, #magic, magic, __VA_ARGS__)
400
401
#define PAN_dump_once(vsb, ptr, magic, ...)   \
402
0
    PAN__DumpStruct(vsb, 1, 0, ptr, #magic, magic, __VA_ARGS__)
403
404
#define PAN_dump_once_oneline(vsb, ptr, magic, ...)   \
405
0
    PAN__DumpStruct(vsb, 0, 0, ptr, #magic, magic, __VA_ARGS__)
406
407
/* cache_pool.c */
408
void Pool_Init(void);
409
int Pool_Task(struct pool *pp, struct pool_task *task, enum task_prio prio);
410
int Pool_Task_Arg(struct worker *, enum task_prio, task_func_t *,
411
    const void *arg, size_t arg_len);
412
void Pool_Sumstat(const struct worker *w);
413
int Pool_TrySumstat(const struct worker *wrk);
414
void Pool_PurgeStat(unsigned nobj);
415
int Pool_Task_Any(struct pool_task *task, enum task_prio prio);
416
void pan_pool(struct vsb *);
417
418
/* cache_range.c */
419
int VRG_CheckBo(struct busyobj *);
420
421
/* cache_req.c */
422
struct req *Req_New(struct sess *, const struct req *);
423
void Req_Release(struct req *);
424
void Req_Rollback(VRT_CTX);
425
void Req_Cleanup(struct sess *sp, struct worker *wrk, struct req *req);
426
void Req_Fail(struct req *req, stream_close_t reason);
427
void Req_AcctLogCharge(struct VSC_main_wrk *, struct req *);
428
void Req_LogHit(struct worker *, struct req *, struct objcore *, intmax_t);
429
const char *Req_LogStart(const struct worker *, struct req *);
430
int Resp_l_storage(struct req *req, const struct stevedore *stv);
431
432
/* cache_req_body.c */
433
int VRB_Ignore(struct req *);
434
ssize_t VRB_Cache(struct req *, ssize_t maxsize);
435
void VRB_Free(struct req *);
436
437
/* cache_req_fsm.c [CNT] */
438
439
int Resp_Setup_Deliver(struct req *);
440
void Resp_Setup_Synth(struct req *);
441
442
enum req_fsm_nxt {
443
  REQ_FSM_MORE,
444
  REQ_FSM_DONE,
445
  REQ_FSM_DISEMBARK,
446
};
447
448
void CNT_Embark(struct worker *, struct req *);
449
enum req_fsm_nxt CNT_Request(struct req *);
450
451
/* cache_session.c */
452
void SES_NewPool(struct pool *, unsigned pool_no);
453
void SES_DestroyPool(struct pool *);
454
void SES_Wait(struct sess *, const struct transport *);
455
void SES_Ref(struct sess *sp);
456
void SES_Rel(struct sess *sp);
457
458
void HTC_Status(enum htc_status_e, const char **, const char **);
459
void HTC_RxInit(struct http_conn *htc, struct ws *ws);
460
void HTC_RxPipeline(struct http_conn *htc, char *);
461
enum htc_status_e HTC_RxStuff(struct http_conn *, htc_complete_f *,
462
    vtim_real *t1, vtim_real *t2, vtim_real ti, vtim_real tn, vtim_dur td,
463
    int maxbytes);
464
465
#define SESS_ATTR(UP, low, typ, len)          \
466
  int SES_Set_##low(const struct sess *sp, const typ *src); \
467
  int SES_Reserve_##low(struct sess *sp, typ **dst, ssize_t *sz);
468
#include "tbl/sess_attr.h"
469
int SES_Set_String_Attr(struct sess *sp, enum sess_attr a, const char *src);
470
471
/* cache_shmlog.c */
472
extern struct VSC_main *VSC_C_main;
473
void VSM_Init(void);
474
void VSL_Init(struct vsl_log *vsl, void *ptr, size_t len);
475
void VSL_Alloc(struct vsl_log *vsl);
476
void VSL_Free(struct vsl_log *vsl);
477
void VSL_ChgId(struct vsl_log *vsl, const char *typ, const char *why,
478
    vxid_t vxid);
479
void VSL_End(struct vsl_log *vsl);
480
void VSL_Flush(struct vsl_log *, int overflow);
481
482
/* cache_conn_pool.c */
483
struct conn_pool;
484
void VCP_Init(void);
485
void VCP_Panic(struct vsb *, struct conn_pool *);
486
void VCP_RelPoll(void);
487
488
/* cache_backend_probe.c */
489
void VBP_Init(void);
490
491
/* cache_vary.c */
492
int VRY_Create(struct busyobj *bo, struct vsb **psb);
493
int VRY_Match(const struct req *, const uint8_t *vary);
494
void VRY_Prep(struct req *);
495
void VRY_Clear(struct req *);
496
enum vry_finish_flag { KEEP, DISCARD };
497
void VRY_Finish(struct req *req, enum vry_finish_flag);
498
499
/* cache_vcl.c */
500
void VCL_Bo2Ctx(struct vrt_ctx *, struct busyobj *);
501
void VCL_Req2Ctx(struct vrt_ctx *, struct req *);
502
struct vrt_ctx *VCL_Get_CliCtx(int);
503
struct vsb *VCL_Rel_CliCtx(struct vrt_ctx **);
504
void VCL_Panic(struct vsb *, const char *nm, const struct vcl *);
505
void VCL_Poll(void);
506
void VCL_Init(void);
507
void VCL_Shutdown(void);
508
509
#define VCL_MET_MAC(l,u,t,b) \
510
    void VCL_##l##_method(struct vcl *, struct worker *, struct req *, \
511
  struct busyobj *bo, void *specific);
512
#include "tbl/vcl_returns.h"
513
514
515
typedef int vcl_be_func(struct cli *, struct director *, void *);
516
517
int VCL_IterDirector(struct cli *, const char *, vcl_be_func *, void *);
518
519
/* cache_vrt.c */
520
void pan_privs(struct vsb *, const struct vrt_privs *);
521
522
/* cache_vrt_filter.c */
523
int VCL_StackVFP(struct vfp_ctx *, const struct vcl *, const char *);
524
int VCL_StackVDP(struct vdp_ctx *vdc, const struct vcl *vcl, const char *fl,
525
    struct req *req, struct busyobj *bo);
526
const char *resp_Get_Filter_List(struct req *req);
527
void VCL_VRT_Init(void);
528
529
/* cache_vrt_vcl.c */
530
const char *VCL_Return_Name(unsigned);
531
const char *VCL_Method_Name(unsigned);
532
void VCL_Refresh(struct vcl **);
533
void VCL_Recache(const struct worker *, struct vcl **);
534
void VCL_Ref(struct vcl *);
535
void VCL_Rel(struct vcl **);
536
VCL_BACKEND VCL_DefaultDirector(const struct vcl *);
537
const struct vrt_backend_probe *VCL_DefaultProbe(const struct vcl *);
538
539
/* cache_vrt_priv.c */
540
extern struct vrt_privs cli_task_privs[1];
541
void VCL_TaskEnter(struct vrt_privs *);
542
void VCL_TaskLeave(VRT_CTX, struct vrt_privs *);
543
544
/* cache_vrt_vmod.c */
545
void VMOD_Init(void);
546
void VMOD_Panic(struct vsb *);
547
548
#if defined(ENABLE_COVERAGE) || defined(ENABLE_SANITIZER)
549
#  define DONT_DLCLOSE_VMODS
550
#endif
551
552
/* cache_wrk.c */
553
void WRK_Init(void);
554
void WRK_AddStat(const struct worker *);
555
void WRK_Log(enum VSL_tag_e, const char *, ...);
556
557
/* cache_vpi.c */
558
extern const size_t vpi_wrk_len;
559
void VPI_wrk_init(struct worker *, void *, size_t);
560
void VPI_Panic(struct vsb *, const struct wrk_vpi *, const struct vcl *);
561
562
/* cache_ws.c */
563
void WS_Panic(struct vsb *, const struct ws *);
564
static inline int
565
WS_IsReserved(const struct ws *ws)
566
0
{
567
0
568
0
  return (ws->r != NULL);
569
0
}
Unexecuted instantiation: cache_ws_emu.c:WS_IsReserved
Unexecuted instantiation: cache_ws_common.c:WS_IsReserved
Unexecuted instantiation: cache_esi_parse.c:WS_IsReserved
Unexecuted instantiation: esi_parse_fuzzer.c:WS_IsReserved
570
571
void *WS_AtOffset(const struct ws *ws, unsigned off, unsigned len);
572
unsigned WS_ReservationOffset(const struct ws *ws);
573
int WS_Pipeline(struct ws *, const void *b, const void *e, unsigned rollback);
574
575
/* cache_ws_common.c */
576
void WS_Id(const struct ws *ws, char *id);
577
void WS_Rollback(struct ws *, uintptr_t);
578
579
/* http1/cache_http1_pipe.c */
580
void V1P_Init(void);
581
582
/* cache_http2_deliver.c */
583
void V2D_Init(void);
584
585
/* stevedore.c */
586
void STV_open(void);
587
void STV_warn(void);
588
void STV_close(void);
589
const struct stevedore *STV_next(void);
590
int STV_BanInfoDrop(const uint8_t *ban, unsigned len);
591
int STV_BanInfoNew(const uint8_t *ban, unsigned len);
592
void STV_BanExport(const uint8_t *banlist, unsigned len);
593
// STV_NewObject() len is space for OBJ_VARATTR
594
int STV_NewObject(struct worker *, struct objcore *,
595
    const struct stevedore *, unsigned len);
596
597
struct stv_buffer;
598
struct stv_buffer *STV_AllocBuf(struct worker *wrk, const struct stevedore *stv,
599
    size_t size);
600
void STV_FreeBuf(struct worker *wrk, struct stv_buffer **pstvbuf);
601
void *STV_GetBufPtr(struct stv_buffer *stvbuf, size_t *psize);
602
603
#ifdef WITH_PERSISTENT_STORAGE
604
/* storage_persistent.c */
605
void SMP_Ready(void);
606
#endif
607
608
40.7k
#define FEATURE(x)  COM_FEATURE(cache_param->feature_bits, x)
609
#define EXPERIMENT(x) COM_EXPERIMENT(cache_param->experimental_bits, x)
610
14.7k
#define DO_DEBUG(x) COM_DO_DEBUG(cache_param->debug_bits, x)
611
612
#define DSL(debug_bit, id, ...)         \
613
  do {              \
614
    if (DO_DEBUG(debug_bit))      \
615
      VSL(SLT_Debug, (id), __VA_ARGS__);  \
616
  } while (0)
617
618
#define DSLb(debug_bit, ...)          \
619
14.7k
  do {             \
620
14.7k
    if (DO_DEBUG(debug_bit))      \
621
14.7k
      WRK_Log(SLT_Debug, __VA_ARGS__); \
622
14.7k
  } while (0)