Friday, May 17, 2013

Play well with others

Macbook Pro 2012 and Linux



There have been a lot of people talking about running Linux on the Macbook Pro Retina but I don't have the Retina just a Macbook Pro 2012 with HD display and SSD. The Gentoo Documentation is in need of an update. As of today the newest hardware it covers is the early 2011 Macbook Pro. I used to post a lot of stuff to the Gentoo Wiki but I can not invest my time in that any more since the last 2 times I did that the site had disk issues and ended up loosing the stuff I posted. That is a side rant. Tonight is just about the initial issues of installing Gentoo on a none-Retina 2012 Macbook Pro

The keyboard has an odd mapping but that works. There is code floating around to flip the function keys with the special function ones but I like having the same mental training in Linux that I use in MacOS. The audio works well with the hda-intel module. With the b43 module and mac80211 layer the 802.11b/g/n works very well. To solve some of the problems I was having with the nvidia proprietary driver I had to switch to booting with ReFind from the ReFit install I had been using. This solves my problems with Apples some what exotic EFI implementation. The drawback to ReFind is that that to use it I have to boot off of a removable media or void the warranty by installing it on the machine directly. This has reduced me to booting off of a USB stick until the coverage expires. Apple I don't like your policy on this. Please change it or this will be my first and last Mac. Finally the SD-Card slot which worked perfectly when I used ReFit does not work under ReFind. I suspect this is because of some USB mode-setting issue. The camera also worked perfectly under ReFit is out of commission on ReFind boot. To be honest I will investigate this later.

My big grip is that even which all this the graphics chipset is still burning watts and I don't like the heat. nVidia has released some stuff for graphics switching with their module. I had been trying to use bumblebee but it has too many issues even if it has a better architecture for what I am doing. This is a shame but it is the truth. I really like the DMA-Buf work that has been done but again that code reaching maturity is far in the future in my humble opinion. I was on the mail list and did some testing of the earlier releases of the open sourced Broadcom driver. I did the same for the ACX11 from TI back in the day too. I am tired of doing that kind of thing. I still want to pay back to the open source community but I don't want to invest myself in getting basic things to work. I guess I have become spoiled but my time is just worth more to me now in other areas than in this. The good news is that other than nVidia and Broadcom most vendors are warming to the idea of doing open source modules I feel because of Android. Sorry but my nature is very tangential.

Finally to force the fan to keep things cooler I installed macfanctld and tweaked some constants to make the thermal zone lower. I should alter the program because by default it does not monitor all the thermal sensors. It was written with the naive idea that only the CPU or GPU matter. To be fair to the author the MacBook Pro has like 30 temperature sensors. The number of sensors and what they do seems to change between hardware revisions. I will probably revise this code more later.

Next I will probably post some stuff on my actual projects and not just more on this day to day.


-Evan

2013.05.19-Added news

I realized today that a while ago when I changed kernels I failed to include the kernel modules for the webcam so to make the device work follow the same directions used on the other models.
here
I don't recommend the whole document series of posts because they are for the earlier model and so the really good stuff on graphics switching in there doesn't work as yet. The older model has an ATI card while the new (2012 model) has nVidia. The architecture has also changed. I believe the ATI card was muxed at the output while the new "hybrid graphics" system works in a much more complex concept now. I suspect the mux however may still be there for when the Intel GPU is totally deactivated. If you really want to understand this just check the official documentation.

-Evan

No comments:

Post a Comment