rng_egd_chr_read分析

backends/rng-egd.c

------

buf即Rng的物理buffer指针,size即为Rng的buffer的大小。

static void rng_egd_chr_read(void *opaque, const uint8_t *buf, int size)

{
    RngEgd *s = RNG_EGD(opaque);
    size_t buf_offset = 0;

    while (size > 0 && s->requests) {
        RngRequest *req = s->requests->data;
        int len = MIN(size, req->size - req->offset);

//如果请求的size(即req->size)大于size,则本次只可以读取Rng缓冲区大小的数据(即size大小的数据)


        memcpy(req->data + req->offset, buf + buf_offset, len); //buf+buf_offset的patch很好!!!当req->size > size时,下次重新再读该缓存的时候,重新调用rng_egd_chr_read函数,buf_offset重新被赋值为0.很好!!!
        buf_offset += len;
        req->offset += len;//以备下次读取的时候,不再读取上次已经读取过的数据。因为本次请求的数据大于Rng的缓冲区大小,所以只能等到Rng刷新缓冲区以后,再次读取本次请求还需读取的数据。
---
第二种情况,如果本次请求的size小于size的大小,则会不断循环的处理请求链表上的请求。直到Rng的buf为空。
---
        size -= len;

        if (req->offset == req->size) {

            s->requests = g_slist_remove_link(s->requests, s->requests);

//如果本次请求处理完了,则把本次请求从请求链表上删除。


            req->receive_entropy(req->opaque, req->data, req->size);

            rng_egd_free_request(req);
        }
    }
}

你可能感兴趣的:(rng_egd_chr_read分析)