implemented Linux IMA functional component
authorAndreas Steffen <andreas.steffen@strongswan.org>
Fri, 25 Nov 2011 23:24:23 +0000 (00:24 +0100)
committerAndreas Steffen <andreas.steffen@strongswan.org>
Mon, 28 Nov 2011 20:24:00 +0000 (21:24 +0100)
12 files changed:
src/libpts/Makefile.am
src/libpts/libpts.c
src/libpts/plugins/imv_attestation/data.sql
src/libpts/plugins/imv_attestation/tables.sql
src/libpts/pts/components/ita/ita_comp_func_name.c
src/libpts/pts/components/ita/ita_comp_func_name.h
src/libpts/pts/components/ita/ita_comp_ima.c [new file with mode: 0644]
src/libpts/pts/components/ita/ita_comp_ima.h [new file with mode: 0644]
src/libpts/pts/components/ita/ita_comp_tboot.c
src/libpts/pts/pts.c
src/libpts/pts/pts_database.c
src/libpts/pts/pts_database.h

index abe3cda..3ff9417 100644 (file)
@@ -24,6 +24,7 @@ libpts_la_SOURCES = \
        pts/components/pts_comp_evidence.h pts/components/pts_comp_evidence.c \
        pts/components/pts_comp_func_name.h pts/components/pts_comp_func_name.c \
        pts/components/ita/ita_comp_func_name.h pts/components/ita/ita_comp_func_name.c \
+       pts/components/ita/ita_comp_ima.h pts/components/ita/ita_comp_ima.c \
        pts/components/ita/ita_comp_tboot.h pts/components/ita/ita_comp_tboot.c \
        pts/components/ita/ita_comp_tgrub.h pts/components/ita/ita_comp_tgrub.c \
        pts/components/tcg/tcg_comp_func_name.h pts/components/tcg/tcg_comp_func_name.c \
index 268f438..384ee4e 100644 (file)
@@ -18,6 +18,7 @@
 #include "pts/components/pts_component_manager.h"
 #include "pts/components/tcg/tcg_comp_func_name.h"
 #include "pts/components/ita/ita_comp_func_name.h"
+#include "pts/components/ita/ita_comp_ima.h"
 #include "pts/components/ita/ita_comp_tboot.h"
 #include "pts/components/ita/ita_comp_tgrub.h"
 
@@ -62,6 +63,9 @@ bool libpts_init(void)
                pts_components->add_component(pts_components, PEN_ITA,
                                                                          PTS_ITA_COMP_FUNC_NAME_TBOOT,
                                                                          pts_ita_comp_tboot_create);
+               pts_components->add_component(pts_components, PEN_ITA,
+                                                                         PTS_ITA_COMP_FUNC_NAME_IMA,
+                                                                         pts_ita_comp_ima_create);
 
                DBG1(DBG_LIB, "libpts initialized");
        }
