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

Side by Side Diff: src/trusted/validator_ragel/unreviewed/dfa_validate_32.c

Issue 10070010: validator_ragel: Link into TCB, use under env var (Closed) Base URL: svn://svn.chromium.org/native_client/trunk/src/native_client
Patch Set: . Created 8 years, 8 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 /*
2 * Copyright (c) 2012 The Native Client Authors. All rights reserved.
3 * Use of this source code is governed by a BSD-style license that can be
4 * found in the LICENSE file.
5 */
6
7 /* Implement the ApplyDfaValidator API for the x86-32 architecture. */
8 #include <assert.h>
9 #include "native_client/src/shared/platform/nacl_log.h"
10 #include "native_client/src/trusted/validator/ncvalidate.h"
11 #include "native_client/src/trusted/validator/validation_cache.h"
12 #include "native_client/src/trusted/validator_ragel/unreviewed/validator.h"
13
14 /* Be sure the correct compile flags are defined for this. */
15 #if NACL_ARCH(NACL_TARGET_ARCH) != NACL_x86
16 # error("Can't compile, target is for x86-32")
17 #else
18 # if NACL_TARGET_SUBARCH != 32
19 # error("Can't compile, target is for x86-32")
20 # endif
21 #endif
22
23
24 static void ProcessError(const uint8_t *ptr, void *userdata) {
25 UNREFERENCED_PARAMETER(ptr);
26 UNREFERENCED_PARAMETER(userdata);
27 }
28
29 NaClValidationStatus NACL_SUBARCH_NAME(ApplyDfaValidator, x86, 32) (
30 enum NaClSBKind sb_kind,
31 uintptr_t guest_addr,
32 uint8_t *data,
33 size_t size,
34 int stubout_mode,
35 int readonly_text,
36 const NaClCPUFeaturesX86 *cpu_features,
37 struct NaClValidationCache *cache) {
38 UNREFERENCED_PARAMETER(guest_addr);
39 UNREFERENCED_PARAMETER(readonly_text);
Nick Bray 2012/04/19 23:11:08 I'd check if readonly_text and error if it's reque
pasko-google - do not use 2012/04/20 14:30:38 Done.
40 UNREFERENCED_PARAMETER(cache);
41
42 if (stubout_mode || sb_kind != NACL_SB_DEFAULT) {
Nick Bray 2012/04/19 23:11:08 Keep the checks separate, it makes it easier to re
pasko-google - do not use 2012/04/20 14:30:38 Code should be optimized for readability, not for
43 return NaClValidationFailedNotImplemented;
44 }
45 if (!NaClArchSupported(cpu_features)) {
46 return NaClValidationFailedCpuNotSupported;
47 }
48 if (!ValidateChunkIA32(data, size, ProcessError, 0)) {
Nick Bray 2012/04/19 23:11:08 Nit: == 0? This would make it clearer that you're
pasko-google - do not use 2012/04/20 14:30:38 Good nit. Done.
49 return NaClValidationSucceeded;
50 }
51 return NaClValidationFailed;
52 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698