Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Flags error when a [15:8] access occurs #185

Closed
JonathanSalwan opened this issue Sep 29, 2015 · 3 comments
Closed

Flags error when a [15:8] access occurs #185

JonathanSalwan opened this issue Sep 29, 2015 · 3 comments
Assignees
Milestone

Comments

@JonathanSalwan
Copy link
Owner

[KO] 0x400584: or ah, 0x8 (1 error)
     Register       : pf
     Symbolic Value : 0000000000000001
     Concrete Value : 0000000000000000
     Expression     : (bvxor (bvxor (bvxor (bvxor (bvxor (bvxor (bvxor (bvxor (_ bv1 1) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #162) (_ bv0 8)))) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #162) (_ bv1 8)))) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #162) (_ bv2 8)))) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #162) (_ bv3 8)))) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #162) (_ bv4 8)))) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #162) (_ bv5 8)))) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #162) (_ bv6 8)))) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #162) (_ bv7 8))))
[OK] 0x400587: mov rax, 0xfbad2284
[KO] 0x400591: or ah, 0x8 (2 error)
     Register       : pf
     Symbolic Value : 0000000000000001
     Concrete Value : 0000000000000000
     Expression     : (bvxor (bvxor (bvxor (bvxor (bvxor (bvxor (bvxor (bvxor (_ bv1 1) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #171) (_ bv0 8)))) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #171) (_ bv1 8)))) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #171) (_ bv2 8)))) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #171) (_ bv3 8)))) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #171) (_ bv4 8)))) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #171) (_ bv5 8)))) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #171) (_ bv6 8)))) ((_ extract 0 0) (bvlshr ((_ extract 7 0) #171) (_ bv7 8))))
     Register       : sf
     Symbolic Value : 0000000000000001
     Concrete Value : 0000000000000000
     Expression     : (ite (= ((_ extract 7 7) #171) (_ bv1 1)) (_ bv1 1) (_ bv0 1))

We must update EflagsBuilder and EflagsExpressions to take into account the vector size of the destination.

@JonathanSalwan JonathanSalwan self-assigned this Sep 29, 2015
@JonathanSalwan JonathanSalwan added this to the v0.2 milestone Sep 29, 2015
JonathanSalwan added a commit that referenced this issue Nov 28, 2015
@JonathanSalwan JonathanSalwan reopened this Dec 6, 2015
@JonathanSalwan JonathanSalwan modified the milestones: v0.3, v0.2 Dec 6, 2015
@JonathanSalwan
Copy link
Owner Author

Still not done in specific cases.

@JonathanSalwan
Copy link
Owner Author

It's because we use sometime createRegSE() and others times createSE(). Three solutions:

  • createSE() should build expression as like as a register bitvector.
  • Eflags should take the high and low in their parameters.
  • SymbolicExpression should contain the size of the root node

@JonathanSalwan JonathanSalwan modified the milestones: v0.4, v0.3 Dec 9, 2015
@JonathanSalwan
Copy link
Owner Author

Fixed with the v0.3 (#226)

@JonathanSalwan JonathanSalwan modified the milestones: v0.3, v0.4 Jan 26, 2016
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant