Pages:
1
2 |
dom cook
Div Pro
Posts: 387
Registered: 4-3-2016
Member Is Offline
|
|
Tutorial?
Hey Mike,
Is there any chance of a tutorial on how to put together and use one of these DLL things?
My understanding of how it all works under the hood is zero and, to be honest, I'm seriously daunted at the thought of trying to figure it out myself
so it would be great if you could make a basic walk-through with respect to getting things up and running,
I'd definitely like to start contributing more both with DLLs and the source code itself.
|
|
MikeDX
|
|
DLLs are fairly straightforward regarding the compilation.
It's easy to compile the examples especially on Linux.
Clone the div source tree (not actually necessary as the dll code is seperate)
In tools there is a makedll.bat you can use to compile an example e.g.
tools/makedll.bat dll/hboy.c hboy.so
Should create a hboy.so "dll" which will autoload on any div program being run
Please forgive the accuracy of this info, I'm replying from my phone and going mostly on memory.
The examples are definitely the place to start but if you have specific questions I'm happy to help.
Also creating DLLs is definitely a "way in" to contributing to the main div codebase as quite a few functions started off as plugins and got
integrated into the main codebase (network, mode8)
|
|
tvault
DIV Newbie
Posts: 3
Registered: 18-12-2016
Member Is Offline
|
|
Hi, I used DIV many years ago and decided to get back onboard as I always enjoyed using it.
If you're interested I found my copy of DIV and installed it using DOSbox, found a nice tutorial
from Daniel Navarro Medrano.
I hope this is useful to you:
Code: |
DIV Games Studio - Dinamic Link Libraries
ÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ
This document shows you all the needed information to build your own DLL's for
DIV Games Studio
- "What is a DLL?"
A DLL (Dynamic Link Library) is a piece of code of a program that can be
merged with another program in execution time, which contains functions or
procedures that can be used on the program.
- ¨What are DLL's for?"
DLL's are useful to extend the programming language capabilities of DIV, so
you can modify partially the way they work. These allow you to implement pieces
of code in the C language, to be used or called from within DIV.
- ¨Types of DLL's"
Basically, there are three types of DLL's that can be built for DIV. The
first ones are screen savers, the second are autoloading and the
third ones add new functions to the language.
General Instructions.
ÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ
This is procedure only recommended for EXPERT programmers on C language, who
own the "WATCOM C++ Compiler". Other compilers are available, of course, but
since we haven't tried them for this purpose, we cannot guarantee that they
will work...
First thing to do is add the following text to the WLSYSTEM.LNK file of
Watcom (which can be found on the BINB\ directory of that compiler).
system begin div_dll
option osname='DIV DLL'
libpath %WATCOM%\lib386
libpath %WATCOM%\lib386\dos
format windows nt dll ^
end
The format of the code used is the one of the Windows NT DLL's, and this is the
way you inform Watcom to generate this kind of code.
After this, you should include the header file named DIV.H, which is included
on this directory. On this header file are the defined variables and basic
functions with which you can use. In addition, this file contains a set
of "#define" instructions, accessing the internal variables of DIV32RUN,
which is the module that has all the internal functions and routines of
DIV Games Studio.
Several examples are included, the most basic being:
DEMO0.CPP - Basic example of a screensaver with DIV's games.
DEMO1.CPP - Basic example of an autoload DLL.
DEMO2.CPP - Basic example of DLL functions.
You may use the batch file named MAKE.BAT to compile these DLL's (if you own
Watcom C++ for DOS) which, if no error is found, generates the corresponding
DLL (with the same name).
Basic rules.
ÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ
DLL's must be created in standard C, and they must respect several rules. For
example:
- The "div.h" header must be included on the main module, so the following
definition must be done:
#define GLOBALS
before including the header (#include "div.h"), variables types and basic
structures can be defined, this is for when you build DLL's with several
CPP sources).
- It is not possible to use the functions malloc(), free(), fopen() or fclose()
so you must instead use div_malloc(), div_free(), div_fopen() and div_fclose().
These functions behave exactly the same way than the ones used on C.
- You must always define two functions for the begin and end of the DLL, which
are:
void __export divmain(COMMON_PARAMS) {
GLOBAL_IMPORT();
// Begin of DLL
}
void __export divend(COMMON_PARAMS) {
// End of DLL
}
- Besides functions exported by DIV, you may use most standard C functions,
including its headers.
¨How are DLL's used on the language?"
ÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ
DLL's are divided on two types: normals and autoload.
To use normals, you must indicate on a game the following sentence:
IMPORT "directory\name.dll";
Just after the LOCAL declarations of the main program. You cannot use DLL's from
other languages.
Autoload can be used the same way, or just by copying them into the directory of
the game. They will activate automatically.
For example, if the DEMO0.DLL (the example screen saver) is copied on the
directory of the game made with DIV, this will activate automatically every
time the game is executed. To activate this DLL's while the game is executed
within DIV's environment, you must copy them to the directory where the D.EXE
(the main executable file of DIV) file is placed.
Screen savers (look at demo0.cpp)
ÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ
You may define the following functions in a DLL.
ss_init() - To initialize the screen saver (every time it is executed).
ss_frame() - To make operations over the video buffer, before it is dumped.
ss_end() - To terminate the screen saver.
You have as well, the following available variables:
ss_time - To indicate the period of time after which the screen saver will
execute, on hundreds of a second (default is 3000, which is every
30 seconds).
ss_status - To activate and deactivate the screen saver (0-Inactive/1-Active)
ss_exit - It must be set to 1 on ss_frame() to terminate the screen
saver (the system will set it to 1 when the keyboard, the mouse or
the joystick is activated).
A screen saver is included on the SS1.CPP file, which is a little bit more
complex than the DEMO0.CPP. This simulates a sand picture.
Autoload DLL (look at demo1.cpp)
ÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ
These DLL's are generally used to substitute some of the internal functions
of DIV for another ones. The functions that can be defined are explained on the
DIV.H file (under the "DIV standard Entry-Points" header).
For a DLL to autoload, you must include the following sentence within the
div_main() function:
Autoload();
Two autoload DLL's are included as examples:
WATER.CPP - Simulates a water effect on the bottom of the screen
HBOY.CPP - Try it with any DIV game!... you will see...
DLL of functions (look at demo2.cpp)
ÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ
It is easy to add new functions to the language:
First, you must create the new function on the DLL, which must read its
calling parameters with getparm() (who always returns an int), and at
termination, a value must ALWAYS be returned with retval() (look at demo2.cpp).
After, you must define the function on the DLL:
void __export divlibrary(LIBRARY_PARAMS) { }
and within this, you must make a call to COM_export() for each function that
is added to the language.
COM_export() receives three parameters. The first one is the name that the
function will have, the pointer to that function, and the number of parameters
of the call.
In the programs created with DIV, after making the IMPORT of the DLL, you may
directly use these functions.
¨What can be done?"
ÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ
If you take a look at DIV.H, you will find many things to which you may access
from a DLL, you may create programs that modify variables of the process, that
substitute video routines, or that apply effects in windows, etc...
If you succeed to create a functional DLL, you are free to distribute it as
Shareware or on any other format, even Freeware... which will be best! :)
In any case, we will thank you, if you inform us, through the www.div-arena.com
web site, about your personal success with DIV ;)
We will also thank you any suggestion about DIV Games Studio, and much more if
those suggestions are original and useful. Don't waste your time on asking us
for sound modules, for 3D, or true colour....- we are already working on it!.
Thanks for trying!
Daniel Navarro Medrano
Main programmer of DIV Games Studio
and from
FastTrak Software Publishing
|
|
|
dom cook
Div Pro
Posts: 387
Registered: 4-3-2016
Member Is Offline
|
|
Hey Tvault, this is interesting. Thanks for posting.
|
|
dom cook
Div Pro
Posts: 387
Registered: 4-3-2016
Member Is Offline
|
|
Hi Mike
Just a quick question. I've just downloaded the source code and have started looking into this DLL business. I'm confused about the makedll file.
In the tools folder there's a makedll.sh but not a makedll.bat as you stated is that the same thing?
|
|
MikeDX
|
|
Yeah i was sure I'd named it .bat but it is the .sh file
Should work fairly easily
Let me know if you need any help
|
|
dom cook
Div Pro
Posts: 387
Registered: 4-3-2016
Member Is Offline
|
|
Quote: Originally posted by MikeDX | Yeah i was sure I'd named it .bat but it is the .sh file
Should work fairly easily
Let me know if you need any help |
I NEED HELP
I tried this:
tools/makedll.sh dll/hboy.c hboy.so
but got errors referring to the spectrum and sdlgfx folders in the dll one
|
|
MikeDX
|
|
edit the last line in the file and change it to:
Code: |
gcc $1 -o $2 -funsigned-char -shared -I./dll/ `sdl-config --cflags --libs` -ggdb3 -O3 -fPIC
|
It had been hardcoded to use my working directory and for zxspectrum dll / sdlgfx, neither of which you really need.
|
|
dom cook
Div Pro
Posts: 387
Registered: 4-3-2016
Member Is Offline
|
|
well that got rid of that problem but I can't see a .so file, Help!
|
|
MikeDX
|
|
interesting
if you run the command manually what do you get
Code: |
gcc dll/hboy.c -o hboy.so -funsigned-char -shared -I./dll/ `sdl-config --cflags --libs` -ggdb3 -O3 -fPIC
ls *.so
|
any errors or warnings or anything?
|
|
dom cook
Div Pro
Posts: 387
Registered: 4-3-2016
Member Is Offline
|
|
/Desktop/DIV2015$ gcc dll/hboy.c -o hboy.so -funsigned-char -shared -I./dll/ `sdl-config --cflags --libs` -ggdb3 -O3 -fPIC
dll/hboy.c: In function ‘set_video_mode’:
dll/hboy.c:512:32: warning: passing argument 2 of ‘SDL_SetVideoMode’ makes pointer from integer without a cast [-Wint-conversion]
screen = SDL_SetVideoMode(320,200,8,0);
^
In file included from /usr/include/SDL/SDL_mouse.h:32:0,
from /usr/include/SDL/SDL_events.h:35,
from /usr/include/SDL/SDL.h:37,
from dll/hboy.c:8:
/usr/include/SDL/SDL_video.h:384:39: note: expected ‘int *’ but argument is of type ‘int’
extern DECLSPEC SDL_Surface * SDLCALL SDL_SetVideoMode
^
dll/hboy.c: In function ‘divmain’:
dll/hboy.c:697:29: warning: passing argument 2 of ‘SDL_SetVideoMode’ makes pointer from integer without a cast [-Wint-conversion]
screen=SDL_SetVideoMode(320,200,8,0);
^
In file included from /usr/include/SDL/SDL_mouse.h:32:0,
from /usr/include/SDL/SDL_events.h:35,
from /usr/include/SDL/SDL.h:37,
from dll/hboy.c:8:
/usr/include/SDL/SDL_video.h:384:39: note: expected ‘int *’ but argument is of type ‘int’
extern DECLSPEC SDL_Surface * SDLCALL SDL_SetVideoMode
|
|
MikeDX
|
|
That looks fine to me
try it with errors ignored:
Code: |
gcc dll/hboy.c -o hboy.so -w -funsigned-char -shared -I./dll/ `sdl-config --cflags --libs` -ggdb3 -O3 -fPIC
|
|
|
dom cook
Div Pro
Posts: 387
Registered: 4-3-2016
Member Is Offline
|
|
Hang on! the .so is there, it's in the parent folder. Sorry about that.
Where should it be placed in order to by included in a running prg?
|
|
dom cook
Div Pro
Posts: 387
Registered: 4-3-2016
Member Is Offline
|
|
Ok. Forget the last question. I managed to figure it out all on my own.
So It looks like everything is working now, Thanks for the help.
By the way how do you post code into a nifty little sub window in these forums (like you just did)?
|
|
dom cook
Div Pro
Posts: 387
Registered: 4-3-2016
Member Is Offline
|
|
And while I'm being a pain in the neck, do you think could you point me in the direction of the part of the source code which deals with mode 7? I'm
interested to see the exact way DIV calculates the screen projections.
[Edited on 21-12-2016 by dom cook]
|
|
MikeDX
|
|
Dom you know full well I am happy for you to be a pain in the neck
some DLLs are "autoload" which means they will automatically be picked up by DIV, this means put them in the same folder as your prg (or d.exe /
d-LINUX / d-OSX etc). hboy is an example of such a dll.
to post code in a mini window use the code tags
e.g.
[code]
your code here
[/code]
I'm unsure about the mode7 in DIV, let me find that for you.
[Edited on 21-12-2016 by MikeDX]
|
|
MikeDX
|
|
The Mode7 function is called 'pinta_m7' and is located in src/runtime/s.c
|
|
dom cook
Div Pro
Posts: 387
Registered: 4-3-2016
Member Is Offline
|
|
Thanks dood. and merry Christmas
|
|
dom cook
Div Pro
Posts: 387
Registered: 4-3-2016
Member Is Offline
|
|
I've think I've found a bug in mode 7 now
The x coordinate of the vanishing point in a screen region ought to be the midpoint in x of the region. This the case for mode7 objects but not for
the plane that's declared in the start_mode 7 function. Instead it looks like it's using the midpoint (in x) of the whole screen.
|
|
MikeDX
|
|
Interesting
I think you can prove or disprove this by making 4 mode 7 regions on a single screen with identical initial views.
|
|
dom cook
Div Pro
Posts: 387
Registered: 4-3-2016
Member Is Offline
|
|
Here's what I meant, although it seems I had it the wrong way round. It's the objects that focus on the centre of the screen.
This example should draw the object at point 0,0 on each of the m7 planes. (being the top-left corner)
By rotating the camera (keys _a, _d) you can see that it's being draw as if it lay on planes that were centred in x around the screen centre.
Attachment: m7bug.PRG (2kB) This file has been downloaded 1877 times
|
|
dom cook
Div Pro
Posts: 387
Registered: 4-3-2016
Member Is Offline
|
|
It's only taken me two and a half years but I think I've found this little bug.
It's in the source code so I'm not in a position to fix it but now that you're making more time for DIV Mike, I thought I'd prevail upon you to take a
look. Or Cictec if you're out there.
I might be wrong as I speak neither spanish nor C, but I think the problem is with Line 3057 here: https://github.com/MikeDX/DIV-Games-Studio/blob/master/src/r...
(3057) anchura = vga_an / 2 + (factor * distmax) / (max * 16);
As far as I can tell anchura is passed to the screen x coordinate of the M7 process.
vga_an looks like it refers to the size of a scan line. if that is the case then vga_an /2 is the middle of the screen in the x
direction. In cases where mode 7 is drawn to a region whose centre in x is not the middle of the screen this will be the wrong value. The correct
one being the x value for the middle of the mode 7 region.
Of course, this is admittedly all guess work and I realise that I might well be completely wrong but it at least corresponds with the error as
illustrated in the above example.
Anyway, If one of you boys could take a look, I'd be much obliged.
[Edited on 11-5-2019 by dom cook]
|
|
CicTec
DIV Pro
Posts: 471
Registered: 6-8-2016
Member Is Offline
|
|
Hi dom cook,
The line of the source code you are analyzing refers to the function that takes care of rendering mode7 processes (belonging to all mode7 windows) on
the screen.
vga_an is a variable that stores the width of the game resolution set with SET_MODE, for example if you set the resolution to 640x480, vga_an will be
640 and vga_al will be 480 and so on, then 640/2 = 320 which represents the center of the resolution of the game.
it would be useful to mount a small example that shows the bug that you think exists.
[Edited on 11-5-2019 by CicTec]
|
|
dom cook
Div Pro
Posts: 387
Registered: 4-3-2016
Member Is Offline
|
|
I already did that. Look at the m7bug code 3 posts up from here.
It draws 4 mode7 views in 4 separate screen regions in a typical 4-way split-screen format.
If you rotate the views, using keys _A and _D you will see two red markers rotating around the centre of the screen.
These markers are actually the same mode 7 process drawn in the 4 separate views so we should be seeing 4 of them. Given that the coordinates of this
process are 0,0 (Which corresponds to the top left corner of the mode 7 plane you can see that while the y coordinates are translated correctly, the x
coordinates, are being translated as if the x_centres of all the m7 regions are always the x_centre of the screen.
So yes, in all likelihood vga_an is the culprit here. We need something that relates to individual screen regions. I don't know
what that is going to be. However it's probably worth noting that, given that the y coordinate is being translated correctly, there might be a clue
in the lines of code which deal with the corresponding altura variable.
Here is some pertinent code. (3045-3048)
Code: |
h = (m7 + n)->height - mem[ide + _Height];
altura = (h * (max - factor)) / (max); // in pix/4
altura = im7[n].y + im7[n].al / 2 + (h - altura) / 4; // in pix
altura += (m7 + n)->horizon - im7[n].al / 2;
|
I'm thinking that the variable n is probably the m7 number. Notably, there is no reference to this in the line which calculates the x
coordinate.
Any ideas?
My best guess is that there's a variable out there called im7[n].an and subsituting it for vga_an in the alledged
offending line might just help solve the problem. This would account for the width of the region, to account for its start position we might try
im7[n].x
(we can already see that there is an im7[n].y)
My suggested correction would be this:
anchura = im7[n].x + im7[n].an/2 + (factor * distmax) / (max * 16);
[Edited on 11-5-2019 by dom cook]
|
|
CicTec
DIV Pro
Posts: 471
Registered: 6-8-2016
Member Is Offline
|
|
Quote: Originally posted by dom cook | I already did that. Look at the m7bug code 3 posts up from here.
It draws 4 mode7 views in 4 separate screen regions in a typical 4-way split-screen format.
If you rotate the views, using keys _A and _D you will see two red markers rotating around the centre of the screen.
These markers are actually the same mode 7 process drawn in the 4 separate views so we should be seeing 4 of them. Given that the coordinates of this
process are 0,0 (Which corresponds to the top left corner of the mode 7 plane you can see that while the y coordinates are translated correctly, the x
coordinates, are being translated as if the x_centres of all the m7 regions are always the x_centre of the screen.
|
Please post this example to be able to try and verify the actual presence of bugs
Quote: Originally posted by dom cook |
So yes, in all likelihood vga_an is the culprit here. We need something that relates to individual screen regions. I don't know
what that is going to be. However it's probably worth noting that, given that the y coordinate is being translated correctly, there might be a clue
in the lines of code which deal with the corresponding altura variable.
|
Based on the example above (to be tested with the real example), the culprit of the bug could be vga_an
Quote: Originally posted by dom cook |
Here is some pertinent code. (3045-3048)
Code: |
h = (m7 + n)->height - mem[ide + _Height];
altura = (h * (max - factor)) / (max); // in pix/4
altura = im7[n].y + im7[n].al / 2 + (h - altura) / 4; // in pix
altura += (m7 + n)->horizon - im7[n].al / 2;
|
I'm thinking that the variable n is probably the m7 number. Notably, there is no reference to this in the line which calculates the x
coordinate.
Any ideas?
|
Yes, N is the variable that represents the mode7 number (of the window)
Quote: Originally posted by dom cook |
My best guess is that there's a variable out there called im7[n].an and subsituting it for vga_an in the alledged
offending line might just help solve the problem. This would account for the width of the region, to account for its start position we might try
im7[n].x
(we can already see that there is an im7[n].y)
My suggested correction would be this:
anchura = im7[n].x + im7[n].an/2 + (factor * distmax) / (max * 16);
[Edited on 11-5-2019 by dom cook] |
The im7 structure is an internal structure that stores data when a request is made to create mode7 using the START_MODE7 function.
X y Y represent the coordinates where it starts on the screen (physical resolution chosen for the game) of the mode7 window.
AN y AL represent the widh y the height of the mode7 window, these 2 variables are updated based on what you pass in the "region" parameter of the
START_MODE7 function, if you pass 0, they represent the width and height of the resolution (vga_an y vga_al), otherwise the width and the height of
the region (for example we pass a region 1 previously defined with DEFINE_REGION of 300x300).
Based on what you have indicated, the modification of the code could be correct, please publish the example so as to be able to prove the result.
|
|
Pages:
1
2 |