aboutsummaryrefslogtreecommitdiff
path: root/libctf/testsuite
diff options
context:
space:
mode:
Diffstat (limited to 'libctf/testsuite')
-rw-r--r--libctf/testsuite/libctf-lookup/add-to-opened-ctf.c19
-rw-r--r--libctf/testsuite/libctf-lookup/add-to-opened.c147
-rw-r--r--libctf/testsuite/libctf-lookup/add-to-opened.lk3
3 files changed, 169 insertions, 0 deletions
diff --git a/libctf/testsuite/libctf-lookup/add-to-opened-ctf.c b/libctf/testsuite/libctf-lookup/add-to-opened-ctf.c
new file mode 100644
index 0000000..b5d483e
--- /dev/null
+++ b/libctf/testsuite/libctf-lookup/add-to-opened-ctf.c
@@ -0,0 +1,19 @@
+int an_int;
+char *a_char_ptr;
+typedef int (*a_typedef) (int main);
+struct struct_forward;
+enum enum_forward;
+union union_forward;
+typedef int an_array[50];
+struct a_struct { int foo; };
+union a_union { int bar; };
+enum an_enum { FOO };
+
+a_typedef a;
+struct struct_forward *x;
+union union_forward *y;
+enum enum_forward *z;
+struct a_struct *xx;
+union a_union *yy;
+enum an_enum *zz;
+an_array ar;
diff --git a/libctf/testsuite/libctf-lookup/add-to-opened.c b/libctf/testsuite/libctf-lookup/add-to-opened.c
new file mode 100644
index 0000000..dc2e1f5
--- /dev/null
+++ b/libctf/testsuite/libctf-lookup/add-to-opened.c
@@ -0,0 +1,147 @@
+/* Make sure you can add to ctf_open()ed CTF dicts, and that you
+ cannot make changes to existing types. */
+
+#include <ctf-api.h>
+#include <stdio.h>
+#include <stdlib.h>
+
+int
+main (int argc, char *argv[])
+{
+ ctf_dict_t *fp;
+ ctf_archive_t *ctf;
+ ctf_id_t type, ptrtype;
+ ctf_arinfo_t ar = {0, 0, 0};
+ ctf_encoding_t en = { CTF_INT_SIGNED, 0, sizeof (int) };
+ unsigned char *ctf_written;
+ size_t size;
+ int err;
+
+ if (argc != 2)
+ {
+ fprintf (stderr, "Syntax: %s PROGRAM\n", argv[0]);
+ exit(1);
+ }
+
+ if ((ctf = ctf_open (argv[1], NULL, &err)) == NULL)
+ goto open_err;
+ if ((fp = ctf_dict_open (ctf, NULL, &err)) == NULL)
+ goto open_err;
+
+ /* Check that various modifications to already-written types
+ are prohibited. */
+
+ if (ctf_add_integer (fp, CTF_ADD_ROOT, "int", &en) == 0)
+ fprintf (stderr, "allowed to add integer existing in readonly portion\n");
+
+ if (ctf_errno (fp) != ECTF_RDONLY)
+ fprintf (stderr, "unexpected error %s attempting to add integer in readonly portion\n", ctf_errmsg (ctf_errno (fp)));
+
+ if (ctf_add_typedef (fp, CTF_ADD_ROOT, "a_typedef", 0) == 0)
+ fprintf (stderr, "allowed to add typedef existing in readonly portion\n");
+
+ if (ctf_errno (fp) != ECTF_RDONLY)
+ fprintf (stderr, "unexpected error %s attempting to add typedef in readonly portion\n", ctf_errmsg (ctf_errno (fp)));
+
+ if (ctf_add_struct (fp, CTF_ADD_ROOT, "a_struct") == 0)
+ fprintf (stderr, "allowed to add struct existing in readonly portion\n");
+
+ if (ctf_errno (fp) != ECTF_RDONLY)
+ fprintf (stderr, "unexpected error %s attempting to add struct in readonly portion\n", ctf_errmsg (ctf_errno (fp)));
+
+ if (ctf_add_union (fp, CTF_ADD_ROOT, "a_union") == 0)
+ fprintf (stderr, "allowed to add union existing in readonly portion\n");
+
+ if (ctf_errno (fp) != ECTF_RDONLY)
+ fprintf (stderr, "unexpected error %s attempting to add union in readonly portion\n", ctf_errmsg (ctf_errno (fp)));
+
+ if (ctf_add_enum (fp, CTF_ADD_ROOT, "an_enum") == 0)
+ fprintf (stderr, "allowed to add enum existing in readonly portion\n");
+
+ if (ctf_errno (fp) != ECTF_RDONLY)
+ fprintf (stderr, "unexpected error %s attempting to add enum in readonly portion\n", ctf_errmsg (ctf_errno (fp)));
+
+ if (ctf_add_struct (fp, CTF_ADD_ROOT, "struct_forward") == 0)
+ fprintf (stderr, "allowed to promote struct forward existing in readonly portion\n");
+
+ if (ctf_errno (fp) != ECTF_RDONLY)
+ fprintf (stderr, "unexpected error %s attempting to promote struct forward in readonly portion\n", ctf_errmsg (ctf_errno (fp)));
+
+ if (ctf_add_union (fp, CTF_ADD_ROOT, "union_forward") == 0)
+ fprintf (stderr, "allowed to promote union forward existing in readonly portion\n");
+
+ if (ctf_errno (fp) != ECTF_RDONLY)
+ fprintf (stderr, "unexpected error %s attempting to promote union forward in readonly portion\n", ctf_errmsg (ctf_errno (fp)));
+
+ if (ctf_add_enum (fp, CTF_ADD_ROOT, "enum_forward") == 0)
+ fprintf (stderr, "allowed to promote enum forward existing in readonly portion\n");
+
+ if (ctf_errno (fp) != ECTF_RDONLY)
+ fprintf (stderr, "unexpected error %s attempting to promote enum forward in readonly portion\n", ctf_errmsg (ctf_errno (fp)));
+
+ if ((type = ctf_lookup_by_name (fp, "struct a_struct")) == CTF_ERR)
+ fprintf (stderr, "Lookup of struct a_struct failed: %s\n", ctf_errmsg (ctf_errno (fp)));
+
+ if (ctf_add_member (fp, type, "wombat", 0) == 0)
+ fprintf (stderr, "allowed to add member to struct existing in readonly portion\n");
+
+ if (ctf_errno (fp) != ECTF_RDONLY)
+ fprintf (stderr, "unexpected error %s attempting to add member to struct in readonly portion\n", ctf_errmsg (ctf_errno (fp)));
+
+ if ((type = ctf_lookup_by_name (fp, "union a_union")) == CTF_ERR)
+ fprintf (stderr, "Lookup of union a_union failed: %s\n", ctf_errmsg (ctf_errno (fp)));
+
+ if (ctf_add_member (fp, type, "wombat", 0) == 0)
+ fprintf (stderr, "allowed to add member to union existing in readonly portion\n");
+
+ if (ctf_errno (fp) != ECTF_RDONLY)
+ fprintf (stderr, "unexpected error %s attempting to add member to union in readonly portion\n", ctf_errmsg (ctf_errno (fp)));
+
+ if ((type = ctf_lookup_by_name (fp, "enum an_enum")) == CTF_ERR)
+ fprintf (stderr, "Lookup of enum an_enum failed: %s\n", ctf_errmsg (ctf_errno (fp)));
+
+ if (ctf_add_enumerator (fp, type, "wombat", 0) == 0)
+ fprintf (stderr, "allowed to add enumerator to enum existing in readonly portion\n");
+
+ if (ctf_errno (fp) != ECTF_RDONLY)
+ fprintf (stderr, "unexpected error %s attempting to add enumerator to enum in readonly portion\n", ctf_errmsg (ctf_errno (fp)));
+
+ if ((type = ctf_lookup_by_name (fp, "an_array")) == CTF_ERR)
+ fprintf (stderr, "Lookup of an_array failed: %s\n", ctf_errmsg (ctf_errno (fp)));
+
+ if ((type = ctf_type_reference (fp, type)) == CTF_ERR)
+ fprintf (stderr, "Lookup of type reffed by an_array failed: %s\n", ctf_errmsg (ctf_errno (fp)));
+
+ if (ctf_set_array (fp, type, &ar) == 0)
+ fprintf (stderr, "allowed to set array in readonly portion\n");
+
+ if (ctf_errno (fp) != ECTF_RDONLY)
+ fprintf (stderr, "unexpected error %s attempting to set array in readonly portion\n", ctf_errmsg (ctf_errno (fp)));
+
+ if ((ctf_written = ctf_write_mem (fp, &size, 4096)) != NULL)
+ fprintf (stderr, "Writeout unexpectedly succeeded: %s\n", ctf_errmsg (ctf_errno (fp)));
+
+ if (ctf_errno (fp) != ECTF_RDONLY)
+ fprintf (stderr, "unexpected error %s trying to write out previously serialized dict\n", ctf_errmsg (ctf_errno (fp)));
+
+ /* Finally, make sure we can add new types, and look them up again. */
+
+ if ((type = ctf_lookup_by_name (fp, "struct a_struct")) == CTF_ERR)
+ fprintf (stderr, "Lookup of struct a_struct failed: %s\n", ctf_errmsg (ctf_errno (fp)));
+
+ if ((ptrtype = ctf_add_pointer (fp, CTF_ADD_ROOT, type)) == CTF_ERR)
+ fprintf (stderr, "Cannot add pointer to ctf_opened dict: %s\n", ctf_errmsg (ctf_errno (fp)));
+
+ if (ctf_type_reference (fp, ptrtype) == CTF_ERR)
+ fprintf (stderr, "Lookup of pointer preserved across writeout failed: %s\n", ctf_errmsg (ctf_errno (fp)));
+
+ if (ctf_type_reference (fp, ptrtype) != type)
+ fprintf (stderr, "Look up of newly-added type in serialized dict yields ID %lx, expected %lx\n", ctf_type_reference (fp, ptrtype), type);
+
+ printf ("All done.\n");
+ return 0;
+
+ open_err:
+ fprintf (stderr, "%s: cannot open: %s\n", argv[0], ctf_errmsg (err));
+ return 1;
+}
diff --git a/libctf/testsuite/libctf-lookup/add-to-opened.lk b/libctf/testsuite/libctf-lookup/add-to-opened.lk
new file mode 100644
index 0000000..af84259
--- /dev/null
+++ b/libctf/testsuite/libctf-lookup/add-to-opened.lk
@@ -0,0 +1,3 @@
+# source: add-to-opened-ctf.c
+# lookup: add-to-opened.c
+All done.