View previous topic :: View next topic |
Author |
Message |
artic Veteran
Joined: 22 Nov 2003 Posts: 1208
|
Posted: Sat Feb 11, 2006 1:01 am Post subject: [Howto] SDHCI |
|
|
Hola ,antes de nada agradecer a Pierre Ossman el trabajo realizado , y que tantos agradecemos.
Manual para kernel 2.6.28 a 2.6.24 (testeado y comprobado con el 2.6.28 )
(testeado con portatil Sony-Vaio FZ21E )
Bueno , como comprendereis han cambiado algunas cosas en el kernel , y este driver no ha sido diferente.
Tecleamos como root :
Code: | 09:03.0 CardBus bridge: Texas Instruments PCIxx12 Cardbus Controller
09:03.1 FireWire (IEEE 1394): Texas Instruments PCIxx12 OHCI Compliant IEEE 1394 Host Controller
09:03.2 Mass storage controller: Texas Instruments 5-in-1 Multimedia Card Reader (SD/MMC/MS/MS PRO/xD)
|
Nos aparece la famosa controladora de texas instruments que montan muchos portátiles , lo más importante aqui para identificar el driver es que aparezca PCIxx12 , ya que segun lo que aparezca el proceder es diferente.
Vamos ahora al kernel :
Code: | Device Drivers --->
[m] Misc devices --->
<m> TI Flash Media interface support
<m> TI Flash Media PCI74xx/PCI76xx host adapter support
<m> MMC/SD card support --->
<m> TI Flash Media MMC/SD Interface support |
Code: | Device Drivers --->
<m> MMC/SD card support --->
<m> Secure Digital Host Controller Interface support
|
Seleccionamos todo como módulos , no compilar directamente en el kernel o no funcionará ,es importante tener esto claro.
Una vez realizado esto no hace falta recompilar el kernel , salvo que aprovechásemos para hacer más cambios y compilásemos algo directamente en el.
Code: | make modules_install |
Ya tenemos nuestros nuevos módulos listos para cargar.
Ahora necesitamos editar un archivo de configuración para que nos cargue un módulo automaticamente (debería de hacerlo udev por si solo pero en la realidad no es asi )
Code: | echo "mmc_block" >> /etc/modules.autoload.d/kernel-2.6 |
Code: | echo "tifm_core" >> /etc/modules.autoload.d/kernel-2.6 |
Code: | echo "tifm_7xx1" >> /etc/modules.autoload.d/kernel-2.6 |
es importante respetar el orden de carga de los módulos.......
Ahora necesitamos bloquear 1 módulos en el momento del arranque , sino hacemos esto no funcionará :
Code: | echo "blacklist tifm_sd" >> /etc/modules.d/blacklist |
el módulo se cargará cuando insertemos la tarjeta en la ranura ( si se carga en el arranque no detecta la tarjeta aunque lo carguemos el último ), esto no debería de ser asi ,pero en mi caso es el unico modo de que funcione .
Bien , ahora procederemos a reiniciar , y una vez estemos logueados insertamos la tarjeta SD :
Code: | tifm_core: MMC/SD card detected in socket 0:1
[ 2082.205568] mmc0: new SD card at address b368
[ 2082.205766] mmcblk0: mmc0:b368 SDC 121 MiB
[ 2082.205820] mmcblk0: p1
|
Como veis en el dmesg funciona perfectamente , en mi caso he configurado mi kde 4 para que me lo monte automaticamente .Si quereis hacerlo de forma manual , teneis que editar el /etc/fstab con nano por ej :
Code: | /dev/mmcblk0p1 /mnt/sd vfat noauto,rw,users 0 0 |
y crear el punto de montaje por ej :
ya está todo listo , podeis montar vuestras tarjetas SD en vuestro linux.
Si no funciona probad a cambiar :
Code: | setpci -s 09:03.2 4c=0x02 | o Code: | setpci -s 09:03.2 4c=0x22 | sino funciona dejad el que venia predeterminado en mi caso
Code: | setpci -s 09:03.2 4c=0x44 |
esto varia según cada placa , para obtener los datos del comando hacer un y os saldrá algo como esto :
Code: | 09:03.2 Mass storage controller: Texas Instruments 5-in-1 Multimedia Card Reader (SD/MMC/MS/MS PRO/xD)
00: 4c 10 3b 80 06 01 10 02 00 00 80 01 10 39 80 00
10: 00 10 10 fc 00 00 00 00 00 00 00 00 00 00 00 00
20: 00 00 00 00 00 00 00 00 00 00 00 00 4d 10 05 90
30: 00 00 00 00 44 00 00 00 00 00 00 00 07 03 07 04
40: 00 00 00 00 01 00 02 7e 00 80 00 00 44 00 00 00
50: 4d 10 05 90 05 01 00 00 00 00 00 00 00 00 00 00
60: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
70: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
80: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
90: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
a0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
b0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
c0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
d0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
e0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
f0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
donde 5 fila 14 columna es el valor que hemod de modificar , en este caso es el número 44 , el otro dato que necesitamos es la cifra que va antes del Code: | Mass storage controller | lo digo porque muchos haceis copy paste en los howto y hay variables que no son iguales en todos los equipos.
Recordad que en esta versión del driver no debería de hacer falta cambiar registros con setpci , como se muestra en el manual antiguo , cuidado con lo que cambiais ,recordad que los cambios con setpci permancen con los reinicios , si os olvidasteis del valor original apagad y volver a arrancar el PC.Tambien recordad que el cambiar el registro con setpci activa el modo sdhci exclusivamente .
--------------------------------------------------------------------------------------------------------
--------------------------------------------------------------------------------------------------------
Manual para kernel inferiores a 2.6.24
(testeado con portatil toshiba satellite A80)
Una aclaracion este driver funciona con portatiles que monten controladoras texas instruments y ricoh.
A partir del kernel 2.6.17 no es necesareo parchear
Para comenzar nos bajamos los 3 parches de :
http://list.drzeus.cx/pipermail/sdhci-devel/2006-February/000426.html
Lo segundo sera parchear nuestro kernel (para quien no sepa parchear es muy sencillo) ,nos vamos al directorio /usr/src/linux y tecleamos lo siguiente:
Code: | patch -p1 < /ruta/del/parche |
y hacemos eso con los parches que nos hemos descargado
luego tenemos que configurar nuestro kernel y habilitar los modulos para poder compilarlos,nos vamos a :
DEVICES DRIVERS buscas MMC/SD CARD SUPPORT ,logicamente debes de habilitar el que necesites ,que se supone que debe de ser SECURE DIGITAL HOST CONTROLLER que es el que hemos añadido con el parche.Los compilamos como modulos y si quieres opcion de debug pues tb.
Una vez efectuado esto guardamos los cambios y compilamos el kernel.
Hacemos un make modules_install ,metemos imagen en /boot (bueno lo de siempre)
Y arrancamos ........ como vereis 2 modulos se cargan ya en el arranque,y si no fuese asi pues los insertamos:
Code: | modprobe mmc_core sdhci mmc_block |
este ultimo es importante y no se inserta solo.Si no lo insertamos no tendremos los nodos en /dev ya que Udev no los creara............
una vez realizado comprobamos con un :
Code: | # lsmod
Module Size Used by
mmc_block 6664 0
sdhci 12800 0
mmc_core 18688 2 mmc_block,sdhci
|
todo esta OK
Lo siguiente es para los que tenemos Texas Instruments (TI)
ahora hacemos un :
y no saldra algo como esto:
Code: | 0000:06:04.3 Mass storage controller: Texas Instruments PCIxx21 Integrated FlashMedia Controller
00: 4c 10 33 80 06 00 10 02 00 00 80 01 08 39 80 00
10: 00 40 00 b4 00 00 00 00 00 00 00 00 00 00 00 00
20: 00 00 00 00 00 00 00 00 00 00 00 00 79 11 01 ff
30: 00 00 00 00 44 00 00 00 00 00 00 00 0a 02 07 04
40: 00 00 00 00 01 00 02 7e 00 00 00 00 20<-- 00 00 00
50: 79 11 01 ff 05 01 00 00 00 00 00 00 00 00 00 00
60: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
70: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
80: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
90: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
a0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
b0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
c0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
d0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
e0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
f0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |
bueno pues esto puede variar en cada caso ,antes de nada nosotros necesitamos conocer el valor actual del reg,esta en subfuncion 3 en offset 4C :
Code: |
0: 00 00 00 00 01 00 02 7e 00 00 00 00 [b]20[/b] 00 00 00 |
El bit que queremos cambiar es 2 ,entonces cambiamos lo de arriba por 22 de la siguiente manera :
Code: | setpci -s 06:04.3 4c=0x22 |
si volvemos a teclear :
nos saldra esto:
Code: | 00: 4c 10 33 80 06 00 10 02 00 00 80 01 08 39 80 00
10: 00 40 00 b4 00 00 00 00 00 00 00 00 00 00 00 00
20: 00 00 00 00 00 00 00 00 00 00 00 00 79 11 01 ff
30: 00 00 00 00 44 00 00 00 00 00 00 00 0a 02 07 04
40: 00 00 00 00 01 00 02 7e 00 00 00 00 22<-- 00 00 00
50: 79 11 01 ff 05 01 00 00 00 00 00 00 00 00 00 00
60: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
70: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
80: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
90: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
a0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
b0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
c0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
d0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
e0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
f0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |
bien observamos que ha cambiado
ahora insertamos una tarjeta en la unidad y nos fijamos que en /dev tenemos creados los siguientes /dev:
Code: | /dev/mmcblk0 /dev/mmcblk0p1 |
pues nada montamos la unidad :
Code: | mount /dev/mmcblk0p1 /mnt/flash -t vfat |
y ya tendremos nuestro unidad montada y lista para usarse.
Este driver ha sido probado con exito en un toshiba satellite a80,con un kernel 2.6.15-r2.
El driver esta disponible sin necesidad de parchear en los ultimos kernel a partir del 2.6.17 en adelante.
FAQ
Es necesario ejecutar Code: | setpci -s 06:04.3 4c=0x22 | con TI en cada sesion???
Si es necesario ,pero lo podeis meter en Code: | /etc/conf.d/local.start |
No soi capaz de montarlo como usuario
Debes editar tu y añadir lo siguiente Code: | /dev/mmcblk0p1 /mnt/sd vfat noauto,rw,users 0 0 | el punto de montaje es a gusto de cada uno.
Espero haberos ayudado _________________ Pwd by Gentoo | 2.6.28-gentoo-x64 | kde4.2| ext4 | xorg 7.4 |
Last edited by artic on Mon Jan 19, 2009 2:20 am; edited 12 times in total |
|
Back to top |
|
|
zorth l33t
Joined: 17 Feb 2004 Posts: 780 Location: Lovin' Gentoo
|
Posted: Sat Feb 11, 2006 5:55 am Post subject: |
|
|
hola.
bueno, tan solo comentar, que tras darle soporte al nucleo en las tipicas opciones sobre usb y emulacion scsi, yo tengo montado como /dev/sdX, las 4 ranuras y los tipos de tarjetas soportados sin problema alguno ( SD, MMC, MS, SM, CF ) que son las que tienen mi hardcano13 y como digo, tan solo he de insertar una tarjeta como la mmc de mi nokia, como si pongo el pendrive de 128 mbs, tanto da y hacer un dmesg para ver donde esta asignada... si /dev/sdc, /dev/sdd, /dev/sdb.... el que sea. mount -t vfat /dev/sdX /mnt/sdX y ya esta todo.
Code: |
Vendor: Generic Model: STORAGE DEVICE Rev: 9144
Type: Direct-Access ANSI SCSI revision: 00
sd 2:0:0:0: Attached scsi removable disk sdb
sd 2:0:0:0: Attached scsi generic sg1 type 0
Vendor: Generic Model: STORAGE DEVICE Rev: 9144
Type: Direct-Access ANSI SCSI revision: 00
sd 2:0:0:1: Attached scsi removable disk sdc
sd 2:0:0:1: Attached scsi generic sg2 type 0
Vendor: Generic Model: STORAGE DEVICE Rev: 9144
Type: Direct-Access ANSI SCSI revision: 00
sd 2:0:0:2: Attached scsi removable disk sdd
sd 2:0:0:2: Attached scsi generic sg3 type 0
Vendor: Generic Model: STORAGE DEVICE Rev: 9144
Type: Direct-Access ANSI SCSI revision: 00
sd 2:0:0:3: Attached scsi removable disk sde
sd 2:0:0:3: Attached scsi generic sg4 type 0
usb-storage: device scan complete
|
no se si sera lo mismo al howto.... pero bueno
saludos. _________________ Geŋtoo Worłd Rułe§ |
|
Back to top |
|
|
Tambor n00b
Joined: 07 Apr 2005 Posts: 53 Location: Girona (CAT)
|
Posted: Sat Feb 11, 2006 9:57 am Post subject: |
|
|
Buenas prove lo que decias pero no me ha funcionado, te pongo un poco de informacion:
parchee el kernel como dijiste, hasta aquí ningún problema, luego con
Code: |
lspci -xxx
02:0d.0 System peripheral: Toshiba America Info Systems SD TypA Controller (rev 03)
00: 79 11 05 08 02 00 10 02 03 00 80 08 00 00 00 00
10: 00 7c ef fc 00 00 00 00 00 00 00 00 00 00 00 00
20: 00 00 00 00 00 00 00 00 00 00 00 00 79 11 01 00
30: 00 00 00 00 80 00 00 00 00 00 00 00 0b 01 00 00
40: 00 00 00 00 37 5f 00 00 00 00 00 00 02 00 00 00
50: 01 00 00 00 00 00 00 00 02 01 00 00 00 00 00 00
60: 10 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
70: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
80: 01 00 02 fe 00 80 00 00 02 02 00 00 00 00 00 00
90: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
a0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
b0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
c0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
d0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
e0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
f0: 00 00 00 00 00 ff 00 00 00 01 00 00 00 00 00 00
|
Por lo qual vi que no tengo una controladora TI sino que la controladora es de toshiba, pero vi en el help del parche del kernel, que se supone que la controladora de toshiba esta suportada.
La cosa esta que como es normal no puedo modificar el valor del registro asi como asi sin saber que toco, admas los valores no coinciden con los de la TI. I si miro si se han creado los /dev veo que no ha passado, al igual como al hacer dmesg no me da ninguna informacion de que entre ninguna tarjeta SD.
Alguien sabe de algo relacionado? |
|
Back to top |
|
|
artic Veteran
Joined: 22 Nov 2003 Posts: 1208
|
Posted: Sat Feb 11, 2006 10:46 am Post subject: |
|
|
Hola, este driver es para lectoras de portatiles integradas para controladoras texas y ricoh,que utilizan interface sdhci.Las usb no tienen nada que ver,se configuran de manera distinta y se montan como dispositivos scsi.Las Usb hace años que estan soportadas,y ya hay howto al respecto .
salu2 _________________ Pwd by Gentoo | 2.6.28-gentoo-x64 | kde4.2| ext4 | xorg 7.4 |
Last edited by artic on Sat Feb 11, 2006 11:09 am; edited 2 times in total |
|
Back to top |
|
|
artic Veteran
Joined: 22 Nov 2003 Posts: 1208
|
Posted: Sat Feb 11, 2006 11:01 am Post subject: |
|
|
Hola tambor ,tu controladora no es de Texas instruments ,como la de mi toshiba .Que portatil tienes???? que tipo de bios tiene pheonix?????Que kernel usas???
Hecha un vistazo aqui :
http://mmc.drzeus.cx/wiki/Controllers/SDHCI aunque creo que va ser que no
Este driver soporta ricoh y texas instruments ,y fuera de ahi nada mas que yo sepa.Estas controladoras estan presentes en portatiles toshiba,dell,etc.....
Creo haber leido que para las controladoras toshiba no hay proyecto,ya que toshiba se niega a dar especificaciones de su hardware.
salu2 _________________ Pwd by Gentoo | 2.6.28-gentoo-x64 | kde4.2| ext4 | xorg 7.4 | |
|
Back to top |
|
|
Tambor n00b
Joined: 07 Apr 2005 Posts: 53 Location: Girona (CAT)
|
Posted: Sat Feb 11, 2006 2:17 pm Post subject: |
|
|
Haver,
ordenador: Toshiba Satellite 2450-s203
bios: ACPI BIOS version 1.30
kernel: linux-2.6.15-gentoo-r1 de gentoo-sources
Por lo que veo en la pàgina no se comenta nada de Toshiba
en la informacion de Secure Digital Host Controller Interface support (EXPERIMENTAL) sale:
Code: |
CONFIG_MMC_SDHCI:
x This select the generic Secure Digital Host Controller Interface.
x It is used by manufacturers such as Texas Instruments(R), Ricoh(R)
x and Toshiba(R). Most controllers found in laptops are of this type.
x If you have a controller with this interface, say Y or M here.
|
Por lo que si habla de toshiba, pero no se especifica que controladoras.
No se si alguien sabe algo más que informe. |
|
Back to top |
|
|
artic Veteran
Joined: 22 Nov 2003 Posts: 1208
|
Posted: Sat Feb 11, 2006 2:34 pm Post subject: |
|
|
Hola ,has probado a saltarte ese paso ya que al no tener una TI no es necesareo .Los dev se crean al meter la tarjeta,pero si el dmesg no es cupe nada mal asunto.
Mi dmesg suelta esto:
Code: | sdhci: Secure Digital Host Controller Interface driver, 0.10
sdhci: Copyright(c) Pierre Ossman
sdhci [sdhci_probe()]: found at 0000:06:04.4
sdhci [sdhci_probe()]: found 3 slot(s)
ACPI: PCI Interrupt 0000:06:04.4[D] -> GSI 19 (level, low) -> IRQ 19
sdhci [sdhci_probe_slot()]: slot 0 at 0xb4009000, irq 19
sdhci: ============== REGISTER DUMP ==============
sdhci: Sys addr: 0x00000000 | Version: 0x00008400
sdhci: Blk size: 0x00000000 | Blk cnt: 0x00000000
sdhci: Argument: 0x00000000 | Trn mode: 0x00000000
sdhci: Present: 0x00020000 | Host ctl: 0x00000000
sdhci: Power: 0x00000000 | Blk gap: 0x00000000
sdhci: Walk up: 0x00000000 | Clock: 0x00000002
sdhci: Timeout: 0x0000000e | Int stat: 0x00000000
sdhci: Int enab: 0x11ff00cf | Sig enab: 0x11ff00cf
sdhci: AC12 err: 0x00000000 | Slot int: 0x00000000
sdhci: Caps: 0x01821090 | Max curr: 0x00000000
sdhci: ===========================================
sdhci [sdhci_set_ios()]: clock 0Hz busmode 1 powermode 0 cs 0 Vdd 0 width 0
sdhci [sdhci_set_ios()]: clock 0Hz busmode 1 powermode 1 cs 0 Vdd 21 width 0
mmc0: SDHCI at 0xb4009000 irq 19 PIO
sdhci [sdhci_probe_slot()]: slot 1 at 0xb4008c00, irq 19
sdhci [sdhci_set_ios()]: clock 62500Hz busmode 1 powermode 2 cs 0 Vdd 21 width 0
sdhci: ============== REGISTER DUMP ==============
sdhci: Sys addr: 0x00000000 | Version: 0x00008400
sdhci: Blk size: 0x00000000 | Blk cnt: 0x00000000
sdhci: Argument: 0x00000000 | Trn mode: 0x00000000
sdhci: Present: 0x00020000 | Host ctl: 0x00000000
sdhci: Power: 0x00000000 | Blk gap: 0x00000000
sdhci: Walk up: 0x00000000 | Clock: 0x00000002
sdhci: Timeout: 0x0000000e | Int stat: 0x00000000
sdhci: Int enab: 0x11ff00cf | Sig enab: 0x11ff00cf
sdhci: AC12 err: 0x00000000 | Slot int: 0x00000000
sdhci: Caps: 0x01821090 | Max curr: 0x00000000
sdhci: ===========================================
sdhci [sdhci_set_ios()]: clock 62500Hz busmode 1 powermode 2 cs 1 Vdd 21 width 0
sdhci [sdhci_set_ios()]: clock 0Hz busmode 1 powermode 0 cs 0 Vdd 0 width 0
MMC: starting cmd 00 arg 00000000 flags 00000000
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (0)
MMC: req done (00): 1: 00000000 00000000 00000000 00000000
sdhci [sdhci_set_ios()]: clock 62500Hz busmode 1 powermode 2 cs 0 Vdd 21 width 0
MMC: starting cmd 37 arg 00000000 flags 00000029
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (37)
MMC: req done (37): 1: 00000000 00000000 00000000 00000000
MMC: starting cmd 37 arg 00000000 flags 00000029
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (37)
MMC: req done (37): 1: 00000000 00000000 00000000 00000000
MMC: starting cmd 37 arg 00000000 flags 00000029
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (37)
MMC: req done (37): 1: 00000000 00000000 00000000 00000000
MMC: starting cmd 37 arg 00000000 flags 00000029
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (37)
MMC: req done (37): 1: 00000000 00000000 00000000 00000000
MMC: starting cmd 01 arg 00000000 flags 00000001
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (1)
MMC: req done (01): 1: 00000000 00000000 00000000 00000000
sdhci [sdhci_set_ios()]: clock 0Hz busmode 1 powermode 0 cs 0 Vdd 0 width 0
sdhci [sdhci_set_ios()]: clock 0Hz busmode 1 powermode 1 cs 0 Vdd 21 width 0
mmc1: SDHCI at 0xb4008c00 irq 19 PIO
sdhci [sdhci_probe_slot()]: slot 2 at 0xb4008800, irq 19
sdhci: ============== REGISTER DUMP ==============
sdhci: Sys addr: 0x00000000 | Version: 0x00008400
sdhci: Blk size: 0x00000000 | Blk cnt: 0x00000000
sdhci: Argument: 0x00000000 | Trn mode: 0x00000000
sdhci: Present: 0x000a0000 | Host ctl: 0x00000000
sdhci: Power: 0x00000000 | Blk gap: 0x00000000
sdhci: Walk up: 0x00000000 | Clock: 0x00000002
sdhci: Timeout: 0x0000000e | Int stat: 0x00000000
sdhci: Int enab: 0x11ff00cf | Sig enab: 0x11ff00cf
sdhci: AC12 err: 0x00000000 | Slot int: 0x00000000
sdhci: Caps: 0x01821898 | Max curr: 0x00000000
sdhci: ===========================================
sdhci [sdhci_set_ios()]: clock 62500Hz busmode 1 powermode 2 cs 0 Vdd 21 width 0
sdhci [sdhci_set_ios()]: clock 0Hz busmode 1 powermode 0 cs 0 Vdd 0 width 0
sdhci [sdhci_set_ios()]: clock 62500Hz busmode 1 powermode 2 cs 1 Vdd 21 width 0
mmc2: SDHCI at 0xb4008800 irq 19 PIO
MMC: starting cmd 00 arg 00000000 flags 00000000
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (0)
MMC: req done (00): 1: 00000000 00000000 00000000 00000000
sdhci [sdhci_set_ios()]: clock 62500Hz busmode 1 powermode 2 cs 0 Vdd 21 width 0
MMC: starting cmd 37 arg 00000000 flags 00000029
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (37)
MMC: req done (37): 1: 00000000 00000000 00000000 00000000
MMC: starting cmd 37 arg 00000000 flags 00000029
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (37)
MMC: req done (37): 1: 00000000 00000000 00000000 00000000
MMC: starting cmd 37 arg 00000000 flags 00000029
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (37)
MMC: req done (37): 1: 00000000 00000000 00000000 00000000
MMC: starting cmd 37 arg 00000000 flags 00000029
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (37)
MMC: req done (37): 1: 00000000 00000000 00000000 00000000
MMC: starting cmd 01 arg 00000000 flags 00000001
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (1)
MMC: req done (01): 1: 00000000 00000000 00000000 00000000
sdhci [sdhci_set_ios()]: clock 0Hz busmode 1 powermode 0 cs 0 Vdd 0 width 0
sdhci [sdhci_set_ios()]: clock 0Hz busmode 1 powermode 1 cs 0 Vdd 21 width 0
sdhci [sdhci_set_ios()]: clock 93750Hz busmode 1 powermode 2 cs 0 Vdd 21 width 0
sdhci [sdhci_set_ios()]: clock 93750Hz busmode 1 powermode 2 cs 1 Vdd 21 width 0
MMC: starting cmd 00 arg 00000000 flags 00000000
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (0)
MMC: req done (00): 1: 00000000 00000000 00000000 00000000
sdhci [sdhci_set_ios()]: clock 93750Hz busmode 1 powermode 2 cs 0 Vdd 21 width 0
MMC: starting cmd 37 arg 00000000 flags 00000029
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (37)
MMC: req done (37): 1: 00000000 00000000 00000000 00000000
MMC: starting cmd 37 arg 00000000 flags 00000029
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (37)
MMC: req done (37): 1: 00000000 00000000 00000000 00000000
MMC: starting cmd 37 arg 00000000 flags 00000029
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (37)
MMC: req done (37): 1: 00000000 00000000 00000000 00000000
MMC: starting cmd 37 arg 00000000 flags 00000029
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (37)
MMC: req done (37): 1: 00000000 00000000 00000000 00000000
MMC: starting cmd 01 arg 00000000 flags 00000001
sdhci [sdhci_tasklet_finish()]: Ending request, cmd (1)
MMC: req done (01): 1: 00000000 00000000 00000000 00000000
sdhci [sdhci_set_ios()]: clock 0Hz busmode 1 powermode 0 cs 0 Vdd 0 width 0 |
lo de la ayuda del kernel estoi de acuerdo contigo,ya que aunque mi portatil sea toshiba lleva controladora texas y no toshiba como el tuyo.Creo que dentro de toshiba se montan diferentes tipos de controladoras,si mal no he leido unas utilizan el bus pcmcia y otras no.De ahi que no todas esten soportadas.
salu2 _________________ Pwd by Gentoo | 2.6.28-gentoo-x64 | kde4.2| ext4 | xorg 7.4 | |
|
Back to top |
|
|
Tambor n00b
Joined: 07 Apr 2005 Posts: 53 Location: Girona (CAT)
|
Posted: Sat Feb 11, 2006 8:06 pm Post subject: |
|
|
Pues no el dmesg lamentablemente no escupe nada, o sea que mal lo veo. I por lo que a /dev creados pues tampoco como es normal, sino ya me informaria de ello.
Bueno veo que tocara esperar, o desear que toshiba sea más generosa. |
|
Back to top |
|
|
artic Veteran
Joined: 22 Nov 2003 Posts: 1208
|
Posted: Sun Feb 12, 2006 11:30 am Post subject: |
|
|
Bueno creo haber leido por aquella pagina que hay mas gente desarrollando drivers.Estoi un poco cansado de que cuando vas a las paginas de los fabricantes de portatiles te recomienden o diseñen los equipos para el XP.Ademas de que imagino que la licencia que va pegada debajo del portatil nos la cobran en el precio.Deberian dar la posibilidad de elegir.Otras marcas minoritarias si lo hacen ,pero sus equipos fallan mas que escopetas de feria.
salu2 _________________ Pwd by Gentoo | 2.6.28-gentoo-x64 | kde4.2| ext4 | xorg 7.4 | |
|
Back to top |
|
|
artic Veteran
Joined: 22 Nov 2003 Posts: 1208
|
Posted: Thu Feb 16, 2006 5:52 pm Post subject: |
|
|
Actualizado a version 0.11
El driver esta ya en las mm-sources a partir de la 2.6.16-rc6-mm2 en adelante.......... es interesante ya que han añadido un driver para escribir el doble de rapido.
Salu2 _________________ Pwd by Gentoo | 2.6.28-gentoo-x64 | kde4.2| ext4 | xorg 7.4 | |
|
Back to top |
|
|
artic Veteran
Joined: 22 Nov 2003 Posts: 1208
|
Posted: Sun Jun 25, 2006 12:18 am Post subject: |
|
|
A partir de la version 2.6.17 no hace falta parchear el kernel .
Salu2 _________________ Pwd by Gentoo | 2.6.28-gentoo-x64 | kde4.2| ext4 | xorg 7.4 | |
|
Back to top |
|
|
dmery Apprentice
Joined: 15 Sep 2004 Posts: 225 Location: Coral Gables, Florida, USA
|
Posted: Wed Jul 26, 2006 5:58 pm Post subject: Sigo teniendo problemas |
|
|
Artic,
Tengo el kernel 2.6.17-gentoo-r4, en el cual habilite (*) los siguientes:
(*) MMC support
(*) MMC block device driver
(*) Secure Digital Host Controller Interface support (EXPERIMENTAL)
luego realizo el lspci -xxx y modifico el valor 20 a 22, como bien explicas en tu howto, pero nada (intento colocar un memory stick de 4 mb Sony, cuando cargo la particion windows funciona perfecto, por lo cual descarto problemas de hard)
el dmesg me tira lo siguiente en la parte referida a los drivers:
sdhci: Secure Digital Host Controller Interface driver, 0.11
sdhci: Copyright(c) Pierre Ossman
GSI 22 sharing vector 0xE9 and IRQ 22
ACPI: PCI Interrupt 0000:03:04.4[D] -> GSI 23 (level, low) -> IRQ 233
mmc0: SDHCI at 0xb0209000 irq 233 PIO
mmc1: SDHCI at 0xb0208c00 irq 233 PIO
mmc2: SDHCI at 0xb0208800 irq 233 PIO
te envio la salida del lspci
linuxfour linux # lspci
00:00.0 Host bridge: ATI Technologies Inc RS480 Host Bridge
00:01.0 PCI bridge: ATI Technologies Inc Unknown device 5a3f
00:04.0 PCI bridge: ATI Technologies Inc Unknown device 5a36
00:13.0 USB Controller: ATI Technologies Inc IXP SB400 USB Host Controller
00:13.1 USB Controller: ATI Technologies Inc IXP SB400 USB Host Controller
00:13.2 USB Controller: ATI Technologies Inc IXP SB400 USB2 Host Controller
00:14.0 SMBus: ATI Technologies Inc IXP SB400 SMBus Controller (rev 10)
00:14.1 IDE interface: ATI Technologies Inc Standard Dual Channel PCI IDE Controller ATI
00:14.3 ISA bridge: ATI Technologies Inc IXP SB400 PCI-ISA Bridge
00:14.4 PCI bridge: ATI Technologies Inc IXP SB400 PCI-PCI Bridge
00:14.5 Multimedia audio controller: ATI Technologies Inc IXP SB400 AC'97 Audio Controller (rev 01)
00:14.6 Modem: ATI Technologies Inc ATI SB400 - AC'97 Modem Controller (rev 01)
00:18.0 Host bridge: Advanced Micro Devices [AMD] K8 [Athlon64/Opteron] HyperTransport Technology Configuration
00:18.1 Host bridge: Advanced Micro Devices [AMD] K8 [Athlon64/Opteron] Address Map
00:18.2 Host bridge: Advanced Micro Devices [AMD] K8 [Athlon64/Opteron] DRAM Controller
00:18.3 Host bridge: Advanced Micro Devices [AMD] K8 [Athlon64/Opteron] Miscellaneous Control
01:05.0 VGA compatible controller: ATI Technologies Inc ATI Radeon XPRESS 200M 5955 (PCIE)
03:00.0 FireWire (IEEE 1394): Texas Instruments TSB43AB22/A IEEE-1394a-2000 Controller (PHY/Link)
03:02.0 Network controller: Broadcom Corporation BCM4306 802.11b/g Wireless LAN Controller (rev 03)
03:04.0 CardBus bridge: Texas Instruments PCIxx21/x515 Cardbus Controller
03:04.3 Mass storage controller: Texas Instruments PCIxx21 Integrated FlashMedia Controller
03:04.4 Class 0805: Texas Instruments PCI6411, PCI6421, PCI6611, PCI6621, PCI7411, PCI7421, PCI7611, PCI7621 Secure Digital (SD) Controller
03:06.0 Ethernet controller: Realtek Semiconductor Co., Ltd. RTL-8139/8139C/8139C+ (rev 10)
linuxfour linux #
pero no puedo ponerla a funcionar, lo mismo me paso con el kernel 2.6.15-gentoo-r9 y los "parches" agregados, no hay forma.
Tienes alguna idea ??? me he salteado algun paso ???
Te agradezco cualquier ayuda que me puedas brindar
Salu2
Daniel Mery _________________ "El conocimiento es patrimonio de la humanidad, por lo tanto no tiene propietarios ni necesita de licencias"
Usuario linux registrado: 364487
Gentoo user
Arch user |
|
Back to top |
|
|
capira Tux's lil' helper
Joined: 02 May 2005 Posts: 147 Location: Spain
|
Posted: Fri Aug 18, 2006 5:17 pm Post subject: |
|
|
Antes de nada quiero dar las gracias a artic por su mini howto.
Lo he seguido y casi sin problema he conseguido leer una tarjeta MMC.
Sin embargo me quedan algunas dudas sin resolver:
- Cada vez que reinicio tengo que ejecutar setpci. ¿Hay alguna forma de evitar esto?
- No he conseguido leer tarjetas XD o MS
- ¿Es posible conseguir un comportamiento igual que cuando inserto mi pendrive de manera que se me pregunte si quiero montar mi unidad?
Para dmery, ¿puedes pegar lo que te sale al ejecutar lsmod | grep -e sd -e mmc? |
|
Back to top |
|
|
capira Tux's lil' helper
Joined: 02 May 2005 Posts: 147 Location: Spain
|
Posted: Fri Aug 18, 2006 5:20 pm Post subject: |
|
|
Por cierto, mi configuración es:
Hardware: Portatil Toshiba Satellite M40-285
Kernel: 2.6.17-gentoo-r5 |
|
Back to top |
|
|
dmery Apprentice
Joined: 15 Sep 2004 Posts: 225 Location: Coral Gables, Florida, USA
|
Posted: Fri Aug 18, 2006 5:36 pm Post subject: Te envio la salida.... |
|
|
capira, gracias por tu ayuda,
aqui va la salida
[root@gentoo]: ~ # lsmod | grep -e sd -e mmc
sdhci 12416 0
mmc_core 19288 1 sdhci
Te comento -por si te sirve- que para el setpci construi un "alias" y es mas facil. Ya que segun el mini howto de Artic hay que realizarlo cada vez "levantas" el sistema.
un salu2
Daniel Mery _________________ "El conocimiento es patrimonio de la humanidad, por lo tanto no tiene propietarios ni necesita de licencias"
Usuario linux registrado: 364487
Gentoo user
Arch user |
|
Back to top |
|
|
capira Tux's lil' helper
Joined: 02 May 2005 Posts: 147 Location: Spain
|
Posted: Fri Aug 18, 2006 5:54 pm Post subject: Re: Te envio la salida.... |
|
|
dmery wrote: | capira, gracias por tu ayuda,
aqui va la salida
[root@gentoo]: ~ # lsmod | grep -e sd -e mmc
sdhci 12416 0
mmc_core 19288 1 sdhci
Te comento -por si te sirve- que para el setpci construi un "alias" y es mas facil. Ya que segun el mini howto de Artic hay que realizarlo cada vez "levantas" el sistema.
un salu2
Daniel Mery |
Vale, era lo que me suponÃa. A mi me ha pasado lo mismo al principio. En algún punto del post inicial, artic dice que hay que cargar el módulo mmc_block. Dice que no se carga por defecto. Una vez echo esto, mira a ver si necesitas utilizar le comando setpci, pero asegurate del que el id del dispositivo, está bien escrito, que yo he estado a punto de liarla: Quote: | # lspci -xxx
...
06:06.3 Mass storage controller: Texas Instruments PCIxx21 Integrated FlashMedia Controller
...
# setpci -s 06:06.3 4c=0x22 |
|
|
Back to top |
|
|
dmery Apprentice
Joined: 15 Sep 2004 Posts: 225 Location: Coral Gables, Florida, USA
|
Posted: Fri Aug 18, 2006 6:53 pm Post subject: gracias por tu respuesta |
|
|
Capira,
Correcto ya realice: modprobe mmc_block,
la salida es:
[root@gentoo]: ~ # lsmod | grep -e sd -e mmc
mmc_block 6792 0
sdhci 12416 0
mmc_core 19288 2 mmc_block,sdhci
respecto a setpci:
[root@gentoo]: ~ # lspci -xxx
[b]03:04.3 Mass storage controller: Texas Instruments PCIxx21 Integrated FlashMedia Controller
........
40: 00 00 00 00 01 00 02 7e 00 00 00 00 22 00 00 00
........
o sea que ahora esta todo bien, pero cuando coloco un memory stick en dispositivo lector multiple "no pasa nada". Realmente no se si puede leer este tipo de "memory-stick". Pasa que con el mismo equipo en una particion Ubuntu lee perfectamente este "stick memory" en el "sd-card reader"; igual que la particion Guin2. Mi pregunta seria tu puedes leer este tipo de "memory stick" ?
Gracias por tu ayuda
Salu2
Daniel Mery _________________ "El conocimiento es patrimonio de la humanidad, por lo tanto no tiene propietarios ni necesita de licencias"
Usuario linux registrado: 364487
Gentoo user
Arch user |
|
Back to top |
|
|
pcmaster Advocate
Joined: 04 Dec 2003 Posts: 2221 Location: Barcelona
|
Posted: Sat Aug 19, 2006 9:01 am Post subject: |
|
|
dmery: si puedes leer una tarjeta mmc/sd pero no una en otro slot, puede ser que no tengas activado el soporte para LUN múĺtiple en el kernel.
Normalmente, cada dispositivo scsi contiene un sólo disco, con una tabla de particiones, por lo que esa opción no hace falta activarla, pero en el caso de los lectores múltiples de tarjetas, hay un sólo dispositivo, donde cada slot se comporta como una unidad de disco independiente con su propia tabla de particiones, por lo que debes activarla.
Si os liáis con los nombres de los dispositivos, y tenéis udev, podéis mirar en /dev/disk a ver si se os crean automáticamente nombres permanentes. por ejemplo, con mi lector compacto de tarjetas (con dos ranuras), se crean /dev/sda, /dev/sdb, etc según haya otro dispositivo o no, pero en /dev/disk/by-id se crean enlaces que siempre se llaman igual:
usb-Hama_MS_Card_Reader_000000000003
usb-Hama_SD_Card_Reader_000000000003
uno para cada slot, y al insertar una tarjeta SD:
usb-Hama_MS_Card_Reader_000000000003
usb-Hama_SD_Card_Reader_000000000003
usb-Hama_SD_Card_Reader_000000000003-part1
Si os parecen demasiado largos, siempre podéis añadir reglas a udev para que os cree otros a gusto.
Saludos _________________ pcmaster |
|
Back to top |
|
|
dmery Apprentice
Joined: 15 Sep 2004 Posts: 225 Location: Coral Gables, Florida, USA
|
Posted: Sat Aug 19, 2006 5:55 pm Post subject: PCmaster, gracias por tu ayuda |
|
|
Hoy mismo vere el kernel y activare de ser necesario el "Lun multiple", despues te comentare como marcha la cuestion, por si me "como" algun paso. Es que a este asunto de "SD card reader" lo vengo siguiendo desde hace rato y no lo pude resolver con Gentoo. Gracias nuevamente pos tu soporte.
Salu2
Daniel Mery _________________ "El conocimiento es patrimonio de la humanidad, por lo tanto no tiene propietarios ni necesita de licencias"
Usuario linux registrado: 364487
Gentoo user
Arch user |
|
Back to top |
|
|
pcmaster Advocate
Joined: 04 Dec 2003 Posts: 2221 Location: Barcelona
|
Posted: Sat Aug 19, 2006 7:50 pm Post subject: |
|
|
Pues yo lo tengo funcionando, por USB. Asà que ánimo. _________________ pcmaster |
|
Back to top |
|
|
dmery Apprentice
Joined: 15 Sep 2004 Posts: 225 Location: Coral Gables, Florida, USA
|
Posted: Sat Aug 19, 2006 10:10 pm Post subject: Bueno, no puedo leer MS |
|
|
Finalmente compile el kernel con el "Lun multiple" y realizo todos los pasos del minihowto, pero nada... no puedo leer los "Memory Stick". Realmente no se mas por donde ir y ya llevo mucho "tiempo invertido" en este asuntillo....mucho me temo que quedara asi hasta que quiza mas adelante sea mas facil este "merequetenge". Com Guin2 y Ubuntu Edgy no tengo problemas, inserto el "Memory Stick" se enciende un "led" verde y me abre la ventana con los datos. Pero en Gentoo no he logrado leer ese bendito MS.
Bueno de todos modos, muchas gracias por la colaboracion a todos los companieros del foro.
fraternos salu2
Daniel Mery _________________ "El conocimiento es patrimonio de la humanidad, por lo tanto no tiene propietarios ni necesita de licencias"
Usuario linux registrado: 364487
Gentoo user
Arch user |
|
Back to top |
|
|
pcmaster Advocate
Joined: 04 Dec 2003 Posts: 2221 Location: Barcelona
|
Posted: Sat Aug 19, 2006 10:26 pm Post subject: |
|
|
1- Asegúrate de tener udev y hotplug actualizados a la última versión.
2- A ver si te sirve esto:
http://www.webcon.ca/~imorgan/tifm21/ _________________ pcmaster |
|
Back to top |
|
|
dmery Apprentice
Joined: 15 Sep 2004 Posts: 225 Location: Coral Gables, Florida, USA
|
Posted: Sat Aug 19, 2006 11:05 pm Post subject: Me parece lo siguiente... |
|
|
Efectivamente tengo actualizado el sistema, antes de compilar el kernel realice un "emerge --sync" y despues un "emerge -uDav world".
en cuanto al enlace que me envias (muchas gracias) en una parte plantea que no trabaja para las "memory stick"
It was merged in 2.6.17-rc1, and also worked for me when backported to 2.6.16. This will give you read/write access (albeit quite slow, < 500 kB/s) to SD cards (and maybe MMC?) only. This will not work for Memory Stick, XD, or SM.
Esa es precisamente el tipo de tarjeta que me interesa poder "leer" ya que las utilizan la camara de foto digital mia (CyberShot de Sony). De todas maneras maniana le "echare" otra "encarada" a ver que pasa...esperemos la victoria !!! Obviamente te comentare que tanto pude o no avanzar. Reitero -la gratitud nunca esta de mas- mi mas sincero agradecimiento por tu ayuda.
Salu2
Daniel Mery _________________ "El conocimiento es patrimonio de la humanidad, por lo tanto no tiene propietarios ni necesita de licencias"
Usuario linux registrado: 364487
Gentoo user
Arch user |
|
Back to top |
|
|
capira Tux's lil' helper
Joined: 02 May 2005 Posts: 147 Location: Spain
|
Posted: Sun Aug 20, 2006 11:06 am Post subject: |
|
|
dmery, haznos saber tus avances ... yo también quiero leer las MS. He coseguido leer una SD, pero no escribir, a ver si luego le echo otro rato.
Saludos |
|
Back to top |
|
|
artic Veteran
Joined: 22 Nov 2003 Posts: 1208
|
Posted: Thu Nov 09, 2006 5:04 pm Post subject: |
|
|
Actualizado a 9 /11/06 añadida una pequeña FAQ.
salu2 _________________ Pwd by Gentoo | 2.6.28-gentoo-x64 | kde4.2| ext4 | xorg 7.4 | |
|
Back to top |
|
|
|
|
You cannot post new topics in this forum You cannot reply to topics in this forum You cannot edit your posts in this forum You cannot delete your posts in this forum You cannot vote in polls in this forum
|
|