Index: mojo/public/c/bindings/lib/message.c |
diff --git a/mojo/public/c/bindings/lib/message.c b/mojo/public/c/bindings/lib/message.c |
new file mode 100644 |
index 0000000000000000000000000000000000000000..cfbe01f8d5a4280ca3bb8039e4f0ffdf08682700 |
--- /dev/null |
+++ b/mojo/public/c/bindings/lib/message.c |
@@ -0,0 +1,50 @@ |
+// Copyright 2016 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "mojo/public/c/bindings/message.h" |
+ |
+#include <stdint.h> |
+ |
+_Static_assert(sizeof(mojo_message_header_t) == 16u, |
+ "mojo_message_header_t should be 16 bytes"); |
+ |
+_Static_assert(sizeof(mojo_message_header_with_request_id_t) == 24u, |
+ "mojo_message_header_t should be 24 bytes"); |
+ |
+bool mojo_validate_message_header(const mojo_struct_header_t* header, |
+ size_t size) { |
+ if (header->num_bytes < sizeof(mojo_message_header_t) || |
+ size < sizeof(mojo_message_header_t) || size > UINT32_MAX) { |
+ return false; |
+ } |
+ |
+ const mojo_message_header_t* message_header = |
+ (const mojo_message_header_t*)header; |
+ |
+ // Message expects response and message is response flags are mutually |
+ // exclusive. |
+ if ((message_header->flags & MOJO_MESSAGE_HEADER_FLAGS_EXPECTS_RESPONSE) && |
+ (message_header->flags & MOJO_MESSAGE_HEADER_FLAGS_IS_RESPONSE)) { |
+ return false; |
+ } |
+ |
+ if (header->version == 0u) { |
+ if (header->num_bytes != sizeof(mojo_message_header_t)) { |
+ return false; |
+ } |
+ |
+ // Version 0 has no request id and should not have either of these flags. |
+ if ((message_header->flags & MOJO_MESSAGE_HEADER_FLAGS_EXPECTS_RESPONSE) || |
+ (message_header->flags & MOJO_MESSAGE_HEADER_FLAGS_IS_RESPONSE)) { |
+ return false; |
+ } |
+ } else if (header->version == 1u) { |
+ if (header->num_bytes != sizeof(mojo_message_header_with_request_id_t)) { |
+ return false; |
+ } |
+ } |
+ // Accept unknown versions of the message header to be future-proof. |
+ |
+ return true; |
+} |