This repository has been archived by the owner on Apr 2, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1
/
realhw.txt
96 lines (69 loc) · 5.1 KB
/
realhw.txt
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
Notes to make games run on real hardware
--------------------
Emulators are often inaccurate or can't emulate some quirk of the real
hardware easily. This is a list of what you mustn't do and what you
should do in order to fix the problem.
Some quirks might even be present only on some revisions of the PlayStation
hardware, but the goal is that something has to run on every revision, and so
one has to respect all the tips, regardless of model.
So if you want to add something to the list, also specify the model it happens
on.
ALL MODELS:
The most noticeable quirk is that the GPU in emulators finishes to draw instantly,
while on the real hardware the GPU has its own speed and so you must wait for
it to finish drawing. The result of this is that on the emulator your program will
run just fine, while on the real hardware the graphics will be entirely scrambled
The way to fix this is to add
while(GsIsDrawing());
after calls like GsDrawList(), LoadImage(), MoveImage(), etc.
This ensures that your program will first check if the GPU has finished drawing
before doing anything else.
Why doesn't the SDK do this automatically? It is designed more or less to do what
you want to do. If you want to somewhat exploit this quirk to make something nice,
you can.
********************************************************************
Controller vibration (pad_enable_vibration() and pad_set_vibration() )
On controllers which are not DualShock vibration will not work. This is taken for granted.
If you enabled vibration, and set vibration values, you unplug your controller and you plug it again,
there will be no vibration as vibration data is not kept by the console and then sent to the controller,
but it is sent by the console and kept by the controller. Thus when the controller is detached it loses
its memory about vibration.
A way to work around this is enabling vibration before using pad_set_vibration().
Another way to work around this would be detecting when the pad is detached and when it is plugged
again, and if it's plugged again enable vibration and set it at its past values
(you can check pad type, 0xFF = no pad, 0x41 = normal pad, etc.)
The second solution is the best one but the first is much simpler.
For pad_set_vibration() the second argument is the level of vibration for the small motors,
and the third argument is the level of vibration for the big motors.
The small motors always seem to vibrate with the same strength.
To enable them, set their vibration level to 0xFF. To disable them, set their level to 0.
This does not seem to happen on every controller, but on my no-name third party controller,
the small motors vibrated when their vibration level AND'ed with 1 was 1, thus also when their
vibration level was not necessarily 0xFF. But stick to 0xFF and 0 to be sure.
The big motors have a regulable strength.
The minimum vibration level to make the big motors vibrate on most controllers seems to be 0x40,
although on mine the big motors started to vibrate starting from 0x20.
Small values will be barely noticeable, so it is better to use a value which is higher than 0xA0
to make the player feel the vibration.
********************************************************************
SsKeyOn() and SsKeyOff() must not have multiple calls in a very small amount of time or the
hardware won't register the changes and will start playing or stop the voice it happens to start playing or stop,
and not all the voices you wanted it to. You have to use SsKeyOnMask() or SsKeyOffMask() instead.
For example, you want to start playing voices #0, #1, #2 and #3 at the same time.
DO NOT do:
SsKeyOn(0); SsKeyOn(1); SsKeyOn(2); SsKeyOn(3);
But DO:
SsKeyOnMask((1<<0) | (1<<1) | (1<<2)|(1<<3));
Likewise, if you want to stop voices #0, #1, #2, and #3 at the same time, DO: SsKeyOffMask((1<<0)|(1<<1)|(1<<2)|(1<<3));
Using SsKeyOn() to start playing a background music, and then to play a sound, for example, a second later, is perfectly fine.
Just not at the same time or very near.
********************************************************************
GsDrawList() is not blocking, but GsUploadImage() and LoadImage() are blocking.
In any case after any function which uploads data to the GPU if you want to be sure that
the uploading process finished do: while(GsIsDrawing());
********************************************************************
Audio streams for the PlayStation SPU are in an ADPCM format. There is no way to play PCM audio streams directly.
********************************************************************
Response of the joystick when asking for pressed buttons (PSX_ReadPad()).
It is unwise to read the pad too often and it is recommended to read it only 60 or 50 times a second (vblank/vsync period), because some joysticks will not be able to keep up, will report that no buttons are pressed and they will cause strange behavior in your program/game.
An example of joystick that shows this problem is the Sony SCPH-1200, if probed too often some times it will report that no buttons are pressed even if some of its buttons are pressed. This does not seem to happen with some clone controllers which apparently can be probed more often.