Programming/protocols/decompiling

GEC: Discuss gaming, computers and electronics and venture into the bizarre world of STGODs.

Moderator: Thanas

Post Reply
User avatar
Shrykull
Jedi Master
Posts: 1270
Joined: 2002-07-05 09:11pm

Programming/protocols/decompiling

Post by Shrykull »

Is it illegal to decompile software, even if you're just doing it to modify the program for your own personal use, to tailor it to your preferences? And how would you even know what programming language to decompile it into?

I'd like just to get a look at how some snippet of code that handles how internet software, like a web browser interacts/makes a request with protocols of the OSI model, TCP/IP mostly.
User avatar
Hugh
Youngling
Posts: 116
Joined: 2007-05-06 03:19pm
Location: Bucharest, Romania
Contact:

Post by Hugh »

I don't know about the legal side of the issue, but I don't think it's possible to reliably turn machine code back into C, or whatever. There is too much information loss when compiling. It does work for Java bytecode, though, but don't expect perfect recovery of the original source.
User avatar
phongn
Rebel Leader
Posts: 18487
Joined: 2002-07-03 11:11pm

Post by phongn »

If you want to see how all that stuff works, there's plenty of open-source code available.
User avatar
Starglider
Miles Dyson
Posts: 8709
Joined: 2007-04-05 09:44pm
Location: Isle of Dogs
Contact:

Re: Programming/protocols/decompiling

Post by Starglider »

Shrykull wrote:Is it illegal to decompile software,
Usually it's not illegal in the general sense; some countries even have specific protection for it, though large software companies are lobbying to have it made illegal. That said, most shrink-wrap licenses try to forbid it (the legality of these clauses is dubious in most jurisdictions)
Shrykull wrote:even if you're just doing it to modify the program for your own personal use, to tailor it to your preferences?
Does it really matter, on a personal level? If you're the only one that's going to use it frankly I wouldn't give a damn whether insanely excessive IP laws make it technically illegal.
And how would you even know what programming language to decompile it into?
You can decompile it into any language you like; any Turing-complete language can theoretically be transformed into any other Turing-complete language, though in practice it's often very hard to do this in a way that actually enhances readability to humans and only limited tools exist. The main problem is that a great deal of metadata (comments, variable names, even precise control structures when decompiling JMP tangles) exists in source code but not in object code, and there's no way to recreate that other than manual guesswork. In particular any program that uses nontrivial pointer arithmetic is going to be effectively impossible to decompile into a language that doesn't support it. Disassembly is much more reliable and straightforward, but of course you have to be able to read and understand uncommented x86 (typically) assembly language, which is frankly a bitch for nontrivial programs.
I'd like just to get a look at how some snippet of code that handles how internet software, like a web browser interacts/makes a request with protocols of the OSI model, TCP/IP mostly.
As others have mentioned looking at open source software (e.g. Firefox and the Linux TCP/IP stack) is a much, much better idea than trying to reverse engineer commercial software. Reverse engineering is a difficult and quite specialised skill that even the vast majority of competent software engineers don't have. But yeah, OSI is an academia-bred abstraction hardly anyone pays attention to.
User avatar
Braedley
Jedi Council Member
Posts: 1716
Joined: 2005-03-22 03:28pm
Location: Ida Galaxy
Contact:

Post by Braedley »

There's also the problem that assembly typically has several times as many lines of code as C or C++. And the code won't even be chunked, may or may not include defines, and may or may not include labels. Those are the three things that make assembly even remotely human readable. And now you want to convert that heap of a mess into a higher level language? You'll have constants all over the place which will have no meaning by themselves, good luck with extracting functions, and all sorts of other pieces of mayhem. At best, you're looking at proper indentation, and that's about it.
Image
My brother and sister-in-law: "Do you know where milk comes from?"
My niece: "Yeah, from the fridge!"
User avatar
Singular Intellect
Jedi Council Member
Posts: 2392
Joined: 2006-09-19 03:12pm
Location: Calgary, Alberta, Canada

Post by Singular Intellect »

A sufficiently knowledgeable programmer can make his program virtually impossible to decompile if he or she really wants.
User avatar
Resinence
Jedi Knight
Posts: 847
Joined: 2006-05-06 08:00am
Location: Australia

Post by Resinence »

You only get (basically) unreadable and therefore useless code from decompiling any non-trivial program anyway and reading the output of a dissassembler...lol, no real need to try and obfuscate your program unless you are making alot of money off it/security is an issue.
“Most people are other people. Their thoughts are someone else's opinions, their lives a mimicry, their passions a quotation.” - Oscar Wilde.
Post Reply