index fcefd83..cc580bc 100644 (file)
@@ -176,150 +176,6 @@ INSERT INTO files (
   0, '/etc/tnc_config'
 );
 
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr00'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr01'
-);
-
-INSERT INTO files (                    /* 25 */
-  type, path
-) VALUES (
-  2, 'pcr02'
-);
-             
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr03'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr04'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr05'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr06'
-);
-
-INSERT INTO files (                    /* 30 */
-  type, path
-) VALUES (
-  2, 'pcr07'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr08'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr09'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr10'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr11'
-);
-
-INSERT INTO files (                    /* 35 */
-  type, path
-) VALUES (
-  2, 'pcr12'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr13'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr14'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr15'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr16'
-);
-
-INSERT INTO files (                    /* 40 */
-  type, path
-) VALUES (
-  2, 'pcr17'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr18'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr19'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr20'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr21'
-);
-
-INSERT INTO files (                    /* 45 */
-  type, path
-) VALUES (
-  2, 'pcr22'
-);
-
-INSERT INTO files (
-  type, path
-) VALUES (
-  2, 'pcr23'
-);
-
 /* Components */
 
 INSERT INTO components (
@@ -555,19 +411,19 @@ INSERT INTO product_file (
 /* Product Component */
 
 INSERT INTO product_component (
-  product, component, depth, sequence
+  product, component, depth, seq_no
 ) VALUES (
   4, 2, 0, 1
 );
 
 INSERT INTO product_component (
-  product, component, depth, sequence
+  product, component, depth, seq_no
 ) VALUES (
-  7, 1, 0, 1
+  7, 3, 0, 1
 );
 
 INSERT INTO product_component (
-  product, component, depth, sequence
+  product, component, depth, seq_no
 ) VALUES (
   7, 2, 0, 2
 );
@@ -1439,77 +1295,789 @@ INSERT INTO file_hashes (
   20, 7, 7, 8192, X'84200bd318bb022915150842ddf4002e061ef593604ad0d07021dc662cc40bfa749cce084ddf25d0e5137f6380f613d8'
 );
 
-INSERT INTO file_hashes (
-  file, product, component, algo, hash
+/* Component Hashes */
+
+/* ITA TBOOT Functional Component */
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
 ) VALUES (
-  23, 7, 3, 32768, X'284ae59c737c4d1ddf785374cbb59a4c8d635590'
+  2, 4, 1, 17, 32768, X'9704353630674bfe21b86b64a7b0f99c297cf902'
 );
 
-INSERT INTO file_hashes (
-  file, product, component, algo, hash
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
 ) VALUES (
-  24, 7, 3, 32768, X'311087044256d9c3a0b570ba3124cbb4d46f1197'
+  2, 4, 2, 18, 32768, X'8397d8048ee36d7955e38da16fc33e86ef61d6b0'
 );
 
-INSERT INTO file_hashes (
-  file, product, component, algo, hash
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
 ) VALUES (
-  25, 7, 3, 32768, X'b1f1f675427640aaa77bef93f26a333f0d57c9c5'
+  2, 7, 1, 17, 32768, X'd537d437f058136eb3d7be517dbe7647b623c619'
 );
 
-INSERT INTO file_hashes (
-  file, product, component, algo, hash
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
 ) VALUES (
-  26, 7, 3, 32768, X'b2a83b0ebf2f8374299a5b2bdfc31ea955ad7236'
+  2, 7, 2, 18, 32768, X'160d2b04d11eb225fb148615b699081869e15b6c'
 );
 
-INSERT INTO file_hashes (
-  file, product, component, algo, hash
+/* ITA IMA Functional Component */
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
 ) VALUES (
-  27, 7, 3, 32768, X'781c3cee5c3468a09f5ebee8e7d534acea0d2513'
+  3, 7,  1, 0, 32768, X'4d894eef0ae7cb124740df4f6c5c35aa0fe7dae8'
 );
 
-INSERT INTO file_hashes (
-  file, product, component, algo, hash
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
 ) VALUES (
-  28, 7, 3, 32768, X'fec194a9d8f3af2b3876d4bfbbebf980e87e36e9'
+  3, 7,  2, 0, 32768, X'f2c846e7f335f7b9e9dd0a44f48c48e1986750c7'
 );
 
-INSERT INTO file_hashes (
-  file, product, component, algo, hash
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
 ) VALUES (
-  29, 7, 3, 32768, X'ee1b0f997d7517b286bc9d73a4cf742c65a769be'
+  3, 7,  3, 0, 32768, X'db0b68f3ad06b5c0c35deb56af22b8f0bc23ea50'
 );
 
-INSERT INTO file_hashes (
-  file, product, component, algo, hash
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
 ) VALUES (
-  30, 7, 3, 32768, X'b2a83b0ebf2f8374299a5b2bdfc31ea955ad7236'
+  3, 7,  4, 0, 32768, X'a662680c8564f92cf20c5857d781ed3f0806da5d'
 );
 
-INSERT INTO file_hashes (
-  file, product, component, algo, hash
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
 ) VALUES (
-  40, 4, 2, 32768, X'9704353630674bfe21b86b64a7b0f99c297cf902'
+  3, 7,  5, 0, 32768, X'10bfa817da3a9e5760fbe78f216502e8ca4f94ef'
 );
 
-INSERT INTO file_hashes (
-  file, product, component, algo, hash
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
 ) VALUES (
-  40, 7, 2, 32768, X'd537d437f058136eb3d7be517dbe7647b623c619'
+  3, 7,  6, 0, 32768, X'd0e1af1be845f570e44612613c4ddf3f08996151'
 );
 
-INSERT INTO file_hashes (
-  file, product, component, algo, hash
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
 ) VALUES (
-  41, 4, 2, 32768, X'8397d8048ee36d7955e38da16fc33e86ef61d6b0'
+  3, 7,  7, 0, 32768, X'f05553c39e8130c7bb5db6cd6a6bf627311a9b01'
 );
 
-INSERT INTO file_hashes (
-  file, product, component, algo, hash
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7,  8, 0, 32768, X'96ef1ad4efc5be2b894a12e5bffddcd496044a08'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7,  9, 0, 32768, X'e9055f2050b99b9127b6feef3164cb8ead8eb2eb'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 10, 0, 32768, X'6f8150aa3423544ea59ea10025993e660568cc08'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 11, 0, 32768, X'f843e55c9061fec89f2aeb369a74b73fe8eb09e4'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 12, 0, 32768, X'1d1efd1cb89be96f8fdf20ee0b67a89670659208'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 13, 0, 32768, X'f907598ec6fcc5779ff9091ba0925c1d58500352'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 14, 0, 32768, X'42f32d6fba099b0eea2e9a480dc8d4482e20412e'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 15, 0, 32768, X'e8a7cd52522ebacf4637a2b875494cda1c26bd8c'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 16, 0, 32768, X'd62d2c550fd06cae76f3e9c4d63f5fc22e34d4fe'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 17, 0, 32768, X'dc1293a87cab43024a4eaeb684a0186e33dacfe3'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 18, 0, 32768, X'03df488f642a9614ed718bf149fb7289d124189a'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 19, 0, 32768, X'46f1426433c57ee44b5593584308f8b7ac414e17'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 20, 0, 32768, X'1a837850cff01cd311948abd611174fa5699804b'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 21, 0, 32768, X'1c15052b28ac97e6e1cd0b4671fe75607c07de02'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 22, 0, 32768, X'1839bc8b6cd9351565a6bacb57f0e35562962cba'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 23, 0, 32768, X'f428189580a77b142b3de6cd3c183cb0a24dba6f'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 24, 0, 32768, X'f9b7302c9212a5398057ddea9c7506b265c3276f'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 25, 0, 32768, X'3af5d2929b9606b94b404a45deed9a9d673f49b7'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 26, 0, 32768, X'51a7df78bd7a23399b2824ec053f2abe5e4ee049'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 27, 0, 32768, X'2a3675f5efce9151670e9d4ec41e2edf4708d336'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 28, 0, 32768, X'a0cc14b4fde29d7251673af434b2ab246e5acf5a'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 29, 0, 32768, X'5932b35ba45894e65d6aa1afbe2101f677e17000'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 30, 0, 32768, X'ee12ad673d19d8f436ea7832e64935a0ddf9930e'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 31, 0, 32768, X'7bd9b4947ae9b600e6a2d61ead80104d878bb9d2'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 32, 0, 32768, X'849c60fc7b366717aea2295a37b341e40626dd28'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 33, 0, 32768, X'cdd448834760041cc30edd09f41ae36cbf9459ef'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 34, 0, 32768, X'9471225809633ae61f2693711cd878ba2ac59ef9'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 35, 0, 32768, X'4aaa26a4d1389b2400138269d3415bb492cc4312'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 36, 0, 32768, X'a08b0c957c8f741e273e8aa9a88d87b32b860228'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 37, 0, 32768, X'7ecbc26a2272256969e4c626998570c7e013be9c'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 38, 0, 32768, X'12dcf52c5a92b64dd5113031379f27b9f42d5c49'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 39, 0, 32768, X'ca1b8cc8e8ee8b209fc7b55656c3f6ac0b8f86fd'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 40, 0, 32768, X'8566865ae43d19574e85f9f3b6376715ffb3c707'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 41, 0, 32768, X'39c9fda07d57fc185b37bac70ba1068d6e7c41d3'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
 ) VALUES (
-  41, 7, 2, 32768, X'160d2b04d11eb225fb148615b699081869e15b6c'
+  3, 7, 42, 0, 32768, X'96a2c8b6caf11da5a37b41706217d4e94bb627c0'
 );
 
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 43, 0, 32768, X'6ee8c5a500af82a1fdf42e5122196fad4f2bbc06'
+);
 
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 44, 0, 32768, X'd2f71dff59d0ab86d0ada6ea288227602d6cf371'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 45, 0, 32768, X'095c8df0b106947e2c62a4458b13f38c6fc4f982'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 46, 0, 32768, X'706071d37157e1030900df60e6efaf897fbab1ec'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 47, 0, 32768, X'97f093c5ab5e2baf9b6f1473b631d3db2595fe99'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 48, 0, 32768, X'c12dd08ffbb4c09e3c282dd7f94cdcc9148ab866'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 49, 0, 32768, X'fb3df3be6d847db26e07eb61312bdc533bda53d2'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 50, 0, 32768, X'88195da5656b80c68bd3e131fb673b197281c2b0'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 51, 0, 32768, X'28353744f0fab757b1a870de007b6c8821d4723e'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 52, 0, 32768, X'9338b619160d4fb1a844acc95b0556b3d6109a77'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 53, 0, 32768, X'cd7f42895c6e4f9752f8b34184059d7ad4e5e6ce'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 54, 0, 32768, X'da5611278bf6855a44e5b1b5d62c76822a81674d'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 55, 0, 32768, X'eb4148c57806114b755416ba96b282fcc99ac2d1'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 56, 0, 32768, X'5e05f61508a391480dc83f741920a5de059546bc'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 57, 0, 32768, X'a23b279883915b0dc3313081924366ea5e75bdc1'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 58, 2, 32768, X'ef7511b5248557ae637f46b552f8af59020f2b00'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 59, 2, 32768, X'6240c588a2d7740f5c2c9523bff7d98334998d77'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 60, 2, 32768, X'808ce28868d844d547e0c2cc4271c14be2a568b6'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 61, 2, 32768, X'd736a206033ecbefc09e909f0d2d72c38d49d50b'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 62, 2, 32768, X'387a7087c3159f7d0a6388d722c200a599b4703b'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 63, 2, 32768, X'b6a679dda488042eee3cf9a525a9ae88b9514229'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 64, 2, 32768, X'693b89dc96682f85b389208ec052f4853fd971eb'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 65, 2, 32768, X'e4b83a6888c69eeb1c65c7ff50ee39897ca51008'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 66, 2, 32768, X'9e0735ad94f4d10faa43f75d02c4edb9b7eb91d4'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 67, 2, 32768, X'881dd3cb2f1f0e3323bf8c5586dfaba2ffcb1a55'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 68, 2, 32768, X'6461d3771999c3a4b3c15bf4e38da30b91bc1b17'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 69, 6, 32768, X'fcad787f7771637d659638d92b5eee9385b3d7b9'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 70, 0, 32768, X'4b90d9178efc5cf9a9ddf4f8bcc49008785d76ec'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 71, 2, 32768, X'e79e468b1921b2293a80c5917efa6a45c379e810'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 72, 2, 32768, X'be1bdec0aa74b4dcb079943e70528096cca985f8'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 73, 2, 32768, X'bc3a1d50aaffa207d2e6645228bb4f1cd40c88e0'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 74, 2, 32768, X'96ea8b0ccfb43fa6da4e98d8f51609cf8eabd91e'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 75, 2, 32768, X'd05ef7250cc103540601fb8956c89c3ba1f47a4e'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 76, 2, 32768, X'd5c28da6b58a66fba125e99c6b6d0e36a1b18315'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 77, 2, 32768, X'0ba611dd45de9acbe3d0da0d2e478e4aa77ff515'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 78, 4, 32768, X'9b4d80cfefc7d5576c4d9f224872505896ef2798'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 79, 2, 32768, X'e79e468b1921b2293a80c5917efa6a45c379e810'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 80, 2, 32768, X'be1bdec0aa74b4dcb079943e70528096cca985f8'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 81, 2, 32768, X'e79e468b1921b2293a80c5917efa6a45c379e810'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 82, 2, 32768, X'be1bdec0aa74b4dcb079943e70528096cca985f8'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 83, 1, 32768, X'230b3bf13c752834decf47f5a86a75582abee51c'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 84, 1, 32768, X'61f59f7782bb39610dbb6b1f57033c161810a267'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 85, 1, 32768, X'c744cac6af7621524fc3a2b0a9a135a32b33c81b'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 86, 1, 32768, X'8a7532af1862f9f61ed08d2b92b82a2ecc99c54f'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 87, 1, 32768, X'ba8fa710d303b3b2a594cba1cb73797c970ffa0b'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 88, 1, 32768, X'a46c5c8b58e67fbe9d3203bae335c0e39f68eff9'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 89, 1, 32768, X'67476198f63603b84afa235970611cd614560cf2'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 90, 2, 32768, X'cdf4d79ac0a10d46a1d9d7ec9642883c71f77fc7'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 91, 2, 32768, X'436067385bf6cd43e2f65f8d70d264af8fca876d'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 92, 2, 32768, X'4916c4e9f1e91b34bd8acef1f827f0b444bdb858'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 93, 2, 32768, X'c66007c47ea62816006d220bbb8fc9d5681c4cc6'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 94, 2, 32768, X'85782c59534d3915298da3da35101891a84be99e'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 95, 2, 32768, X'335f1897c44fef511bed7eb4394375bc2a36dbc3'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 96, 2, 32768, X'82ca255a4c2655eca1516b4249dcdd1edb892eef'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 97, 2, 32768, X'1086445009abbad955b9e915be04ac9afc74567d'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 98, 2, 32768, X'18fe7ae42869e2b3b11bf67215ef4f1c2e260251'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 99, 2, 32768, X'061efe921cad309990e63ed35a7b833e2eabfd2f'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 100, 2, 32768, X'aab5803005883807e91538fdc71968edf81f367c'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 101, 2, 32768, X'aab5803005883807e91538fdc71968edf81f367c'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 102, 2, 32768, X'0ba199b3cd6991a884fe30f40e89d3d603aa5cbd'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 103, 2, 32768, X'0ba199b3cd6991a884fe30f40e89d3d603aa5cbd'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 104, 2, 32768, X'2a5aa44e77a223d701a53b0f9af6d13cf8443b2a'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 105, 2, 32768, X'2a5aa44e77a223d701a53b0f9af6d13cf8443b2a'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 106, 2, 32768, X'c32ab71e81421207255b2665316a9049ddff3653'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 107, 2, 32768, X'c32ab71e81421207255b2665316a9049ddff3653'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 108, 2, 32768, X'cafaeff88886bf0d07b0a6527341da22c08b609d'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 109, 2, 32768, X'cafaeff88886bf0d07b0a6527341da22c08b609d'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 110, 2, 32768, X'68d74b6eacdc3360615744c6aaddb357df9bdbec'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 111, 2, 32768, X'68d74b6eacdc3360615744c6aaddb357df9bdbec'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 112, 2, 32768, X'ac254b04f277ca7e887a4141bf5ed0cf62600d10'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 113, 2, 32768, X'ac254b04f277ca7e887a4141bf5ed0cf62600d10'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 114, 1, 32768, X'4f135c9ee49ca7fbfea079e5d6714802f0405407'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 115, 0, 32768, X'9069ca78e7450a285173431b3e52c5c25299e473'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 116, 1, 32768, X'9069ca78e7450a285173431b3e52c5c25299e473'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 117, 2, 32768, X'9069ca78e7450a285173431b3e52c5c25299e473'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 118, 3, 32768, X'9069ca78e7450a285173431b3e52c5c25299e473'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 119, 4, 32768, X'9069ca78e7450a285173431b3e52c5c25299e473'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 120, 5, 32768, X'9069ca78e7450a285173431b3e52c5c25299e473'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 121, 6, 32768, X'9069ca78e7450a285173431b3e52c5c25299e473'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 122, 7, 32768, X'9069ca78e7450a285173431b3e52c5c25299e473'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 123, 4, 32768, X'c1e25c3f6b0dc78d57296aa2870ca6f782ccf80f'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 124, 4, 32768, X'67a0a98bc4d6321142895a4d938b342f6959c1a9'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 125, 4, 32768, X'06d60b3a0dee9bb9beb2f0b04aff2e75bd1d2860'
+);
+
+INSERT INTO component_hashes (
+  component, product, seq_no, pcr, algo, hash
+) VALUES (
+  3, 7, 126, 5, 32768, X'1b87003b6c7d90483713c90100cca3e62392b9bc'
+);
 
