On Tue, Apr 28, 2020 at 11:16:43PM +0200, Patrick Wildt wrote: > Hi, > > on my i.MX8MM EVK there's a ath10k-based WiFi chip which we > unfortunately do not support (yet?). But the SD/MMC CIS parser > complains: > > sdmmc0: CIS parse error at 4136, tuple code 0x14, length 0 > manufacturer 0x0271, product 0x0701 at sdmmc0 function 1 not configured > > It's not a transmission bug though, since I saw prints from a Linux > dmesg on the web[0] stating something similar: > > <4>mmc0: queuing unknown CIS tuple 0x01 (3 bytes) > <4>mmc0: queuing unknown CIS tuple 0x1a (5 bytes) > <4>mmc0: queuing unknown CIS tuple 0x1b (8 bytes) > <4>mmc0: queuing unknown CIS tuple 0x14 (0 bytes) > > I guess the ath10k-Chips use some vendor-specific tuples in the CIS > structure. The thing that our CIS parser complains about is the tuple > without a length. > > Section 16 of the SDIO Simplified Specification 3.0[1] describes the CIS > formats, with Section 16.2 describing the Basic Tuple Format. What our > code calls "tpllen", the tuple body length, is called "link field" in > the specification. > > The specification explicitly says, that a empty tuple body is fine, by > saying: "If the link field is 0, then the tuple body is empty." > > Thus I propose that instead of complaining about that tuple, we just > continue our job. I guess sometimes the existance of a code is infor- > mation enough. > > ok? > > Patrick > > [0] > https://linuxlists.cc/l/9/linux-wireless/t/3226749/ath10k-sdio:_failed_to_load_firmware > [1] > https://www.sdcard.org/downloads/pls/pdf/index.php?p=PartE1_SDIO_Simplified_Specification_Ver3.00.jpg&f=PartE1_SDIO_Simplified_Specification_Ver3.00.pdf&e=EN_SSE1
Actually it would be even better to just remove the check, since then we would fall into the default case which, given SDMMC_DEBUG is on, also lets us know of the unknown tuple: sdmmc0: unknown tuple code 0x1, length 3 sdmmc0: unknown tuple code 0x22, length 4 sdmmc0: unknown tuple code 0x1a, length 5 sdmmc0: unknown tuple code 0x1b, length 8 sdmmc0: unknown tuple code 0x14, length 0 sdmmc0: unknown tuple code 0x22, length 42 sdmmc0: unknown tuple code 0x80, length 1 sdmmc0: unknown tuple code 0x81, length 1 sdmmc0: unknown tuple code 0x82, length 1 The individual switch-cases are checking tpllen properly, so there is no harm. ok? Patrick diff --git a/sys/dev/sdmmc/sdmmc_cis.c b/sys/dev/sdmmc/sdmmc_cis.c index 21cf530b24f..70e5b6283a7 100644 --- a/sys/dev/sdmmc/sdmmc_cis.c +++ b/sys/dev/sdmmc/sdmmc_cis.c @@ -76,12 +76,6 @@ sdmmc_read_cis(struct sdmmc_function *sf, struct sdmmc_cis *cis) continue; tpllen = sdmmc_io_read_1(sf0, reg++); - if (tpllen == 0) { - printf("%s: CIS parse error at %d, " - "tuple code %#x, length %d\n", - DEVNAME(sf->sc), reg, tplcode, tpllen); - break; - } switch (tplcode) { case SD_IO_CISTPL_FUNCID: