diff options
Diffstat (limited to 'test/DSGraphs')
-rw-r--r-- | test/DSGraphs/ggcollapse.c | 32 | ||||
-rw-r--r-- | test/DSGraphs/ggfuncptr.c | 34 |
2 files changed, 66 insertions, 0 deletions
diff --git a/test/DSGraphs/ggcollapse.c b/test/DSGraphs/ggcollapse.c new file mode 100644 index 0000000..c055caf --- /dev/null +++ b/test/DSGraphs/ggcollapse.c @@ -0,0 +1,32 @@ +#include <stdio.h> + +typedef struct Tree_struct { + int data; + struct Tree_struct *left, *right; +} Tree; + +static Tree T1, T2, T3, T4, T5; +static Tree *Root, *ANode; +static int N = 4107; + +/* forces *Tb->right to be collapsed */ +void makeMore(Tree* Ta, Tree* Tb) +{ + Ta->left = &T1; + Ta->right = &T2; + Tb->left = &T4; + Tb->right = (Tree*) (((char*) &T5) + 5); /* point to fifth byte of T5 */ +} + +void makeRoots() +{ + T1.left = &T2; + makeMore(&T1, &T3); +} + +int main() +{ + makeRoots(); + T3.right = &T4; + printf("T3.data = %d\n", T3.data); +} diff --git a/test/DSGraphs/ggfuncptr.c b/test/DSGraphs/ggfuncptr.c new file mode 100644 index 0000000..9349124 --- /dev/null +++ b/test/DSGraphs/ggfuncptr.c @@ -0,0 +1,34 @@ +/* Test resolvable and unresolvable calls through function pointers: + * -- both should be retained in function graphs until resolved or until main + * -- former should get resolved in or before main() and never appear in GG + * -- latter should remain unresolved in main() and copied to GG + * -- globals in GG pointed to by latter should be marked I, but not other nodes + */ + +#include <stdlib.h> + +extern void exit_dummy(int*); + +static int X, M, Z; + +void makeCalls(void(*GpKnown)(int*), void(*GpUnknown)(int*)) +{ + if (Z == 0) GpUnknown(&X); /* pass to exit_dummy: never resolved */ + else GpKnown(&M); /* pass to knownF: resolved in main*/ + ++Z; + printf("&Z = %p\n", &Z); /* "known external": resolved here */ +} + +void knownF(int* Y) +{ + if (Y == 0) knownF(Y); /* direct call to self: resolved here */ +} + +int main(int argc, char** argv) +{ + void(*GpKnown)(int*) = knownF; + void(*GpUnknown)(int*) = exit_dummy; + Z = argc; + makeCalls(GpKnown, GpUnknown); + return 0; +} |