index 6a1df8e..564914e 100644 (file)
@@ -39,7 +39,7 @@ CREATE TABLE product_component (
   product INTEGER NOT NULL,
   component INTEGER NOT NULL,
   depth INTEGER DEFAULT 0,
-  sequence INTEGER DEFAULT 0,
+  seq_no INTEGER DEFAULT 0,
   PRIMARY KEY (product, component)
 );
 
@@ -48,8 +48,18 @@ CREATE TABLE file_hashes (
   file INTEGER NOT NULL,
   directory INTEGER DEFAULT 0,
   product INTEGER NOT NULL,
-  component INTEGER DEFAULT 0,
   algo INTEGER NOT NULL,
   hash BLOB NOT NULL,
-  PRIMARY KEY(file, directory, product, component, algo)
+  PRIMARY KEY(file, directory, product, algo)
+);
+
+DROP TABLE IF EXISTS component_hashes;
+CREATE TABLE component_hashes (
+  component INTEGER NOT NULL,
+  product INTEGER NOT NULL,
+  seq_no INTEGER NOT NULL,
+  pcr INTEGER NOT NULL,
+  algo INTEGER NOT NULL,
+  hash BLOB NOT NULL,
+  PRIMARY KEY(component, product, seq_no, algo)
 );
index f0a1cdc..a593281 100644 (file)
@@ -36,9 +36,10 @@ ENUM_NEXT(pts_ita_qualifier_type_names, PTS_ITA_QUALIFIER_TYPE_ALL,
 ENUM_END(pts_ita_qualifier_type_names, PTS_ITA_QUALIFIER_TYPE_ALL);
 
 ENUM(pts_ita_comp_func_names, PTS_ITA_COMP_FUNC_NAME_IGNORE,
-                                                         PTS_ITA_COMP_FUNC_NAME_TBOOT,
+                                                         PTS_ITA_COMP_FUNC_NAME_IMA,
        "Ignore",
        "Trusted GRUB Boot Loader",
-       "Trusted Boot"
+       "Trusted Boot",
+       "Linux IMA"
 );
 
index d5729b4..eb2f363 100644 (file)
@@ -76,6 +76,8 @@ enum pts_ita_comp_func_name_t {
        PTS_ITA_COMP_FUNC_NAME_TGRUB =                          0x0001,
        /** Trusted Boot */
        PTS_ITA_COMP_FUNC_NAME_TBOOT =                          0x0002,
+       /** Linux Integrity Measurement Architecture */
+       PTS_ITA_COMP_FUNC_NAME_IMA =                            0x0003,
 };
 
 extern enum_name_t *pts_ita_comp_func_names;
diff --git a/src/libpts/pts/components/ita/ita_comp_ima.c b/src/libpts/pts/components/ita/ita_comp_ima.c
new file mode 100644 (file)
index 0000000..a05dc7e
--- /dev/null
@@ -0,0 +1,331 @@
+/*
+ * Copyright (C) 2011 Andreas Steffen
+ *
+ * HSR Hochschule fuer Technik Rapperswil
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by the
+ * Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version.  See <http://www.fsf.org/copyleft/gpl.txt>.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+ * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * for more details.
+ */
+
+#include "ita_comp_ima.h"
+#include "ita_comp_func_name.h"
+
+#include "pts/components/pts_component.h"
+
+#include <debug.h>
+#include <pen/pen.h>
+
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <unistd.h>
+#include <fcntl.h>
+#include <errno.h>
+
+#define IMA_SECURITY_DIR                       "/sys/kernel/security/tpm0/"
+#define IMA_BIOS_MEASUREMENT_PATH      IMA_SECURITY_DIR "binary_bios_measurements"
+#define IMA_PCR_MAX                                    8
+#define IMA_SEQUENCE                           126
+
+typedef struct pts_ita_comp_ima_t pts_ita_comp_ima_t;
+
+/**
+ * Private data of a pts_ita_comp_ima_t object.
+ *
+ */
+struct pts_ita_comp_ima_t {
+
+       /**
+        * Public pts_component_t interface.
+        */
+       pts_component_t public;
+
+       /**
+        * Component Functional Name
+        */
+       pts_comp_func_name_t *name;
+
+       /**
+        * Sub-component depth
+        */
+       u_int32_t depth;
+
+       /**
+     * IMA BIOS measurement time
+        */
+       time_t bios_measurement_time;
+
+       /**
+     * IMA BIOS measurements
+        */
+       linked_list_t *list;
+
+       /**
+        * Measurement sequence number
+        */
+       int seq_no;
+
+       /**
+        * Shadow PCR registers
+        */
+       chunk_t pcrs[IMA_PCR_MAX];
+};
+
+typedef struct entry_t entry_t;
+
+/**
+ * Linux IMA measurement entry
+ */
+struct entry_t {
+
+       /**
+        * PCR register
+        */
+       u_int32_t pcr;
+
+       /**
+        * SHA1 measurement hash
+        */     
+       chunk_t measurement;
+};
+
+/**
+ * Free an entry_t object
+ */
+static void free_entry(entry_t *this)
+{
+       free(this->measurement.ptr);
+       free(this);
+}
+
+/**
+ * Load a PCR measurement file and determine the creation date
+ */
+static bool load_measurements(char *file, linked_list_t *list, time_t *created)
+{
+       u_int32_t pcr, num, len;
+       entry_t *entry;
+       struct stat st;
+       ssize_t res;
+       int fd;
+
+       fd = open(file, O_RDONLY);
+       if (fd == -1)
+       {
+               DBG1(DBG_PTS, "  opening '%s' failed: %s", file, strerror(errno));
+               return FALSE;
+       }
+
+       if (fstat(fd, &st) == -1)
+       {
+               DBG1(DBG_PTS, "  getting statistics of '%s' failed: %s", file,
+                        strerror(errno));
+               close(fd);
+               return FALSE;
+       }
+       *created = st.st_ctime;
+
+       while (TRUE)
+       {
+               res = read(fd, &pcr, 4);
+               if (res == 0)
+               {
+                       DBG2(DBG_PTS, "loaded bios measurements '%s' (%d entries)",
+                                                  file, list->get_count(list));
+                       close(fd);
+                       return TRUE;
+               }
+
+               entry = malloc_thing(entry_t);
+               entry->pcr = pcr;
+               entry->measurement = chunk_alloc(HASH_SIZE_SHA1);
+
+               if (res != 4)
+               {
+                       break;
+               }
+               if (read(fd, &num, 4) != 4)
+               {
+                       break;
+               }
+               if (read(fd, entry->measurement.ptr, HASH_SIZE_SHA1) != HASH_SIZE_SHA1)
+               {
+                       break;
+               }
+               if (read(fd, &len, 4) != 4)
+               {
+                       break;
+               }
+               if (lseek(fd, len, SEEK_CUR) == -1)
+               {
+                       break;
+               }
+               list->insert_last(list, entry);
+       }
+
+       DBG1(DBG_PTS, "loading bios measurements '%s' failed: %s",
+                                  file, strerror(errno));
+       close(fd);
+       return FALSE;
+}
+
+METHOD(pts_component_t, get_comp_func_name, pts_comp_func_name_t*,
+       pts_ita_comp_ima_t *this)
+{
+       return this->name;
+}
+
+METHOD(pts_component_t, get_evidence_flags, u_int8_t,
+       pts_ita_comp_ima_t *this)
+{
+       return PTS_REQ_FUNC_COMP_EVID_PCR;
+}
+
+METHOD(pts_component_t, get_depth, u_int32_t,
+       pts_ita_comp_ima_t *this)
+{
+       return this->depth;
+}
+
+METHOD(pts_component_t, measure, status_t,
+       pts_ita_comp_ima_t *this, pts_t *pts, pts_comp_evidence_t **evidence)
+{
+       pts_comp_evidence_t *evid;
+       chunk_t pcr_before, pcr_after;
+       pts_pcr_transform_t pcr_transform;
+       pts_meas_algorithms_t hash_algo;
+       size_t pcr_len;
+       entry_t *entry;
+       hasher_t *hasher;
+
+       hash_algo = PTS_MEAS_ALGO_SHA1;
+       pcr_len = pts->get_pcr_len(pts);   
+       pcr_transform = pts_meas_algo_to_pcr_transform(hash_algo, pcr_len);
+
+       if (this->list->get_count(this->list) == 0)
+       {
+               if (!load_measurements(IMA_BIOS_MEASUREMENT_PATH, this->list,
+                                                          &this->bios_measurement_time))
+               {
+                       return FAILED;
+               }
+       }
+       
+       if (this->list->remove_first(this->list, (void**)&entry) != SUCCESS)
+       {
+               DBG1(DBG_PTS, "could not retrieve measurement entry");
+               return FAILED;
+       }
+       
+       pcr_before = chunk_clone(this->pcrs[entry->pcr]);
+       
+       hasher = lib->crypto->create_hasher(lib->crypto, HASH_SHA1);
+       hasher->get_hash(hasher, pcr_before, NULL);
+       hasher->get_hash(hasher, entry->measurement, this->pcrs[entry->pcr].ptr);
+       hasher->destroy(hasher);
+
+       pcr_after = chunk_clone(this->pcrs[entry->pcr]);
+
+       evid = *evidence = pts_comp_evidence_create(this->name->clone(this->name),
+                                                       this->depth, entry->pcr, hash_algo, pcr_transform,
+                                                       this->bios_measurement_time, entry->measurement);
+       evid->set_pcr_info(evid, pcr_before, pcr_after);
+
+       free(entry);
+
+       return (this->list->get_count(this->list)) ? NEED_MORE : SUCCESS;
+}
+
+METHOD(pts_component_t, verify, status_t,
+       pts_ita_comp_ima_t *this, pts_t *pts, pts_database_t *pts_db,
+       pts_comp_evidence_t *evidence)
+{
+       bool has_pcr_info;
+       char *platform_info;
+       u_int32_t extended_pcr;
+       pts_meas_algorithms_t algo;
+       pts_pcr_transform_t transform;
+       time_t measurement_time;
+       chunk_t measurement, pcr_before, pcr_after;
+
+       platform_info = pts->get_platform_info(pts);
+       if (!pts_db || !platform_info)
+       {
+               DBG1(DBG_PTS, "%s%s%s not available",
+                                         (pts_db) ? "" : "pts database",
+                                         (!pts_db && !platform_info) ? "and" : "",
+                                         (platform_info) ? "" : "platform info");
+               return FAILED;
+       }
+       measurement = evidence->get_measurement(evidence, &extended_pcr,
+                                                                       &algo, &transform, &measurement_time);
+
+       if (pts_db->check_comp_measurement(pts_db, measurement, this->name,
+                       platform_info, ++this->seq_no, extended_pcr, algo) != SUCCESS)
+       {
+               return FAILED;
+       }
+
+       has_pcr_info = evidence->get_pcr_info(evidence, &pcr_before, &pcr_after);
+       if (has_pcr_info)
+       {
+               if (!pts->add_pcr(pts, extended_pcr, pcr_before, pcr_after))
+               {
+                       return FAILED;
+               }
+       }
+
+       return (this->seq_no < IMA_SEQUENCE) ? NEED_MORE : SUCCESS;
+}
+
+METHOD(pts_component_t, destroy, void,
+       pts_ita_comp_ima_t *this)
+{
+       int i;
+
+       for (i = 0; i < IMA_PCR_MAX; i++)
+       {
+               free(this->pcrs[i].ptr);
+       }
+       this->list->destroy_function(this->list, (void *)free_entry);
+       this->name->destroy(this->name);
+       free(this);
+}
+
+/**
+ * See header
+ */
+pts_component_t *pts_ita_comp_ima_create(u_int8_t qualifier, u_int32_t depth)
+{
+       pts_ita_comp_ima_t *this;
+       int i;
+
+       INIT(this,
+               .public = {
+                       .get_comp_func_name = _get_comp_func_name,
+                       .get_evidence_flags = _get_evidence_flags,
+                       .get_depth = _get_depth,
+                       .measure = _measure,
+                       .verify = _verify,
+                       .destroy = _destroy,
+               },
+               .name = pts_comp_func_name_create(PEN_ITA, PTS_ITA_COMP_FUNC_NAME_IMA,
+                                                                                 qualifier),
+               .depth = depth,
+               .list = linked_list_create(),
+       );
+
+       for (i = 0; i < IMA_PCR_MAX; i++)
+       {
+               this->pcrs[i] = chunk_alloc(HASH_SIZE_SHA1);
+               memset(this->pcrs[i].ptr, 0x00, HASH_SIZE_SHA1);
+       }
+       return &this->public;
+}
+
diff --git a/src/libpts/pts/components/ita/ita_comp_ima.h b/src/libpts/pts/components/ita/ita_comp_ima.h
new file mode 100644 (file)
index 0000000..4293518
--- /dev/null
@@ -0,0 +1,34 @@
+/*
+ * Copyright (C) 2011 Andreas Steffen
+ * HSR Hochschule fuer Technik Rapperswil
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by the
+ * Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version.  See <http://www.fsf.org/copyleft/gpl.txt>.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+ * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * for more details.
+ */
+
+/**
+ * @defgroup pts_ita_comp_func_name pts_ita_comp_func_name
+ * @{ @ingroup pts
+ */
+
+#ifndef PTS_ITA_COMP_IMA_H_
+#define PTS_ITA_COMP_IMA_H_
+
+#include "pts/components/pts_component.h"
+
+/**
+ * Create a PTS ITS Functional Component object
+ *
+ * @param qualifier            PTS Component Functional Name Qualifier
+ *
+ */
+pts_component_t* pts_ita_comp_ima_create(u_int8_t qualifier, u_int32_t depth);
+
+#endif /** PTS_ITA_COMP_IMA_H_ @}*/
index 6b514e5..572828a 100644 (file)
@@ -23,6 +23,8 @@
 #include <debug.h>
 #include <pen/pen.h>
 
+#define TBOOT_SEQUENCE         2
+
 typedef struct pts_ita_comp_tboot_t pts_ita_comp_tboot_t;
 
 /**
@@ -47,14 +49,14 @@ struct pts_ita_comp_tboot_t {
        u_int32_t depth;
 
        /**
-        * Extended PCR last handled
+        * Time of TBOOT measurement
         */
-       u_int32_t extended_pcr;
+       time_t measurement_time;
 
        /**
-        * Time of TBOOT measurement
+        * Measurement sequence number
         */
-       time_t measurement_time;
+       int seq_no;
 
 };
 
