|
转载:
! t% W) _; E7 e8 }* |0 h来教你如何在vb里嵌入汇编!1 h' {$ }& W; q9 ~* N" e
作者: wl3000wl
* E; T" [8 ]% D1 r6 L) p本贴绝对值得你珍藏.
" g$ i3 p; s _8 A9 p0 V下面的例子完全用VB进行ASM编程的示例,本例获得CPU ID.) F+ H+ f& x" w% V4 h: U
工程文件分为一个form1.frm 和一个模块module1.bas
' @5 k2 F& @! i3 m7 w* D5 x----------------------form1.frm的源文件---------------------# G7 i" `, I; A
VERSION 5.006 W5 k2 ^( u, A& l0 R& K6 z1 T
Begin VB.Form Form1
4 h2 F" ]8 ~' n. o% e8 Z) m Caption = "Form1"
4 A* B2 q8 g g, K" F- H9 K, N ClientHeight = 1965
* c6 e9 k7 `+ Y% k$ \: X/ c ClientLeft = 60; f7 O0 s0 q1 q& y
ClientTop = 345
& J* S; t/ [' @4 l$ X9 t ClientWidth = 3105
4 [* d9 ?4 |7 R+ S LinkTopic = "Form1"
% S/ \2 l! f. c. n7 t2 } ScaleHeight = 19658 T& z$ }2 {4 n1 y( f. h
ScaleWidth = 3105
* W* o' R- u. r# a StartUpPosition = 2 'Bildschirmmitte/ C' i6 F1 w# X
Begin VB.CommandButton Command1
* h$ A+ K2 |1 ^; S3 J: s. v Caption = "Get CPU Name"
5 }* H8 O1 a2 U6 v$ M+ U! z% n: `. P+ t Height = 495
- ~& b5 t3 |, M Left = 840
; d$ O7 b0 w8 ]" n( m; }5 Z$ ?+ _: C" G+ m TabIndex = 0. [, \7 M$ a% I, U
Top = 315
; e# [; i, \; q8 b# S& a Width = 1425
8 b+ H& F0 X0 f End
% N: i+ L# T1 _: ?" l2 C/ r, z Begin VB.Label Label2 9 d( f l I5 b/ g
Alignment = 2 'Zentriert ]% T" Y D8 Y+ X Y) M1 L: k3 u; g
AutoSize = -1 'True
: J' Y) K! \. H( A- ~$ [6 O BeginProperty Font ! e2 F) {! H, n5 S0 f0 a9 l8 R, U
Name = "MS Sans Serif"9 U6 I! ~& O) a' J; f* B- e
Size = 9.75
0 u3 c1 [) j* @: e$ Q) |# L' M1 _2 D Charset = 03 e% x; J& X- \. d* l! ~! V; K! n
Weight = 400
; n$ S3 Q$ W! t1 w9 R Underline = 0 'False
4 a& a) A8 k0 p; m' g2 Z2 _ Italic = 0 'False) B, W+ A$ \. e/ x9 l
Strikethrough = 0 'False
, G! F, Z1 X# Y4 p EndProperty5 S5 @( t( w" }6 J4 k
Height = 2401 k6 r5 P- E. b% z5 F
Left = 1515% A: s6 W* R) z! K. l1 i
TabIndex = 2+ F( A4 l) U0 p: h; c! u$ {- t8 }
Top = 1065. N& p& ?% m0 G# K) I# Z7 o
Width = 60, ~ s" r+ D) n" w
End1 q; E( a8 C/ k4 s6 k
Begin VB.Label Label1
C1 x5 |% e: w0 @; F5 x- @ Alignment = 2 'Zentriert8 V) W" e% q4 x [7 ]" W* L
AutoSize = -1 'True$ ^0 |, O: ~, |
BeginProperty Font . b+ b& T! h5 Y( c) f
Name = "Arial"
- h& |4 U2 @% p x: ^ Size = 12" ~4 @* L; X6 G, F
Charset = 0. r6 [$ Y: E+ `1 {1 H
Weight = 700
0 E, A7 _5 T; Z) A8 ^5 S Underline = 0 'False
0 r K$ q8 k! f Italic = 0 'False
. R$ e% r9 u6 N0 C+ Z$ S6 x! n Strikethrough = 0 'False
- E/ M9 v7 M, A, W' s+ N6 ^# b EndProperty" F4 [! U' Z7 n- [7 J2 I2 A
Height = 285
' j/ z* i& S8 U! ?" ^, G Left = 1515
/ N2 z& e) ?0 J8 s; @" z6 [ TabIndex = 16 O# R, S! x! }/ c/ a# ?
Top = 1350* L+ U3 z2 [# X: D+ G3 E
Width = 75
Q. `% y* w: t z# K End
0 Q6 m) q9 N% nEnd
4 V6 i; T8 v9 F5 A& c0 AAttribute VB_Name = "Form1"
& \- H' f+ j0 z8 ^2 B2 qAttribute VB_GlobalNameSpace = False0 v( u8 a8 F Z- w' G# q. X
Attribute VB_Creatable = False# h8 H, _$ r/ w0 J
Attribute VB_PredeclaredId = True
" x* t7 l/ @/ v/ _4 w0 P' K; o: zAttribute VB_Exposed = False
1 C; k1 @- L( e8 [Option Explicit
9 u7 E* k# V9 ]6 I1 r% z! q9 f. f, ^" h6 t; q1 C: W
Private Sub Command1_MouseDown(Button As Integer, Shift As Integer, x As Single, Y As Single)% F' X0 z1 L* u( X) c
3 N: e) }' F% ^! G0 ]" C: g7 |
Label1 = ""9 F Z7 }& O2 [% ~
Label2 = ""
6 x3 T; ~6 k, p+ D. [7 d2 E1 [: M3 X( J; Z E
End Sub
3 `; S: w* P( r6 U9 M
* h' {& Q" F/ ~. m/ a! bPrivate Sub Command1_Click()8 n) W' y+ a: M+ H
8 c5 V, r* H7 ~! N+ @7 z/ g) T5 S; B Label1 = GetCpuName() & " CPU"
) w+ b8 ]& y. F/ m+ U Label2 = "You have a" & IIf(InStr("AEIOU", Left$(Label1, 1)), "n", ""): t; t4 U+ l# m: W5 f
3 f. @ C2 K& nEnd Sub
3 Y5 A+ h0 k0 m1 z8 d+ v: r: \------------------------------end---------------------------------8 L* n6 q1 _3 z+ r" W+ S$ C' f4 {
?3 |8 D' Z1 g5 r$ p0 l3 a6 g2 e
5 n) R6 q" k/ }8 U7 x* S( l: Y
9 y# f% p! f) ~, k7 V0 w) y# l( C$ e: i5 M. c8 g9 B: e
( }# M7 m. K6 {0 \4 {9 Q; g下面是modu1e.bas的源代码
* ?* b8 w2 W8 u! y$ h9 ~; Q Y! D
----------------------module1.bas的源文件--------------------------' D' W9 h6 S6 C
Option Explicit
: v3 G, P# z6 ^6 E* W" t' @4 x+ B7 k'! e7 V t. P8 A4 @' m
'This shows how to incorporate machine code into VB" J! j G" c. C8 X1 w e8 i2 Z& e
'''''''''''''''''''''''''''''''''''''''''''''''''''. f. _, D1 m1 d9 }2 b: @! N4 C' l
'The example fills the array with a few machine instructions and then copies4 ?& m) n3 W' I
'them to a procedure address. The modified procedure is then called thru
) T. J# J u0 Z; W; P'CallWindowProc. The result of this specific machine code is your CPU Vendor Name.
4 t2 D2 O( Q. p9 m' v, k'
% Z; A- `4 E. f6 U* B: `7 t'##########################################################################" ~( E' Q2 q0 D* E5 @
'Apparently it gets a Stack Pointer Error, but I don't know why; if anybody8 h$ \* c( R' z- Z
'can fix that please let me know... UMGEDV@AOL.COM: G4 t3 w$ A J& o- t& T5 }9 Q7 o) E
'The Error is not present in the native compiled version; so I think it got
/ F/ Z/ E3 A! F+ \4 o0 t' |6 _'something to do with the P-Code Calling Convention (strange though)...0 [1 u! C% U" l' E
'##########################################################################: ~" _$ D2 O) L- X
') u& @& D7 e) a( e; T
'Sub Dummy serves to reserve some space to copy the machine instructions into.
* X( {9 j2 M: h( L. m'
$ ~1 w3 {. g8 W' ~+ T" ?4 d: O'
" G3 }" h) c7 F'Tested on Intel and AMD CPU's (uncompiled and compiled)
5 |2 [, |; D. s: U'( s3 o3 @* m: ~. w) t; c" V: u ~4 s
'0 Q9 x6 E; D+ S: ~8 J
Private Declare Function CallWindowProc Lib "user32" Alias "CallWindowProcA" (ByVal lpPrevWndFunc As Long, ByVal hWnd As Long, ByVal Msg As Long, ByVal wParam As Long, ByVal lParam As Long) As Long. k. {; z( ~% ?! @. L+ T
Private Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (lpvDest As Any, lpvSource As Any, ByVal cbCopy As Long). F7 V+ z. C5 V, i' i2 p
Private x As Long: e. B' W' |* @" V0 N1 Z3 w% Y
3 h, T! T! O0 QPublic Function GetCpuName() As String
3 w) e% u$ {3 b: ?9 r1 [8 `) ]
3 T8 N# t0 _4 d# a Dim MachineCode(0 To 35) As Byte
2 \- `" C1 d( | Dim VarAddr As Long$ k# I/ R3 u1 L; \) G6 I% t* `
Dim FunctAddr As Long
1 T8 S0 \3 {# A3 D1 ~ Dim EAX As Long
% U$ d3 e' D/ K/ Q Dim CPUName(1 To 12) As Byte% y/ e- [# R% a' P* L9 p
' B0 w- {# W0 N1 r% z% s9 X- T4 E$ h 'set up machine code
7 W, w/ X/ Q8 D; [
" X6 _7 I3 F* k5 G: ?( b. m MachineCode(0) = &H55 'push ebp
9 a! e" V8 z8 ~1 J6 }7 F- V # `2 I2 V: A4 A9 N- ]8 }
MachineCode(1) = &H8B 'move ebp,esp
- n* E! T$ t6 w7 i( | MachineCode(2) = &HEC
! {8 x6 X& o' s' h% g4 J) F% I8 g2 b & ^. S( G t, q! @
MachineCode(3) = &H57 'push edi
$ o! _( F4 z* v; m2 y9 m- f6 d4 S . T: I9 X" I0 W
MachineCode(4) = &H52 'push edx6 l+ e& T! {: }; c0 U8 Y1 a3 Z
2 m: D- w% L- X
MachineCode(5) = &H51 'push ecx1 k$ ~+ V. k9 V/ [9 h: S3 ^( h- P
, B6 e5 Q3 g- G# C MachineCode(6) = &H53 'push ebx9 }; w( g+ g8 ^+ A, O# `
7 O: }' x2 j5 `/ D, y( \1 }, W$ p4 ]
MachineCode(7) = &H8B 'move eax,dword ptr [ebp+8]
2 R$ G) `% T ?' l MachineCode(8) = &H45, h: {) e' b& r, ]5 [& n
MachineCode(9) = &H8% }( S$ ~6 K; p* Y9 y, @
6 J* d2 B( Q: q) k MachineCode(10) = &HF 'cpuid5 q) _( z ^. z$ l+ N3 ]
MachineCode(11) = &HA2
3 U& L0 L D+ Y% y; n
! p& O( k7 Z+ w2 G MachineCode(12) = &H8B 'mov edi,dword ptr [ebp+12]+ N* Z9 e. V S6 e" F- A
MachineCode(13) = &H7D
: J) Q! \+ e5 M9 r) ]* @ MachineCode(14) = &HC
0 P' J- [5 r, `; j( \' W
1 z q! X0 `4 h, V$ _5 m MachineCode(15) = &H89 'move dword ptr [edi],ebx$ Z5 _ I' W, @
MachineCode(16) = &H1F
" k$ s; V& S, ^8 F, \ ( X/ r7 z- w% k5 L
MachineCode(17) = &H8B 'mov edi,dword ptr [ebp+16]
. r# B: c" p% L3 q4 y; u" B4 k MachineCode(18) = &H7D
6 I- J, k8 Q+ v. L: v MachineCode(19) = &H101 W& K2 ?$ ?$ x. e
* j( p# h8 x' `- z4 S2 G5 d
MachineCode(20) = &H89 'move dword ptr [edi],ecx* F! g4 i# R2 x2 h0 {$ h/ ]$ F
MachineCode(21) = &HF
5 w0 x. x; W* G6 w
: B5 A' y) C. E* g MachineCode(22) = &H8B 'mov edi,dword ptr [ebp+20]
% ^, E/ {$ M: O0 G: j MachineCode(23) = &H7D3 L1 w/ s6 t' U( {5 k ^5 Y( O/ K! H
MachineCode(24) = &H14, M* E& K0 T/ {6 g: |! v. [
8 M0 \; X3 S6 B MachineCode(25) = &H89 'move dword ptr [edi],edx
' `3 N) J* V. R2 s8 S6 [ MachineCode(26) = &H17$ ^; b9 c5 j5 `2 a) K+ j0 D( |4 k5 n
# z- l! s5 v; I
MachineCode(27) = &H58 'pop ebx7 e' L( b+ x' h: R7 x& j; r$ i
6 y! X' h1 A2 b t; a
MachineCode(28) = &H59 'pop ecx" E' o6 X6 Z. B5 ]5 P5 r2 e: I+ T
/ r2 q; C- V0 x1 N$ r
MachineCode(29) = &H5A 'pop edx
6 g4 y5 B% F! G: A# P3 U5 Z! Z
' u, j$ r W) F$ A/ d# E- A8 S2 h MachineCode(30) = &H55 'pop edi3 Q/ i; L) X; \& @
( r8 \3 `0 ?# C2 F) D! ?% D4 o' R* b
MachineCode(31) = &HC9 'leave
% R1 W N E: `0 W4 e' I; _0 U5 G3 g5 J
MachineCode(32) = &HC2 'ret 16 I tried everything from 0 to 24
) s9 q; u! |+ d. X MachineCode(33) = &H10 ' but all produce the stack error
' Z S% @8 h5 k6 q. e$ e4 A MachineCode(34) = &H0
. m$ t3 {7 }/ y7 V: x6 Q/ _ $ \- @6 G3 a0 ]* \4 x# L
'tell cpuid what we want
! @) g1 g0 c. x% }+ _; { EAX = 0
+ `% p- r) g# h' \4 |/ m + ~4 a5 U* [6 T% I4 d
'get address of Machine Code: N8 z- `- J( O$ w4 {6 E! |9 Z; e
VarAddr = VarPtr(MachineCode(0))
1 l* D$ S: o; D5 a # [) [$ j: H3 ?8 o5 z6 r
'get address of Sub Dummy t! f6 G# k0 [% p3 }
FunctAddr = GetAddress(AddressOf Dummy)
9 O2 h# @( o1 c1 Y5 _4 Q n- T0 Z
9 j( m% D! c" k1 o8 b1 J 'copy the Machine Code to where it can be called4 g9 x" n+ X w" F2 ]2 D' D
CopyMemory ByVal FunctAddr, ByVal VarAddr, 35 '35 bytes machine code
& |3 y: U4 f6 j" U8 r: c( B8 c5 J7 h
; ~, e* `0 ~; U& @# N2 z* b* ~ 'call it+ H {6 l; E, Q% a: G7 o
On Error Resume Next 'apparently it gets a stack pointer error when in P-Code but i dont know why
# F6 E: F7 [ J9 @' } CallWindowProc FunctAddr, EAX, VarPtr(CPUName(1)), VarPtr(CPUName(9)), VarPtr(CPUName(5))
+ }4 `0 S( x! Q$ x 'Debug.Print Err; Err.Description: }, Q6 T) t" g. F
'MsgBox Err & Err.Description
* i% t' A s* M: z0 g4 j On Error GoTo 03 u# m$ _& Q+ M- u4 e4 X) ^1 G
* _$ m1 ]0 b: S; _
GetCpuName = StrConv(CPUName(), vbUnicode) 'UnicodeName8 S0 j2 n& i9 S K$ f; i
- T$ l' {6 r5 O8 g( w/ a |% u) k
End Function
: {4 D- G, k; m- [/ f; |# _: Z/ x; D8 y2 L S/ y% o; p
Private Function GetAddress(Address As Long) As Long
0 {3 d, M: d: R, U3 Z
6 W) K& W8 f: l/ k GetAddress = Address
# T* _, E \, O
: _7 c9 K7 [2 K7 {$ J0 c7 N! BEnd Function
1 a% q( m" J0 g9 v; G0 y* o5 w1 J* k
& w. y, b# t2 e( y' J3 n& H1 iPrivate Sub Dummy(): d3 E( X; |. r; n+ ~: ?
% K9 G2 e- W2 l3 u 'the code below just reserves some space to copy the machine code into
/ K5 v2 O7 ?$ L$ ~ 'it is never executed" V" |# W# I+ ~: f0 ^- W
; y) X4 Z p' Y1 J+ ~
x = 0
8 E% k% {- a1 i! \ x = 1! l. W. ~! A3 K
x = 2% t+ N- }* n+ L Q R+ E9 l
x = 3
& c; l6 o: H" ?0 _ x = 4& |/ o& w) a2 v. X. y
x = 5) m- j- q- N+ U, A# A
x = 6, c+ V/ \, o% B' _" y v2 d- }' Q+ i5 f
x = 77 X; b8 r# U- `5 K- v: v% ?
x = 8
. @: Y- ?2 m3 Z6 J) N; o; ^ x = 9
: c& r A; ]( U, v& W x = 10
4 ?- e0 I, k. D y; `1 W x = 0
) n% V! r ~4 `+ O x = 1
6 j" A" g$ l% \ x = 2
# T9 m; Q) }1 }$ q x = 3. i* y9 N$ V7 H7 d8 F9 Q
x = 43 L" L* s, O! ]
x = 5
- n% H% J; P7 n. ^ x = 66 K& ^. k2 W1 r# `) S
x = 7
; p$ C8 @* P. a) e8 o x = 8, o$ o# z. h; I9 }
x = 9+ W, v3 m6 Y) Y6 k; _
x = 102 w6 u4 f: C$ }/ _: G
( x% e/ C2 b. o
End Sub
@9 Z' X! d4 m$ D- t% Q------------------------------end--------------------------------------- W% }1 K! J# V0 I, X
* f3 e: T" U4 s" a6 X& d ; x2 Y% m1 d9 J3 A
; x4 u0 i6 Y! U9 ` C! h7 y
|
|