(→Mission) |
(Removed one level from the headings) |
||
| Line 1: | Line 1: | ||
| - | + | ''' !!! THIS IS STILL A DRAFT !!! ''' | |
This document describes the MeeGo 1.1 Application SDK contents and how we get there. It should include but not limit to: | This document describes the MeeGo 1.1 Application SDK contents and how we get there. It should include but not limit to: | ||
| Line 7: | Line 7: | ||
* Resources allocated with clear R&R | * Resources allocated with clear R&R | ||
| - | + | == Mission == | |
* Delivering MeeGo SDK for developers to develop MeeGo Applicaitons at best chance running across platforms and segments(netbook, handset, tablet and TV..). | * Delivering MeeGo SDK for developers to develop MeeGo Applicaitons at best chance running across platforms and segments(netbook, handset, tablet and TV..). | ||
| Line 17: | Line 17: | ||
The application SDK should run on multiple different host environments (Linux, Win, Mac). In general all the parts of the Application SDK should run similarly on all the hosts! Still it is possible that we will have features that will only work on some of the hosts or with only some of the targets. This aspect should be considered in the SDK architecture. | The application SDK should run on multiple different host environments (Linux, Win, Mac). In general all the parts of the Application SDK should run similarly on all the hosts! Still it is possible that we will have features that will only work on some of the hosts or with only some of the targets. This aspect should be considered in the SDK architecture. | ||
| - | + | == Key Drivers == | |
* MeeGo Application SDK which allows developers to use any host and develop to any target with a similar manner. | * MeeGo Application SDK which allows developers to use any host and develop to any target with a similar manner. | ||
| Line 28: | Line 28: | ||
| - | + | == Project Group == | |
This chapter lists the people involved an their responsibilities. | This chapter lists the people involved an their responsibilities. | ||
| Line 35: | Line 35: | ||
| - | + | == Schedule == | |
| - | + | === Milestones === | |
{| class="wikitable" border=1 | {| class="wikitable" border=1 | ||
| Line 54: | Line 54: | ||
|} | |} | ||
| - | + | === Meetings === | |
| - | + | == Architecture of MeeGo SDK == | |
| - | + | == Integration, Distribution and Installation of MeeGo SDK == | |
How MeeGo SDK components to be integrated and distributed | How MeeGo SDK components to be integrated and distributed | ||
| Line 64: | Line 64: | ||
** QT Creator | ** QT Creator | ||
** QEMU | ** QEMU | ||
| - | ** | + | ** Xephyr |
** Mad-developer | ** Mad-developer | ||
| Line 81: | Line 81: | ||
| - | + | == Quality Assurance == | |
*QA should cover: | *QA should cover: | ||
| Line 92: | Line 92: | ||
** Other tools, like packaging tool, performance tunning tools. | ** Other tools, like packaging tool, performance tunning tools. | ||
| - | + | == Key Components of MeeGo SDK == | |
The components of MeeGo Application SDK are listed in this section. Each component should have a responsible, package maintainer and some status information as we go along. | The components of MeeGo Application SDK are listed in this section. Each component should have a responsible, package maintainer and some status information as we go along. | ||
| - | + | === Qt Creator === | |
Qt Creator is the chosen IDE for MeeGo Application SDK. | Qt Creator is the chosen IDE for MeeGo Application SDK. | ||
| Line 108: | Line 108: | ||
** Adding MADDE targets seems somewhat complicated | ** Adding MADDE targets seems somewhat complicated | ||
| - | + | ====Compiling plugins==== | |
The compiling plugins are used for compiling and packaging the software with different tools (MADDE / OBS). The end result should be installable application RPM. | The compiling plugins are used for compiling and packaging the software with different tools (MADDE / OBS). The end result should be installable application RPM. | ||
| - | + | =====MADDE plugin===== | |
This plugin uses MADDE for compiling and packaging the software. | This plugin uses MADDE for compiling and packaging the software. | ||
| Line 121: | Line 121: | ||
** Just a dream | ** Just a dream | ||
| - | + | ===== OBS plugin ===== | |
This plugin uses OBS for compiling and packaging the software. | This plugin uses OBS for compiling and packaging the software. | ||
| Line 130: | Line 130: | ||
** Just a dream | ** Just a dream | ||
| - | + | ==== Run plugins ==== | |
The run plugins are used for installing, running and debugging the software. In general the plugin could use e.g. MADDE to provide this feature. | The run plugins are used for installing, running and debugging the software. In general the plugin could use e.g. MADDE to provide this feature. | ||
| - | + | ===== Qemu plugin ===== | |
This plugin provides the possibility to use Qemu for "Run plugin" features. This plugin uses MADDE. | This plugin provides the possibility to use Qemu for "Run plugin" features. This plugin uses MADDE. | ||
| Line 143: | Line 143: | ||
** Just a dream | ** Just a dream | ||
| - | + | ===== Device run plugin ===== | |
This plugin provides the possibility to use real devices for "Run plugin" features. This plugin uses MADDE. | This plugin provides the possibility to use real devices for "Run plugin" features. This plugin uses MADDE. | ||
| Line 152: | Line 152: | ||
** Just a dream | ** Just a dream | ||
| - | + | ===== Xephyr plugin ===== | |
This plugin provides the possibility to use Xephyr (and chroot) for "Run plugin" features. | This plugin provides the possibility to use Xephyr (and chroot) for "Run plugin" features. | ||
| Line 161: | Line 161: | ||
** Just a dream | ** Just a dream | ||
| - | + | ==== Debugging plugins ==== | |
These plugins are used for debugging in Qt Creator. These could use MADDE for running the debuggers etc. and different kind of methods for visualization. | These plugins are used for debugging in Qt Creator. These could use MADDE for running the debuggers etc. and different kind of methods for visualization. | ||
| - | + | ===== Valgrind ===== | |
TODO | TODO | ||
| Line 174: | Line 174: | ||
** Just a dream | ** Just a dream | ||
| - | + | ===== Oprofile ===== | |
TODO | TODO | ||
| Line 184: | Line 184: | ||
| - | + | === MADDE === | |
MADDE is multiplatform toolset for compiling, running, debugging and testing. | MADDE is multiplatform toolset for compiling, running, debugging and testing. | ||
| Line 197: | Line 197: | ||
** Not part of the OBS builds yet | ** Not part of the OBS builds yet | ||
| - | + | === Compiling === | |
Compiling is done with combination of a cross-compiler and a sysroot which | Compiling is done with combination of a cross-compiler and a sysroot which | ||
includes target headers and libraries. Compilers come with MADDE. | includes target headers and libraries. Compilers come with MADDE. | ||
| - | + | ==== Hosts and Targets ==== | |
Status of the supported hosts and targets: | Status of the supported hosts and targets: | ||
| Line 227: | Line 227: | ||
|} | |} | ||
| - | + | ===== Sysroots ===== | |
Sysroot is a collection of target headers and libraries which are used by the compilers to compile the software. | Sysroot is a collection of target headers and libraries which are used by the compilers to compile the software. | ||
| Line 251: | Line 251: | ||
|} | |} | ||
| - | + | ===== Cross-Compilers ===== | |
Cross-compiler status per host and responsibles: | Cross-compiler status per host and responsibles: | ||
| Line 294: | Line 294: | ||
|} | |} | ||
| - | + | === Running === | |
With MADDE the application developer can create RPM package on any host | With MADDE the application developer can create RPM package on any host | ||
| Line 300: | Line 300: | ||
emulation. | emulation. | ||
| - | + | ==== RPM support ==== | |
RPM packager is created with ... | RPM packager is created with ... | ||
| Line 325: | Line 325: | ||
|} | |} | ||
| - | + | ==== Targets (devices / Emulation) ==== | |
| - | + | ===== Aava ===== | |
| - | ===== | + | ===== CDK ===== |
| + | ===== N900 ===== | ||
| - | + | ||
| + | ===== Qemu ===== | ||
The status and the responsible of the Qemu on different host platforms. | The status and the responsible of the Qemu on different host platforms. | ||
| Line 375: | Line 377: | ||
|} | |} | ||
| - | + | ====== Qemu Images ====== | |
The Qemu images are images used with the QEMU full system emulation. The images are as similar as possible to the actual device images. | The Qemu images are images used with the QEMU full system emulation. The images are as similar as possible to the actual device images. | ||
| Line 398: | Line 400: | ||
| - | + | === Testing & Debugging tools === | |
What do we have? | What do we have? | ||
| - | + | == Documentation of MeeGo SDK == | |
The Documentation of MeeGo SDK tells how to install/set up MeeGo SDK on any host machine, how to get started to use SDK to create first MeeGo applicaiton, including creating project, editing, compiling and building and remotely deploying and debuging applicaton. | The Documentation of MeeGo SDK tells how to install/set up MeeGo SDK on any host machine, how to get started to use SDK to create first MeeGo applicaiton, including creating project, editing, compiling and building and remotely deploying and debuging applicaton. | ||
Supported APIs are also important part of SDK docmentation. | Supported APIs are also important part of SDK docmentation. | ||
!!! THIS IS STILL A DRAFT !!!
This document describes the MeeGo 1.1 Application SDK contents and how we get there. It should include but not limit to:
Contents |
MeeGo 1.1 Application SDK is going to be the first MeeGo Application SDK release created in collaboration between MeeGo partners (Nokia & Intel at this point). The Application SDK is mainly targetted for Application developers who are interested in creating new applications for MeeGo platform.
The application SDK should run on multiple different host environments (Linux, Win, Mac). In general all the parts of the Application SDK should run similarly on all the hosts! Still it is possible that we will have features that will only work on some of the hosts or with only some of the targets. This aspect should be considered in the SDK architecture.
This chapter lists the people involved an their responsibilities.
| id | Date | Short description |
|---|---|---|
| M1 | 20100630 | Project start (Targets set, resources allocated...) |
| M2 | 2010???? | Beta release... |
How MeeGo SDK components to be integrated and distributed
The components of MeeGo Application SDK are listed in this section. Each component should have a responsible, package maintainer and some status information as we go along.
Qt Creator is the chosen IDE for MeeGo Application SDK.
The compiling plugins are used for compiling and packaging the software with different tools (MADDE / OBS). The end result should be installable application RPM.
This plugin uses MADDE for compiling and packaging the software.
This plugin uses OBS for compiling and packaging the software.
The run plugins are used for installing, running and debugging the software. In general the plugin could use e.g. MADDE to provide this feature.
This plugin provides the possibility to use Qemu for "Run plugin" features. This plugin uses MADDE.
This plugin provides the possibility to use real devices for "Run plugin" features. This plugin uses MADDE.
This plugin provides the possibility to use Xephyr (and chroot) for "Run plugin" features.
These plugins are used for debugging in Qt Creator. These could use MADDE for running the debuggers etc. and different kind of methods for visualization.
TODO
TODO
MADDE is multiplatform toolset for compiling, running, debugging and testing. It provides same API for underlying tools on all the host platforms. MADDE can be used from commandline or from IDE. Primary IDE is Qt Creator but others, like eclipse, can be supported too (although not in this project).
Compiling is done with combination of a cross-compiler and a sysroot which includes target headers and libraries. Compilers come with MADDE.
Status of the supported hosts and targets:
| MeeGo chroot | Ubuntu 32bit | Ubuntu 64bit | Fedora 32bit | Fedora 64bit | Windows 7 | Mac OS X | |
|---|---|---|---|---|---|---|---|
| ARMv5 - (cs2007q3) | ? | ||||||
| ARMv7 - (cs2007q3) | ? | ||||||
| Intel (gcc-...) | ok |
Sysroot is a collection of target headers and libraries which are used by the compilers to compile the software.
Sysroot responsibles and statuses:
| sysroot | Responsible | Status |
|---|---|---|
| ARMv5 | Fathi Boudra | Work in progress |
| ARMv7 | Fathi Boudra | Work in progress |
| Intel | ? | ? |
Cross-compiler status per host and responsibles:
| ARM-cs2007q3 | ARM-MeeGo 4.? | Intel-MeeGo 4.? | ||
|---|---|---|---|---|
| MeeGo chroot | (not planned) | (not planned) | (ok) | ? |
| Ubuntu 32bit | (ok) | Martti Lumme (work in progress) | ||
| Ubuntu 64bit | (ok) | |||
| Fedora 32bit | (ok) | |||
| Fedora 64bit | (ok) | |||
| Windows 7 | (ok) | |||
| Mac OS X | (ok) |
With MADDE the application developer can create RPM package on any host environment, transfer and run the software on the device or in the emulation.
RPM packager is created with ...
The status of the RPM support on different host platforms.
| Host | RPM creation | Transfer | Run |
|---|---|---|---|
| Ubuntu 32bit | |||
| Ubuntu 64bit | |||
| Fedora 32bit | |||
| Fedora 64bit | |||
| Windows 7 | |||
| Mac OS X |
The status and the responsible of the Qemu on different host platforms.
| ARMv5 (N900) | ARMv7 (N900) | Intel (Aava?) | |
|---|---|---|---|
| Ubuntu 32bit | Riku Voipio (ok) | Riku Voipio (ok) | ? |
| Ubuntu 64bit | Riku Voipio (ok) | Riku Voipio (ok) | ? |
| Fedora 32bit | Riku Voipio (ok) | Riku Voipio (ok) | ? |
| Fedora 64bit | Riku Voipio (ok) | Riku Voipio (ok) | ? |
| Windows 7 | Riku Voipio (ok) | Riku Voipio (ok) | ? |
| Mac OS X | ? | ? | ? |
The Qemu images are images used with the QEMU full system emulation. The images are as similar as possible to the actual device images.
| Target | Responsible | Status |
|---|---|---|
| ARMv5 (Qemu N900) | Fathi Boudra | Work in progress |
| ARMv7 (Qemu N900) | Fathi Boudra | Work in progress |
| Intel (Aava?) | ? | ? |
What do we have?
The Documentation of MeeGo SDK tells how to install/set up MeeGo SDK on any host machine, how to get started to use SDK to create first MeeGo applicaiton, including creating project, editing, compiling and building and remotely deploying and debuging applicaton.
Supported APIs are also important part of SDK docmentation.