@@ -83,10 +85,11 @@ METHOD(pts_component_t, measure, status_t,
        char *meas_hex, *pcr_before_hex, *pcr_after_hex;
        chunk_t measurement, pcr_before, pcr_after;
        size_t hash_size, pcr_len;
+       u_int32_t extended_pcr;
        pts_pcr_transform_t pcr_transform;
        pts_meas_algorithms_t hash_algo;
        
-       switch (this->extended_pcr)
+       switch (this->seq_no++)
        {
                case 0:
                        /* dummy data since currently the TBOOT log is not retrieved */
@@ -97,9 +100,9 @@ METHOD(pts_component_t, measure, status_t,
                                                "libimcv.plugins.imc-attestation.pcr17_before", NULL);
                        pcr_after_hex = lib->settings->get_str(lib->settings,
                                                "libimcv.plugins.imc-attestation.pcr17_after", NULL);
-                       this->extended_pcr = PCR_TBOOT_POLICY;
+                       extended_pcr = PCR_TBOOT_POLICY;
                        break;
-               case PCR_TBOOT_POLICY:
+               case 1:
                        /* dummy data since currently the TBOOT log is not retrieved */
                        meas_hex = lib->settings->get_str(lib->settings,
                                                "libimcv.plugins.imc-attestation.pcr18_meas", NULL);
@@ -107,7 +110,7 @@ METHOD(pts_component_t, measure, status_t,
                                                "libimcv.plugins.imc-attestation.pcr18_before", NULL);
                        pcr_after_hex = lib->settings->get_str(lib->settings,
                                                "libimcv.plugins.imc-attestation.pcr18_after", NULL);
-                       this->extended_pcr = PCR_TBOOT_MLE;
+                       extended_pcr = PCR_TBOOT_MLE;
                        break;
                default:
                        return FAILED;
@@ -136,12 +139,12 @@ METHOD(pts_component_t, measure, status_t,
        }
 
        evid = *evidence = pts_comp_evidence_create(this->name->clone(this->name),
-                                                               this->depth, this->extended_pcr,
+                                                               this->depth, extended_pcr,
                                                                hash_algo, pcr_transform,
                                                                this->measurement_time, measurement);
        evid->set_pcr_info(evid, pcr_before, pcr_after);
 
-       return (this->extended_pcr == PCR_TBOOT_MLE) ? SUCCESS : NEED_MORE;
+       return (this->seq_no < TBOOT_SEQUENCE) ? NEED_MORE : SUCCESS;
 }
 
 METHOD(pts_component_t, verify, status_t,
@@ -149,14 +152,12 @@ METHOD(pts_component_t, verify, status_t,
        pts_comp_evidence_t *evidence)
 {
        bool has_pcr_info;
+       char *platform_info;
        u_int32_t extended_pcr;
        pts_meas_algorithms_t algo;
        pts_pcr_transform_t transform;
        time_t measurement_time;
        chunk_t measurement, pcr_before, pcr_after, hash;
-       enumerator_t *enumerator;
-       char *file, *platform_info;
-       status_t status = NOT_FOUND;
 
        platform_info = pts->get_platform_info(pts);
        if (!pts_db || !platform_info)
@@ -167,58 +168,12 @@ METHOD(pts_component_t, verify, status_t,
                                          (platform_info) ? "" : "platform info");
                return FAILED;
        }
-
-       switch (this->extended_pcr)
-       {
-               case 0:
-                       this->extended_pcr = PCR_TBOOT_POLICY;
-                       file = "pcr17";
-                       break;
-               case PCR_TBOOT_POLICY:
-                       this->extended_pcr = PCR_TBOOT_MLE;
-                       file = "pcr18";
-                       break;
-               default:
-                       return FAILED;
-       }
-
        measurement = evidence->get_measurement(evidence, &extended_pcr,
-                                                                                       &algo, &transform, &measurement_time);
-       if (extended_pcr != this->extended_pcr)
-       {
-               DBG1(DBG_PTS, "expected PCR %2d but received measurement for PCR %2d",
-                                          this->extended_pcr, extended_pcr);
-               return FAILED;
-       }
-       
-       /* check measurement in database */
-       enumerator = pts_db->create_comp_hash_enumerator(pts_db, file,
-                                                               platform_info, this->name, TRUSTED_HASH_ALGO);
-       while (enumerator->enumerate(enumerator, &hash))
-       {
-               if (chunk_equals(hash, measurement))
-               {
-                       DBG2(DBG_PTS, "PCR %2d matching TBOOT component measurement "
-                                                 "found in database", this->extended_pcr);
-                       status = SUCCESS;
-                       break;
-               }
-               else
-               {
-                       DBG1(DBG_PTS, "PCR %2d no matching TBOOT component measurement "
-                                                 "found in database", this->extended_pcr);
-                       DBG1(DBG_PTS, "  expected: %#B", &hash);
-                       DBG1(DBG_PTS, "  received: %#B", &measurement);
-                       status = FAILED;
-                       break;
-               }
-       }
-       enumerator->destroy(enumerator);
+                                                               &algo, &transform, &measurement_time);
 
-       if (status == NOT_FOUND)
+       if (pts_db->check_comp_measurement(pts_db, measurement, this->name,
+                       platform_info,  ++this->seq_no, extended_pcr, algo) != SUCCESS)
        {
-               DBG1(DBG_PTS, "PCR %2d no measurement found in database",
-                                          this->extended_pcr);
                return FAILED;
        }
 
@@ -231,7 +186,7 @@ METHOD(pts_component_t, verify, status_t,
                }
        }
 
