Tengo una HP Envy 13-ad001la con PopOs 19.10. El lector de tarjetas no funciona; cuando lo uso lspci
obtengo que este es un lector de dispositivo Alcor Micro:
01:00.0 Unassigned class [ff00]: Alcor Micro Device 6625
Subsystem: Hewlett-Packard Company Device 834a
Flags: fast devsel, IRQ 255
Memory at a1200000 (64-bit, non-prefetchable) [disabled] [size=4K]
Capabilities: [40] Power Management version 3
Capabilities: [50] MSI: Enable- Count=1/1 Maskable- 64bit+
Capabilities: [80] Express Endpoint, MSI 00
Capabilities: [100] Latency Tolerance Reporting
Según tengo entendido, "clase no asignada" significa que Linux no puede encontrar un controlador para este dispositivo. Busqué el controlador correspondiente y encontré que el controlador era "alcor_pci" (https://cateee.net/lkddb/web-lkddb/MISC_ALCOR_PCI.html) y no estaba cargado, así que usé modprobe para cargarlo.
~ lsmod | grep alcor
alcor_pci 20480 0
Pero después de esto todavía no funciona, lshw
muestra lo siguiente (NO RECLAMADO significa NO RECLAMADO):
*-pci:0
descripción: PCI bridge
producto: Sunrise Point-LP PCI Express Root Port #5
fabricante: Intel Corporation
id físico: 1c
información del bus: pci@0000:00:1c.0
versión: f1
anchura: 32 bits
reloj: 33MHz
capacidades: pci normal_decode bus_master cap_list
configuración: driver=pcieport
recursos: irq:122 memoria:a1200000-a12fffff
*-generic NO RECLAMADO
descripción: Unassigned class
producto: Alcor Micro
fabricante: Alcor Micro
id físico: 0
información del bus: pci@0000:01:00.0
versión: 00
anchura: 64 bits
reloj: 33MHz
capacidades: cap_list
configuración: latency=0
recursos: memoria:a1200000-a1200fff
¿Puede alguien ayudarme por favor? No sé si necesito hacer algo más después de cargar el módulo.
Respuesta1
No puede funcionar porque el ID del dispositivo AU6625 solo se agregó enLinux 5.6.
(algunos conductoresAdmite módulos de "uso forzado" incluso con una discrepancia, pero realmente no aguantaría la respiración si los lectores de tarjetas lo admitieran)
Respuesta2
(Este texto es una traducción automática del francés al inglés.)
Hola,
mi experiencia con esta tarjeta.:
*"Alcor Micro AU6625 PCI-E Flash card reader controller"*
Si está dispuesto a recompilar su kernel de Linux, la tarjeta parece funcionar muy bien con el controlador AU6621 ya incluido en el kernel (desde la versión 5.5.6 del kernel). Simplemente "cámbiele el nombre" en el código fuente del módulo y luego vuelva a compilar el kernel de Linux. Esto me funciona desde la versión 5.5.9 del kernel. Lo uso desde hace unos meses sin problemas (aparentes), con estas versiones de kernel (5.5.9, 5.5.16, 5.6.7, 5.6.9)
mi entorno:
"HP ENVY Laptop 13-ad1xx"
LSPCI
02:00.0 Unassigned class [ff00]: Alcor Micro AU6625 PCI-E Flash card reader controller
Debian
Stock linux kernel: https://cdn.kernel.org/pub/linux/kernel/v5.x/linux-5.6.7.tar.xz
Advertencia, no soy un desarrollador, solo soy un administrador de sistemas al que le gusta recompilar su kernel de Linux de vez en cuando.
El resto de esta publicación asume que ya sabes cómo recompilar un kernel de Linux. De lo contrario es mejor no continuar con este proceso; Construir mal un kernel y ejecutarlo puede ser muy peligroso, podrías dañar todos los datos de tu disco duro.
Una vez que se extraen las fuentes, es necesario ajustar los siguientes archivos (que se encuentran mediante el comando de shell "$ grep -i -n -r "AU662" *" ) en la raíz de las fuentes del kernel descomprimidas.
Cambie todas las referencias con "6621" a "6625".
Antes del cambio: $ grep -i -r -n "AU662" *
*drivers/misc/cardreader/alcor_pci.c:5: * Driver for Alcor Micro AU6601 and AU6621 controllers*
*drivers/misc/cardreader/alcor_pci.c:37:static const struct alcor_dev_cfg au6621_cfg = {*
*drivers/misc/cardreader/alcor_pci.c:41:static const struct alcor_dev_cfg au6625_cfg = {*
*drivers/misc/cardreader/alcor_pci.c:48: { PCI_DEVICE(PCI_ID_ALCOR_MICRO, PCI_ID_AU6621),*
*drivers/misc/cardreader/alcor_pci.c:49: .driver_data = (kernel_ulong_t)&au6621_cfg },*
*drivers/misc/cardreader/alcor_pci.c:50: { PCI_DEVICE(PCI_ID_ALCOR_MICRO, PCI_ID_AU6625),*
*drivers/misc/cardreader/alcor_pci.c:51: .driver_data = (kernel_ulong_t)&au6625_cfg },*
*drivers/misc/cardreader/Kconfig:8: au6621.*
*drivers/mmc/host/alcor.c:5: * Driver for Alcor Micro AU6601 and AU6621 controllers*
*drivers/mmc/host/alcor.c:892: /* The clk will not work on au6621. We need to trigger data*
*include/linux/alcor_pci.h:5: * Driver for Alcor Micro AU6601 and AU6621 controllers*
*include/linux/alcor_pci.h:19:#define PCI_ID_AU6621 0x6621*
*include/linux/alcor_pci.h:20:#define PCI_ID_AU6625 0x6625*
*include/linux/alcor_pci.h:36: * 0x10 - ADMA phy address. AU6621 only?*
*include/linux/alcor_pci.h:45: * The au6601 and au6621 have different DMA engines with different issues. One*
*include/linux/alcor_pci.h:46: * For example au6621 engine is triggered by addr change. No other interaction*
*include/linux/alcor_pci.h:54:#define AU6621_DMA_PAGE_CNT 0x05*
*include/linux/alcor_pci.h:57:/* ADMA ctrl? AU6621 only. */*
*include/linux/alcor_pci.h:58:#define AU6621_DMA_CTRL 0x0c*
*include/linux/alcor_pci.h:59:#define AU6621_DMA_ENABLE BIT(0)*
Después del cambio:
*drivers/misc/cardreader/alcor_pci.c:5: * Driver for Alcor Micro AU6601 and AU6625 controllers*
*drivers/misc/cardreader/alcor_pci.c:37:static const struct alcor_dev_cfg au6625_cfg = {*
*drivers/misc/cardreader/alcor_pci.c:41:/*static const struct alcor_dev_cfg au6625_cfg = {*
*drivers/misc/cardreader/alcor_pci.c:48: { PCI_DEVICE(PCI_ID_ALCOR_MICRO, PCI_ID_AU6625),*
*drivers/misc/cardreader/alcor_pci.c:49: .driver_data = (kernel_ulong_t)&au6625_cfg },*
*drivers/misc/cardreader/Kconfig:8: au6625.*
*drivers/mmc/host/alcor.c:5: * Driver for Alcor Micro AU6601 and AU6625 controllers*
*drivers/mmc/host/alcor.c:892: /* The clk will not work on au6625. We need to trigger data*
*include/linux/alcor_pci.h:5: * Driver for Alcor Micro AU6601 and AU6625 controllers*
*include/linux/alcor_pci.h:19:#define PCI_ID_AU6621 0x6621*
*include/linux/alcor_pci.h:20:#define PCI_ID_AU6625 0x6625*
*include/linux/alcor_pci.h:36: * 0x10 - ADMA phy address. AU6625 only?*
*include/linux/alcor_pci.h:45: * The au6601 and au6625 have different DMA engines with different issues. One*
*include/linux/alcor_pci.h:46: * For example au6625 engine is triggered by addr change. No other interaction*
*include/linux/alcor_pci.h:54:#define AU6625_DMA_PAGE_CNT 0x05*
*include/linux/alcor_pci.h:57:/* ADMA ctrl? AU6625 only. */*
*include/linux/alcor_pci.h:58:#define AU6625_DMA_CTRL 0x0c*
*include/linux/alcor_pci.h:59:#define AU6625_DMA_ENABLE BIT(0)*
Dos notas importantes:
desde el kernel 5.6.x parece haber un inicio del controlador AU6625 incluido en el kernel, pero este controlador incluido no parece funcionar todavía (al menos en mi configuración y hasta el kernel 5.6.9 que estoy usando actualmente ) Por lo tanto, debes "comentar" o eliminar esta nueva parte del código.
Después de reiniciar en este nuevo kernel compilado, el comando "lspci" seguirá mostrando "Clase no asignada ...".
para mí02:00.0 Clase no asignada [ff00]: Controlador de lector de tarjetas flash PCI-E Alcor Micro AU6625
Pero la tarjeta funciona muy bien de todos modos y está montada en mi Filemanager (Nautilus) como cualquier otra.
dmesg
May 10 13:35:35 MylapX kernel: [ 0.818161] pci 0000:02:00.0: [1aea:6625] type 00 class 0xff0000
May 10 13:35:35 MylapX kernel: [ 0.818209] pci 0000:02:00.0: reg 0x10: [mem 0xb4200000-0xb4200fff 64bit]
May 10 13:35:35 MylapX kernel: [ 0.818386] pci 0000:02:00.0: supports D1 D2
May 10 13:35:35 MylapX kernel: [ 0.818388] pci 0000:02:00.0: PME# supported from D1 D2 D3hot D3cold
May 10 13:35:35 MylapX kernel: [ 2.845290] alcor_pci 0000:02:00.0: enabling device (0000 -> 0002)
May 10 13:35:39 MylapX kernel: [ 7.617586] mmc0: Skipping voltage switch
May 10 13:35:39 MylapX kernel: [ 7.877031] mmc0: new high speed SDXC card at address aaaa
May 10 13:35:39 MylapX kernel: [ 7.880661] mmcblk0: mmc0:aaaa ACLCF 119 GiB
May 10 13:35:39 MylapX kernel: [ 7.896324] mmcblk0: p1
fdisk-l
Disk /dev/mmcblk0: 119.9 GiB, 127865454592 bytes, 249737216 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: dos
Disk identifier: 0x00000000
Device Boot Start End Sectors Size Id Type
/dev/mmcblk0p1 32768 249737215 249704448 119.1G 7 HPFS/NTFS/exFAT
$ df-h
Filesystem Size Used Avail Use% Mounted on
/dev/mmcblk0p1 120G 98G 22G 82% /media/user/3561-6331