Re: Wich programing language are you using for your os
Posted: Wed Sep 05, 2012 4:54 am
-b, -ffreestanding and -mcmodelBrendan wrote:Let me know if I missed any "can't live without" compiler options.
The Place to Start for Operating System Developers
http://f.osdev.org/
-b, -ffreestanding and -mcmodelBrendan wrote:Let me know if I missed any "can't live without" compiler options.
You're right (my plans don't work well for source control systems).thepowersgang wrote:However, one project in a single file presents issues for source control (at least with current systems) so I would use a collection of text files as backing storage for the editor (something that is easily tokenisable but can have diffs cleanly performed).
No libraries means no need for "-ffreestanding".Combuster wrote:-b, -ffreestanding and -mcmodelBrendan wrote:Let me know if I missed any "can't live without" compiler options.
Note: It's a little like ".NET" in that executables are portable byte-code and not native code. A computer compiles the byte-code to native code immediately before that computer executes the executable (unless there's a suitable cached copy of the native code for that specific computer).Brendan wrote:
- architecture options (e.g. for cross-compiling, if things like SSE should be used, etc). For the compiler that converts HLL into portable byte-code this doesn't make sense. The compiler/s that convert byte-code to assembly only ever need the equivalent of GCC's "-march=native".
Heh - I don't use high level languages for boot loaders and kernels anyway..Combuster wrote:-ffreestanding isn't -nostdlib, in other words a lack of host OS rather than libraries. The hint was on how to compile a kernel, bootloader, or something not for your system.
All of the above mentioned point has no conflict with C++ or even java, it's the features of a wonderful IDE.Brendan wrote:Hi,
Yesbluemoon wrote:Now that looks like an RAD tool(not only interface editor, but also equip with core-data style node editor) with extensive auto-completion and context-aware assistance/insertion/deletion.
Guess what? I look at my HTML editor and think that it's totally possible.
It's not "extremely different", and I don't even think it'd be that hard to implement.
The main points are:
- Very little typing needed (just for giving names to classes, methods and variables); which means that someone without a keyboard (e.g. just touch screen or mouse) could be productive. Of course if someone has a keyboard there'd be keyboard shortcuts (e.g. so they can press "w" instead of dragging the "while" icon into their code).
- Syntax errors are impossible. This means less compile-time errors (no "can't find variable foo", no "missing bracket", etc), which means that the developer's "edit then test" cycle doesn't get interrupted by compiler errors as often (which should improve productivity).
- Source code stored in a "pre-tokenised" form (possibly including indexing/lookup tables, etc) to improve the efficiency of the IDE and the compiler
- Can be internationalised or personalised. E.g. an English user might see a loop as a box with the text "while" drawn in it, and a Japanese user might see the exact same loop as a box with Japanese symbols in it instead.
- Entire project stored as a single file (rather than many text files scattered everywhere)
- No user visible tools. The compiler/s and assembler are implemented as "file format converters" to create the illusion that source code can be executed as is.
- No need for "make", scripts, linkers, etc. The project file is compiled/converted to byte-code, which is compiled/converted to assembly, and the assembler generates an executable.
executables are required in 3 cases:Brendan wrote:It's a little like ".NET" in that executables are portable byte-code and not native code.
Because the CPU has trouble executing source code that isn't in an executable format.octavio wrote:executables are required in 3 cases:Brendan wrote:It's a little like ".NET" in that executables are portable byte-code and not native code.
First to save compile time,but actually it is posible to compile a program very fast (unless the toochain is bloated),so they are not really needed.
Second to protect the source code in comercial projects,for open source projects they are not needed.
Third ,if the compiler is not available.
why you need executable format for your hobby Os aplications?
There'd be some sort of "package manager" on top of this. Normally the package manager would install a package that contains the byte-code (and may compile the byte-code to native code optimised for that computer when the package is installed). This is fine for closed source/commercial projects.octavio wrote:And how do you plan to share code if aplications are single file?
Okay, let's stop talking about graphical languages. This doesn't seem to be what any of you are talking about. We're purely talking about an IDE here. Originally suggested by Brendan was an IDE heavily based on drag&drop, but now you all seem to be saying "it's not that bad, you'll have keyboard shortcuts and they'll be really great". Which is probably a good idea.thepowersgang wrote:The biggest issue with drag-drop interfaces is needing to locate the item with the cursor, this (as I think almost all of us are aware) is very slow. With shortcuts such that an action (function call, loop, assignment, addition, ...) can be added at the 'cursor' with one/two keystrokes a visual language could almost end up faster than a "classic" one.
You're doing the abstraction at the wrong level. Nobody said you should emulate your OS at the syscall level. This would be a crazy amount of work.Brendan wrote:I have actually tried this before. The first step was to implement code that emulates the behaviour of my asynchronous messaging using datagrams/sockets. The next step is to implement a process that uses the "IPC emulation" to emulate the behaviour of my VFS (fully asynchronous IO, with a versioning file system where existing files can't be modified and you can only create new versions of them). After that you'd want to extend the "IPC emulation" code to support emulating other parts of the micro-kernel's API - specifically memory management (allocating and freeing pages at specific virtual addresses) and scheduling ("spawnThread()" and "spawnProcess()", and thread priorities, etc).
Good defaults are important. And so is being able to deviate from the defaults. My browser does allow me to increase the font size if I like. It allows me to change the default font, the link colors and whether they are underlined if I like. I believe I could even override the rest of the page layout defaults with custom CSS if I really like. And so on.Imagine if every time you open a web page in your web browser the web browser pops up hundreds of dialog boxes asking you what size different pictures should be, how much detail you want, where the page borders should be, if links should be underlined, what colour and size various pieces of text should be, etc. In this case, would you say that being forced to make all these choices would be good (or would you say that being forced to make choices is a massive design failure, and is far inferior to "it just works")?
So the one graphics format you have has really many subformats, and you just moved the option which one to use from the save dialog to somewhere else in the menu?If the user actually does want to reduce the detail of a picture (e.g. to save disk space), then they can open it in an image editor and reduce the detail.
Sure, I already mentioned going from BMP to MIDI by recognising notes rather than letters.Can you think of an alternative set of conversions from BMP to sound that actually makes sense, and describe how each step is performed?Your very own example: BMP -> Text -> Sound. This is not the obvious right way for opening a graphics file as audio.
I'm not sure if I agree here. "all warnings" is hardly productive. Have you ever tried to use all of them?Ok - which options do you use and why? More importantly; how can the design of these tools be improved to avoid your desire to use these options?
For GCC, the only things I use are:
- the input file name and output file name. The "file format converter" idea makes this entirely redundant.
- the output file type. The "file format converter" idea makes this redundant too.
- options that enable warnings. This is stupid ("all warnings" should be default).
And you're never going to extend it after the first release?language options (e.g. which C standard, "pedantic", etc). I'm only having one dialect of one high level language so this isn't needed.
When looking for a bug that is only revealed with optimisation enabled, sometimes you're glad if you can enable/disable single optimisations.optimiser settings. There only really needs to be 2 choices ("production/optimised" and "debugging/unoptimised") and I can have that without options (e.g. 2 different "executable" file types - one for normal executables and one for debugging).
What does having no libraries mean? Will all programs have to carry their own version of common code? That is, code duplication instead of reuse?options to include libraries (e.g "-pthread") and set the include path. I'm not having any libraries or header files to begin with, so these aren't needed.
No, I think by giving the developer no choice about libraries, language extensions, optimisations and warnings you've pretty much excluded any other useful options. Maybe something to enable/disable some runtime checks as a tradeoff between more graceful failure and performance, but I expect that you know the right setting for everyone, so no need to have a choice there either...Let me know if I missed any "can't live without" compiler options.
Heh, I'd love to watch you programming this way.I'm looking forward to it. I'll even buy a good "multi-touch" screen so I can drag and drop up to 10 things at once!
Right, as I said above it's a great drag&drop IDE that becomes usable by not using drag&drop. Well, kind of defeats the purpose, but yeah...You're forgetting keyboard shortcuts. Why would you want to type "while" when you can just press one key?
I had to use these tools for some university projects, and we had to deliver both documents that included UML and code. The tools supported code generation, but it still took way too long to get the design into these crappy tools even if you could generate bad code out of it afterwards.While I do agree, most of the problem is that the tools I've used have only been UML editors (and weren't able to generate code from the class diagram, for example). This means that everything you do in the class diagram has to be typed in a second time when you start writing the code, which is a duplication of work (and doesn't help to save any time). There are better tools that are able to generate code from the class diagram (it's just that I haven't used them).
This raises interesting questions actually. Compiling bochs takes longer than just a fraction of a second, so the first time you start something like it on your OS, you'd have to wait. First important point is that the user needs some feedback, or the system appears to be hanging while it's really just compiling the program.Brendan wrote:I'm not sure if you're trolling or just stoned. Download the latest "bochs.tar.tz" and double click on the tarball, and tell me if it executes.
If you ignore the "UML class diagram" layer and only look at writing code for methods; then the user could set the icon for "while" to a picture of a fluffy duck (or anything else they like); "break", "continue" and "goto" could all be the same thing (and be drawn as a big arrow pointing to where execution continues); left and right shift might be an animated picture of ones and zeros scrolling left/right. Of course these all just silly examples.Kevin wrote:Okay, let's stop talking about graphical languages. This doesn't seem to be what any of you are talking about. We're purely talking about an IDE here. Originally suggested by Brendan was an IDE heavily based on drag&drop, but now you all seem to be saying "it's not that bad, you'll have keyboard shortcuts and they'll be really great". Which is probably a good idea.thepowersgang wrote:The biggest issue with drag-drop interfaces is needing to locate the item with the cursor, this (as I think almost all of us are aware) is very slow. With shortcuts such that an action (function call, loop, assignment, addition, ...) can be added at the 'cursor' with one/two keystrokes a visual language could almost end up faster than a "classic" one.
But what we have now is an IDE for a boring old language like C that displays boxes instead of relying on indentation (may or may not be helpful, but it probably doesn't hurt) and that auto-completes 'w' to 'while'. This has very little to do with the thing originally suggested, but I can imagine that this would indeed by usable.
Underneath it all is something like a string of tokens. Nothing prevents these tokens from being cut & pasted, compared, merged, etc.Kevin wrote:Now at this point we're almost back to plain text source files, so tools like diff would work again as well...
And all that is very different. In addition the native compiler would be built as "stages", where each stage is a separate "event driven" thread that receives something, does something to it, and then passes the result to the next stage/thread; with no shared data between these stages/threads.Kevin wrote:When writing a compiler, the OS functionality that you need is a) read from the source file, b) write to the output file, and maybe c) allocate some memory. And that's it, more or less.
The native compiler wouldn't do parsing or syntax checking (that's the IDE's job). For the Linux compiler I wouldn't bother with any optimisation (it's just more code to port into a different language later and can be omitted). That only leaves code generation.Kevin wrote:All the parsing, optimisation, code generation algorithms are purely userspace code and automatically portable between OSes.
I'm not sure why you'd think subformats would be needed.Kevin wrote:So the one graphics format you have has really many subformats, and you just moved the option which one to use from the save dialog to somewhere else in the menu?If the user actually does want to reduce the detail of a picture (e.g. to save disk space), then they can open it in an image editor and reduce the detail.
Ok - in that case maybe the user could just open the BMP in a "musical note editor" (so the VFS converts from bitmap into the MIDI file format) and save it as a different file name (so that when the new file is opened in a music player the VFS converts it into the sound file format).Kevin wrote:Sure, I already mentioned going from BMP to MIDI by recognising notes rather than letters.Can you think of an alternative set of conversions from BMP to sound that actually makes sense, and describe how each step is performed?
I normally use "-Wall -Wextra" for GCC. I think there are some warnings that aren't included in this (e.g. conversions between signed and unsigned), which are often annoying because they warn about things that is perfectly valid/acceptable in C.Kevin wrote:I'm not sure if I agree here. "all warnings" is hardly productive. Have you ever tried to use all of them?Ok - which options do you use and why? More importantly; how can the design of these tools be improved to avoid your desire to use these options?
I hope not; but I'll put a "version" field in the project file's header just in case.Kevin wrote:And you're never going to extend it after the first release?language options (e.g. which C standard, "pedantic", etc). I'm only having one dialect of one high level language so this isn't needed.
I'd be more glad to have executables that behave the same regardless of whether optimisation was enabled or not.Kevin wrote:When looking for a bug that is only revealed with optimisation enabled, sometimes you're glad if you can enable/disable single optimisations.optimiser settings. There only really needs to be 2 choices ("production/optimised" and "debugging/unoptimised") and I can have that without options (e.g. 2 different "executable" file types - one for normal executables and one for debugging).
There will never be any support for libraries/DLLs in the OS, IDE, compiler, executable file format or anything else. Instead of implementing something as a library you'd implement it as a "named service". To create a named service, you'd start by writing a formal "Request For Comments" that defines the messaging protocol for the proposed service. After peer review, etc; some organising body (me) would decide to either adopt the proposal, or not. Once adopted, you'd be able to start implementing that named service.Kevin wrote:What does having no libraries mean? Will all programs have to carry their own version of common code? That is, code duplication instead of reuse?options to include libraries (e.g "-pthread") and set the include path. I'm not having any libraries or header files to begin with, so these aren't needed.
I think we're looking at things from completely opposite perspectives. You think choices are good for users; while I think removing the burden of needing to choose is better.Kevin wrote:No, I think by giving the developer no choice about libraries, language extensions, optimisations and warnings you've pretty much excluded any other useful options. Maybe something to enable/disable some runtime checks as a tradeoff between more graceful failure and performance, but I expect that you know the right setting for everyone, so no need to have a choice there either...Let me know if I missed any "can't live without" compiler options.
Most of the problem with Bochs is that it's not designed for one compiler on one OS; but is designed for many different compilers on many different OSs - doing ".configure" takes more time than compiling.Kevin wrote:Cross-quoting from the original thread:This raises interesting questions actually. Compiling bochs takes longer than just a fraction of a second, so the first time you start something like it on your OS, you'd have to wait. First important point is that the user needs some feedback, or the system appears to be hanging while it's really just compiling the program.Brendan wrote:I'm not sure if you're trolling or just stoned. Download the latest "bochs.tar.tz" and double click on the tarball, and tell me if it executes.
The developer compiles the source code into byte-code; then the users install the byte-code (not the source code) and the byte-code is compiled into a native executable when it is installed. This means that normally there's no overhead of compiling when the application/GUI is started (but there is some overhead during package installation).Kevin wrote:The second one is: Didn't you say that the result of a conversion (i.e. the compilation) is cached? This means that if you run out of disk space, the OS chooses some conversion results (i.e. binaries) to be removed because they can be reproduced, right? Now if I think about how long things like KDE or OpenOffice take to compile... Can it happen that I just want to have a quick look at a spread sheet, and surprsingly I need to wait a day or two until the background compilation has completed because I hadn't used the office program recently and so the OS decided that freeing the space used for the binaries was a good idea?
I'm talking about loading the source code and convert it into executable code in ram instead of have the executable files on the HD.Brendan wrote: Because the CPU has trouble executing source code that isn't in an executable format.
Ah - in that case think of it as caching if you like. It's faster to load a the executable from disk instead of loading the source and compiling.octavio wrote:I'm talking about loading the source code and convert it into executable code in ram instead of have the executable files on the HD.Brendan wrote:Because the CPU has trouble executing source code that isn't in an executable format.
Right, that's the worst part of it - I told you about our efficient way to create UML diagrams, by writing source code and then using the reverse engineering functionality of the UML tool. It tells everything. Still I don't expect that we'll agree on this one, nor that there are any new arguments, so ignoring it for now seems most useful.Brendan wrote:If you ignore the "UML class diagram" layer
But I'm supposed to use keyboard shortcuts in order to work efficiently. So why would I care what those unused icons look like that take my valuable screen space away for no reason?and only look at writing code for methods; then the user could set the icon for "while" to a picture of a fluffy duck (or anything else they like); "break", "continue" and "goto" could all be the same thing (and be drawn as a big arrow pointing to where execution continues); left and right shift might be an animated picture of ones and zeros scrolling left/right. Of course these all just silly examples.
Correct, and this is why we're talking about an editor rather than a language. The language is the same, only the presentation is different.I'm not saying that these basic things will cease to exist (or that the language itself is fundamentally different from most other languages); I'm only saying they'd be entered, displayed and stored differently (graphics, not text).
Okay, so each of the stages uses the input and output functions, and you'll have to build a small wrapper that does the plumbing by putting pipes between the stages on Linux. You'll probably have an OS specific main loop, too, but we're talking about a few hundred lines of OS specific code here, not millions.And all that is very different. In addition the native compiler would be built as "stages", where each stage is a separate "event driven" thread that receives something, does something to it, and then passes the result to the next stage/thread; with no shared data between these stages/threads.
Now you're trolling. Porting portably written code between OSes while using the same language is obviously much easier than porting between languages on the same OS. I can take the same piece of C code and as long as it doesn't use the OS (or uses it through the OS specific standard library - which could be very small for a successfully running compiler) it runs on any OS for which a C compiler exists. The same is true for any other language.Now let's talk about your "automatically portable between OSs" theory. Actually, let's make it even easier - let's talk about "automatically" porting code from one language (e.g. C) to a different language (e.g. Java) on the same OS. How do you do this "automatic porting"? Do you open all the files in your text editor, the go to the menus and click on "file -> export as Java" or something? Maybe it's one of those fancy features in emacs.
At least lossy vs. lossless vs. vector graphics. I'm not an expert for graphics formats, there may be more of such important choices that effectively create subformats.I'm not sure why you'd think subformats would be needed.
And so could he do with a text editor so that OCR is used. Sure.Ok - in that case maybe the user could just open the BMP in a "musical note editor" (so the VFS converts from bitmap into the MIDI file format) and save it as a different file name (so that when the new file is opened in a music player the VFS converts it into the sound file format).Kevin wrote:Sure, I already mentioned going from BMP to MIDI by recognising notes rather than letters.Can you think of an alternative set of conversions from BMP to sound that actually makes sense, and describe how each step is performed?
That's the whole point of warnings. They warn against things that are strictly speaking allowed, but there's a certain chance that it's not what you meant to do. And it's your very own choice which of these things you want to make use of anyway. That is, you need options to tell the compiler about your choice.Kevin wrote:I normally use "-Wall -Wextra" for GCC. I think there are some warnings that aren't included in this (e.g. conversions between signed and unsigned), which are often annoying because they warn about things that is perfectly valid/acceptable in C.
Impossible by definition. If the timing doesn't change, you haven't optimised anything.I'd be more glad to have executables that behave the same regardless of whether optimisation was enabled or not.
Okay, and these are registered globally and resolved dynamically with a string lookup, and each program can immediately access all of them (ignoring possible permission restrictions)? Certainly looks doable, and probably doesn't require the binaries to be present when compiling. You'll need the interfaces if you don't want to go completely type unsafe, but if they must be registered globally you can access them without additional options. You'll also need good mechanisms for versioning the interfaces, like shared libs do.There will never be any support for libraries/DLLs in the OS, IDE, compiler, executable file format or anything else. Instead of implementing something as a library you'd implement it as a "named service". To create a named service, you'd start by writing a formal "Request For Comments" that defines the messaging protocol for the proposed service. After peer review, etc; some organising body (me) would decide to either adopt the proposal, or not. Once adopted, you'd be able to start implementing that named service.
The problem with Subway is not choice, but that they don't have defaults... You cut the part where I said that having choice is important, but only having good defaults makes it actually usable.I think we're looking at things from completely opposite perspectives. You think choices are good for users; while I think removing the burden of needing to choose is better.
If you don't understand what I mean by "the burden of needing to choose", trying buying a sandwich at Subway when you're in a hurry...
But you were talking about a bochs.tar.gz. This is a source code tarball. So please, let's compare apples to apples.The developer compiles the source code into byte-code; then the users install the byte-code (not the source code) and the byte-code is compiled into a native executable when it is installed. This means that normally there's no overhead of compiling when the application/GUI is started (but there is some overhead during package installation).
Ah well. I believe reality looks different (either your spreadsheet lacks functionality or it becomes large), but it makes little sense to discuss this based on opposite assumption.Despite this, if you start a spreadsheet and the OS actually does need to compile it first; then I'd expect to see a "Compiling" progress bar for about 30 seconds. Part of the reason for this is that the spreadsheet won't be a big complicated mess that has to handle 20 different file formats (and maths, and fonts, and pictures, and spell checking, and ...).
For the same reason that a schematic diagram of an electronic circuit or an architect's blueprint of a house is better than any description in text; and for the same reason that things like flowcharts and all the different types of UML diagrams exist. Humans are able to understand pictures much faster because of the visual cues.Kevin wrote:But I'm supposed to use keyboard shortcuts in order to work efficiently. So why would I care what those unused icons look like that take my valuable screen space away for no reason?and only look at writing code for methods; then the user could set the icon for "while" to a picture of a fluffy duck (or anything else they like); "break", "continue" and "goto" could all be the same thing (and be drawn as a big arrow pointing to where execution continues); left and right shift might be an animated picture of ones and zeros scrolling left/right. Of course these all just silly examples.
C++, Java and C# all have the same fundamental things - there's variables, there's scope, there's classes, there's loops, there's operators for addition/subtraction, etc. They aren't fundamentally different from each other; but they are different languages.Kevin wrote:Correct, and this is why we're talking about an editor rather than a language. The language is the same, only the presentation is different.I'm not saying that these basic things will cease to exist (or that the language itself is fundamentally different from most other languages); I'm only saying they'd be entered, displayed and stored differently (graphics, not text).
It's not the same language, and I never said it was. Code written in one language is not "automatically portable" to a different (but fundamentally similar) language.Kevin wrote:Now you're trolling. Porting portably written code between OSes while using the same language is obviously much easier than porting between languages on the same OS. I can take the same piece of C code and as long as it doesn't use the OS (or uses it through the OS specific standard library - which could be very small for a successfully running compiler) it runs on any OS for which a C compiler exists. The same is true for any other language.Now let's talk about your "automatically portable between OSs" theory. Actually, let's make it even easier - let's talk about "automatically" porting code from one language (e.g. C) to a different language (e.g. Java) on the same OS. How do you do this "automatic porting"? Do you open all the files in your text editor, the go to the menus and click on "file -> export as Java" or something? Maybe it's one of those fancy features in emacs.
It's possible to design a format that makes these choices unnecessary.Kevin wrote:At least lossy vs. lossless vs. vector graphics. I'm not an expert for graphics formats, there may be more of such important choices that effectively create subformats.I'm not sure why you'd think subformats would be needed.
You're right ("BMP -> Text -> Audio" isn't always the obviously correct way). Using the "most likely to be correct" way as default doesn't really make the idea of automated file format conversion any less appealing though.Kevin wrote:And so could he do with a text editor so that OCR is used. Sure.Ok - in that case maybe the user could just open the BMP in a "musical note editor" (so the VFS converts from bitmap into the MIDI file format) and save it as a different file name (so that when the new file is opened in a music player the VFS converts it into the sound file format).Kevin wrote:Sure, I already mentioned going from BMP to MIDI by recognising notes rather than letters.
But your assumption was that he opens the BMP neither in a "musical note editor" nor in a text editor, but with an audio player. So why is BMP -> Text -> Audio the obviously correct way to convert it and superior to BMP -> MIDI -> Audio?
Making the user choose is a design failure. Could the language and/or tools be modified so that the user has no need to make choices about what should and shouldn't be considered a warning? I think it can, and I don't think it'd be hard to do.Kevin wrote:That's the whole point of warnings. They warn against things that are strictly speaking allowed, but there's a certain chance that it's not what you meant to do. And it's your very own choice which of these things you want to make use of anyway. That is, you need options to tell the compiler about your choice.I normally use "-Wall -Wextra" for GCC. I think there are some warnings that aren't included in this (e.g. conversions between signed and unsigned), which are often annoying because they warn about things that is perfectly valid/acceptable in C.
You're still trying to solve symptoms.Kevin wrote:Impossible by definition. If the timing doesn't change, you haven't optimised anything.I'd be more glad to have executables that behave the same regardless of whether optimisation was enabled or not.
Ok - in that case (source code and not a normal package, with both the byte-code and executable deleted by an OS that's desperate to find a few remaining shreds of free disk space), then I'd expect to see a "Compiling" progress bar for several minutes when the application starts up.Kevin wrote:But you were talking about a bochs.tar.gz. This is a source code tarball. So please, let's compare apples to apples.The developer compiles the source code into byte-code; then the users install the byte-code (not the source code) and the byte-code is compiled into a native executable when it is installed. This means that normally there's no overhead of compiling when the application/GUI is started (but there is some overhead during package installation).
With binaries the world looks different: If you wanted you could have a bochs.sh on Linux that extracted the embedded binaries into temporary files and started it. There's little room for you to differentiate here. It's the choice of bochs that they don't provide their software in this form, not a decision of the OS.
(And before you say that embedding multiple files in the .sh is cheating: You'd need the same, because bochs needs more than just the binary to run - like ROMs etc.)