getting started with PowerPC

Question about which tools to use, bugs, the best way to implement a function, etc should go here. Don't forget to see if your question is answered in the wiki first! When in doubt post here.
feare56
Member
Member
Posts: 97
Joined: Sun Dec 23, 2012 5:48 pm

getting started with PowerPC

Post by feare56 »

I just decided to get back into OSDev and since my last project I have switched to PowerPC Macs, I have a PowerMac g5 dual core 2.3ghz with 10.5.8 and an iBook g4 1.2ghz with 10.4.11. When I ended I had a 64-bit Intel laptop, what I am asking is should I switch one of the mac operating systems with a PowerPC compatible Linux or is it just as easy to create an OS on Mac? Will I need to relearn assembly for the PowerPC architecture? What tools are recommended that work on either mac or Linux that is PowerPC compatible (compiler, virtual machine, etc.)? Lastly if I were to stick with mac software will xcode work for assembly and c?
User avatar
bwat
Member
Member
Posts: 359
Joined: Fri Jul 03, 2009 6:21 am

Re: getting started with PowerPC

Post by bwat »

feare56 wrote:I just decided to get back into OSDev and since my last project I have switched to PowerPC Macs, I have a PowerMac g5 dual core 2.3ghz with 10.5.8 and an iBook g4 1.2ghz with 10.4.11. When I ended I had a 64-bit Intel laptop, what I am asking is should I switch one of the mac operating systems with a PowerPC compatible Linux or is it just as easy to create an OS on Mac? Will I need to relearn assembly for the PowerPC architecture? What tools are recommended that work on either mac or Linux that is PowerPC compatible (compiler, virtual machine, etc.)? Lastly if I were to stick with mac software will xcode work for assembly and c?
I've done over a decade of PowerPC OS development for telecom infrastructure products. Most of the time it was the GCC toolchain hosted on either Sun workstations or PCs running Linux. You don't need to install Linux. Yes you will have to learn assembly language, but it's not hard.
Every universe of discourse has its logical structure --- S. K. Langer.
feare56
Member
Member
Posts: 97
Joined: Sun Dec 23, 2012 5:48 pm

Re: getting started with PowerPC

Post by feare56 »

I already learned assembly but the question was what would be different from developing on Intel and PowerPC architectures? Is virtualpc 7 a good program to test an operating system made for the PowerPC platform?
User avatar
bwat
Member
Member
Posts: 359
Joined: Fri Jul 03, 2009 6:21 am

Re: getting started with PowerPC

Post by bwat »

feare56 wrote:I already learned assembly but the question was what would be different from developing on Intel and PowerPC architectures? Is virtualpc 7 a good program to test an operating system made for the PowerPC platform?
They are two different instruction sets. PowerPC assembly is very different to Intel. It is however very RISCy so it's pretty easy to learn.

The only simulator/emulator I've used was very expensive and chosen by the client. I've forgotten the name of it. Before that came along we tested on real hardware.
Every universe of discourse has its logical structure --- S. K. Langer.
feare56
Member
Member
Posts: 97
Joined: Sun Dec 23, 2012 5:48 pm

Re: getting started with PowerPC

Post by feare56 »

bwat wrote:
feare56 wrote:I already learned assembly but the question was what would be different from developing on Intel and PowerPC architectures? Is virtualpc 7 a good program to test an operating system made for the PowerPC platform?
They are two different instruction sets. PowerPC assembly is very different to Intel. It is however very RISCy so it's pretty easy to learn.

The only simulator/emulator I've used was very expensive and chosen by the client. I've forgotten the name of it. Before that came along we tested on real hardware.
Thank you, any good resources about PowerPC assembly? I created a boot loader that worked on my Intel laptop with assembly and c, will that boot loader work on the PowerPC architecture?
User avatar
bwat
Member
Member
Posts: 359
Joined: Fri Jul 03, 2009 6:21 am

Re: getting started with PowerPC

Post by bwat »

