Neo1973 Hardware/de

From Openmoko

(Difference between revisions)
Jump to: navigation, search
m (Replacing 'OpenMoko' with 'Openmoko')
 
(42 intermediate revisions by 6 users not shown)
Line 1: Line 1:
 +
[[Image:Gta01b v3 top.jpg|thumb|400px|display (top) side]]
 +
[[Image:Gta01b v3 bottom.jpg|thumb|400px|component (back) side]]
  
 +
==Hinweis==
 +
Diese Seite befindet sich im Aufbau. Manche Stellen sind nicht oder nur teilweise übersetzt. Die englische Version dieser Seite findet sich [[:Category:Neo1973 Hardware | hier ]].
 +
 +
==Erfahrungen mit "Phase 0"-Hardware==
 +
[[Wishlist:Neo1973_P0_Review]]
 +
 +
== Physikalische Grösse ==
 +
* 120.7 x 62 x 18.5 mm (4.75 x 2.44 x 0.728 inch)
 +
* 184 +/- 5 g (6.5 ounces)
 +
 +
== Wichtigsten Komponenten ==
 +
=== Prozessor ===
 +
Der Hauptprozessor (CPU) im [[Neo1973]] ist ein "Samsung S3C2410AL-26" (Er kann auf bis zu 266MHz getaktet werden)
 +
 +
