forked from KolibriOS/kolibrios
Wolfenstein 3D:
- Freed from the old ksys.h file git-svn-id: svn://kolibrios.org@8695 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
b183b7c32f
commit
50fc6608b2
@ -1,8 +1,124 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include "../../kolibri-libc/source/include/ksys.h"
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
#define asm_inline __asm__ __volatile__
|
||||||
|
|
||||||
|
#pragma pack(push,1)
|
||||||
|
typedef union{
|
||||||
|
unsigned val;
|
||||||
|
struct{
|
||||||
|
short x;
|
||||||
|
short y;
|
||||||
|
};
|
||||||
|
}ksys_pos_t;
|
||||||
|
|
||||||
|
typedef union ksys_oskey_t{
|
||||||
|
unsigned val;
|
||||||
|
struct{
|
||||||
|
unsigned char state;
|
||||||
|
unsigned char code;
|
||||||
|
unsigned char ctrl_key;
|
||||||
|
};
|
||||||
|
}ksys_oskey_t;
|
||||||
|
|
||||||
|
typedef struct{
|
||||||
|
unsigned handle;
|
||||||
|
unsigned io_code;
|
||||||
|
unsigned *input;
|
||||||
|
int inp_size;
|
||||||
|
void *output;
|
||||||
|
int out_size;
|
||||||
|
}ksys_ioctl_t;
|
||||||
|
|
||||||
|
typedef struct{
|
||||||
|
void *data;
|
||||||
|
size_t size;
|
||||||
|
}ksys_ufile_t;
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct{
|
||||||
|
unsigned p00;
|
||||||
|
union{
|
||||||
|
uint64_t p04;
|
||||||
|
struct {
|
||||||
|
unsigned p04dw;
|
||||||
|
unsigned p08dw;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
unsigned p12;
|
||||||
|
union {
|
||||||
|
unsigned p16;
|
||||||
|
const char *new_name;
|
||||||
|
void *bdfe;
|
||||||
|
void *buf16;
|
||||||
|
const void *cbuf16;
|
||||||
|
};
|
||||||
|
char p20;
|
||||||
|
const char *p21;
|
||||||
|
}ksys70_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
int cpu_usage; //+0
|
||||||
|
int window_pos_info; //+4
|
||||||
|
short int reserved1; //+8
|
||||||
|
char name[12]; //+10
|
||||||
|
int memstart; //+22
|
||||||
|
int memused; //+26
|
||||||
|
int pid; //+30
|
||||||
|
int winx_start; //+34
|
||||||
|
int winy_start; //+38
|
||||||
|
int winx_size; //+42
|
||||||
|
int winy_size; //+46
|
||||||
|
short int slot_info; //+50
|
||||||
|
short int reserved2; //+52
|
||||||
|
int clientx; //+54
|
||||||
|
int clienty; //+58
|
||||||
|
int clientwidth; //+62
|
||||||
|
int clientheight; //+66
|
||||||
|
unsigned char window_state;//+70
|
||||||
|
char reserved3[1024-71]; //+71
|
||||||
|
}ksys_proc_table_t;
|
||||||
|
|
||||||
|
#pragma pack(pop)
|
||||||
|
|
||||||
|
static inline
|
||||||
|
int _ksys_process_info(ksys_proc_table_t* table, int pid)
|
||||||
|
{
|
||||||
|
int val;
|
||||||
|
asm_inline(
|
||||||
|
"int $0x40"
|
||||||
|
:"=a"(val)
|
||||||
|
:"a"(9), "b"(table), "c"(pid)
|
||||||
|
:"memory"
|
||||||
|
);
|
||||||
|
return val;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline
|
||||||
|
void _ksys_change_window(int new_x, int new_y, int new_w, int new_h)
|
||||||
|
{
|
||||||
|
asm_inline(
|
||||||
|
"int $0x40"
|
||||||
|
::"a"(67), "b"(new_x), "c"(new_y), "d"(new_w),"S"(new_h)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline
|
||||||
|
ksys_pos_t _ksys_screen_size()
|
||||||
|
{
|
||||||
|
ksys_pos_t size;
|
||||||
|
ksys_pos_t size_tmp;
|
||||||
|
asm_inline(
|
||||||
|
"int $0x40"
|
||||||
|
:"=a"(size_tmp)
|
||||||
|
:"a"(14)
|
||||||
|
);
|
||||||
|
size.x = size_tmp.y;
|
||||||
|
size.y = size_tmp.x;
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
void *memrchr(const void *m, int c, size_t n)
|
void *memrchr(const void *m, int c, size_t n)
|
||||||
{
|
{
|
||||||
const unsigned char *s = (const unsigned char*)m;
|
const unsigned char *s = (const unsigned char*)m;
|
||||||
@ -23,9 +139,19 @@ void kolibri_set_win_center()
|
|||||||
free(info);
|
free(info);
|
||||||
}
|
}
|
||||||
|
|
||||||
int mkdir(const char * path, unsigned)
|
int mkdir(const char *path, unsigned v)
|
||||||
{
|
{
|
||||||
return _ksys_mkdir(path);
|
int status;
|
||||||
|
ksys70_t dir_opt;
|
||||||
|
dir_opt.p00 = 9;
|
||||||
|
dir_opt.p21 = path;
|
||||||
|
asm_inline(
|
||||||
|
"int $0x40"
|
||||||
|
:"=a"(status)
|
||||||
|
:"a"(70), "b"(&dir_opt)
|
||||||
|
:"memory"
|
||||||
|
);
|
||||||
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *dirname (char *path)
|
char *dirname (char *path)
|
||||||
@ -77,5 +203,8 @@ char *dirname (char *path)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void setcwd(char* path){
|
void setcwd(char* path){
|
||||||
_ksys_setcwd(path);
|
asm_inline(
|
||||||
|
"int $0x40"
|
||||||
|
::"a"(30), "b"(1), "c"(path)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user