Dicas simplificada para a compilação do kernel

Transcrição

Dicas simplificada para a compilação do kernel
Dicas simplificada para a compilação do
kernel do FreeBSD v5.x/6.x/
Autor: Paulo Henrique [RDDCK].
Escrito em: 17 de Junho de 2008.
Última revisão: 09 de Setembro de 2008.
Versão: 0.38.
Abordarei apenas essas duas séries do sistema pelo fato de não ter compilado o mesmo
na sua série atual 7.x, e não comentarei sobre a série 4.x pelo fato de fazer muito tempo
que não compilo o sistema sobre a mesma.
Essa postagem será uma de uma série um pouco extensa, e haverá diversas informações
que poderá torna-se confuso, recomendo a leitura de demais arquivos que deixarei
exposto através de links, com esse links se encontra na internet não poderei colocar
com certeza se o mesmos se encontraram disponíveis quando estiverem lendo esse
documento.
Caso não se encontre satisfeito ou em dúvida com alguma informação presente nesse
documento o mesmo foi escrito baseado sobre primeiramente experiência na utilização
do sistema assim como também através de informações contidas no handbook, fóruns e
lista de discussões.
O handbook se encontra disponível em:
Versão em Inglês: aqui .
Versão em Português: se encontra disponível em:
http://doc.fug.com.br/handbook/
A compilação do kernel "núcleo" do sistema operacional só se torna possível em
sistemas correlatos com modelo de desenvolvimento Open Source no qual se tem
acesso ao código fonte do sistema, entre suas vantagens temos:
Estabilidade, pois somente o necessário para o seu hardware e aplicações realmente
precisem para funcionar.
Velocidade, o kernel no qual integra um sistema de fabrica é de certa forma grande pelo
fato dele possuir suporte nativo ao maior número de hardware possível para que sua
instalação seja realizada, não tem como os desenvolvedores fazer uma versão para cada
hardware específico no qual o sistema irá rodar, na compilação do sistema será
removido suporte a hardware que não se tem presente na maquina, suporte a protocolos
de transporte, suporte a padrões no qual não se fará uso sendo assim deixará o núcleo
consideravelmente compacto, salvo em alguns casos que acabada deixando o núcleo do
sistema maior do que o de fábrica mais com suporte a bem mais funcionalidades nas
quais são necessária para determinadas tarefas.
E sobre meu ponto de vista sendo ela o principal motivo "SEGURANÇA" :
Segurança: quando se compila um sistema pode anteriormente sincronizar a árvore do
código fonte do seu sistema com a última versão disponível nos servidores CVS do
Projeto, irei em após essas postagem colocar um simples guia sobre como fazer essa
sincronização ou mais popularmente update do sistema, corrigindo assim bugs que
surgiu no decorrer da imagem baixada até o momento da sincronização, esse bugs são
tanto por parte de segurança tendo como alvo príncipal, como também por parte de
desempenho, suporte a novos tipos de hardware, suporte a novos protocolos enfim a
lista é um pouquinho grande, depois mostrarei qual o arquivo consultar no sistema para
saber o que foi atualizado.
Para se compilar o kernel primeiramente o que se necessita é ter pelo menos o GCC
Instalado no sistema além do MAKE no caso o pacote DEVELOPED disponível no cd
de instalação, e claro, os fontes do sistema, no caso uma árvore de diretórios disposta
sobre o "/usr/src/” ou “/sys/”.
VERIFICANDO A FERRAMENTAS
DE DESENVOLVIMENTO NO SISTEMA.
No prompt de comando do sistema digite:
matilda%gcc -v
vai ser apresentado como o seguinte exemplo:
matilda%gcc -v
Using built-in specs.
Configured with: FreeBSD/i386 system compiler
Thread model: posix
gcc version 3.4.6 [FreeBSD] 20060305
matilda%
se tiver como retorno a seguinte expressão:
matilda%gcc -v
gcc: Command no found
matilda%
Significa que você não tem um ambiente DEVELOPED instalado no seu sistema, para
instalá-lo basta seguir uns dos passos:
INSTALANDO A DISTRIBUIÇÃO DEVELOPED NO SISTEMA:
Com o CD 1 de instalação:
//como root:
matilda#sysinstall [enter]
///na tela do sysinstall e com o cd dentro do driver de cdrom.
Vai em:
{CUSTOM}
{DISTRIBUTIONS}
{DEVELOPED} Marque a opção com "espaço"
Vai solicitar se deseja instalar a coleção de ports do sistema responde "NO" e depois:
{EXIT}
{MEDIA}
{1CD/DVD}
{COMMIT}
A distribuição DEVELOPED e suas dependências serão todas instaladas no sistema no
caso se estiver com o CD1 de instalação.
Agora instalaremos os fontes do sistema:
INSTALAÇÃO DAS FONTES DO SISTEMA NO SISTEMA:
Para saber se tem as fontes do sistema instaladas execute o seguinte comando no
terminal:
matilda# ls -l /usr/src
total 272
-rw-r--r-- 1 root wheel 6192 1 Jan 09:37 COPYRIGHT
-rw-r--r-- 1 root wheel 403 6 Fev 2006 LOCKS
-rw-r--r-- 1 root wheel 6683 9 Jul 2006 MAINTAINERS
-rw-r--r-- 1 root wheel 11161 28 Mar 2007 Makefile
-rw-r--r-- 1 root wheel 36318 25 Nov 2007 Makefile.inc1
-rw-r--r-- 1 root wheel 140746 20 Dez 2007 ObsoleteFiles.inc
-rw-r--r-- 1 root wheel 2816 4 Mar 2006 README
-rw-r--r-- 1 root wheel 22330 8 Mai 20:31 UPDATING
drwxr-xr-x 37 root wheel 1024 8 Mai 19:37 bin
drwxr-xr-x 55 root wheel 1024 8 Mai 19:36 contrib
drwxr-xr-x 5 root wheel 512 8 Mai 19:37 crypto
drwxr-xr-x 21 root wheel 2048 8 Mai 19:37 etc
drwxr-xr-x 13 root wheel 512 8 Mai 19:37 games
drwxr-xr-x 4 root wheel 512 8 Mai 19:37 gnu
drwxr-xr-x 6 root wheel 2048 8 Mai 19:37 include
drwxr-xr-x 9 root wheel 512 8 Mai 19:37 kerberos5
drwxr-xr-x 71 root wheel 1536 8 Mai 19:37 lib
drwxr-xr-x 33 root wheel 1024 8 Mai 19:37 libexec
drwxr-xr-x 13 root wheel 512 8 Mai 19:37 release
drwxr-xr-x 4 root wheel 512 8 Mai 19:37 rescue
drwxr-xr-x 94 root wheel 2048 8 Mai 19:37 sbin
drwxr-xr-x 6 root wheel 512 8 Mai 19:37 secure
drwxr-xr-x 25 root wheel 512 8 Mai 19:37 share
drwxr-xr-x 58 root wheel 1024 8 Mai 19:37 sys
drwxr-xr-x 12 root wheel 512 8 Mai 19:37 tools
drwxr-xr-x 224 root wheel 4096 8 Mai 19:37 usr.bin
drwxr-xr-x 193 root wheel 3584 8 Mai 19:37 usr.sbin
matilda#
No caso será retornado uma arvore de diretórios e arquivos, caso contrario não obter
retorno é sinal que não possui as fontes instaladas. Para instalar as fontes segue os
seguintes procedimentos:
matilda#sysinstall
{CONFIGURE}
{DISTRIBUTIONS}
{[ ] SRC}
{ALL}
{EXIT}
{EXIT}
{MEDIA}
{1- CD/DVD}
{OK}
No caso assim terá instalado todas as fontes do sistema.
DIRETÓRIOS DE TRABALHO NA COMPILAÇÃO DO KERNEL
ARQUITETURAS I386/X86-64
No caso essa postagem abordará apenas compilações para processadores de arquitetura
CISC que são os mais comuns em computadores pessoais esse processadores são os
seguintes, não listarei todos apenas alguns que lembro de mente no momento.
Intel 386, 386DX, 386SX no caso o suporte a 386 foi removido na RELEASE 5.x
Intel 486, 486DX, 486SX no caso o suporte a 486 foi removido na RELEASE 6.x
Intel Pentium, Pentium MMX, Pentium-PRO, Pentium II, Celeron, Pentium III,
Pentium IV, Pentium D, Celeron D, Celeron M, Centrino, Centrino Duo, Core
Duo, Core 2 Duo, Quad Core, Xeon, Xeon SMP, Xeon Série 3000*¹, Xeon Serie
4000*¹, Xeon Serie 5000*¹
Amd 586, AMD Athlon, AMD Duron, AMD Athlon XP, AMD Sempron, AMD
Athlon XP 64, AMD Athlon FX, AMD Athlon FX 64, ATHLON FX X2, e correlatos
alem dos AMD Opterons.
Obs.: A série de processadores Xeon da Intel tem certos cuidados, pois algumas séries
usa como núcleo outra arquitetura e não a x86-64, no caso eles são baseados no núcleo
do Itanium2 que no caso sua arquitetura referente é a IA64 uma arquitetura 100%
RISC. Caso possua um Xeon procure na documentação do seu hardware sobre qual
tecnologia ele foi baseado, pode até ter instalado uma versão I386 mesmo ele sendo de
arquitetura IA64, pois tal arquitetura oferece emulação para códigos de I386 mais não
terá o desempenho que por sinal é muito superior quando executado com código sobre a
arquitetura correta. No caso o FreeBSD oferece suporte para tal arquitetura, discutirei
sobre ela quando possível.
Bom no caso, voltando ao assunto:
Os diretorios de trabalho para no momento será o diretório:
"/usr/src" => Diretório contento fontes do sistema e documentação básica.
"/usr/src/UPDATING" => Arquivo contendo referências para possíveis atualizações.
"/usr/src/README" => Arquivo explicando demais arquivos e a tarefas empregadas
na compilação do sistema.
"/usr/src/sys/i386/conf/" => Diretório contendo o arquivo de configuração do kernel
para arquiteturas I386.
"/usr/scr/sys/amd64/conf/" => Diretório contendo o arquivo de configuração do kernel
para arquiteturas x86-64 ou amd64.
No caso da arquitetura x86-64, aconselho baixar a versão do sistema para 64Bits pois
até hoje já com várias tentativa não obtive sucesso na compilação do sistema sobre I386
para 64 bits, embora já li que é possível, como não consegui então não aconselho a
perder tempo tentando.
RESSALVAS... Sincronizando o Código Fonte do Sistema com a
arvore disponível nos servidores do Projeto sobre CVSUP.
Bom antes de começar as dicas sobre compilação do kernel do sistema em si,
seria bom já manter um vício sobre a administração do sistema que é atualização do
Código fonte.
Diferente de muitos sistemas em que para se ter que ter um sistema "livres" de bugs o
máximo que se pode fazer é instalar uns updates que na maioria do caso corrige um
problema e surge outro, com os sistema Open Sources uma atualização se tem como
principal forma a reconstrução total ou parcial do sistema, sendo assim não degradando
com a performance do sistema a longo prazo.
Bom diferente do Linux que o que se pode fazer é reinstalar o kernel e aplicar patchs ou
gastar horas a fio para reconstruir uma única biblioteca do sistema com uma falha grave
de seguraça, nos sistemas BSD em geral te oferece não só atualizar o kernel como no
Linux mais sim todo o sistema, bom essa diferença se dá pela seguinte observação
LINUX É SÓ UM KERNEL, SISTEMAS
BSDs SÃO SISTEMAS OPERACIONAIS
COMPLETOS
Mesmo o Linux possuindo creio eu a maior parte dos desenvolvedores open sources
eles não consegue a qualidade de código nem a praticidade dos sistemas BSDs consegue
com seu poucos mais dedicados e talentosos desenvolvedores, o suporte que os BSDs
oferecem sobre linux é quase que esmagadora, quase todas as partes do sistema tem não
uma pessoa mais um grupo de usuários destinados a orientar e resolver determinados
problemas.
Bom mais saindo da filosofia, e falar de algo no momento mais interessante.
Por que atualizar o Código Fonte de sistema ?
Bom tem vários motivos os principais sobre meus olhos de Administrador de Sistemas
"picareta"* entre os benefícios temos por prioridade:
1= > Segurança, atualizando o código fonte após o termino da compilação você terá
um sistema corrigido e sem bugs, sendo esses os descobertos entre o período que você
instalou o sistema até o momento a sincronização dos seus fontes com os
disponibilizados pelo projeto.
2=> Estabilidade => Algumas atualizações são destinadas a partes do sistema que
depois de liberadas se mostraram instáveis ou não testadas o suficiente, mesmo sendo
raro, já que, BSDs no geral até ter uma RELEASE disponibilizada é submetidas em
laboratórios a testes que muitos sistema com raras, mais raras exceções mesmo outros
sistemas suportaria, alguns até com trademark Unix no rótulo, não estou tirando aqui a
qualidade desses sistemas mais é que em se tratando de BSDs, ele são estáveis muito
antes de chegarem ao nível de CURRENT na engenharia de releases. Com o tempo que
já tenho de usuário assim como administrador de sistemas “picareta”* acredito que hoje
pelo menos 35% da Internet está sediado sobre algum dos sistemas BSDs sendo eles
tanto, FreeBSD, OpenBSD, NetBSD, DragonFlyBSD, DarwinBSD, MaC OS X, iBSD,
E possivelmente outros projetos que são embedded de uns desses sistemas bases.
*Picareta por que não possui nenhum curso técnico profissionalizante, nem esquentei a bunda em
um banco de universidade.:D
3=> Desempenho, muitas correções tem muito pouco haver em si com a segurança,
pois o sistema em si já é consideravelmente bem projetado tendo poucas
vulnerabilidades, a maioria das atualizações se refere a um driver ou outro ou rescrita de
parte de um código que ficou lento, tais atualização saem para melhorar a performance
do sistema. De vez enquanto vejo pessoas dizendo que BSD é lento mais sinceramente
não sei se falam que ele é lento ou se é por que tem digamos que preguiça de melhorar o
desempenho... :D, quando puder darei umas dicas de tunning aqui.
4 = > Adicionamento de recursos , alguns recursos são tido estáveis após o
lançamento da RELEASE e então são liberado sobre a árvore para que já se passa a
usufruir de tais recursos sem ter que esperar a próxima RELEASE a ser liberada, e olha
como demora sair uma RELEASE. :D
Bom considerações aparte mãos a obra :D....
O CVSUP
O Cvsup é um utilitário disponível no sistema para auxiliar o administrador na tarefa de
sincronização das fonte do sistema com a do projeto, além dele temos o CTM e o csup,
o CTM é usado muito quando o link de conecção com a internet é muito restrito no
quesito tempo, e o csup é o substituto do cvsup até onde sei.. O CTM quando puder
coloco uma explicação aqui para a sua utilização quanto ao csup assim que usa-lo...
Bom primeiro um guia rápido depois destino um post para a especificação completa do
cvsup.
Primeiro verifique se tem ele instalado no sistema caso contrário instalei através dos
port. o seu diretório de compilação no ports é:
/usr/ports/net/cvsup-without-gui
ou
/usr/ports/net/cvsup
No caso o primeiro não compila e instala a parte destinada ao X11 pois o cvsup em si é
um aplicativo para uso junto com o servidor X, o segundo já compila com a GUI dele.
Pode usar também o "pkg_add" para isso basta:
add_pkg -r cvsup-without-gui ou
add_pkg -r cvsup
Se tiver o CD de instalação ele está no CD1 do FreeBSD no caso o mesmo que se
encontra as distribuições base para o sistema funcionar.
Bom seguindo ...
no diretório /usr/share/examples/cvsup temos alguns exemplos, o conteúdo do mesmo é:
matilda# cd /usr/share/examples/cvsup/
matilda# ls -l
total 36
-r--r--r-- 1 root wheel 1180 24 Jun 14:57 README
-r--r--r-- 1 root wheel 5225 24 Jun 14:57 cvs-supfile
-r--r--r-- 1 root wheel 2636 24 Jun 14:57 doc-supfile
-r--r--r-- 1 root wheel 2290 24 Jun 14:57 gnats-supfile
-r--r--r-- 1 root wheel 3814 24 Jun 14:57 ports-supfile
-r--r--r-- 1 root wheel 367 24 Jun 14:57 refuse
-r--r--r-- 1 root wheel 1949 24 Jun 14:57 refuse.README
-r--r--r-- 1 root wheel 3889 24 Jun 14:57 stable-supfile
-r--r--r-- 1 root wheel 3053 24 Jun 14:57 standard-supfile
-r--r--r-- 1 root wheel 2361 24 Jun 14:57 www-supfile
no caso vamos apenas fazer de momento referencia ao arquivo standart-supfile
copie-o para o /etc e adiciona permissão de escrita nele, basta para isso seguir o seguinte
comando.
matilda# cd /usr/share/examples/cvsup/standart-supfile /etc & chmod u+w /etc/standartsupfile
Bom após isso com um editor qualquer tipo o ee ou vi abra esse arquivo e vamos ao
conteúdo do mesmo.
matilda# ee /etc/standart-supfile
# $FreeBSD: src/share/examples/cvsup/standard-supfile,v 1.23.4.4.2.1 2007/11/25
06:32:51 kensmith Exp $
#
# This file contains all of the "CVSup collections" that make up the
# FreeBSD 6.x-STABLE source tree.
#
# CVSup (CVS Update Protocol) allows you to download the latest CVS
# tree (or any branch of development therefrom) to your system easily
# and efficiently (far more so than with sup, which CVSup is aimed
# at replacing). If you're running CVSup interactively, and are
# currently using an X display server, you should run CVSup as follows
# to keep your CVS tree up-to-date:
#
# cvsup standard-supfile
#
# If not running X, or invoking cvsup from a non-interactive script, then
# run it as follows:
#
# cvsup -g -L 2 standard-supfile
#
# You may wish to change some of the settings in this file to better
# suit your system:
#
# host=CHANGE_THIS.FreeBSD.org
# This specifies the server host which will supply the
# file updates. You must change it to one of the CVSup
# mirror sites listed in the FreeBSD Handbook at
# http://www.freebsd.org/doc/handbook/mirrors.html.
# You can override this setting on the command line
# with cvsup's "-h host" option.
#
# base=/var/db
# This specifies the root where CVSup will store information
# about the collections you have transferred to your system.
# A setting of "/var/db" will generate this information in
# /var/db/sup. You can override the "base" setting on the
# command line with cvsup's "-b base" option. This directory
# must exist in order to run CVSup.
#
# prefix=/usr
# This specifies where to place the requested files. A
# setting of "/usr" will place all of the files requested
# in "/usr/src" (e.g., "/usr/src/bin", "/usr/src/lib").
# The prefix directory must exist in order to run CVSup.
# Defaults that apply to all the collections
#
# IMPORTANT: Change the next line to use one of the CVSup mirror sites
# listed at http://www.freebsd.org/doc/handbook/mirrors.html.
*default host=cvsup12.FreeBSD.org
*default base=/var/db
*default prefix=/usr
*default release=cvs tag=RELENG_6_3
*default delete use-rel-suffix
# If you seem to be limited by CPU rather than network or disk bandwidth, try
# commenting out the following line. (Normally, today's CPUs are fast enough
# that you want to run compression.)
*default compress
## Main Source Tree.
#
# The easiest way to get the main source tree is to use the "src-all"
# mega-collection. It includes all of the individual "src-*" collections.
#src-all
# These are the individual collections that make up "src-all". If you
# use these, be sure to comment out "src-all" above.
src-base
src-bin
src-cddl
src-contrib
src-etc
#src-games
src-gnu
src-include
#src-kerberos5
#src-kerberosIV
src-lib
src-libexec
src-release
src-rescue
src-sbin
src-share
src-sys
src-tools
src-usrbin
src-usrsbin
# These are the individual collections that make up FreeBSD's crypto
# collection. They are no longer export-restricted and are a part of
# src-all
src-crypto
src-eBones
src-secure
src-sys-crypto
###END-SUPFILE ###
Bom no caso o meu já se encontra modificado:
apenas o que temos de momento nos atentar é sobre as alterações das seguintes linhas :
*default host=cvsup12.FreeBSD.org
No caso essa linha estará sem a parte "cvsup12" apenas coloca nesse trecho da linha o
servidor cvsup do projeto que você irá se conectar para sincronizar as fontes. Para mais
informações por favor verifique a seguinte url contendo todos os servidores disponíveis
ao redor do mundo.
http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/cvsup.html#CVSUPMIRRORS
Bom, após isso a próxima linha a verificar é a seguinte:
*default release=cvs tag=RELENG_6_3
Verifique se a ultima entrada "RELENG_6_3" no caso estou sincronizando junto a
release 6.3 que no caso é a atual do meus sistema, faça a modificação correta para o seu
sistema, embora normalmente vai estar já corretamente configurado.
após isso temos a linha
src-all e mais a baixo outras entradas parecidas, bom eu comento a linha src-all e
descomenta apenas as partes do sistema que me é interessante tipo games mesmo eu não
uso então não preciso atualizar ela as linhas referentes a kerberos mesmo só atualizo
quando o sistema vai servir de base para tais aplicações caso contrario também não
atualizo tal parte assim economizo tempo, banda e dinheiro.
bom apos isso salva o arquivo e vamos atualizar os fontes do sistema.
como root rode o seguinte comando:
matilda#cvsup -g -L 2 /etc/standart-supfile
no caso o parâmetro "-g" é para rodar o cvsup em modo CLI e o parâmetro "-L 2" fala
quanto ao nível de debbuger no caso variando de 0-2..
bom se tudo ocorrer bem terá linhas parecidas com essas plotando no seu terminal:
matilda# cvsup -g -L 2 /etc/standard-supfile
Parsing supfile "/etc/standard-supfile"
Connecting to cvsup12.FreeBSD.org
Connected to cvsup12.FreeBSD.org
Server software version: SNAP_16_1h
Negotiating file attribute support
Exchanging collection information
Establishing multiplexed-mode data connection
Running
Updating collection src-all/cvs
bom quando aparecer uma mensagem colocando que a atualização foi realizada com
sucesso terá acabado a atualização e você terá o prompt devolvido para uso.
Com os fontes do sistema atualizado podemos agora retornar a compilação do kernel.
O ARQUIVO DE CONFIGURAÇÃO DO KERNEL
Bom, voltando a compilação do kernel, isso é claro nessa altura já teremos nossa árvore
de fontes do sistema sincronizadas com a última RELEASE STABLE da árvore
disponível nos mirrores de base do projeto FreeBSD.
O DIRETÓRIO "/usr/src/sys/i386/conf".
Nesse diretório encontramos a seguinte listagem de arquivos presentes sobre sua árvore:
matilda# cd /usr/src/sys/i386/conf/
matilda# ls -al /usr/src/sys/i386/conf/
total 96
drwxr-xr-x 2 root wheel 512 25 Jun 12:47 .
drwxr-xr-x 15 root wheel 512 8 Mai 19:37 ..
-rw-r--r-- 1 root wheel 13 20 Jun 2005 .cvsignore
-rw-r--r-- 1 root wheel 372 28 Out 2005 DEFAULTS
-rw-r--r-- 1 root wheel 10755 15 Dez 2007 GENERIC
-rw-r--r-- 1 root wheel 1741 14 Jan 2005 GENERIC.hints
-rw-r--r-- 1 root wheel 17878 25 Jun 12:47 LINT
-rw-r--r-- 1 root wheel 120 26 Fev 2003 Makefile
-rw-r--r-- 1 root wheel 35176 15 Dez 2007 NOTES
-rw-r--r-- 1 root wheel 2069 15 Dez 2007 PAE
-rw-r--r-- 1 root wheel 322 18 Set 2005 SMP
-rw-r--r-- 1 root wheel 7866 10 Mai 10:45 SOLDIER
-rw-r--r-- 1 root wheel 3389 23 Ago 2006 XBOX
matilda#
Bom estando dentro dele teremos os arquivos listados anteriormente, possivelmente e
com certeza dois arquivos presente na listagem não conterá na sua lista os respectivos
arquivos são o LINT e o MATILDA, entrarei em detalhes sobre eles mais tarde.
Voltando aos arquivos default que terão no seu sistema os principais sobre essa árvore é
o GENERIC e o NOTES.
O Arquivo GENERIC:
Esse arquivo é o arquivo de configuração padrão do kernel do FreeBSD. Nele se
encontra todas as especificações bases para o sistema poder ser bootado no maior
número de maquinas possíveis, com tão decisão o projeto coloca nele definições de
configurações cautelosas quem pode e consideravelmente faz o sistema ser um pouco
lento com o uso desse kernel mais mesmo assim ele e funcional em muitas aplicações.
Obs.: Assim como existe o arquivo GENERIC sobre a árvore de diretórios "/usr/src/sys/
i386/conf" o mesmo arquivo se encontrará presente sobre a árvore de diretório de sua
respectiva arquitetura como "/usr/src/sys/amd64/conf" destinado a arquiteturas x86-64,
"/usr/src/sys/sparc64/conf" destinado a arquiteturas dos processadores desenvolvidos
pela Sun Microsystens, "/usr/src/sys/ia64/conf" destinado a arquiteturas baseadas sobre
a dos processadores Itanium da Intel uma plataforma de hardware robusta que assim
como a da Sun MicroSystens destinadas a servidores de alta carga de trabalho, "/usr/src/
sys/pc98/conf" arquitetura disponivel apenas na Ásia, sendo ela uma arquitetura de pc
popular, "/usr/src/sys/alpha/conf" destinado a arquitetura desenvolvida pela HP, com o
mesmo ênfase da IA64 e da SPARC64, essa arquitetura será descontinuada apartir de
2011 como consta no site da HP, o que é uma pena pois é uma arquitetura de alto poder
de processamento e que colocou muitos conceitos entre o contexto das arquiteturas
RISC, como pipeline e outras que de momento não lembro, "/usr/src/sys/powerpc/conf"
Arquitetura RISC desenvolvida pela IBM que durante muito tempo reinou no mundo
dos Macs da Apple Inc, nas últimas informações até o momento apenas um mantenedor
é responsável por essa arquitetura o que a coloca como deficiente de muitos recursos
disponíveis já nas arquiteturas i386, amd64 e outras, isso tudo por que o uso dessa
arquitetura caiu muito no uso com a adoção da Apple por processadores Intel, mais se
você possuir um Xserver G5 ou G4 ou um POWERMAC G5, G4, G3, G2 essa é
ramificação da árvore dos fontes do kernel do freebsd que garantirá suporte para a sua
arquitetura, pode parecer estranho, mais apenas uma observação que foge um pouco no
escopo do nosso assunto, o kernel atual do sistema Mac OS X é FreeBSD e antes do
FreeBSD eles usava o Sistema DarwinBSD o único sistema BSD que não leva a licença
de Berkeley mais tem contribuído em muito com os demais projetos BSDs, antes dos
BSD reinar entre os Macs o sistema usado pela Apple era o OS2 que não confirmado
tem parte do seu código derivado das primeiras versões de Unix, mais não o suficiente
para considera-lo Unix. Bom mais voltando ao assunto....
Creio ter sitado todas as arquiteturas e seus respectivos locais onde se encontra os
arquivo de configuração do kernel dessas arquiteturas.
O CONTEÚDO DO ARQUIVO DE CONFIGURAÇÃO DO
KERNEL GENERIC PARA i386.
Abaixo segue o arquivo de configuração do kernel para a arquitetura i386... Não
colocarei de todas aqui por que alem de não ser necessário, será de certa forma
desnecessário e tomaria muito espaço com algo já escrito por outra pessoa, esse arquivo
será apenas por referencia para poder explicar alguns pontos importantes na edição
desse arquivo para a compilação do kernel.
#
# GENERIC -- Generic kernel configuration file for FreeBSD/i386
#
# For more information on this file, please read the handbook section on
# Kernel Configuration Files:
#
# http://www.FreeBSD.org/doc/en_US.ISO8859-1/books/handbook/kernelconfigconfig.html
#
# The handbook is also available locally in /usr/share/doc/handbook
# if you've installed the doc distribution, otherwise always see the
# FreeBSD World Wide Web server (http://www.FreeBSD.org/) for the
# latest information.
#
# An exhaustive list of options and more detailed explanations of the
# device lines is also present in the ../../conf/NOTES and NOTES files.
# If you are in doubt as to the purpose or necessity of a line, check first
# in NOTES.
#
# $FreeBSD: src/sys/i386/conf/GENERIC,v 1.429.2.14.2.1 2007/12/15 06:32:32 scottl
Exp $
machine i386
cpu I486_CPU
cpu I586_CPU
cpu I686_CPU
ident GENERIC
# To statically compile in device wiring instead of /boot/device.hints
#hints "GENERIC.hints" # Default places to look for devices.
makeoptions DEBUG=-g # Build kernel with gdb(1) debug symbols
options SCHED_4BSD # 4BSD scheduler
options PREEMPTION # Enable kernel thread preemption
options INET # InterNETworking
options INET6 # IPv6 communications protocols
options FFS # Berkeley Fast Filesystem
options SOFTUPDATES # Enable FFS soft updates support
options UFS_ACL # Support for access control lists
options UFS_DIRHASH # Improve performance on big directories
options MD_ROOT # MD is a potential root device
options NFSCLIENT # Network Filesystem Client
options NFSSERVER # Network Filesystem Server
options NFS_ROOT # NFS usable as /, requires NFSCLIENT
options MSDOSFS # MSDOS Filesystem
options CD9660 # ISO 9660 Filesystem
options PROCFS # Process filesystem (requires PSEUDOFS)
options PSEUDOFS # Pseudo-filesystem framework
options GEOM_GPT # GUID Partition Tables.
options COMPAT_43 # Compatible with BSD 4.3 [KEEP THIS!]
options COMPAT_FREEBSD4 # Compatible with FreeBSD4
options COMPAT_FREEBSD5 # Compatible with FreeBSD5
options SCSI_DELAY=5000 # Delay (in ms) before probing SCSI
options KTRACE # ktrace(1) support
options SYSVSHM # SYSV-style shared memory
options SYSVMSG # SYSV-style message queues
options SYSVSEM # SYSV-style semaphores
options _KPOSIX_PRIORITY_SCHEDULING # POSIX P1003_1B real-time
extensions
options KBD_INSTALL_CDEV # install a CDEV entry in /dev
options ADAPTIVE_GIANT # Giant mutex is adaptive.
device apic # I/O APIC
# Bus support.
device eisa
device pci
# Floppy drives
device fdc
# ATA and ATAPI devices
device ata
device atadisk # ATA disk drives
device ataraid # ATA RAID drives
device atapicd # ATAPI CDROM drives
device atapifd # ATAPI floppy drives
options UFS_DIRHASH # Improve performance on big directories
options MD_ROOT # MD is a potential root device
options NFSCLIENT # Network Filesystem Client
options NFSSERVER # Network Filesystem Server
options NFS_ROOT # NFS usable as /, requires NFSCLIENT
options MSDOSFS # MSDOS Filesystem
options CD9660 # ISO 9660 Filesystem
options PROCFS # Process filesystem (requires PSEUDOFS)
options PSEUDOFS # Pseudo-filesystem framework
options GEOM_GPT # GUID Partition Tables.
options COMPAT_43 # Compatible with BSD 4.3 [KEEP THIS!]
options COMPAT_FREEBSD4 # Compatible with FreeBSD4
options COMPAT_FREEBSD5 # Compatible with FreeBSD5
options SCSI_DELAY=5000 # Delay (in ms) before probing SCSI
options KTRACE # ktrace(1) support
options SYSVSHM # SYSV-style shared memory
options SYSVMSG # SYSV-style message queues
options SYSVSEM # SYSV-style semaphores
options _KPOSIX_PRIORITY_SCHEDULING # POSIX P1003_1B real-time
extensions
options KBD_INSTALL_CDEV # install a CDEV entry in /dev
options ADAPTIVE_GIANT # Giant mutex is adaptive.
device apic # I/O APIC
# Bus support.
device eisa
device pci
# Floppy drives
device fdc
# ATA and ATAPI devices
device ata
device atadisk # ATA disk drives
device ataraid # ATA RAID drives
device atapicd # ATAPI CDROM drives
device atapifd # ATAPI floppy drives
device atapist # ATAPI tape drives
options ATA_STATIC_ID # Static device numbering
# SCSI Controllers
device ahb # EISA AHA1742 family
device ahc # AHA2940 and onboard AIC7xxx devices
options AHC_REG_PRETTY_PRINT # Print register bitfields in debug
# output. Adds ~128k to driver.
device ahd # AHA39320/29320 and onboard AIC79xx devices
options AHD_REG_PRETTY_PRINT # Print register bitfields in debug
# output. Adds ~215k to driver.
device amd # AMD 53C974 (Tekram DC-390(T))
device isp # Qlogic family
#device ispfw # Firmware for QLogic HBAs- normally a module
device mpt # LSI-Logic MPT-Fusion
#device ncr # NCR/Symbios Logic
device sym # NCR/Symbios Logic (newer chipsets + those of `ncr')
device trm # Tekram DC395U/UW/F DC315U adapters
device adv # Advansys SCSI adapters
device adw # Advansys wide SCSI adapters
device aha # Adaptec 154x SCSI adapters
device aic # Adaptec 15[012]x SCSI adapters, AIC-6[23]60.
device bt # Buslogic/Mylex MultiMaster SCSI adapters
device ncv # NCR 53C500
device nsp # Workbit Ninja SCSI-3
device stg # TMC 18C30/18C50
# SCSI peripherals
device scbus # SCSI bus (required for SCSI)
device ch # SCSI media changers
device da # Direct Access (disks)
device sa # Sequential Access (tape etc)
device cd # CD
device pass # Passthrough device (direct SCSI access)
device ses # SCSI Environmental Services (and SAF-TE)
# RAID controllers interfaced to the SCSI subsystem
device amr # AMI MegaRAID
device arcmsr # Areca SATA II RAID
device asr # DPT SmartRAID V, VI and Adaptec SCSI RAID
device ciss # Compaq Smart RAID 5*
device dpt # DPT Smartcache III, IV - See NOTES for options
device hptmv # Highpoint RocketRAID 182x
device hptrr # Highpoint RocketRAID 17xx, 22xx, 23xx, 25xx
device rr232x # Highpoint RocketRAID 232x
device iir # Intel Integrated RAID
device ips # IBM (Adaptec) ServeRAID
device mly # Mylex AcceleRAID/eXtremeRAID
device twa # 3ware 9000 series PATA/SATA RAID
# RAID controllers
device aac # Adaptec FSA RAID
device aacp # SCSI passthrough for aac (requires CAM)
device ida # Compaq Smart RAID
device mfi # LSI MegaRAID SAS
device mlx # Mylex DAC960 family
device pst # Promise Supertrak SX6000
device twe # 3ware ATA RAID
# atkbdc0 controls both the keyboard and the PS/2 mouse
device atkbdc # AT keyboard controller
device atkbd # AT keyboard
device psm # PS/2 mouse
device kbdmux # keyboard multiplexer
device vga # VGA video card driver
device splash # Splash screen and screen saver support
# syscons is the default console driver, resembling an SCO console
device sc
# Enable this for the pcvt (VT220 compatible) console driver
#device vt
#options XSERVER # support for X server on a vt console
#options FAT_CURSOR # start with block cursor
device agp # support several AGP chipsets
# Power management support (see NOTES for more options)
#device apm
# Add suspend/resume support for the i8254.
device pmtimer
# PCCARD (PCMCIA) support
# PCMCIA and cardbus bridge support
device cbb # cardbus (yenta) bridge
device pccard # PC Card (16-bit) bus
device cardbus # CardBus (32-bit) bus
# Serial (COM) ports
device sio # 8250, 16[45]50 based serial ports
# Parallel port
device ppc
device ppbus # Parallel port bus (required)
device lpt # Printer
device plip # TCP/IP over parallel
device ppi # Parallel port interface device
#device vpo # Requires scbus and da
# If you've got a "dumb" serial or parallel PCI card that is
# supported by the puc(4) glue driver, uncomment the following
# line to enable it (connects to the sio and/or ppc drivers):
#device puc
# PCI Ethernet NICs.
device de # DEC/Intel DC21x4x (``Tulip'')
device em # Intel PRO/1000 adapter Gigabit Ethernet Card
device ixgb # Intel PRO/10GbE Ethernet Card
device txp # 3Com 3cR990 (``Typhoon'')
device vx # 3Com 3c590, 3c595 (``Vortex'')
# PCI Ethernet NICs that use the common MII bus controller code.
# NOTE: Be sure to keep the 'device miibus' line in order to use these NICs!
device miibus # MII bus support
device bce # Broadcom BCM5706/BCM5708 Gigabit Ethernet
device bfe # Broadcom BCM440x 10/100 Ethernet
device bge # Broadcom BCM570xx Gigabit Ethernet
device dc # DEC/Intel 21143 and various workalikes
device fxp # Intel EtherExpress PRO/100B (82557, 82558)
device lge # Level 1 LXT1001 gigabit Ethernet
device msk # Marvell/SysKonnect Yukon II Gigabit Ethernet
device nge # NatSemi DP83820 gigabit Ethernet
device nve # nVidia nForce MCP on-board Ethernet Networking
device pcn # AMD Am79C97x PCI 10/100(precedence over 'lnc')
device re # RealTek 8139C+/8169/8169S/8110S
device rl # RealTek 8129/8139
device sf # Adaptec AIC-6915 (``Starfire'')
device sis # Silicon Integrated Systems SiS 900/SiS 7016
device sk # SysKonnect SK-984x & SK-982x gigabit Ethernet
device ste # Sundance ST201 (D-Link DFE-550TX)
device stge # Sundance/Tamarack TC9021 gigabit Ethernet
device ti # Alteon Networks Tigon I/II gigabit Ethernet
device tl # Texas Instruments ThunderLAN
device tx # SMC EtherPower II (83c170 ``EPIC'')
device vge # VIA VT612x gigabit Ethernet
device vr # VIA Rhine, Rhine II
device wb # Winbond W89C840F
device xl # 3Com 3c90x (``Boomerang'', ``Cyclone'')
# ISA Ethernet NICs. pccard NICs included.
device cs # Crystal Semiconductor CS89x0 NIC
# 'device ed' requires 'device miibus'
device ed # NE[12]000, SMC Ultra, 3c503, DS8390 cards
device ex # Intel EtherExpress Pro/10 and Pro/10+
device ep # Etherlink III based cards
device fe # Fujitsu MB8696x based cards
device ie # EtherExpress 8/16, 3C507, StarLAN 10 etc.
device lnc # NE2100, NE32-VL Lance Ethernet cards
device sn # SMC's 9000 series of Ethernet chips
device xe # Xircom pccard Ethernet
# Wireless NIC cards
device wlan # 802.11 support
device wlan_wep # 802.11 WEP support
device wlan_ccmp # 802.11 CCMP support
device wlan_tkip # 802.11 TKIP support
device an # Aironet 4500/4800 802.11 wireless NICs.
device ath # Atheros pci/cardbus NIC's
device ath_hal # Atheros HAL (Hardware Access Layer)
device ath_rate_sample # SampleRate tx rate control for ath
device awi # BayStack 660 and others
device ral # Ralink Technology RT2500 wireless NICs.
device wi # WaveLAN/Intersil/Symbol 802.11 wireless NICs.
#device wl # Older non 802.11 Wavelan wireless NIC.
# Pseudo devices.
device loop # Network loopback
device random # Entropy device
device ether # Ethernet support
device sl # Kernel SLIP
device ppp # Kernel PPP
device tun # Packet tunnel.
device pty # Pseudo-ttys (telnet etc)
device md # Memory "disks"
device gif # IPv6 and IPv4 tunneling
device faith # IPv6-to-IPv4 relaying (translation)
# The `bpf' device enables the Berkeley Packet Filter.
# Be aware of the administrative consequences of enabling this!
# Note that 'bpf' is required for DHCP.
device bpf # Berkeley packet filter
# USB support
device uhci # UHCI PCI->USB interface
device ohci # OHCI PCI->USB interface
device ehci # EHCI PCI->USB interface (USB 2.0)
device usb # USB Bus (required)
#device udbp # USB Double Bulk Pipe devices
device ugen # Generic
device uhid # "Human Interface Devices"
device ukbd # Keyboard
device ulpt # Printer
device umass # Disks/Mass storage - Requires scbus and da
device ums # Mouse
device ural # Ralink Technology RT2500USB wireless NICs
device urio # Diamond Rio 500 MP3 player
device uscanner # Scanners
# USB Ethernet, requires miibus
device aue # ADMtek USB Ethernet
device axe # ASIX Electronics USB Ethernet
device cdce # Generic USB over Ethernet
device cue # CATC USB Ethernet
device kue # Kawasaki LSI USB Ethernet
device rue # RealTek RTL8150 USB Ethernet
# FireWire support
device firewire # FireWire bus code
device sbp # SCSI over FireWire (Requires scbus and da)
device fwe # Ethernet over FireWire (non-standard!)
Bom não irei entrar em detalhes sobre cada linha pois alem das disponíveis nesse
arquivo a outras em que entrarei em detalhes mais tarde indicando onde elas se
encontra. Se observar bem verá que o arquivo é dividido em sessão apenas por
organização, até a série 4.x do FreeBSD a ordem nesse arquivo em que as opções de
configuração se encontrava interferiam severamente no processo de compilação do
sistema.
Passei varias noites resolvendo dependências na compilação de kernels sobre a série 4.x.
hoje a compilação do sistema se torno tão bem escrita que em poucos casos acontece
alguns problemas.
Bom vamos descrever as sessões desse arquivo:
AS SESSÕES DO ARQUIVO DE CONFIGURAÇÃO DO
SISTEMA.
Primeira Sessão: Definição da Sub-arquitetura da Máquina.
Como em tudo na tecnologia sofre evolução não seria diferente com os processadores,
apenas exemplo, sobre a arquitetura i386 temos as seguintes sub-arquiteturas ou classes
da arquitetura.
i386 -> i486 -> i586 ->PENTIUM ou i686, como pode ver existe uma linha de
desenvolvimento de uma sub-arquitetura para outra mais em todas o código da
arquitetura mais antiga é suportado nas mais recentes. Bom com isso nessa sessão do
arquivo de configuração se defini a arquitetura e a sub-arquitetura no qual estamos
compilando e que abrigará o sistema.
Segunda Sessão: Opções Gerais do Kernel.
Nessa sessão são declaradas as opções que em algum caso não se pode retirar do kernel,
com pena de ocorrer erros durante a compilação em si ou até com erros no processo do
boot do sistema após a instalação do kernel compilado na máquina.
Nessa sessão tem-se definidas referências sobre Redes, Sistema de arquivos,
Compatibilidades com versões passadas e de outros sistemas como a compatibilidade
linux, Schenduler empregado no sistema como o conhecido 44BSD ou o SMP, Padrões
que o código do sistema segue entre outras configurações relacionada a sistema e suas
funcionalidades.
Terceira Sessão: Dispositivos e Barramentos suportados pelo Sistema.
Nas próximas sessões o que se segue são definições de barramento suportado pelo
sistema, e devices que ele possui, subdividas em outras sessões com suporte a discos
barramento EIDE e IDE, barramento de dispositivos de armazenamento SCSI,
disposivos virtuais como drivers de X11R6, splash, sessão de controladoras com
tecnologia RAID, sessão de dispositivos de entrada, como teclado, mouse..., sessão de
suporte a PCMCIA, portas paralelas e seriais, dispositivos de rede, tanto de
10/100/1000, wireless, sessão de pseudo dispositivos para o kernel, sessão de suporte a
dispositivos USBs, sessão de suporte a dispositivos Firewire. Não está 100% listado
aqui, pois a leitura desse arquivo é de melhor valia do que comentários meus, sempre na
frente de cada opção encontra-se presente uma breve descrição para qual função é
adicionada ao sistema quando tal opção é compilado no kernel.
O ARQUIVO "NOTES".
O Arquivo NOTES contém, contéudo de suma valia no quesito de customização e
adicionamento de novos recursos ao sistema, ele apresenta junto uma descrição melhor
do que a presente no arquivo GENERIC e quando o assunto é muito extenso passa
referência para se conseguir melhores informações sobre tão informação.
Além do arquivo NOTES disponível sobre a arvore "/usr/src/sys/$arch/conf" do sistema
temos também outros arquivos com breves descrições sobre o sistema como o "/usr/src/
sys/conf/NOTES" informações sobre partes do sistema como sobre geom disponivel
sobre a arvore "/usr/src/sys/geom/notes" sendo o arquivo escrito com letras minusculas,
subsistema NETGraph encontrado na árvore: "/usr/src/sys/netgraph/NOTES", além de
outros disponíveis em diretórios específicos de documentação para utilização e
administração do sistema.
Sem duvida que todos os arquivos aqui descritos e outros são importantes para um
melhor controle do sistema ainda mais no processo de compilação do mesmo, mais o
que julgo de maior importância são os NOTES disponíveis sobre a arvores,
"/usr/src/sys/conf", "/usr/src/sys/$arch/conf", pois neles se descreve o maior numero de
detalhes sobre suporte e recursos oferecidos pelo FreeBSD após uma compilação de
kernel.
COMPILANDO O KERNEL DO SISTEMA
Após todo esse ritual vem o tão sonhado e esperado ritual maior, compilando o sistema.
Com o arquivo de configuração do kernel pronto disposto no diretório de configuração
da sua arquitetura seguimos determinados passos.
matilda# make buildkernel KERNCONF=MATILDA
No caso o “MATILDA” é o nome do kernel especificado na opção “ident” no arquivo
de configuração do kernel.
Logo depois desse longo e demorado sistema vira a segunda parte muito importante.
matilda#make installkernel KERNCONF=MATILDA
Com esse comando o kernel será instalado, bastando para depois de concluido a
instalação rebootar o sistema para verificar se ele está 100% ou tem alguma coisa
errada.
Com esse modo de compilação só tive um problema até hoje mais erro na edição do
arquivo de configuração do kernel.
Assim que reinstalar o kernel novo, convém reiniciar o sistema para que ele boot com o
novo kernel e possa aplica a ultima parte de nossa aventura.
matilda#mergemaster -p
Esse comando irá verificar os arquivos que ele gerou cm os presentes contido no /etc do
sistema se tiver alguma coisa diferente atravez de comparações e as ocorrencias que
aparecer leia e verifique qual eh a sua opção, no final após o ultimo reboot teremos
nosso sistema atualizado e o kernel customizado por nós.