-       return (this->extended_pcr == PCR_TBOOT_MLE) ? SUCCESS : NEED_MORE;
+       return (this->seq_no < TBOOT_SEQUENCE) ? NEED_MORE : SUCCESS;
 }
 
 METHOD(pts_component_t, destroy, void,
index 8736780..bf5c2bc 100644 (file)
@@ -626,7 +626,7 @@ static bool file_metadata(char *pathname, pts_file_metadata_t **entry)
 
        if (stat(pathname, &st))
        {
-               DBG1(DBG_PTS, "Unable to obtain statistics about '%s'", pathname);
+               DBG1(DBG_PTS, "unable to obtain statistics about '%s'", pathname);
                return FALSE;
        }
 
index ff193cb..cb2d104 100644 (file)
@@ -80,7 +80,7 @@ METHOD(pts_database_t, create_comp_evid_enumerator, enumerator_t*,
                                "FROM components AS c "
                                "JOIN product_component AS pc ON c.id = pc.component "
                                "JOIN products AS p ON p.id = pc.product "
-                               "WHERE p.name = ? ORDER BY pc.sequence",
+                               "WHERE p.name = ? ORDER BY pc.seq_no",
                                DB_TEXT, product, DB_INT, DB_INT, DB_INT, DB_INT);
        return e;
 }
