Aula 1 - Felipe Silveira

Transcrição

Aula 1 - Felipe Silveira
Android Core
Felipe Silveira
felipesilveira.com.br
Aula 1
Android?
Sistema Operacional + Plataforma de desenvolvimento + Aplicações Padrão
(SMS, Maps, Calendar...)
Código aberto (AOSP - Android Open Source Project)
Desenvolvido pelo Google e posteriormente pela Open Handset Alliance
Histórico
2003: Andy Rubin, Rich Miner, Nick Sears e Chris White
fundam a Android, Inc
2005: Google efetua a compra da Android, Inc
2007: Open Handset Alliance announced along with
Android
2008 - Android 1.0 is released
Histórico
2009 - Android 1.1
2009 - Android 1.5 / Cupcake
2009 - Android 1.6 / Donut
2009 - Android 2.0/2.1 / Eclair
2010 - Android 2.2 / Froyo
2010 - Android 2.3 / Gingerbread
2011 - Android 3.0 / Honeycomb – Tablet-optimized
2011 – Android 3.1 – USB host support
2011 – Android 4.0 / Ice-Cream Sandwich – merge
Gingerbread and Honeycomb22
2012 -Android 4.1 / Jelly Bean
Compilando Android
Requisitos Mínimos
● Ubuntu 10.04 LTS
● Ambiente 64 bits
● 30 GB de disco
● Python 2.7
● GNU make 3.82
● JDK 6
● Git 1.7
Ccache
Ferramenta utilitária para tornar o processo de
compilação mais rápido
$ export USE_CCACHE=1
$ ccache -M 10G
Dependências
Para instalar as dependências, pode-se usar o seguinte
comando:
$ sudo apt-get install git-core gnupg flex bison gperf
build-essential \
zip curl zlib1g-dev libc6-dev lib32ncurses5-dev ia32-libs
\
x11proto-core-dev libx11-dev lib32readline5-dev lib32zdev \
libgl1-mesa-dev g++-multilib mingw32 tofrodos pythonmarkdown \
libxml2-utils xsltproc
Repo
Para instalar o Repo, pode-se usar o seguinte comando:
$ sudo apt-get install curl
$ curl https://dl-ssl.google.com/dl/googlesource/gitrepo/repo > ~/bin/repo $ chmod a+x ~/bin/repo
$ chmod a+x ~/bin/repo
Git
Para instalar o Git, pode-se usar o seguinte comando:
$ sudo apt-get install git
Fazendo download do código
Crie um diretório vazio para armazenar seus arquivos de
trabalho. Dê-lhe o nome que quiser:
$ mkdir working_directory
$ cd working_directory
Execute o repo init
$ repo init -u https://android.googlesource.
com/platform/manifest
ou
$ repo init -u https://android.googlesource.
com/platform/manifest -b android-4.0.1_r1
Fazendo download do código
Execute o comando sync:
$ repo sync
ou:
$ repo sync - jN
Repositórios alternativos
Linaro
Projeto com suporte a diversos SoCs ARM (system on a chip)
Rowboat
Projeto com suporte a dispositivos usando os chips TI Sitara (como a
BeagleBoard XM e a BeagleBone)
Cyanogen Mod
Projeto comunitário que visa a construção de ROMs para vários telefones
comerciais.
https://github.com/cyanogenmod
Entendendo o repositório
bionic - a biblioteca C-runtime para o Android. Note que o
Android não está usando o glibc como a maioria das
distribuições Linux. Em vez disso a biblioteca c é chamado
de bionic e é baseada principalmente em fontes de
derivados do BSD. Neste diretório, você vai encontrar os
arquivos fonte para a c-lib, matemática e outras
bibliotecas de runtime.
Entendendo o repositório
bootable - inicialização e código relacionado a
inicialização. Neste diretório se encontra o código fonte do
bootloader a a implementação do protocolo fastboot.
Entendendo o repositório
build - a implementação do sistema de build, incluindo
todos os makefiles. Um arquivo importante aqui é o script
envsetup.sh que vai ajudá-lo muito quando se trabalha
com a fonte da plataforma. Este arquivo será executado
posteriormente para configurar as variáveis ​de ambiente e
compilar módulos específicos.
Entendendo o repositório
cts - os testes de compatibilidade. O conjunto de testes
para garantir que a build está em conformidade com a
especificação do Android. Iremos falarar mais a respeito
dessas ferramentas posteriormente.
Entendendo o repositório
dalvik - o código fonte da Dalvik Virtual Machine
Entendendo o repositório
development - projetos relacionados ao desenvolvimento
de aplicações, tais como o código-fonte do SDK e NDK.
Entendendo o repositório
device - código específico do produto para diferentes
dispositivos. Este é o lugar para encontrar módulos de
hardware para os diferentes dispositivos Nexus ,
configurações de compilação e muito mais.
Entendendo o repositório
external - contém o código fonte para todos os projetos
de código aberto externos, tais como SQLite, Freetype e
webkit.
Entendendo o repositório
frameworks - esta pasta é essencial para o Android , uma
vez que contém todo o código do framework . Aqui você
vai encontrar a implementação de serviços essenciais
como o System Server, que contém o PackageManager.
Uma grande parte do mapeamento entre as APIs
aplicação java e as bibliotecas nativas também é feito
aqui.
Entendendo o repositório
hardware - código-fonte relacionado ao hardware, como
a especificação de camada de abstração de hardware
Android (HAL - Hardware Abstraction Layer). Esta pasta
também contém a camada de interface de rádio (para
comunicação com modem).
Entendendo o repositório
out - o diretório que contém os artefatos resultantes da
compilação.
Entendendo o repositório
packages - contém o código fonte para os aplicativos
padrão, como contatos, calendário, navegador.
Entendendo o repositório
prebuilts - contém arquivos que são distribuídos em
forma binária por conveniência. Exemplos: toolchain,
emulator kernel
Entendendo o repositório
system - arquivos de código fonte para o núcleo do
sistema Android. Esse é o sistema Linux mínimo que é
iniciado antes do Dalvik VM e quaisquer serviços baseados
em Java são ativados. Isso inclui o código fonte para o
processo de inicialização e o script init.rc padrão que
fornecem a configuração dinâmica da plataforma
Compilando
$ ccache -M 10G
$ . build/envsetup.sh
$ set_stuff_for_environment
Seleção de target
$ lunch full-eng
Build name
Device
Notas
full
emulator
build completa
com todas linguagens,
aplicações, input methods
full_maguro
maguro
build completa
para o Galaxy Nexus
GSM/HSPA+ ("maguro")
full_panda
panda
build completa
para a PandaBoard
("panda")
Seleção de target
Buildtype
Uso
user
acesso limitado; comumente
usado para builds de produção
userdebug
configuração parecida com user,
porém com acesso root e debug
eng
configuração de
desenvolvimento, com algumas ferramentas de
debug adicionais.
Enfim, Compilando
$ make
ou
$ make -jN
Executando o emulador
$ emulator
ADB
O ADB (Android debug bridge) é uma ferramenta utilizada
para acessar muitos dos recursos do emulador e de um
telefone anexado ao computador via USB
$ adb devices
$ adb -help
Arquitetura Android
Arquitetura Android
Por que Linux Kernel?
• Gerenciador de memória e processos estável
• Suporte para shared libraries
• Open source!
Modificações Android
Ashmem - Anonymous shared memory - Implementação
Android para o gerenciador de memória compartilhada
entre processos.
Modificações Android
Binder - Implementação do OpenBinder para android,
contendo também a implementação da runtime AIDL.
Desenvolvido para resolver a necessidade de execução de
código em processos separados (Aplicações e Serviços)
sem o overhead que o IPC introduziria
Modificações Android
Low Memory Killer - Mecanismo para matar processos
quando o sistema está sendo executado com pouca
memória.
Modificações Android
Logging - Mecanismo de logging do android, via /dev/log
Modificações Android
Pmem - Process memory allocator - driver de alocação de
memória física para os processos
Modificações Android
WakeLocks - Mecanismo de gerência de energia,
otimizado para dispositivos móveis. O controle dos
wakelocks é exposto à camada de aplicações através do
componente PowerManager.
Modificações Android
Alarm Timers - Suporte na camada de kernel para o
AlarmManager, que permite que o sistema "acorde"
depois de certos eventos.
Modificações Android
RAM Console - Extensão que permite ao kernel fazer um
dump de dados importante para a memória RAM do
device quando ocorre um 'pânico' - o sistema é reiniciado
por alguma falha.
Libraries
Surface Manager: gerencia o acesso ao display do
dispositivo e camadas de gráficos 2D e 3D de múltiplas
aplicações.
Libraries
Media Framework: as bibliotecas suportam execução e
gravação da maioria dos formatos de áudio e vídeo, bem
como exibição de imagens, incluindo MPEG4, H.264, MP3,
AAC, AMR, JPG, e PNG.
Libraries
Webkit: engine de navegador web usada na
implementação do browser nativo e também na
implementação dos widgets de webview.
Libraries
SGL: uma engine de gráficos 2D.
Libraries
3D libraries: uma implementação baseada na
especificação OpenGL ES 1.0, a qual utiliza tanto
aceleração de hardware 3D e um avançado e otimizado
software para renderização de modelos tridimensionais.
Libraries
FreeType: renderização de fontes em formatos bitmaps e
vetoriais.
Libraries
SQLite: um SGBD (Sistema gerenciador de banco de
dados) relacional e otimizado para ocupar pouco espaço e
ser suficiententemente rápido.
Libraries
Biblioteca de sistema C (libc): é uma implementação da
biblioteca C padrão, otimizada para dispositivos que
suportam a plataforma Linux (embbeded- linux). A
implementação da libc em Android é conhecida como
Bionic e tem características muito importantes:
Tamanho Reduzido e Velocidade
Android Runtime
Android possui sua própria máquina virtual Java: A Dalvik
VM, mais rápida e leve, com set de instruções menor do
que a JVM.
Android Runtime
Existe um passo adicional, que é a conversão dos arquivos
.class em .dex, que são reconhecidos e executados pela
Dalvik VM.
Android Runtime
Na inicialização do sistema, é criado um processo para a
máquina virtual chamado Zygote. A partir desse processo,
outras instâncias da máquina virtual são criadas com
fork() quando necessário para executar outras aplicações.
Android Runtime
Para completar a camada de Android Runtime, temos as
core libraries, que sofreram pouca ou nenhuma
modificação no projeto AOSP. São elas: Data structures,
Utilities, File access, Network Access, Graphics, etc.
Application Framework
Acima das camadas de Libraries e Runtime está a camada
Application Framework. Esta é a camada responsável
por prover às aplicações APIs amigáveis que permitem o
acesso às funcionalidades da plataforma.
Application Framework
Activity Manager - Gerencia o ciclo de vida de aplicações.
Responsável por iniciar, parar e retomar as diversas
aplicações.
Application Framework
Window Manager - Responsável por renderizar a UI.
Application Framework
Package Manager - Instala / remove aplicativos
Application Framework
Telephony Manager - Permite a interação com os
serviços de telefonia, como SMS e MMS.
Application Framework
Content Providers - O componente responsável por
compartilhar dados entre aplicações.
Application Framework
Resource Manager - Gerenciamento de recursos de
aplicações - por exemplo, imagens, sons, etc
Application Framework
View System - Fornece às aplicações os widgets (como
botões, listas, etc) e gerencia seu comportamento.
Application Framework
Location Manager - Permite que as aplicações acessem
serviços baseados em localização seja por GPS, celltower
IDs, ou bancos de dados Wi-Fi locais.
Application Framework
XMPP - Mecanismo de troca de mensagens entre
aplicações.
Applications
A última camada da stack Android - Applications - contém
as aplicações, que apresentam conteúdo ao usuárioe
interage com este diretamente.
Existem algumas aplicações que já vem embutidas na
plataforma, como o cliente de Email, de SMS, Calendário,
Mapas, Navegador, Home Screen, Contatos e outros.
Applications
Nessa camada comumente temos diversas customizações
feitas pelas fabricantes de celular, como o MotoBlur, da
Motorola, o Sense da HTC e o TouchWiz, da Samsung. Essa
flexibilidade contribuiu para a adoção da plataforma por
diversos fabricantes e sua decorrente popularização.