feare56 wrote: Thank you, any good resources about PowerPC assembly? I created a boot loader that worked on my Intel laptop with assembly and c, will that boot loader work on the PowerPC architecture?
Try http://www.power.org for generic info and google for the chip you're using, e.g., ppc750 or whatever your machine has.

Your bootstrap loader will most definitely need to be rewritten.
Every universe of discourse has its logical structure --- S. K. Langer.
User avatar
qw
Member
Member
Posts: 792
Joined: Mon Jan 26, 2009 2:48 am

Re: getting started with PowerPC

Post by qw »

feare56
Member
Member
Posts: 97
Joined: Sun Dec 23, 2012 5:48 pm

Re: getting started with PowerPC

Post by feare56 »

Thank you guys, I will get those checked out. In order to create an operating system for macintosh systems how would you go about accessing the bios? Would it be the same way as any other computer? All I have really researched as of now is that Apple uses Open Firmware for the bios, what I would like to know is if coding for the Open Firmware bios is different than any other bios?
User avatar
bwat
Member
Member
Posts: 359
Joined: Fri Jul 03, 2009 6:21 am

Re: getting started with PowerPC

Post by bwat »

I remember poking around the source code of OpenBSD for the details on how to communicate with the firmware. It's just a forth interpreter .
Every universe of discourse has its logical structure --- S. K. Langer.
User avatar
iansjack
Member
Member
Posts: 4720
Joined: Sat Mar 31, 2012 3:07 am
Location: Chichester, UK

Re: getting started with PowerPC

Post by iansjack »

Apple Open Firmware is very different from PC BIOS. But, in both cases, you only need it to load your OS kernel. This is easy enough: http://mac.linux.be/content/guide-open- ... ple-bios-0 . I suspect that your major problem, as with any non-PC hardware, will be to find documentation on the hardware in your Mac. As bwat suggests, the PPC FreeBSD source will provide some help, as will the PPC Linux source. You might also read Mac OS X Internals by Singh.
feare56
Member
Member
Posts: 97
Joined: Sun Dec 23, 2012 5:48 pm

Re: getting started with PowerPC

Post by feare56 »

Thank you, that should get me started
User avatar
bwat
Member
Member
Posts: 359
Joined: Fri Jul 03, 2009 6:21 am

Re: getting started with PowerPC

Post by bwat »

Remember to tell us how you got on. OSDev is very Intel heavy so the information you gather on your travels will be new to many of us. I'll be particularly interested in your development environment.
Every universe of discourse has its logical structure --- S. K. Langer.
feare56
Member
Member
Posts: 97
Joined: Sun Dec 23, 2012 5:48 pm

Re: getting started with PowerPC

Post by feare56 »

bwat wrote:Remember to tell us how you got on. OSDev is very Intel heavy so the information you gather on your travels will be new to many of us. I'll be particularly interested in your development environment.
I've noticed that OSDev is very Intel heavy, the only thing PowerPC I saw was that one article under non-x86. I'll keep you guys posted on the development process and share the latest files that work so if you guys would like to emulate or the source code for PowerPC architecture.
feare56
Member
Member
Posts: 97
Joined: Sun Dec 23, 2012 5:48 pm

Re: getting started with PowerPC

Post by feare56 »

Ok, I was doing research on what language I could use and I noticed that NASM works with intel and PowerPC. So for those of you who are using NASM and are looking to expand the architectures their OS is supported on you won't have to learn a different assembly language.
User avatar
nerdguy
Member
Member
Posts: 70
Joined: Wed Oct 30, 2013 8:11 am

Re: getting started with PowerPC

Post by nerdguy »

This is an interesting discussion, I have never programmed anything for PPC, The only time I ever programmed on my Mac was to make glorified versions of a hello world program. Good to see people thinking out of x86.
When you say, "I wrote a program that crashed Windows," people just stare at you blankly and say, "Hey, I got those with the system, for free." - Linus Torvalds
64 bit Kernel in early development
http://github.com/nerdguy12/core64
Post Reply