Added gbb_utility (tool for Google Binary Block)

Review URL: http://codereview.chromium.org/2346001
diff --git a/utility/include/gbb_utility.h b/utility/include/gbb_utility.h
new file mode 100644
index 0000000..70a4527
--- /dev/null
+++ b/utility/include/gbb_utility.h
@@ -0,0 +1,78 @@
+// Copyright (c) 2010 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.
+
+
+#ifndef VBOOT_REFERENCE_GBB_UTILITY_H_
+#define VBOOT_REFERENCE_GBB_UTILITY_H_
+
+#include <string>
+#include "gbb_header.h"
+
+namespace vboot_reference {
+
+class GoogleBinaryBlockUtil {
+ public:
+  GoogleBinaryBlockUtil();
+  ~GoogleBinaryBlockUtil();
+
+  // load GBB from a BIOS image file.
+  // return true if a valid GBB was retrieved.
+  bool load_from_file(const char *filename);
+
+  // save loaded (and modified) GBB with BIOS image to new file
+  // return true on success.
+  bool save_to_file(const char *filename);
+
+  // getters and setters of properties in GBB
+  bool set_hwid(const char *hwid);      // hwid is NUL-terminated.
+  bool set_rootkey(const std::string &value);
+  bool set_bmpfv(const std::string &value);
+  std::string get_hwid() const    { return get_property(PROP_HWID); }
+  std::string get_rootkey() const { return get_property(PROP_ROOTKEY); }
+  std::string get_bmpfv() const   { return get_property(PROP_BMPFV); }
+
+ private:
+  // enumerate of available data fields
+  enum PROPINDEX {
+    PROP_HWID,          // hardware id
+    PROP_ROOTKEY,       // root key
+    PROP_BMPFV,         // bitmap FV
+  };
+
+  // clear all cached data and initialize to original state
+  void initialize();
+
+  // search and count for GBB signatures in loaded image.
+  // return the number of signatures found.
+  int search_header_signatures(const std::string &image, long *poffset) const;
+
+  // load and check header structure from image by given offset.
+  // return true if a valid GBB header is loaded into *phdr.
+  bool load_gbb_header(const std::string &image, long offset,
+                       GoogleBinaryBlockHeader *phdr) const;
+
+  // retrieve a property from GBB data.
+  // return the property value.
+  std::string get_property(PROPINDEX i) const;
+
+  // overwrite a property in GBB data.
+  // return true on success.
+  bool set_property(PROPINDEX i, const std::string &value);
+
+  // find the size and offset information for given property
+  // return true if the offset and size are assign to *poffset and *psize.
+  bool find_property(PROPINDEX i, uint32_t *poffset, uint32_t *psize) const;
+
+  GoogleBinaryBlockHeader header_;      // copy of GBB header from image
+  std::string file_content_;            // complete image file content
+  long header_offset_;                  // offset to GBB header in file_content_
+  bool is_valid_gbb;                    // if we are holding a valid GBB
+
+  bool verbose;                         // provide verbose messages
+};
+
+}  // namespace vboot_reference
+
+#endif  // VBOOT_REFERENCE_GBB_UTILITY_H_
+