Fix gcc version of backy and add to autobuild

git-svn-id: svn://kolibrios.org@8467 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
maxcodehack 2020-12-22 19:49:57 +00:00
parent b7804a951e
commit e3201d94c3
6 changed files with 70 additions and 169 deletions

View File

@ -1,104 +0,0 @@
/*
* Backy_lib.h
* Author: JohnXenox aka Aleksandr Igorevich.
*/
#ifndef __jxl_Date_get_h__
#define __jxl_Date_get_h__
#ifdef ___TINY_C___
typedef unsigned int uint32_t;
typedef unsigned char uint8_t;
typedef unsigned short int uint16_t;
typedef unsigned long long uint64_t;
typedef char int8_t;
typedef short int int16_t;
typedef int int32_t;
typedef long long int64_t;
static inline int32_t saveFile(uint32_t nbytes, uint8_t *data, uint32_t enc, uint8_t *path)
{
int32_t val;
uint8_t dt[28]; // basic information structure.
(uint32_t) dt[0] = 2; // subfunction number.
(uint32_t) dt[4] = 0; // reserved.
(uint32_t) dt[8] = 0; // reserved.
(uint32_t) dt[12] = nbytes; // number of bytes to write.
(uint8_t *) dt[16] = data; // pointer to data.
(uint32_t) dt[20] = enc; // string encoding (0 = default, 1 = cp866, 2 = UTF-16LE, 3 = UTF-8).
(uint8_t *) dt[24] = path; // pointer to path.
__asm__ __volatile__("int $0x40":"=a"(val):"a"(80), "b"(&dt));
return val;
}
#else
#include <stdint.h>
static inline int32_t saveFile(uint32_t nbytes, uint8_t *data, uint32_t enc, uint8_t *path)
{
int32_t val;
struct file_op_t
{
uint32_t fn;
uint32_t reserved0;
uint32_t reserved1;
uint32_t number_of_bytes_to_write;
void * pointer_to_data;
char path[1];
} *file_op = calloc(sizeof(*file_op) + strlen(path) + 2, 1); // FIXME: Not works on UTF16LE enc
file_op->fn = 2;
file_op->number_of_bytes_to_write = nbytes;
file_op->pointer_to_data = data;
if (enc != 0)
{
file_op->path[0] = enc;
strcpy(file_op->path + 1, path);
}
else
{
strcpy(file_op->path, path);
}
asm volatile ("int $0x40":"=a"(val):"a"(80), "b"(file_op));
return val;
}
#endif
static inline uint32_t getDate(void)
{
uint32_t date;
__asm__ __volatile__("int $0x40":"=a"(date):"a"(29));
return date;
}
static inline uint32_t getTime(void)
{
uint32_t time;
__asm__ __volatile__("int $0x40":"=a"(time):"a"(3));
return time;
}
static inline void *openFile(uint32_t *length, const uint8_t *path)
{
uint8_t *fd;
__asm__ __volatile__ ("int $0x40":"=a"(fd), "=d"(*length):"a" (68), "b"(27),"c"(path));
return fd;
}
#endif

View File

@ -9,38 +9,6 @@
* Works from command line, only! * Works from command line, only!
*/ */
// Copied from TCC
char* strrev(char *p)
{
char *q = p, *res = p, z;
while(q && *q) ++q; /* find eos */
for(--q; p < q; ++p, --q)
{
z = *p;
*p = *q;
*q = z;
}
return res;
}
char* itoab(unsigned int n, char* s, int b)
{
char *ptr;
int lowbit;
ptr = s;
b >>= 1;
do {
lowbit = n & 1;
n = (n >> 1) & 0x7FFFFFFF;
*ptr = ((n % b) << 1) + lowbit;
if(*ptr < 10) *ptr += '0'; else *ptr += 55;
++ptr;
} while(n /= b);
*ptr = 0;
return strrev(s);
}
#define CREATION_DATE "2020.05.27" #define CREATION_DATE "2020.05.27"
#include <stdlib.h> #include <stdlib.h>
@ -48,7 +16,6 @@ char* itoab(unsigned int n, char* s, int b)
#include <string.h> #include <string.h>
#include "console_obj.h" #include "console_obj.h"
#include "Backy_lang.h"
#include "Backy_lib.h" #include "Backy_lib.h"
int date = 0; int date = 0;
@ -421,6 +388,7 @@ int main(int argc, char** argv)
return 13; return 13;
} }
return checkStateOnSave(saveFile(length, data, 0, path_out));
saveFile(length, data, 0, path_out);//return checkStateOnSave(saveFile(length, data, 0, path_out));
} }

View File