@@ -114,26 +114,60 @@ METHOD(pts_database_t, create_file_hash_enumerator, enumerator_t*,
        return e;
 }
 
-METHOD(pts_database_t, create_comp_hash_enumerator, enumerator_t*,
-       private_pts_database_t *this, char *file, char *product,
-       pts_comp_func_name_t *comp_name, pts_meas_algorithms_t algo)
+METHOD(pts_database_t, check_comp_measurement, status_t,
+       private_pts_database_t *this, chunk_t measurement,
+       pts_comp_func_name_t *comp_name,  char *product,
+       int seq_no, int pcr, pts_meas_algorithms_t algo)
 {
        enumerator_t *e;
+       chunk_t hash;
+       status_t status = NOT_FOUND;
        
        e = this->db->query(this->db,
-                               "SELECT fh.hash FROM file_hashes AS fh "
-                               "JOIN files AS f ON fh.file = f.id "
-                               "JOIN products AS p ON fh.product = p.id "
-                               "JOIN components AS c ON fh.component = c.id "
-                               "WHERE f.path = ? AND p.name = ? AND c.vendor_id = ? "
-                               "AND c.name = ? AND c.qualifier = ? AND fh.algo = ? ",
-                               DB_TEXT, file, DB_TEXT, product,
-                               DB_INT, comp_name->get_vendor_id(comp_name),
-                               DB_INT, comp_name->get_name(comp_name),
-                               DB_INT, comp_name->get_qualifier(comp_name),
-                               DB_INT, algo, DB_BLOB);
+                       "SELECT ch.hash FROM component_hashes AS ch "
+                       "JOIN products AS p ON ch.product = p.id "
+                       "JOIN components AS c ON ch.component = c.id "
+                       "WHERE c.vendor_id = ?  AND c.name = ? AND c.qualifier = ? "
+                       "AND p.name = ? AND ch.seq_no = ? AND ch.pcr = ? AND ch.algo = ? ",
+                       DB_INT, comp_name->get_vendor_id(comp_name),
+                       DB_INT, comp_name->get_name(comp_name),
+                       DB_INT, comp_name->get_qualifier(comp_name),
+                       DB_TEXT, product, DB_INT, seq_no, DB_INT, pcr, DB_INT, algo,
+                       DB_BLOB);
+       if (!e)
+       {
+               DBG1(DBG_PTS, "no database query enumerator returned"); 
+               return FAILED;
+       }
 
