Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(95)

Unified Diff: src/trusted/validator/x86/ncval_reg_sfi/address_sets_inl.c

Issue 7980021: Speed up x86-64 validator by inlining heavily called routines. Speeds up (Closed) Base URL: svn://svn.chromium.org/native_client/trunk/src/native_client/
Patch Set: '' Created 9 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: src/trusted/validator/x86/ncval_reg_sfi/address_sets_inl.c
===================================================================
--- src/trusted/validator/x86/ncval_reg_sfi/address_sets_inl.c (revision 0)
+++ src/trusted/validator/x86/ncval_reg_sfi/address_sets_inl.c (revision 0)
@@ -0,0 +1,72 @@
+/*
+ * Copyright (c) 2011 The Native Client Authors. All rights reserved.
+ * Use of this source code is governed by a BSD-style license that can be
+ * found in the LICENSE file.
+ */
+
+/*
+ * address_sets_inl.c - Holds inline routines for commonly used (simple)
+ * functions in address_sets.h. Used to speed up code. Inlined routines
+ * correspond to the following functions in address_sets.h, but with
+ * an 'Inline' suffix:
+ *
+ * NaClAddressSetAdd
+ */
+
+#ifndef NATIVE_CLIENT_SRC_TRUSTED_VALIDATOR_X86_NCVAL_REG_SFI_ADDRESS_SETS_INL_C__
+#define NATIVE_CLIENT_SRC_TRUSTED_VALIDATOR_X86_NCVAL_REG_SFI_ADDRESS_SETS_INL_C__
+
+#include "native_client/src/trusted/validator/x86/ncval_reg_sfi/address_sets.h"
+
+/* Model the offset created by removing the bottom three bits of a PcAddress. */
+typedef NaClPcAddress NaClPcOffset;
+
+/* Model the set of possible 3-bit tails of possible PcAddresses. */
+static const uint8_t nacl_pc_address_masks[8] = {
+ 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80 };
+
+/* Convert the 3 lower bits of an address into the corresponding address mask
+ * to use.
+ */
+static INLINE uint8_t NaClPcAddressToMask(NaClPcAddress address) {
+ return nacl_pc_address_masks[(int) (address & (NaClPcAddress)0x7)];
+}
+
+/* Convert an address into the corresponding offset in an address table.
+ * That is, strip off the last three bits, since these remaining bits
+ * will be encoded using the union of address masks in the address table.
+ */
+static INLINE NaClPcOffset NaClPcAddressToOffset(NaClPcAddress address) {
+ return address >> 3;
+}
+
+/* Returns true if the given address is within the code segment. Generates
+ * error messages if it isn't.
+ */
+static INLINE Bool NaClCheckAddressRange(NaClPcAddress address,
+ NaClValidatorState* state) {
+ if (address < state->vbase) {
+ NaClValidatorPcAddressMessage(LOG_ERROR, state, address,
+ "Jump to address before code block.\n");
+ return FALSE;
+ }
+ if (address >= state->vlimit) {
+ NaClValidatorPcAddressMessage(LOG_ERROR, state, address,
+ "Jump to address beyond code block limit.\n");
+ return FALSE;
+ }
+ return TRUE;
+}
+
+static INLINE void NaClAddressSetAddInline(NaClAddressSet set,
+ NaClPcAddress address,
+ NaClValidatorState* state) {
+ if (NaClCheckAddressRange(address, state)) {
+ NaClPcAddress offset = address - state->vbase;
+ DEBUG(NaClLog(LOG_INFO,
+ "Address set add: %"NACL_PRIxNaClPcAddress"\n", address));
+ set[NaClPcAddressToOffset(offset)] |= NaClPcAddressToMask(offset);
+ }
+}
+
+#endif /* NATIVE_CLIENT_SRC_TRUSTED_VALIDATOR_X86_NCVAL_REG_SFI_ADDRESS_SETS_INL_C__ */
Property changes on: src/trusted/validator/x86/ncval_reg_sfi/address_sets_inl.c
___________________________________________________________________
Added: svn:eol-style
+ LF
« no previous file with comments | « src/trusted/validator/x86/ncval_reg_sfi/address_sets.c ('k') | src/trusted/validator/x86/ncval_reg_sfi/nc_cpu_checks.c » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698