* Homepage: [http://www.samsung.com/products/semiconductor/MobileSoC/ApplicationProcessor/ARM9Series/S3C2410/S3C2410.htm S3C2410.htm]
 +
* Benutzerhandbuch: [http://www.samsung.com/Products/Semiconductor/MobileSoC/ApplicationProcessor/ARM9Series/S3C2410/2410UserManual.pdf 2410UserManual.pdf]
 +
* BSDL Datei: [http://www.samsung.com/Products/Semiconductor/MobileSoC/ApplicationProcessor/ARM9Series/S3C2410/S3C2410_BGA_BSDLJTAGFILE.bsd S3C2410_BGA_BSDLJTAGFILE.bsd]
 +
* GPIO Pinbelegung: https://svn.openmoko.org/trunk/doc/hardware/GTA01Bv3/gpio.txt
 +
 +
=== Flash ===
 +
64MB Samsung NAND flash (K9F1208U0B), verbunden mit dem NAND controller im S3C2410.
 +
 +
* Homepage: [http://www.samsung.com/products/semiconductor/NANDFlash/SLC_SmallBlock/512Mbit/K9F1208U0B/K9F1208U0B.htm K9F1208U0B.htm]
 +
* Datenblatt: [http://www.samsung.com/Products/Semiconductor/NANDFlash/SLC_SmallBlock/512Mbit/K9F1208U0B/ds_k9f1208x0b_rev03.pdf ds_k9f1208x0b_rev03.pdf]
 +
* Verbunden mit: S3C2410 NAND controller
 +
 +
Das ist der einzige Flash-Speicher neben der microSD-Karte in diesem Gerät. Der S3C2410 booted direkt vom "nand" mittels des [[S3C2410 Steppingstone]].
 +
 +
Es wird nur freie Software benutzt, deshalb auch keine geschützten Flash-Filesysteme. Weitere Informationen zum NAND finden sich unter [[NAND bad blocks]].
 +
 +
=== RAM ===
 +
128MB SDRAM (2x Samsung K4M511633C), direkt verbundem mit dem S3C2410 SDRAM controller.
 +
* Homepage: [http://www.samsung.com/Products/Semiconductor/MobileSDRAM/MobileSDRSDRAM/512Mbit/K4M511633C/K4M511633C.htm K4M511633C.htm]
 +
* Datenblatt: [http://www.samsung.com/Products/Semiconductor/MobileSDRAM/MobileSDRSDRAM/512Mbit/K4M511633C/ds_k4m511633c.pdf ds_k4m511633c.pdf]
 +
* Verbunden mit: S3C2410
 +
 +
=== GSM/GPRS ===
 +
Das GSM/GPRS Modem basiert auf "Texas Instruments Calypso".
 +
 +
* Verbindung: S3C2410 UART1 (full-uart, RxD, TxD, CTS, RTS), /dev/ttySAC0 in userspace
 +
* PM Treiber: https://svn.openmoko.org/trunk/src/target/kernel/patches/gta01-power_control.patch
 +
* Verfügbarer GSM/GPRS Antennestecker (Wenn das Akkufach geöffnet ist)
 +
 +
==== CALYPSO digital Basisband ====
 +
Leider gibt es zum GSM Chipsatz wegen strikten Geheimhaltungsvertägen nur sehr wenige Informationen.  Allerdings kommuniziert der calypso über einen normalen seriellen UART mit dem S3C2410. Hier werden [http://www.3gpp.org/ftp/Specs/archive/07_series/07.05/ GSM 07.05], [http://www.3gpp.org/ftp/Specs/archive/07_series/07.10/ GSM 07.10] und andere standartisierte Protokolle benutzt.
 +
 +
-- [[User:Xkr47|xkr47]]: Could we at least know the [http://en.wikipedia.org/wiki/Gprs#The_GPRS_capability_classes GPRS capabilitiy class and the GPRS multislot class] ?
 +
 +
==== TWL3014 analog baseband ====
 +
Homepage: [http://focus.ti.com/general/docs/wtbu/wtbuproductcontent.tsp?templateId=6123&navigationId=12295&contentId=4703 TWL3014]
 +
 +
==== TRF6151 RF Transceiver ====
 +
Homepage: [http://focus.ti.com/general/docs/wtbu/wtbuproductcontent.tsp?templateId=6123&navigationId=12296&contentId=4701 TRF6151]
 +
 +
=== [[Hardware:AGPS|AGPS]] ===
 +
Hammerhead AGPS von Global Locate.
 +
 +
* Homepage: [http://www.globalocate.com/SEMICONDUCTORS/SEMI_HAMMER_Frameset.htm Hammerhead]
 +
* Verbunden mit: S3C2410 UART2 (full-uart, RxD, TxD, CTS, RTS) /dev/ttySAC1 in userspace
 +
* Treiber: Implementiert als Plugin für den gpsd daemon ([[gpsd]])
 +
* PM Driver: https://svn.openmoko.org/trunk/src/target/kernel/patches/gta01-power_control.patch
 +
* Externe Antennenverbindung (Welche: SMB, SMA, ..?)
 +
 +
=== microSD-Card ===
 +
Das [[Neo1973]] hat einen Slot für microSD/Transflash.
 +
SDHC sollte funktionieren, wurde aber mangels microSD-Karten >2GB noch nicht getestet. Falls ja, sollten solche Speicherkarten keine Probleme bereiten.
 +
* Verbunden mit: S3C2410 MMC/SD controller
 +
* Treiber: https://svn.openmoko.org/trunk/src/target/kernel/patches/s3c_mci.patch
 +
* [[Supported microSD cards]]
 +
* Spezifikationen: [http://www.sdcard.org/confirm/confirm_memorycard.aspx SD Simplified Specification], [http://www.mmca.org/compliance/buy_spec/AN_MMCA050419.pdf MMC (partial)], [http://www.sandisk.com/Assets/File/OEM/Manuals/manual-rs-mmcv1.0.pdf MMC (product manual)]
 +
 +
=== LCD Display Module (LCM) ===
 +
Verwendet wird ein 2.8" 480x640 toppoly (tpo) TD028TTEC1 Modul, angesteuert mit einem Toshiba JBT6K74 TFT LCD Driver Chipset.
 +
* Homepage: [http://www.tpo.biz/ENG/business-eng/Activer-Matrix-VGA.htm Activer-Matrix-VGA.htm]
 +
* Treiber: https://svn.openmoko.org/trunk/src/target/kernel/patches/gta01-jbt6k74.patch
 +
* Treiber für die Hintergrundbeleuchtung: https://svn.openmoko.org/trunk/src/target/kernel/patches/gta01-backlight.patch
 +
* Verbunden mit: S3C2410 Display Controller
 +
 +
==== Touch Screen ====
 +
* Verbunden mit: S3C2410 TS controller
 +
* Treiber: https://svn.openmoko.org/trunk/src/target/kernel/patches/s3c2410_touchscreen.patch
 +
 +
==== Stylus ====
 +
 +
Scheinbar identisch zu [http://cgi.ebay.com/4in1-PDA-Stylus-LED-Light-Torch-Laser-Pointer-Pen-h7_W0QQitemZ280089656134QQihZ018QQcategoryZ48677QQrdZ1QQcmdZViewItem Diesem auf ebay]
 +
 +
=== Bluetooth ===
 +
Delta DFBM-CS320 Class2 Modul, benutzt CSR BlueCore4
 +
 +
* Datenblatt: [http://www.delta.com.tw/product/cp/vco/BT/download/pdf/CS/2.DFBM-CS320.pdf 2.DFBM-CS320.pdf]
 +
* CSR Datenblatt: [http://www.csrsupport.com/download/2302/CS-101564-DSP10%20BlueCore4-ROM%20Product%20Data%20Sheet.pdf CS-101564-DSP10 BlueCore4-ROM Product Data Sheet.pdf]
 +
* Treiber: Stock Linux Kernel BlueZ
 +
* Verbunden mit: S3C2410 USB Host controller (OHCI)
 +
* PM Driver: https://svn.openmoko.org/trunk/src/target/kernel/patches/gta01-power_control.patch
 +
 +
=== Vibrator ===
 +
* Treiber: https://svn.openmoko.org/trunk/src/target/kernel/patches/gta01-vibrator.patch
 +
* Verbunden mit: S3C2410 GPIO
 +
 +
=== USB Host ===
 +
Der USB Host Controller ist im S3C2410 integriert.
 +
* Treiber: Stock Linux kernel ohci_hcd
 +
 +
=== USB Device ===
 +
Der USB Device controller ist im S3C2410 integriert.
 +
* Treiber: https://svn.openmoko.org/trunk/src/target/kernel/patches/s3c2410_udc.patch
 +
* Unter [[USB Product IDs]] finden sich Informamtionen welche Vendor/Product IDs benutzt werden.
 +
* 1200mAh (1700mAh in der finalen Version) Lithium Akku, wird über USB geladen.
 +
* Standard Mini-AB Verbindung.
 +
 +
=== Audio ===
 +
Siehe: [[Neo1973 Audio Subsystem]]
 +
 +
==== Wolfson Codierer-Decodierer ====
 +
Verwendet wird der Codierer-Decodierer WM8753 von Wolfson Microelectronics.
 +
Der Baustein kann keine Formate wie MP3 dekodieren, sondern ist nur eine einfache Sounkarte.
 +
 +
* Homepage: http://www.wolfsonmicro.com/products/WM8753/
 +
* Datenblatt: [http://www.wolfsonmicro.com/uploads/documents/en/WM8753.pdf WM8753.pdf]
 +
* Verbunden mit: S3C2410 IIS Schnittstelle (PCM data), S3C2410 I2C (Control)
 +
* Treiber: https://svn.openmoko.org/trunk/src/target/kernel/patches/asoc.patch
 +
 +
==== Stereo Verstärker ====
 +
Der von National Semiconductor Stereo Verstärker [[LM4857]] ist direkt mit dem analogen Ausgang des WM8753 verbunden.
 +
 +
* Homepage: [http://www.national.com/pf/LM/LM4857.html LM4857.html]
 +
* Datenblatt: [http://www.national.com/ds.cgi/LM/LM4857.pdf LM4857.pdf]
 +
* Verbunden mit: S3C2410 I2C (Control)
 +
 +
==== Kabelgebundenen Kopfhörer (für den Analogausgang) ====
 +
 +
Angesteckt wird das Headset über ein klassische 2,5 mmm Klinkenbuchse mit 4 Anschlüssen.
 +
Das Headset ist kompatibel zu den Smartphones von Motorola (A780,A1200, V-360, ...).
 +
 +
 +
==== Bluetooth Headset (Kopfhörer) ====
 +
Das Headset ist über dem PCM-Bus mit dem CSR-Bluetooth Controller und dem Wolfson Codierer-Decodierer verbunden.
 +
 +
=== Stromversorgung/Stromverwaltung ===
 +
Für die Stromversorgung bzw. Stromverwaltung wird ein Philips PCF50606 eingesetzt.
 +
 +
* Datenblatt: [http://www.nxp.com/acrobat/literature/9397/75009763.pdf PCF50606/605]
 +
* Benutzerhandbuch: [http://www.rockbox.org/twiki/pub/Main/DataSheets/pcf50606.pdf pcf50606.pdf]
 +
* Verbunden mit: S3C2410 via I2C, client address is 0x08.
 +
* Treiber: https://svn.openmoko.org/trunk/src/target/kernel/patches/gta01-pcf50606.patch
 +
 +
=== Akku ===
 +
Der Akku vom Neo1973 ist kompatibel mit dem Nokia Akku BL5C.
 +
Siehe entsprechenden [http://lists.openmoko.org/pipermail/community/2007-February/003758.html Beitrag] auf der Maillingliste. Hier ist noch ein
 +
[http://wiki.openmoko.org/index.php?title=Image:Neo1973-with-BL5C-battery.png Foto] von dem Akku eingesetzt im [[Neo1973]].
 +
 +
=== Eingabetaster ===
 +
Das [[Neo1973]] bietet zwei Taster an:
 +
# Ein Einschaltknopf
 +
# Eine Multifunktionstaste (AUX)
 +
 +
== History ==
 +
=== GTA01 ===
 +
This is the most simple, non-bluetooth version of the prototype.
 +
 +
==== GTA01v3 ====
 +
First generation of prototypes that was given to internal Openmoko software developers.
 +
 +
Unfortunately not useful at all due to non-working touchscreen.
 +
 +
* ATAG_REVISION: 0x0000130
 +
 +
==== GTA01v4 ====
 +
Second generation of prototypes that was given to Harald + Mickey.
 +
 +
Unfortunately still not useful due to half-working touchscreen.
 +
 +
* ATAG_REVISION: 0x00000140
 +
 +
=== GTA01B ===
 +
This is the bluetooth-enabled fork of GTA01
 +
 +
==== GTA01Bv2 ====
 +
This is the first produced version of the bluetooth-enabled version.
 +
 +
* ATAG_REVISION: 0x00000220
 +
 +
==== GTA01Bv3 ====
 +
This is the second produced version of the bluetooth-enabled version. It contains mainly GPS-related fixes.
 +
 +
* ATAG_REVISION: 0x00000230
 +
 +
This is the version that is shipped in Phase 0
 +
 +
===== GTA01Bv3 Errata =====
 +
====== PMU unable to resume from suspend ======
 +
Due to use of wrong GPIO/EINT pin, the PMU cannot wake-up the phone after suspend.  This means, specifically, '''the following events can not bring the phone back from suspend-to-ram''':
 +
* PMU RTC Alarm
 +
* Power button press
 +
* Charger events (charger insertion/removal/error)
 +
* Low battery
 +
 +
====== Stand-by time extremely low ======
 +
This is due to a design bug resulting in at least 30mA additional standby current, since we cannot properly switch off the power supply to the S3C2410 PLL's.  There is nothing we can do to change this with post-production fixes.  GTA01Bv4 will address this issue.
 +
 +
====== GSM doesn't resume phone from suspend ======
 +
The GSM modem currently doesn't signalize a wakeup interrupt to the S3C2410 in case there's some noteworthy event, such as incoming call, loss of network, incoming SMS or the like.
 +
 +
This is a serious issue, but can be fixed with a GSM Modem Firmware update.
 +
 +
====== GSM Sidetone too loud ======
 +
The local feedback sidetone (see [http://en.wikipedia.org/wiki/Sidetone]) is too loud.  This will be addressed in a GSM firmware update
 +
 +
====== Bad block ======
 +
Due to an error in the production process, the factory-programmed NAND bad block information has been lost.  This means that some blocks in the flash will wear out rapidly, which might become as bad as rendering the device unusable.
 +
 +
==== GTA01Bv4 ====
 +
This is the version that will be shipped in Phase 1
 +
 +
===== Changes from GTA01Bv3 =====
 +
# Fix all Errata items from GTA01Bv3
 +
# Add I2C, SPI and one irq and wakeup capable GPIO pin to debug port plus have test pads for all these signals (for soldering wires directly on the pcb)
 +
# Fix a number of production related details and minor hardware details that are not user-visible
 +
 +
== Distinguishing hardware revisions ==
 +
=== Inside the [[Bootloader]] ===
 +
Every hardware revision has its own u-boot image type.  Thus, the bootloader has the revision hard-coded.
 +
The hardware revision is passed on to the kernel via the ATAG mechanism (ATAG_REVISION)
 +
 +
=== Inside the [[Kernel]] ===
 +
The kernel receives the ATAG_REVISION during bootup, and saves its contents in the "system_rev" global variable.
 +
 +
=== From Userspace ===
 +
The kernel exports the system_rev variable in /proc/cpuinfo as "Revision :" line.
 +
 +
{{Languages|Neo1973 Hardware}}
 +
 +
[[Category:Neo1973 Hardware/de| ]]

Latest revision as of 00:15, 23 August 2008

display (top) side
component (back) side

Contents

[edit] Hinweis

Diese Seite befindet sich im Aufbau. Manche Stellen sind nicht oder nur teilweise übersetzt. Die englische Version dieser Seite findet sich hier .

[edit] Erfahrungen mit "Phase 0"-Hardware

Wishlist:Neo1973_P0_Review

[edit] Physikalische Grösse

  • 120.7 x 62 x 18.5 mm (4.75 x 2.44 x 0.728 inch)
  • 184 +/- 5 g (6.5 ounces)

[edit] Wichtigsten Komponenten

[edit] Prozessor

Der Hauptprozessor (CPU) im Neo1973 ist ein "Samsung S3C2410AL-26" (Er kann auf bis zu 266MHz getaktet werden)

[edit] Flash

64MB Samsung NAND flash (K9F1208U0B), verbunden mit dem NAND controller im S3C2410.

Das ist der einzige Flash-Speicher neben der microSD-Karte in diesem Gerät. Der S3C2410 booted direkt vom "nand" mittels des S3C2410 Steppingstone.

Es wird nur freie Software benutzt, deshalb auch keine geschützten Flash-Filesysteme. Weitere Informationen zum NAND finden sich unter NAND bad blocks.

[edit] RAM

128MB SDRAM (2x Samsung K4M511633C), direkt verbundem mit dem S3C2410 SDRAM controller.

[edit] GSM/GPRS

Das GSM/GPRS Modem basiert auf "Texas Instruments Calypso".

[edit] CALYPSO digital Basisband

Leider gibt es zum GSM Chipsatz wegen strikten Geheimhaltungsvertägen nur sehr wenige Informationen. Allerdings kommuniziert der calypso über einen normalen seriellen UART mit dem S3C2410. Hier werden GSM 07.05, GSM 07.10 und andere standartisierte Protokolle benutzt.

-- xkr47: Could we at least know the GPRS capabilitiy class and the GPRS multislot class ?

[edit] TWL3014 analog baseband

Homepage: TWL3014

[edit] TRF6151 RF Transceiver

Homepage: TRF6151

[edit] AGPS

Hammerhead AGPS von Global Locate.

[edit] microSD-Card

Das Neo1973 hat einen Slot für microSD/Transflash. SDHC sollte funktionieren, wurde aber mangels microSD-Karten >2GB noch nicht getestet. Falls ja, sollten solche Speicherkarten keine Probleme bereiten.

[edit] LCD Display Module (LCM)

Verwendet wird ein 2.8" 480x640 toppoly (tpo) TD028TTEC1 Modul, angesteuert mit einem Toshiba JBT6K74 TFT LCD Driver Chipset.

[edit] Touch Screen

[edit] Stylus

Scheinbar identisch zu Diesem auf ebay

[edit] Bluetooth

Delta DFBM-CS320 Class2 Modul, benutzt CSR BlueCore4

[edit] Vibrator

[edit] USB Host

Der USB Host Controller ist im S3C2410 integriert.

  • Treiber: Stock Linux kernel ohci_hcd

[edit] USB Device

Der USB Device controller ist im S3C2410 integriert.

[edit] Audio

Siehe: Neo1973 Audio Subsystem

[edit] Wolfson Codierer-Decodierer

Verwendet wird der Codierer-Decodierer WM8753 von Wolfson Microelectronics. Der Baustein kann keine Formate wie MP3 dekodieren, sondern ist nur eine einfache Sounkarte.

[edit] Stereo Verstärker

Der von National Semiconductor Stereo Verstärker LM4857 ist direkt mit dem analogen Ausgang des WM8753 verbunden.

[edit] Kabelgebundenen Kopfhörer (für den Analogausgang)

Angesteckt wird das Headset über ein klassische 2,5 mmm Klinkenbuchse mit 4 Anschlüssen. Das Headset ist kompatibel zu den Smartphones von Motorola (A780,A1200, V-360, ...).


[edit] Bluetooth Headset (Kopfhörer)

Das Headset ist über dem PCM-Bus mit dem CSR-Bluetooth Controller und dem Wolfson Codierer-Decodierer verbunden.

[edit] Stromversorgung/Stromverwaltung

Für die Stromversorgung bzw. Stromverwaltung wird ein Philips PCF50606 eingesetzt.

[edit] Akku

Der Akku vom Neo1973 ist kompatibel mit dem Nokia Akku BL5C. Siehe entsprechenden Beitrag auf der Maillingliste. Hier ist noch ein Foto von dem Akku eingesetzt im Neo1973.

[edit] Eingabetaster

Das Neo1973 bietet zwei Taster an:

  1. Ein Einschaltknopf
  2. Eine Multifunktionstaste (AUX)

[edit] History

[edit] GTA01

This is the most simple, non-bluetooth version of the prototype.

[edit] GTA01v3

First generation of prototypes that was given to internal Openmoko software developers.

Unfortunately not useful at all due to non-working touchscreen.

  • ATAG_REVISION: 0x0000130

[edit] GTA01v4

Second generation of prototypes that was given to Harald + Mickey.

Unfortunately still not useful due to half-working touchscreen.

  • ATAG_REVISION: 0x00000140

[edit] GTA01B

This is the bluetooth-enabled fork of GTA01

[edit] GTA01Bv2

This is the first produced version of the bluetooth-enabled version.

  • ATAG_REVISION: 0x00000220

[edit] GTA01Bv3

This is the second produced version of the bluetooth-enabled version. It contains mainly GPS-related fixes.

  • ATAG_REVISION: 0x00000230

This is the version that is shipped in Phase 0

[edit] GTA01Bv3 Errata
[edit] PMU unable to resume from suspend

Due to use of wrong GPIO/EINT pin, the PMU cannot wake-up the phone after suspend. This means, specifically, the following events can not bring the phone back from suspend-to-ram:

  • PMU RTC Alarm
  • Power button press
  • Charger events (charger insertion/removal/error)
  • Low battery
[edit] Stand-by time extremely low

This is due to a design bug resulting in at least 30mA additional standby current, since we cannot properly switch off the power supply to the S3C2410 PLL's. There is nothing we can do to change this with post-production fixes. GTA01Bv4 will address this issue.

[edit] GSM doesn't resume phone from suspend

The GSM modem currently doesn't signalize a wakeup interrupt to the S3C2410 in case there's some noteworthy event, such as incoming call, loss of network, incoming SMS or the like.

This is a serious issue, but can be fixed with a GSM Modem Firmware update.

[edit] GSM Sidetone too loud

The local feedback sidetone (see [1]) is too loud. This will be addressed in a GSM firmware update

[edit] Bad block

Due to an error in the production process, the factory-programmed NAND bad block information has been lost. This means that some blocks in the flash will wear out rapidly, which might become as bad as rendering the device unusable.

[edit] GTA01Bv4

This is the version that will be shipped in Phase 1

[edit] Changes from GTA01Bv3
  1. Fix all Errata items from GTA01Bv3
  2. Add I2C, SPI and one irq and wakeup capable GPIO pin to debug port plus have test pads for all these signals (for soldering wires directly on the pcb)
  3. Fix a number of production related details and minor hardware details that are not user-visible

[edit] Distinguishing hardware revisions

[edit] Inside the Bootloader

Every hardware revision has its own u-boot image type. Thus, the bootloader has the revision hard-coded. The hardware revision is passed on to the kernel via the ATAG mechanism (ATAG_REVISION)

[edit] Inside the Kernel

The kernel receives the ATAG_REVISION during bootup, and saves its contents in the "system_rev" global variable.

[edit] From Userspace

The kernel exports the system_rev variable in /proc/cpuinfo as "Revision :" line.

Personal tools