-       return e;
+       while (e->enumerate(e, &hash))
+       {
+               if (chunk_equals(hash, measurement))
+               {
+                       DBG2(DBG_PTS, "PCR %2d matching component measurement #%d "
+                                                 "found in database", pcr, seq_no);
+                       status = SUCCESS;
+                       break;
+               }
+               else
+               {
+                       DBG1(DBG_PTS, "PCR %2d no matching component measurement #%d "
+                                                 "found in database", pcr, seq_no);
+                       DBG1(DBG_PTS, "  expected: %#B", &hash);
+                       DBG1(DBG_PTS, "  received: %#B", &measurement);
+                       status = FAILED;
+                       break;
+               }
+       }
+       e->destroy(e);
+
+       if (status == NOT_FOUND)
+       {
+               DBG1(DBG_PTS, "PCR %2d no measurement #%d "
+                                         "found in database", pcr, seq_no);
+       }
+
+       return status;
 }
 
 METHOD(pts_database_t, destroy, void,
@@ -156,7 +190,7 @@ pts_database_t *pts_database_create(char *uri)
                        .create_file_meta_enumerator = _create_file_meta_enumerator,
                        .create_comp_evid_enumerator = _create_comp_evid_enumerator,
                        .create_file_hash_enumerator = _create_file_hash_enumerator,
-                       .create_comp_hash_enumerator = _create_comp_hash_enumerator,
+                       .check_comp_measurement = _check_comp_measurement,
                        .destroy = _destroy,
                },
                .db = lib->db->create(lib->db, uri),