@ -6,6 +6,37 @@
#ifndef __Backy_lib_h__ #ifndef __Backy_lib_h__
#define __Backy_lib_h__ #define __Backy_lib_h__
// Copied from TCC
char* strrev(char *p)
{
char *q = p, *res = p, z;
while(q && *q) ++q; /* find eos */
for(--q; p < q; ++p, --q)
{
z = *p;
*p = *q;
*q = z;
}
return res;
}
char* itoab(unsigned int n, char* s, int b)
{
char *ptr;
int lowbit;
ptr = s;
b >>= 1;
do {
lowbit = n & 1;
n = (n >> 1) & 0x7FFFFFFF;
*ptr = ((n % b) << 1) + lowbit;
if(*ptr < 10) *ptr += '0'; else *ptr += 55;
++ptr;
} while(n /= b);
*ptr = 0;
return strrev(s);
}
/* /*
typedef unsigned int uint32_t; typedef unsigned int uint32_t;
typedef unsigned char uint8_t; typedef unsigned char uint8_t;
@ -43,37 +74,34 @@ static inline void *openFile(uint32_t *length, const uint8_t *path)
return fd; return fd;
} }
// FILE SAVING NOT WORKING struct saveFileStruct
/*
struct saveFile__
{ {
int num; int p1;
int res_; int p2;
int res; int p3;
int nbyte; int p4;
char* data_; char* p5;
int enc_; int p6;
char* path_; char* p7;
}; };
*/
static inline int32_t saveFile(uint32_t nbytes, uint8_t *data, uint32_t enc, uint8_t *path) static inline int32_t saveFile(uint32_t nbytes, uint8_t *data, uint32_t enc, uint8_t *path)
{ {
int32_t val; int32_t val;
/*
struct saveFile__ dt;
//uint8_t dt[28]; // basic information structure.
dt.num = 2; // subfunction number. struct saveFileStruct dt; // basic information structure.
dt.res_= 0; // reserved.
dt.res = 0; // reserved. dt.p1 = 2; // subfunction number.
dt.nbyte = nbytes; // number of bytes to write. dt.p2= 0; // reserved.
dt.data_ = data; // pointer to data. dt.p3 = 0; // reserved.
dt.enc_ = enc; // string encoding (0 = default, 1 = cp866, 2 = UTF-16LE, 3 = UTF-8). dt.p4 = nbytes; // number of bytes to write.
dt.path_ = path; // pointer to path. dt.p5 = data; // pointer to data.
dt.p6 = enc; // string encoding (0 = default, 1 = cp866, 2 = UTF-16LE, 3 = UTF-8).
dt.p7 = path; // pointer to path.
__asm__ __volatile__("int $0x40":"=a"(val):"a"(80), "b"(&dt):"memory");
__asm__ __volatile__("int $0x40":"=a"(val):"a"(80), "b"(&dt));
*/
return val; return val;
} }

View File

@ -9,19 +9,17 @@ CFLAGS = -c -fno-ident -O2 -fomit-frame-pointer -fno-ident -U__WIN32__ -U_Win32
INCLUDES = -I $(SDK_DIR)/sources/newlib/libc/include INCLUDES = -I $(SDK_DIR)/sources/newlib/libc/include
LIBPATH = -L $(SDK_DIR)/lib -L /home/autobuild/tools/win32/mingw32/lib LIBPATH = -L $(SDK_DIR)/lib -L /home/autobuild/tools/win32/mingw32/lib
ifndef LANG_backy ifndef LANG_
LANG_backy = lang_en LANG_ = lang_en
endif endif
default: backy default: backy
backy: $(OBJECTS) Makefile backy: $(OBJECTS) Makefile
echo "#define $(LANG_backy)" > Backy_lang.h $(CC) $(CFLAGS) $(INCLUDES) -D$(LANG_) -o Backy.o Backy.c
$(CC) $(CFLAGS) $(INCLUDES) -o Backy.o Backy.c
$(LD) $(LDFLAGS) $(LIBPATH) --subsystem console -o Backy Backy.o -lgcc -lc.dll $(LD) $(LDFLAGS) $(LIBPATH) --subsystem console -o Backy Backy.o -lgcc -lc.dll
kos32-strip -s Backy -o Backy kos32-strip -s Backy -o Backy
objcopy Backy -O binary objcopy Backy -O binary
rm Backy.o rm Backy.o
rm Backy_lang.h
clean: clean:
rm Backy rm Backy

View File

@ -0,0 +1,12 @@
if tup.getconfig("NO_GCC") ~= "" then return end
HELPERDIR = (tup.getconfig("HELPERDIR") == "") and "../../.." or tup.getconfig("HELPERDIR")
tup.include(HELPERDIR .. "/use_gcc.lua")
tup.include(HELPERDIR .. "/use_newlib.lua")
if tup.getconfig("LANG") == "ru"
then CFLAGS = CFLAGS .. " -Dlang_ru"
else CFLAGS = CFLAGS .. " -Dlang_en"
end
compile_gcc{"backy.c"}
link_gcc("backy")

View File

@ -1,7 +1,6 @@
Port backy to gcc Port backy to gcc
Files not working yet
Languages: Languages:
Eng: Eng:
make make
Rus: Rus:
env LANG_backy=lang_ru make env LANG_=lang_ru make