| #!/bin/sh |
| # Copyright 2014 The Chromium OS Authors. All rights reserved. |
| # Use of this source code is governed by a BSD-style license that can be |
| # found in the LICENSE file. |
| |
| # Pull out types. |
| cat $1 | |
| # Mark tables and section boundaries. |
| sed 's/^[0-9][0-9]*\([.][0-9][0-9]*\)\+.*$/_SECTION_BOUNDARY/' | |
| sed 's/^Table [0-9]* . Definition of .*Types[^.]*$/_TYPES/' | |
| # Keep only table sections. |
| awk '/^_TYPES$/,/^_SECTION_BOUNDARY$/ { print $0; }' | |
| sed 's/^_TYPES$//' | |
| sed 's/^_SECTION_BOUNDARY$//' | |
| # Remove headers and footers. |
| sed 's/^.*Trusted Platform Module Library.*$//' | |
| sed 's/^.*Part 2: Structures.*$//' | |
| sed 's/^.*Family .2.0..*$//' | |
| sed 's/^.*Level 00 Revision.*$//' | |
| sed 's/^.*Published.*$//' | |
| sed 's/^.*Copyright.*$//' | |
| sed 's/^.*Page [0-9].*$//' | |
| sed 's/^.*October 31, 2013.*$//' | |
| # Remove table headers. |
| sed 's/^Type$//' | sed 's/^Name$//' | sed 's/^Description$//' | |
| # Remove leading spaces. |
| sed 's/^[ ][ ]*//' | |
| # Remove empty lines. |
| sed '/^$/d' | |
| # Mark begin and end and filter types. |
| awk ' |
| BEGIN { print "_BEGIN_TYPES"; state = 0; } |
| /^[^ ]*$/ { if (!state) { print "_OLD_TYPE " $0; state = 1; } |
| else { print "_NEW_TYPE " $0; state = 0; } } |
| END { print "_END"; } |
| ' | |
| # Sanity check. The format should now follow this grammar: |
| # Format:Begin||Typedef*||End |
| # Begin:_BEGIN_TYPES\n |
| # End:_END\n |
| # Typedef:OldType||NewType |
| # OldType:_OLD_TYPE <type>\n |
| # NewType:_NEW_TYPE <type>\n |
| awk ' |
| BEGIN { RS = ""; } |
| $0 !~ /_BEGIN_TYPES\n(_OLD_TYPE[^\n]*\n_NEW_TYPE[^\n]*\n)*_END/ { |
| print "_ERROR: Format check failed."; } |
| { print $0; } |
| ' |
| |
| # Pull out interface types. |
| cat $1 | |
| awk ' |
| BEGIN { print "_BEGIN_TYPES"; FS = "[ ()]+"; } |
| /^Table [0-9]* . Definition of \([A-Z_]*\) TPMI_.* Type[^.]*$/ { |
| print "_OLD_TYPE " $6; |
| print "_NEW_TYPE " $7; } |
| /^Table [0-9]* . Definition of \{.*\} \([A-Z_]*\) TPMI_.* Type[^.]*$/ { |
| print "_OLD_TYPE " $7; |
| print "_NEW_TYPE " $8; } |
| /^Table [0-9]* . Definition of \([A-Z_]*\) \{.*\} TPMI_.* Type[^.]*$/ { |
| print "_OLD_TYPE " $6; |
| print "_NEW_TYPE " $8; } |
| END { print "_END"; } |
| ' | |
| # Sanity check. The format should now follow this grammar: |
| # Format:Begin||Typedef*||End |
| # Begin:_BEGIN_TYPES\n |
| # End:_END\n |
| # Typedef:OldType||NewType |
| # OldType:_OLD_TYPE <type>\n |
| # NewType:_NEW_TYPE <type>\n |
| awk ' |
| BEGIN { RS = ""; } |
| $0 !~ /_BEGIN_TYPES\n(_OLD_TYPE[^\n]*\n_NEW_TYPE[^\n]*\n)*_END/ { |
| print "_ERROR: Format check failed."; } |
| { print $0; } |
| ' |
| |
| # Pull out attribute types. |
| cat $1 | |
| awk ' |
| BEGIN { print "_BEGIN_TYPES"; FS = "[ ()]+"; } |
| /^Table [0-9]* . Definition of \([A-Z_0-9]*\) TPM[A-Z_]* Bits[^.]*$/ { |
| print "_OLD_TYPE " $6; |
| print "_NEW_TYPE " $7; } |
| END { print "_END"; } |
| ' | |
| # Sanity check. The format should now follow this grammar: |
| # Format:Begin||Typedef*||End |
| # Begin:_BEGIN_TYPES\n |
| # End:_END\n |
| # Typedef:OldType||NewType |
| # OldType:_OLD_TYPE <type>\n |
| # NewType:_NEW_TYPE <type>\n |
| awk ' |
| BEGIN { RS = ""; } |
| $0 !~ /_BEGIN_TYPES\n(_OLD_TYPE[^\n]*\n_NEW_TYPE[^\n]*\n)*_END/ { |
| print "_ERROR: Format check failed."; } |
| { print $0; } |
| ' |
| |
| # Pull out constant values. |
| cat $1 | |
| # Mark tables and section boundaries. |
| sed 's/^[0-9][0-9]*\([.][0-9][0-9]*\)\+.*$/_SECTION_BOUNDARY/' | |
| sed 's/^Table [0-9]* . Definition of \(.*\) Constants[^.]*$/_CONSTANTS \1/' | |
| # Keep only table sections. |
| awk '/^_CONSTANTS .*$/,/^_SECTION_BOUNDARY$/ { print $0; }' | |
| sed 's/^_SECTION_BOUNDARY$//' | |
| # Remove headers and footers. |
| sed 's/^.*Trusted Platform Module Library.*$//' | |
| sed 's/^.*Part 2: Structures.*$//' | |
| sed 's/^.*Family .2.0..*$//' | |
| sed 's/^.*Level 00 Revision.*$//' | |
| sed 's/^.*Published.*$//' | |
| sed 's/^.*Copyright.*$//' | |
| sed 's/^.*Page [0-9].*$//' | |
| sed 's/^.*October 31, 2013.*$//' | |
| # Remove table headers. |
| sed 's/^Name$//' | sed 's/^Value$//' | sed 's/^Comments$//' | |
| # Remove leading spaces. |
| sed 's/^[ ][ ]*//' | |
| # Remove empty lines. |
| sed '/^$/d' | |
| # Mark begin and end. |
| awk ' |
| BEGIN { print "_BEGIN_CONSTANTS"; } |
| { print $0; } |
| END { print "_END"; } |
| ' | |
| # Mark type. |
| awk ' |
| BEGIN { FS = "[ ()]+"; } |
| { print $0; } |
| /^_CONSTANTS \(\w*\) .*$/ { print "_TYPE " $2; } |
| ' | |
| # Mark names. |
| sed 's/^\(TPM_[_A-Z0-9a]*\)$/_NAME \1/' | |
| sed 's/^\(TPM_CC_[_A-Z0-9a-z]*\)$/_NAME \1/' | |
| sed 's/^\(RC_[_A-Z0-9]*\)$/_NAME \1/' | |
| sed 's/^\(PT_[_A-Z0-9]*\)$/_NAME \1/' | |
| sed 's/^\(HR_[_A-Z0-9]*\)$/_NAME \1/' | |
| sed 's/^\([_A-Z0-9]*FIRST\)$/_NAME \1/' | |
| sed 's/^\([_A-Z0-9]*LAST\)$/_NAME \1/' | |
| sed 's/^\(PLATFORM_PERSISTENT\)$/_NAME \1/' | |
| # Mark values and throw away everything else. |
| awk ' |
| BEGIN { last_line_was_name = 0; } |
| /^_.*$/ { if ($0 !~ /^_NAME .*$/) { print $0; } } |
| /^_NAME .*$/ { if (last_line_was_name) { |
| last_line_was_name = 0; |
| if ($0 !~ /[A-Z_0-9x +]*/) { print "_ERROR: Invalid value"; } |
| print "_VALUE " $2; } |
| else { last_line_was_name = 1; print $0; } } |
| /^[^_].*$/ { if (last_line_was_name) { |
| last_line_was_name = 0; |
| if ($0 !~ /[A-Z_0-9x +]*/) { print "_ERROR: Invalid value"; } |
| print "_VALUE " $0; } } |
| ' | |
| # Sanity check. The format should now follow this grammar: |
| # Format:Begin||TableBlock*||End |
| # Begin:_BEGIN_CONSTANTS\n |
| # End:_END\n |
| # TableBlock:TableTag||Type||Constant* |
| # TableTag:_CONSTANTS <name>\n |
| # Constant:Name||Value |
| # Type:_TYPE <type>\n |
| # Name:_NAME <name>\n |
| # Value:_VALUE <value>\n |
| awk ' |
| BEGIN { RS = ""; } |
| $0 !~ /_BEGIN_CONSTANTS\n(_CONSTANTS[^\n]*\n_TYPE[^\n]*\n(_NAME[^\n]*\n_VALUE[^\n]*\n)*)*_END/ { |
| print "_ERROR: Format check failed."; } |
| { print $0; } |
| ' |
| |
| # Pull out structures. |
| cat $1 | |
| # Mark tables and section boundaries. |
| sed 's/^[0-9][0-9]*\([.][0-9][0-9]*\)\+.*$/_SECTION_BOUNDARY/' | |
| sed 's/^Table [0-9]* . Definition of \(.*\) Structure[^.]*$/_STRUCTURE \1/' | |
| # Keep only table sections. |
| awk '/^_STRUCTURE .*$/,/^_SECTION_BOUNDARY$/ { print $0; }' | |
| sed 's/^_SECTION_BOUNDARY$//' | |
| # Remove headers and footers. |
| sed 's/^.*Trusted Platform Module Library.*$//' | |
| sed 's/^.*Part 2: Structures.*$//' | |
| sed 's/^.*Family .2.0..*$//' | |
| sed 's/^.*Level 00 Revision.*$//' | |
| sed 's/^.*Published.*$//' | |
| sed 's/^.*Copyright.*$//' | |
| sed 's/^.*Page [0-9].*$//' | |
| sed 's/^.*October 31, 2013.*$//' | |
| # Remove table headers. |
| sed 's/^Parameter$//' | sed 's/^Type$//' | sed 's/^Description$//' | |
| # Remove leading spaces. |
| sed 's/^[ ][ ]*//' | |
| # Remove empty lines. |
| sed '/^$/d' | |
| # Mark begin and end. |
| awk ' |
| BEGIN { print "_BEGIN_STRUCTURES"; } |
| { print $0; } |
| END { print "_END"; } |
| ' | |
| # Mark field types. |
| sed 's/^\(+*TPM[_A-Z0-9+]*\)$/_TYPE \1/' | |
| sed 's/^\(UINT[0-9]*\)$/_TYPE \1/' | |
| sed 's/^\(BYTE*\)$/_TYPE \1/' | |
| # Mark field names and throw away everything else. |
| awk ' |
| BEGIN { last_line = ""; } |
| /^_.*$/ { print $0; } |
| /^_TYPE .*$/ { if (last_line != "") { print "_NAME " last_line; } |
| else { print "_ERROR: Type with no name"; } |
| last_line = ""; } |
| /^[^_].*$/ { last_line = $0; } |
| ' | |
| # Change 'value [size] {:max}' to 'value[max]'. |
| sed 's/^\(_NAME \w*\).*\[\w*\].*[{][:] *\([a-zA-Z0-9_()/]*\)[}]$/\1[\2]/' | |
| # Strip off other modifiers. |
| sed 's/^\(_NAME \w*\)[ {].*/\1/' | |
| sed 's/^_TYPE +\(.*\)$/_TYPE \1/' | |
| sed 's/^_TYPE \(.*\)+$/_TYPE \1/' | |
| sed 's/^_NAME \/*\[.*\] *\(.*\)$/_NAME \1/' | |
| sed 's/^\(_NAME \w*\)=/\1/' | |
| sed 's/^_STRUCTURE \((.*) \)*{.*} \(.*\)/_STRUCTURE \2/' | |
| # Sanity check. The format should now follow this grammar: |
| # Format:Begin||TableBlock*||End |
| # Begin:_BEGIN_STRUCTURES\n |
| # End:_END\n |
| # TableBlock:TableTag||Field* |
| # TableTag:_STRUCTURE <name>\n |
| # Field:Type||Name |
| # Type:_TYPE <type>\n |
| # Name:_NAME <name>\n |
| awk ' |
| BEGIN { RS = ""; } |
| $0 !~ /_BEGIN_STRUCTURES\n(_STRUCTURE[^\n]*\n(_TYPE[^\n]*\n_NAME[^\n]*\n)*)*_END/ { |
| print "_ERROR: Format check failed."; } |
| { print $0; } |
| ' |
| |
| # Pull out unions. |
| cat $1 | |
| # Mark tables and section boundaries. |
| sed 's/^[0-9][0-9]*\([.][0-9][0-9]*\)\+.*$/_SECTION_BOUNDARY/' | |
| sed 's/^Table [0-9]* . Definition of \(.*\) Union[^.]*$/_UNION \1/' | |
| # Keep only table sections. |
| awk '/^_UNION .*$/,/^_SECTION_BOUNDARY$/ { print $0; }' | |
| sed 's/^_SECTION_BOUNDARY$//' | |
| # Remove headers and footers. |
| sed 's/^.*Trusted Platform Module Library.*$//' | |
| sed 's/^.*Part 2: Structures.*$//' | |
| sed 's/^.*Family .2.0..*$//' | |
| sed 's/^.*Level 00 Revision.*$//' | |
| sed 's/^.*Published.*$//' | |
| sed 's/^.*Copyright.*$//' | |
| sed 's/^.*Page [0-9].*$//' | |
| sed 's/^.*October 31, 2013.*$//' | |
| # Remove table headers. |
| sed 's/^Parameter$//' | sed 's/^Type$//' | sed 's/^Selector$//' | |
| sed 's/^Description$//' | |
| # Remove leading spaces. |
| sed 's/^[ ][ ]*//' | |
| # Remove empty lines. |
| sed '/^$/d' | |
| # Mark begin and end. |
| awk ' |
| BEGIN { print "_BEGIN_UNIONS"; } |
| { print $0; } |
| END { print "_END"; } |
| ' | |
| # Mark field types. |
| sed 's/^\(+*TPM[_A-Z0-9+a]*\)$/_TYPE \1/' | |
| sed 's/^\(UINT[0-9]*\)$/_TYPE \1/' | |
| sed 's/^\(BYTE*\)$/_TYPE \1/' | |
| # Mark field names and throw away everything else. |
| awk ' |
| BEGIN { last_line = ""; } |
| /^_.*$/ { if ($0 !~ /^_TYPE .*$/) { last_line = ""; print $0; } } |
| /^_TYPE .*$/ { if (last_line !~ /^_TYPE .*$/) { |
| if (last_line != "" && |
| last_line != "null" && |
| last_line != "NOTE") { |
| print $0; |
| print "_NAME " last_line; } |
| else if (last_line == "") { |
| print "_ERROR: Type with no name"; } |
| last_line = $0; } } |
| /^[^_].*$/ { last_line = $0; } |
| ' | |
| # Change 'value [size] {:max}' to 'value[max]'. |
| sed 's/^\(_NAME \w*\).*\[\w*\].*[{][:] *\([a-zA-Z0-9_()/]*\)[}]$/\1[\2]/' | |
| # Strip off other modifiers. |
| sed 's/^\(_NAME \w*\) \(\[.*\]\)/\1\2/' | |
| sed 's/^\(_NAME \w*\)\( {|{\).*/\1/' | |
| sed 's/^_TYPE +\(.*\)$/_TYPE \1/' | |
| # Sanity check. The format should now follow this grammar: |
| # Format:Begin||TableBlock*||End |
| # Begin:_BEGIN_UNIONS\n |
| # End:_END\n |
| # TableBlock:TableTag||Field* |
| # TableTag:_UNION <name>\n |
| # Field:Type||Name |
| # Type:_TYPE <type>\n |
| # Name:_NAME <name>\n |
| awk ' |
| BEGIN { RS = ""; } |
| $0 !~ /_BEGIN_UNIONS\n(_UNION[^\n]*\n(_TYPE[^\n]*\n_NAME[^\n]*\n)*)*_END/ { |
| print "_ERROR: Format check failed."; } |
| { print $0; } |
| ' |
| |
| # Pull out default defines. |
| cat $1 | |
| sed 's/^[A-Z]\([.][0-9][0-9]*\)\+.*$/_SECTION_BOUNDARY/' | |
| sed 's/^Table [0-9]* . Defines for \([^.]*\)$/_DEFINES \1/' | |
| sed 's/^_DEFINES Implemented Commands$//' | |
| sed 's/^_DEFINES Implemented Algorithms$//' | |
| awk '/^_DEFINES .*$/,/^_SECTION_BOUNDARY$/ { print $0; }' | |
| sed 's/^_SECTION_BOUNDARY$//' | |
| # Remove headers and footers. |
| sed 's/^.*Trusted Platform Module Library.*$//' | |
| sed 's/^.*Part 2: Structures.*$//' | |
| sed 's/^.*Family .2.0..*$//' | |
| sed 's/^.*Level 00 Revision.*$//' | |
| sed 's/^.*Published.*$//' | |
| sed 's/^.*Copyright.*$//' | |
| sed 's/^.*Page [0-9].*$//' | |
| sed 's/^.*October 31, 2013.*$//' | |
| # Remove table headers. |
| sed 's/^Name$//' | sed 's/^Value$//' | sed 's/^Description$//' | |
| # Remove most comments. |
| sed 's/^.*[g-wyz?]\+.*$//' | |
| # Remove leading spaces. |
| sed 's/^[ ][ ]*//' | |
| # Remove empty lines. |
| sed '/^$/d' | |
| # Mark begin and end. |
| awk ' |
| BEGIN { print "_BEGIN_DEFINES"; } |
| { print $0; } |
| END { print "_END"; } |
| ' | |
| # Mark define names. |
| sed 's/^\([A-Z][_A-Z0-9]*\)$/_NAME \1/' | |
| sed 's/^_NAME NOTE$//' | |
| # Mark values and throw away everything else. |
| awk ' |
| BEGIN { last_line_was_name = 0; } |
| /^_.*$/ { if ($0 !~ /^_NAME .*$/) { print $0; } } |
| /^_NAME .*$/ { if (last_line_was_name) { |
| last_line_was_name = 0; |
| if ($0 !~ /[A-Z_0-9x +()]*/) { |
| print "_ERROR: Invalid value"; } |
| print "_VALUE " $2; } |
| else { last_line_was_name = 1; print $0; } } |
| /^[^_].*$/ { if (last_line_was_name) { |
| last_line_was_name = 0; |
| if ($0 !~ /[A-Z_0-9x +()]*/) { |
| print "_ERROR: Invalid value"; } |
| print "_VALUE " $0; } } |
| ' | |
| # Sanity check. The format should now follow this grammar: |
| # Format:Begin||Define*||End |
| # Begin:_BEGIN_DEFINES\n |
| # End:_END\n |
| # Define:Name||Value |
| # Name:_NAME <name>\n |
| # Value:_VALUE <value>\n |
| awk ' |
| BEGIN { RS = ""; } |
| $0 !~ /_BEGIN_DEFINES\n(_NAME[^\n]*\n_VALUE[^\n]*\n)*_END/ { |
| print "_ERROR: Format check failed."; } |
| { print $0; } |
| ' |
| |
| exit 0 |