index 687c156..3ed0b5b 100644 (file)
@@ -36,8 +36,8 @@ struct pts_database_t {
        /**
        * Get files/directories to be measured by PTS
        *
-       * @param product                software product (os, vpn client, etc.)
-       * @return                               enumerator over all matching files/directories
+       * @param product                Software product (os, vpn client, etc.)
+       * @return                               Enumerator over all matching files/directories
        */
        enumerator_t* (*create_file_meas_enumerator)(pts_database_t *this,
                                                                                                 char *product);
@@ -45,8 +45,8 @@ struct pts_database_t {
        /**
        * Get files/directories to request metadata of
        *
-       * @param product                software product (os, vpn client, etc.)
-       * @return                               enumerator over all matching files/directories
+       * @param product                Software product (os, vpn client, etc.)
+       * @return                               Enumerator over all matching files/directories
        */
        enumerator_t* (*create_file_meta_enumerator)(pts_database_t *this,
                                                                                                 char *product);
@@ -54,8 +54,8 @@ struct pts_database_t {
        /**
        * Get functional components to request evidence of
        *
-       * @param product                software product (os, vpn client, etc.)
-       * @return                               enumerator over all matching components
+       * @param product                Software product (os, vpn client, etc.)
+       * @return                               Enumerator over all matching components
        */
        enumerator_t* (*create_comp_evid_enumerator)(pts_database_t *this,
                                                                                                 char *product);
@@ -63,29 +63,30 @@ struct pts_database_t {
        /**
        * Get stored measurement hash for single file or directory entries
        *
-       * @param product                software product (os, vpn client, etc.)
-       * @param algo                   hash algorithm used for measurement
-       * @param id                             primary key of measured file/directory
+       * @param product                Software product (os, vpn client, etc.)
+       * @param algo                   Hash algorithm used for measurement
+       * @param id                             Primary key of measured file/directory
        * @param is_dir                 TRUE if directory was measured
-       * @return                               enumerator over all matching measurement hashes
+       * @return                               Enumerator over all matching measurement hashes
        */
        enumerator_t* (*create_file_hash_enumerator)(pts_database_t *this,
                                                                char *product, pts_meas_algorithms_t algo,
                                                                int id, bool is_dir);
 
        /**
-       * Get stored measurement hash for functional component entries
+       * Check a functional component measurement against value stored in database
        *
-       * @param file                   file path in files table
-       * @param product                software product (os, vpn client, etc.)
-       * @param algo                   hash algorithm used for measurement
-       * @param comp_name              functional component name object
-       * @return                               enumerator over all matching measurement hashes
+       * @param measurement    measurement hash
+       * @param comp_name              Component Functional Name
+       * @param product                Software product (os, vpn client, etc.)
+       * @param seq_no                 Measurement sequence number
+       * @param prc                    Number of the PCR the measurement was extended into
+       * @param algo                   Hash algorithm used for measurement
+       * @return                               return code
        */
-       enumerator_t* (*create_comp_hash_enumerator)(pts_database_t *this,
-                                               char *file, char *product,
-                                               pts_comp_func_name_t *comp_name,
-                                               pts_meas_algorithms_t algo);
+       status_t (*check_comp_measurement)(pts_database_t *this, chunk_t measurement,
+                                                       pts_comp_func_name_t *comp_name, char *product,
+                                                       int seq_no, int pcr, pts_meas_algorithms_t algo);
 
        /**
        * Destroys a pts_database_t object.