12
pcilib_view_t pcilib_find_view_by_name(pcilib_t *ctx, const char *view) {
15
for(i = 0; ctx->views[i]; i++) {
16
if (!strcasecmp(ctx->views[i]->name, view))
20
return PCILIB_VIEW_INVALID;
25
int pcilib_add_views(pcilib_t *ctx, size_t n, const pcilib_view_description_t *desc) {
30
// No padding between array elements
33
const pcilib_view_description_t *v = (const pcilib_view_description_t*)ptr;
36
ptr += v->api->description_size;
40
if ((ctx->num_views + n + 1) > ctx->alloc_views) {
42
pcilib_view_description_t **views;
43
for (size = ctx->alloc_views; size < 2 * (n + ctx->num_views + 1); size<<=1);
45
views = (pcilib_view_description_t**)realloc(ctx->views, size * sizeof(pcilib_view_description_t*));
46
if (!views) return PCILIB_ERROR_MEMORY;
49
ctx->alloc_views = size;
51
ctx->model_info.views = (const pcilib_view_description_t**)views;
54
// No padding between array elements
56
for (i = 0; i < n; i++) {
57
const pcilib_view_description_t *v = (const pcilib_view_description_t*)ptr;
58
ctx->views[ctx->num_views + i] = (pcilib_view_description_t*)malloc(v->api->description_size);
59
if (!ctx->views[ctx->num_views + i]) {
61
for (j = 0; j < i; j++)
62
free(ctx->views[ctx->num_views + j]);
63
ctx->views[ctx->num_views] = NULL;
64
pcilib_error("Error allocating %zu bytes of memory for the view description", v->api->description_size);
65
return PCILIB_ERROR_MEMORY;
67
memcpy(ctx->views[ctx->num_views + i], v, v->api->description_size);
68
ptr += v->api->description_size;
70
ctx->views[ctx->num_views + i] = NULL;