OSDN Git Service

[DOC] Update revison and credits.
[csp-qt/common_source_project-fm7.git] / source / readme_by_artane.txt
1 ** Qt porting for Common Source Code Project **
2                                           June 18, 2016
3               K.Ohta <whatisthis.sowhat _at_ gmail.com>
4
5 * If you can't read Japanese, read readme.qt.txt .
6
7 0. 概要
8    このパッケージは、Common Source Code Project (以下、CSP)
9    をQt5に移植したものです。
10    バイナリはGNU/Linux(64bit)用とMinGW (32bit Windows)用を
11    用意しています。
12    
13    ソースコード:
14      https://github.com/Artanejp/common_source_project-fm7/releases/tag/SNAPSHOT_20160618
15
16 1. 背景
17    CSPは、非常に優れた構造のエミュレータです(しかし、些か重くてコンパイラ
18    がいい最適化をしないと重めですが)。
19    しかし、このコードはM$ Visual C++依存の部分が非常に多いです。
20    そこで、GNU/Linuxでこれを動かすためにQtに色々と移植していきましょう。
21    と言う感じで作業をはじめました。
22
23 2. 最低限必要なもの(Qt版)
24    a. Qt5 ツールキット
25    b. OpenGL, 多分、最低OpenGL 3.0は必要です。 (New!)
26    c. gcc / g++ (4.7以降?)もしくは llvm clang / clang++ (3.5以降?)
27       コンパイラツールチェーン。
28    d. SDL2 (SDL 1.xではないので注意)
29    e. CMake 2.8以降。
30    f. ffmpegから、libavとlibswが必要です。 http://ffmpeg.org/ より。
31    
32    * Windows もしくは GNU/Linux のcross tool chain (要Wine)で、
33      MinGW と Qt 5.5.1 でのビルドができることを確認しました。
34      
35    * TIPS:
36      Windows等で動かした時に、画面の書き替えが表示されない場合は、
37      環境変数 QT_OPENGL を software にしてみてください。(例えば、
38      WindowsをVirtualBoxのゲストで使ってる場合など)
39      
40 3. ビルドの方法
41    ソースコードを解凍するか、git clone / pull した後で:
42    $ cd {srctop}/source/build-cmake/{Machine name}/
43    $ mkdir build
44    $ cd build
45    
46    To configure:
47    $ cmake ..
48    or
49    $ ccmake ..
50
51    To build:
52    $ make
53
54    To install:
55    $ sudo make install
56
57 4. Qt固有の話(Windows除く)
58    ・R@Mを $HOME/emu{Machine Name}/ に配置してください。(Windowsの場合は今の所 .\emu{Machine Name}\)
59     なお、このディレクトリは最初起動した後で作成されます。
60    ・設定ファイルは、$HOME/.config/emu{Machine Name}/ に書き込まれます。(Windowsの場合は今の所 .\.config\emu{Machine Name}\)
61    ・ステートセーブファイルは、$HOME/emu{Machine Name}/{Machine Name}.sta に書き込まれます。
62    ・キーコード変換テーブルファイルが、$HOME/.config/emu{Machine Name}/scancode.cfg に書き込まれます。
63      書式は、カンマで区切られた16進データです(10進ではないので注意) .
64      1カラム目はM$ ヴァーチャルキーコード。
65      2カラム目はQtネィティブのスキャンキーコードです。
66    ・UI部分の共通コンポーネント (src/qt/gui) を共有ライブラリlibCSPgui.soにまとめました。
67    ・インストール用のBASHスクリプトを用意しました。src/tool/installer_unix.shです。
68    
69      
70 5. 移植状況
71    a. 現在、Debian GNU/Linux "sid" の AMD64版でしかテストしていません。
72      が、多分他のGNU/Linux OSやBSD系のOS (Mac含む) でもビルドすれば
73      動くでしょう。
74       Windows もしくは GNU/Linux(要Wineとbinfmt-support)上でのMinGWと
75       Qt community edition でのビルドが通るようになりました。
76       安定したWindowsビルドを必要な方は、Visual Studio 2013 か 2015 のCommunity Edition
77       でビルドしてください。(もう少ししたら、MinGWに切り替えようとは思ってます。)
78       
79    b. 今は、Qtの開発側が「Qt4おわりね」とアナウンスしたので、Qt4ではなく
80       Qt5を使っています。
81       添付してあるバイナリは、Qt 5.5でビルドしました(が、Qt 5.1以降なら動くはずです)。
82
83    c.上流の2016-04-17現在でのPX7以外の全ての仮想マシンがQtに移植出来ています。
84    d. Linux用ビルドでは、GCC 6をリンク時最適化(LTO)モードで使っています。
85    
86 6. Upstream repositry:
87       https://github.com/Artanejp/common_source_project-fm7
88       https://www.pikacode.com/Artanejp/common_source_project-fm7/
89
90 7. Upstream (Takeda Toshiyaさんのオリジナル) 
91       http://homepage3.nifty.com/takeda-toshiya/
92
93 Changes:
94
95 * SNAPSHOT June 11, 2016
96   * Upstream 2016-04-13 .
97   * Use osdn.jp to distibute binaries.
98     https://osdn.jp/projects/csp-qt .
99   * [MOVIE_SAVER] Use ffmpeg internal aac codec, because faac or fdk_aac are not *Free* .
100   * [VM/MOVIE_SAVER] Fix stopping when changing cartridge, now refer to upstream (split movies).
101   * [Qt/Win32] Fix not work with WindowsXP, using homebrew version of ffmpeg-2.8.7.
102   * Build with 89d31ce8daa733ea4a0c38f0a1890d3a0fcfce38 (or later).
103   
104 -- Jun 11, 2016 05:09:55 +0900 K.Ohta <whatisthis.sowhat@gmail.com>
105
106 * SNAPSHOT June 09, 2016
107   * Upstream 2016-04-13 .
108   * Now, all of binaries are built with ffmpeg-2.8.7 at GNU/Linux,  with ffmpeg-3.0 at Windows.
109   * Please read README.ffmpeg.txt .
110   * [FM7/Disk] Add exceptions for Xanadu Scenario 2, this has not booted with changes 49dceaca9401d3c6037cb51ec013ca032ff0e83c .
111   * Build with 64df71cd492be91289f883224640f42cace090ed (or later).
112
113 -- Jun 09, 2016 05:50:50 +0900 K.Ohta <whatisthis.sowhat@gmail.com>
114
115 * SNAPSHOT June 08, 2016
116   * Upstream 2016-04-13 .
117   * Add movie saver, using libav with x264.
118   * Now, all of binaries are built with ffmpeg-3.0.
119   * Build with 2142d5c7426e21cfeedbaea0450f238f8b4d7d38 (or later).
120
121 -- Jun 08, 2016 07:34:45 +0900 K.Ohta <whatisthis.sowhat@gmail.com>
122
123 * SNAPSHOT May 23-2, 2016
124   * Win32 binary only RELEASE
125   * Fix unable to run with some natibve Windows environment.
126   * Build with c1448dc84f5439c7c8931614a8397dbefb6383da .
127
128 -- May 24, 2016 22:42:00 +0900 K.Ohta <whatisthis.sowhat@gmail.com>
129
130 * SNAPSHOT May 23, 2016
131   * Upstream 2016-04-13 .
132   * [Win32] Now built with -msse -msse2 . You can run only later than Pentium4 .
133   * Move FILEIO:: FIFO:: COMMON:: to libCSPemu_utils .
134   * Make OSD:: to inherited by OSD_BASE:: .
135   * [Win32] Disable LINKFLAGS with "-static-libgcc -static-libstdc++" to reduce size of executions, now, bundled libstc++ is for gcc-5 .
136   * [Win32/Build] Support build with MSYS2 (but not display because MSYS2's Qt was build without OpenGL).
137   * [Linux] Build shared libraries with Link-Time-Optimize, reduce size of libs.
138   * [X1/VM] Configurable buttons for X1/Turbo/Turbo Z.
139   * [FM7/FDC] Set MB8877_NO_BUSY_AFTER_SEEK. Fixed unable to boot OS0. Thanks to Anna_Wu.
140   * [FM77AV/MB61VH010] ALULINE: Reduce CPU usage (at delta X > delta Y).
141   * [UI/Qt/DRAW] Fix crash sometimes when exit emulator.
142   * Build with 1c1ddc85dfa7456b1ce48662c2e2930dcc4fc9d8 (or later).
143
144 -- May 23, 2016 02:22:07 +0900 K.Ohta <whatisthis.sowhat@gmail.com>
145
146 Upstream changes:
147 -----
148 4/13/2016
149
150 [WINMAIN] improve auto key for the case to switch upper/lowercase with capslock
151 [EMU/DEBUGGER] fix issue that u command may cause the infinite loop
152
153 [VM/DATAREC] support to detect the frequency of signal
154 [VM/DATAREC] fix to always adjust zero position of wave signal
155 [VM/UPD1990A] fix not to check clk signal is low when stb signal is raised
156 [VM/UPD7810] support debugger
157 [VM/UPD7810] support MOV A,S opecode
158 [VM/UPD7810] fix not to change V register (thanks PockEmul)
159
160 [PC2001] support NEC PC-2001
161 [PC2001] fix cpu clock
162 [PC2001] support beep sound
163 [PC2001/IO] support rtc control signals
164 [YALKY] support Yuasa Kyouiku System YALKY
165 [YALKY/IO] improve data recorder controller
166
167 -----
168
169
170 お楽しみあれ!
171 -- Ohta.