mirror of
https://github.com/urbit/shrub.git
synced 2024-12-29 23:23:52 +03:00
vere: implements lmdb event log format
This commit is contained in:
parent
d1294f9083
commit
5747cc68d1
@ -353,7 +353,6 @@
|
|||||||
*/
|
*/
|
||||||
typedef struct _u3_fact {
|
typedef struct _u3_fact {
|
||||||
c3_d eve_d; // event number
|
c3_d eve_d; // event number
|
||||||
c3_l bug_l; // kernel mug before XX remove
|
|
||||||
c3_l mug_l; // kernel mug after
|
c3_l mug_l; // kernel mug after
|
||||||
u3_noun job; // (pair date ovum)
|
u3_noun job; // (pair date ovum)
|
||||||
struct _u3_fact* nex_u; // next in queue
|
struct _u3_fact* nex_u; // next in queue
|
||||||
|
@ -165,23 +165,24 @@ _disk_commit_start(struct _cd_save* req_u)
|
|||||||
_disk_commit_after_cb);
|
_disk_commit_after_cb);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* _disk_serialize_v0(): serialize events in format v0.
|
/* _disk_serialize_v1(): serialize events in format v1.
|
||||||
*/
|
*/
|
||||||
static c3_w
|
static c3_w
|
||||||
_disk_serialize_v0(u3_fact* tac_u, c3_y** dat_y)
|
_disk_serialize_v1(u3_fact* tac_u, c3_y** out_y)
|
||||||
{
|
{
|
||||||
u3_noun val = u3nc(tac_u->bug_l, u3k(tac_u->job));
|
|
||||||
u3_atom mat;
|
|
||||||
c3_w len_w;
|
|
||||||
|
|
||||||
#ifdef DISK_TRACE_JAM
|
#ifdef DISK_TRACE_JAM
|
||||||
u3t_event_trace("king disk jam", 'B');
|
u3t_event_trace("king disk jam", 'B');
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
mat = u3ke_jam(val);
|
{
|
||||||
len_w = u3r_met(3, mat);
|
u3_atom mat = u3qe_jam(tac_u->job);
|
||||||
*dat_y = c3_malloc(len_w);
|
c3_w len_w = u3r_met(3, mat);
|
||||||
u3r_bytes(0, len_w, *dat_y, mat);
|
c3_y* dat_y = c3_malloc(4 + len_w);
|
||||||
|
dat_y[0] = tac_u->mug_l & 0xff;
|
||||||
|
dat_y[1] = (tac_u->mug_l >> 8) & 0xff;
|
||||||
|
dat_y[2] = (tac_u->mug_l >> 16) & 0xff;
|
||||||
|
dat_y[3] = (tac_u->mug_l >> 24) & 0xff;
|
||||||
|
u3r_bytes(0, len_w, dat_y + 4, mat);
|
||||||
|
|
||||||
#ifdef DISK_TRACE_JAM
|
#ifdef DISK_TRACE_JAM
|
||||||
u3t_event_trace("king disk jam", 'E');
|
u3t_event_trace("king disk jam", 'E');
|
||||||
@ -189,7 +190,9 @@ _disk_serialize_v0(u3_fact* tac_u, c3_y** dat_y)
|
|||||||
|
|
||||||
u3z(mat);
|
u3z(mat);
|
||||||
|
|
||||||
return len_w;
|
*out_y = dat_y;
|
||||||
|
return len_w + 4;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* _disk_batch(): create a write batch
|
/* _disk_batch(): create a write batch
|
||||||
@ -213,7 +216,7 @@ _disk_batch(u3_disk* log_u, c3_d len_d)
|
|||||||
for ( c3_d i_d = 0ULL; i_d < len_d; ++i_d) {
|
for ( c3_d i_d = 0ULL; i_d < len_d; ++i_d) {
|
||||||
c3_assert( (req_u->eve_d + i_d) == tac_u->eve_d );
|
c3_assert( (req_u->eve_d + i_d) == tac_u->eve_d );
|
||||||
|
|
||||||
req_u->siz_i[i_d] = _disk_serialize_v0(tac_u, &req_u->byt_y[i_d]);
|
req_u->siz_i[i_d] = _disk_serialize_v1(tac_u, &req_u->byt_y[i_d]);
|
||||||
|
|
||||||
tac_u = tac_u->nex_u;
|
tac_u = tac_u->nex_u;
|
||||||
}
|
}
|
||||||
@ -276,7 +279,6 @@ u3_disk_boot_plan(u3_disk* log_u, u3_noun job)
|
|||||||
// NB, boot mugs are 0
|
// NB, boot mugs are 0
|
||||||
//
|
//
|
||||||
u3_fact* tac_u = u3_fact_init(++log_u->sen_d, 0, job);
|
u3_fact* tac_u = u3_fact_init(++log_u->sen_d, 0, job);
|
||||||
tac_u->bug_l = 0; // XX
|
|
||||||
|
|
||||||
if ( !log_u->put_u.ent_u ) {
|
if ( !log_u->put_u.ent_u ) {
|
||||||
c3_assert( !log_u->put_u.ext_u );
|
c3_assert( !log_u->put_u.ext_u );
|
||||||
@ -381,9 +383,17 @@ _disk_read_one_cb(void* ptr_v, c3_d eve_d, size_t val_i, void* val_p)
|
|||||||
u3_disk* log_u = red_u->log_u;
|
u3_disk* log_u = red_u->log_u;
|
||||||
u3_fact* tac_u;
|
u3_fact* tac_u;
|
||||||
|
|
||||||
|
if ( 4 >= val_i ) {
|
||||||
|
return c3n;
|
||||||
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
u3_noun val, mug, job;
|
u3_noun job;
|
||||||
c3_l bug_l;
|
c3_y* dat_y = val_p;
|
||||||
|
c3_l mug_l = dat_y[0]
|
||||||
|
^ (dat_y[1] << 8)
|
||||||
|
^ (dat_y[2] << 16)
|
||||||
|
^ (dat_y[3] << 24);
|
||||||
|
|
||||||
#ifdef DISK_TRACE_CUE
|
#ifdef DISK_TRACE_CUE
|
||||||
u3t_event_trace("king disk cue", 'B');
|
u3t_event_trace("king disk cue", 'B');
|
||||||
@ -391,39 +401,23 @@ _disk_read_one_cb(void* ptr_v, c3_d eve_d, size_t val_i, void* val_p)
|
|||||||
|
|
||||||
// XX u3m_soft?
|
// XX u3m_soft?
|
||||||
//
|
//
|
||||||
val = u3ke_cue(u3i_bytes(val_i, val_p));
|
job = u3ke_cue(u3i_bytes(val_i - 4, dat_y + 4));
|
||||||
|
|
||||||
#ifdef DISK_TRACE_CUE
|
#ifdef DISK_TRACE_CUE
|
||||||
u3t_event_trace("king disk cue", 'E');
|
u3t_event_trace("king disk cue", 'E');
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if ( (c3n == u3r_cell(val, &mug, &job))
|
tac_u = u3_fact_init(eve_d, mug_l, job);
|
||||||
|| (c3n == u3r_safe_word(mug, &bug_l)) ) // XX
|
|
||||||
{
|
|
||||||
// failure here triggers cleanup in _disk_read_start_cb()
|
|
||||||
//
|
|
||||||
u3z(val);
|
|
||||||
return c3n;
|
|
||||||
}
|
|
||||||
|
|
||||||
// NB: mug is unknown due to log format
|
|
||||||
//
|
|
||||||
tac_u = u3_fact_init(eve_d, 0, u3k(job));
|
|
||||||
tac_u->bug_l = bug_l;
|
|
||||||
|
|
||||||
u3z(val);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( !red_u->ent_u ) {
|
if ( !red_u->ent_u ) {
|
||||||
c3_assert( !red_u->ext_u );
|
c3_assert( !red_u->ext_u );
|
||||||
|
|
||||||
c3_assert( red_u->eve_d == eve_d );
|
c3_assert( red_u->eve_d == eve_d );
|
||||||
// tac_u->mug_l = 0; // XX
|
|
||||||
red_u->ent_u = red_u->ext_u = tac_u;
|
red_u->ent_u = red_u->ext_u = tac_u;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
c3_assert( (1ULL + red_u->ent_u->eve_d) == eve_d );
|
c3_assert( (1ULL + red_u->ent_u->eve_d) == eve_d );
|
||||||
// log_u->get_u.ent_u->mug_l = tac_u->bug_l; // XX
|
|
||||||
red_u->ent_u->nex_u = tac_u;
|
red_u->ent_u->nex_u = tac_u;
|
||||||
red_u->ent_u = tac_u;
|
red_u->ent_u = tac_u;
|
||||||
}
|
}
|
||||||
|
@ -546,8 +546,6 @@ _lord_work_done(u3_lord* god_u,
|
|||||||
u3_noun act)
|
u3_noun act)
|
||||||
{
|
{
|
||||||
u3_fact* tac_u = u3_fact_init(eve_d, mug_l, job);
|
u3_fact* tac_u = u3_fact_init(eve_d, mug_l, job);
|
||||||
tac_u->bug_l = god_u->mug_l; // XX
|
|
||||||
|
|
||||||
god_u->mug_l = mug_l;
|
god_u->mug_l = mug_l;
|
||||||
god_u->eve_d = eve_d;
|
god_u->eve_d = eve_d;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user