Bochs/bochs
Dreg da43cc4580
add port e9 hack support for all rings (#64)
By enabling the 'all_rings' option, you can utilize the port e9 hack
from ring3

IMO very useful for:
- user-mode sandbox (ex Cuckoo)
- malware analysis
- API/SYSCALL logger with a simple hook from ring3
- automation + instrumentation from user mode code
- ...

So yes, from this PR a user-mode-sandbox can display on the console of
the system running Bochs anything that is written to 0xE9 port


![porte9hackallrings](https://github.com/bochs-emu/Bochs/assets/9882181/ddbca3fa-729b-4a3e-95ad-078e44c7a17a)

**This PR is 100% backward compatibility**

btw, @stlintel I'm not certain if **bochs/config.cc** is the ideal
location to define **bool port_e9_hack_all_rings** (unmapped io/dev is
better?)
2023-08-26 18:37:55 +03:00
..
bios fixing coding style in bios source files (#6) 2022-07-17 18:16:44 +03:00
build Fix windows build 2022-10-30 14:48:57 -07:00
bx_debug add updated lex and yacc scripts 2023-08-20 18:35:19 +03:00
cpu add port e9 hack support for all rings (#64) 2023-08-26 18:37:55 +03:00
doc add port e9 hack support for all rings (#64) 2023-08-26 18:37:55 +03:00
docs-html Documentation updates (e.g. improved gui debugger section). 2021-06-05 20:00:12 +00:00
gui Wider statusbar elements 2023-02-10 21:17:21 -07:00
host/linux/pcidev Applied two patches from Debian. 2021-09-10 15:33:22 +00:00
instrument fixed compilation of instrumentation examples with debugger OFF 2023-04-06 22:18:01 +03:00
iodev Include cstddef 2023-04-09 10:54:08 -07:00
memory use true / false for boolean instead of const 0 and 1 in memory 2022-08-23 21:56:09 +03:00
misc Applied two patches from Debian. 2021-09-10 15:33:22 +00:00
patches Updated user plugin example. 2021-02-07 18:37:34 +00:00
.bochsrc add port e9 hack support for all rings (#64) 2023-08-26 18:37:55 +03:00
.conf.amigaos
.conf.everything update .conf.everything script 2022-08-26 21:15:46 +03:00
.conf.linux Add --enable-avx to add predefined configure targets 2022-08-27 09:01:18 +03:00
.conf.macos Add --enable-avx to add predefined configure targets 2022-08-27 09:01:18 +03:00
.conf.macosx Add --enable-avx to add predefined configure targets 2022-08-27 09:01:18 +03:00
.conf.nothing Enable PCI support by default / better text formatting for 'configure --help' 2012-10-25 16:02:03 +00:00
.conf.sparc
.conf.win32-cygwin Add --enable-avx to add predefined configure targets 2022-08-27 09:01:18 +03:00
.conf.win32-vcpp Merge pull request #5 from tandasat/update-vs-projects 2022-08-27 19:10:14 +03:00
.conf.win64-cross-mingw32 Add --enable-avx to add predefined configure targets 2022-08-27 09:01:18 +03:00
.conf.win64-vcpp Merge pull request #5 from tandasat/update-vs-projects 2022-08-27 19:10:14 +03:00
aclocal.m4 configure: Improve compatibility with strict(er) C99 compilers 2022-11-27 23:12:58 +01:00
bochs.h improvement of the magic breakpoints fix #55 (#58) 2023-08-20 18:21:16 +03:00
bxdisasm.cc more bx_bool -> bool also fixing bxhub.cc case where bx_bool were assigned integer -1 value 2021-01-30 17:37:42 +00:00
bxthread.cc Started bx_bool to bool type changes in the Bochs core. 2021-01-30 15:16:00 +00:00
bxthread.h Started bx_bool to bool type changes in the Bochs core. 2021-01-30 15:16:00 +00:00
bxversion.h.in Releases (SVN flaG 0) now use the timestamp from README file instead of the 2020-01-02 16:19:02 +00:00
bxversion.rc.in Changed the name of the 3rd part of the Bochs version number from "patch" to "revision". 2019-11-30 12:20:00 +00:00
CHANGES updated CHANGES 2022-10-08 20:30:31 +03:00
config.cc add port e9 hack support for all rings (#64) 2023-08-26 18:37:55 +03:00
config.guess Updated configure helper scripts from automake 1.16 (required for MSYS2). 2020-01-31 13:41:25 +00:00
config.h.in remove instrument.h from bochs.h so it won't be included everywhere 2022-07-30 22:35:43 +03:00
config.sub Updated configure helper scripts from automake 1.16 (required for MSYS2). 2020-01-31 13:41:25 +00:00
configure configure: Improve compatibility with strict(er) C99 compilers 2022-11-27 23:12:58 +01:00
configure.ac configure: Improve compatibility with strict(er) C99 compilers 2022-11-27 23:12:58 +01:00
COPYING remove trailing whitespace from source files 2022-08-23 21:46:04 +03:00
cpudb.h ! CPUID: Added TigerLake CPU definition (features CET and CLWB support) 2021-01-30 08:35:35 +00:00
crc.cc
extplugin.h Added new plugin type PLUGTYPE_CI for config interfaces. Updated related code 2021-03-27 17:23:31 +00:00
gdbstub.cc Fixed instruction pointer truncation in gdbstub 2023-05-25 00:00:24 +03:00
install-sh
LICENSE - added original authors on top of LGPL'd sources ported from Qemu 2012-08-30 20:41:25 +00:00
logio.cc remove siminterface.h from bochs.h and include it only where required 2021-01-30 19:40:18 +00:00
logio.h remove siminterface.h from bochs.h and include it only where required 2021-01-30 19:40:18 +00:00
ltdl-bochs.h Renamed "ltdl.h" to "ltdl-bochs.h" to avoid conflicts with the include file 2013-12-17 19:58:43 +00:00
ltdl.c fixed problems found by cppcheck tool (patch by Maxim Derbasov) 2015-01-03 13:53:52 +00:00
ltdlconf.h.in
ltmain.sh
main.cc remove trailing whitespace from source files 2022-08-23 21:46:04 +03:00
Makefile.in build: extract vs2019-workspace.zip 2022-08-26 19:46:11 -07:00
msrs.def
osdep.cc Moved all Bochs event / wait functions required for multi-threading to a new 2017-09-14 16:18:12 +00:00
osdep.h Some fixes for MSVC. 2018-05-21 16:11:46 +00:00
param_names.h add port e9 hack support for all rings (#64) 2023-08-26 18:37:55 +03:00
PARAM_TREE.txt add port e9 hack support for all rings (#64) 2023-08-26 18:37:55 +03:00
pc_system.cc * convert bx_bool -> bool in pc_system.cc/pc_system.h 2021-01-30 18:05:55 +00:00
pc_system.h move stuff from bochs.h to more appropriate include 2021-01-30 18:50:09 +00:00
plugin.cc Some more cleanup in the plugins code. 2021-04-03 18:26:03 +00:00
plugin.h Updates to USBMSD/SCSI emulation 2023-03-31 18:30:11 -07:00
qemu-queue.h Added QEMU queue macros (required for EHCI) as a separate file. Removed already 2016-01-08 18:58:27 +00:00
README Preparing final release 2.7. 2021-08-01 08:07:38 +00:00
README-wxWidgets Domumentation updates and cleanups 2013-12-24 08:55:07 +00:00
TESTFORM.txt update TESTFORM for 2.5 release 2011-11-07 19:04:52 +00:00
TODO remove trailing whitespace from source files 2022-08-23 21:46:04 +03:00
win32_enh_dbg.rc Added capability to use the gui debugger output window as a log viewer 2014-01-13 21:31:14 +00:00
win32res.rc Win32: Make panic dialog a little wider 2023-02-18 12:29:45 -07:00
wxbochs.rc Modified win32 resource files based on patch.mingw-resources. We already use 2013-12-28 15:11:13 +00:00

Bochs - The cross platform IA-32 (x86) emulator
Updated: Sun Aug  1 10:07:00 CEST 2021
Version: 2.7

WHAT IS BOCHS?

Bochs is a highly portable open source IA-32 (x86) PC emulator
written in C++, that runs on most popular platforms.  It includes
emulation of the Intel x86 CPU, common I/O devices, and a custom
BIOS. Bochs can be compiled to emulate many different x86 CPUs,
from early 386 to the most recent x86-64 Intel and AMD processors
which may even not reached the market yet. Bochs is capable of running
most Operating Systems inside the emulation, for example DOS,
Linux or Windows. Bochs was written by Kevin Lawton and is currently
maintained by the Bochs project at "https://bochs.sourceforge.io".

Bochs can be compiled and used in a variety of modes, some which are
still in development.  The 'typical' use of bochs is to provide
complete x86 PC emulation, including the x86 processor, hardware
devices, and memory.  This allows you to run OS's and software within
the emulator on your workstation, much like you have a machine
inside of a machine.  Bochs will allow you to run Windows
applications on a Solaris machine with X11, for example.

Bochs is distributed under the GNU LGPL. See LICENSE and COPYING for details.

GETTING CURRENT SOURCE CODE

Source code for Bochs is available from the Bochs home page at
https://bochs.sourceforge.io.  You can download the most recent
release, use SVN to get the latest sources, or grab a SVN
snapshot which is updated frequently. The releases contain the most
stable code, but if you want the very newest features try the
SVN version instead.

WHERE ARE THE DOCS?

The Bochs documentation is written in Docbook.  Docbook is a text
format that can be rendered to many popular browser formats such
as HTML, PDF, and Postscript.  Each binary release contains the
HTML rendering of the documentation.  Also, you can view the
latest documentation on the web at
  https://bochs.sourceforge.io/doc/docbook/index.html

WHERE CAN I GET MORE INFORMATION?  HOW DO I REPORT PROBLEMS?

Both the documentation and the Bochs website have instructions on how
to join the bochs-developers mailing list, which is the primary
forum for discussion of Bochs.  The main page of the website also
has links to bug reports and feature requests.  You can browse and
add to the content in these areas even if you do not have a (free)
SourceForge account.  We need your feedback so that we know what
parts of Bochs to improve.

There is a patches section on the web site too, if you have made
some changes to Bochs that you want to share.

HOW CAN I HELP?

If you would like contribute to the Bochs project, a good first step
is to join the bochs-developers mailing list, and read the archive
of recent messages to see what's going on.

If you are a technical person (can follow hardware specs, can write
C/C++) take a look at the list of open bug reports and feature
requests to see if you are interested in working on any of the
problems that are mentioned in them.  If you check out the SVN
sources, make some changes, and create a patch, one of the
developers will be very happy to apply it for you.  Developers who
frequently submit patches, or who embark on major changes in the
source can get write access to SVN.  Be sure to communicate with the
bochs-developers list to avoid several people working on the same
thing without realizing it.

If you are a Bochs user, not a hardware/C++ guru, there are still
many ways you could help out.  For example:
  - write instructions on how to install a particular operating system
  - writing/cleaning up documentation
  - testing out Bochs on every imaginable operating system and
    reporting how it goes.

CHANGES

Brief summary of changes in 2.7:
  - Bugfixes for CPU emulation correctness (CPUID/VMX/SVM fixes to support
    Windows Hyper-V as guest in Bochs)
  - Improvements for the plugin handling to simplify Bochs extensions
  - Added "multiple NICs" support to the NE2000 and E1000 devices
  - Added experimental FTP service for networking modules 'vnet' and 'socket'
  - Fixes and improvements for all supported Voodoo graphics adapters
  - Added USB keyboard emulation with most of the keys supported
  - GUI "cmdmode": create a headerbar event with key combo starting with F7
  - LGPL'd VGABIOS updated to version 0.8a (new VGABIOS for Voodoo Banshee)

See CHANGES file for more information!