Home | History | Annotate | Download | only in obj
      1 OID information is generated via a series of perl scripts. In order, the full
      2 list of commands to run are:
      3 
      4         perl objects.pl objects.txt obj_mac.num ../../include/openssl/obj_mac.h
      5         perl obj_dat.pl ../../include/openssl/obj_mac.h obj_dat.h
      6         perl obj_xref.pl obj_mac.num obj_xref.txt > obj_xref.h
      7 
      8 objects.txt contains the list of all built-in OIDs. It is processed by
      9 objects.pl to output obj_mac.num and obj_mac.h. obj_mac.num is the list of NID
     10 values for each OID. This is an input/output parameter so NID values are stable
     11 across regenerations. obj_mac.h is the header which defines macros for all the
     12 built-in OIDs in C.
     13 
     14 obj_mac.h is read by obj_dat.pl to generate obj_dat.h. obj_dat.h contains the
     15 ASN1_OBJECTs corresponding to built-in OIDs themselves along with lookup tables
     16 for search by short name, OID, etc.
     17 
     18 obj_mac.num and obj_xref.txt are read by obj_xref.pl to generate
     19 obj_xref.h. obj_xref.txt links signature OIDs to corresponding public key
     20 algorithms and digests. obj_xref.h contains lookup tables for querying this
     21 information in both directions.
     22 
     23 Dependency graph:
     24 
     25                         objects.txt
     26                             |
     27                             V
     28                        [objects.pl] <--+
     29                          /      \      |
     30                         V        V     |
     31                   obj_mac.h    obj_mac.num  obj_xref.txt
     32                       |              \      /
     33                       V               V    V
     34                  [obj_dat.pl]      [obj_xref.pl]
     35                       |                  |
     36                       V                  V
     37                   obj_dat.h         obj_xref.h
     38