summaryrefslogtreecommitdiffstats
path: root/views/register.c
blob: 8256a4aa4718ace7e81085ad28faff1d12e5cbd8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#define _PCILIB_VIEW_ENUM_C

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <strings.h>

#include <uthash.h>

#include "error.h"
#include "version.h"
#include "model.h"
#include "enum.h"
#include "view.h"
#include "value.h"
#include "register.h"


static void pcilib_register_view_free(pcilib_t *ctx, pcilib_view_description_t *view) {
    if (view->name)
        free((void*)view->name);
    free(view);
}

static int pcilib_register_view_read(pcilib_t *ctx, pcilib_view_context_t *view_ctx, pcilib_register_value_t dummy, pcilib_value_t *val) {
    int err;

    const pcilib_model_description_t *model_info = pcilib_get_model_description(ctx);
    pcilib_register_view_description_t *v = (pcilib_register_view_description_t*)(model_info->views[view_ctx->view]);

    if (v->view) {
        return pcilib_read_register_view(ctx, v->bank, v->reg, v->view, val);
    } else {
        pcilib_register_value_t regval;

        err = pcilib_read_register(ctx, v->bank, v->reg, &regval);
        if (err) return err;

        return pcilib_set_value_from_register_value(ctx, val, regval);
    }
}

static int pcilib_register_view_write(pcilib_t *ctx, pcilib_view_context_t *view_ctx, pcilib_register_value_t *dummy, const pcilib_value_t *val) {
    int err;

    const pcilib_model_description_t *model_info = pcilib_get_model_description(ctx);
    pcilib_register_view_description_t *v = (pcilib_register_view_description_t*)(model_info->views[view_ctx->view]);

    if (v->view) {
        return pcilib_write_register_view(ctx, v->bank, v->reg, v->view, val);
    } else {
        pcilib_register_value_t regval;

        regval = pcilib_get_value_as_register_value(ctx, val, &err);
        if (err) return err;

        return pcilib_write_register(ctx, v->bank, v->reg, regval);
    }

    return err;
}

const pcilib_view_api_description_t pcilib_register_view_api =
  { PCILIB_VERSION, sizeof(pcilib_register_view_description_t), NULL, NULL, pcilib_register_view_free,  pcilib_register_view_read,  pcilib_register_view_write };