1
0
mirror of https://github.com/catseye/SixtyPical.git synced 2024-11-25 07:32:16 +00:00
SixtyPical/tests/SixtyPical Callgraph.md
2019-10-21 21:45:59 +01:00

3.6 KiB

SixtyPical Callgraph

This is a test suite, written in Falderal format, for the ability of a SixtyPical analyzer to construct a callgraph of which routines call which other routines, and its ability to discover which routines will never be called.

-> Tests for functionality "Dump callgraph info for SixtyPical program"

The main routine is always called. The thing that it will be called by is the system, but the callgraph analyzer will simply consider it to be "marked as preserved".

| define main routine
| {
| }
= {
=     "main": {
=         "potentially-called-by": [
=             "*preserved*"
=         ],
=         "potentially-calls": []
=     }
= }

If a routine is called by another routine, this fact will be noted.

| define main routine
| {
|   call other
| }
| 
| define other routine
| {
| }
= {
=     "main": {
=         "potentially-called-by": [
=             "*preserved*"
=         ],
=         "potentially-calls": [
=             "other"
=         ]
=     },
=     "other": {
=         "potentially-called-by": [
=             "main"
=         ],
=         "potentially-calls": []
=     }
= }

If a routine is not called by another routine, and it is not main and it is not explicitly marked as preserved, this absence will be noted, and a compiler or linker will be permitted to omit it from the final executable.

| define main routine
| {
| }
| 
| define other routine
| {
| }
= {
=     "main": {
=         "potentially-called-by": [
=             "*preserved*"
=         ],
=         "potentially-calls": []
=     },
=     "other": {
=         "potentially-called-by": [],
=         "potentially-calls": []
=     }
= }

If a routine is not called by another routine, but it is declared explicitly as preserved, then it will not be considered unused, and a compiler or linker will not be permitted to omit it from the final executable. This is useful for interrupt routines and such that really are used by some part of the system, even if not directly by another SixtyPical routine.

| define main routine
| {
| }
| 
| define other preserved routine
| {
| }
= {
=     "main": {
=         "potentially-called-by": [
=             "*preserved*"
=         ],
=         "potentially-calls": []
=     },
=     "other": {
=         "potentially-called-by": [
=             "*preserved*"
=         ],
=         "potentially-calls": []
=     }
= }

If two routines potentially call each other, this will be noted, even if nothing else potentially calls either of those routines. This may change in the future.

| define main routine
| {
| }
| 
| define other1 routine
| {
|   call other2
| }
| 
| define other2 routine
| {
|   call other1
| }
= {
=     "main": {
=         "potentially-called-by": [
=             "*preserved*"
=         ],
=         "potentially-calls": []
=     },
=     "other1": {
=         "potentially-called-by": [
=             "other2"
=         ],
=         "potentially-calls": [
=             "other2"
=         ]
=     },
=     "other2": {
=         "potentially-called-by": [
=             "other1"
=         ],
=         "potentially-calls": [
=             "other1"
=         ]
=     }
= }