[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20100120.145316.109996493.davem@davemloft.net>
Date: Wed, 20 Jan 2010 14:53:16 -0800 (PST)
From: David Miller <davem@...emloft.net>
To: alan@...rguk.ukuu.org.uk
Cc: jarkao2@...il.com, shemminger@...ux-foundation.org,
mbreuer@...jas.com, akpm@...ux-foundation.org, flyboy@...il.com,
linux-kernel@...r.kernel.org, netdev@...r.kernel.org,
mchan@...adcom.com, pcnet32@...izon.net, romieu@...zoreil.com,
mcarlson@...adcom.com
Subject: Re: [PATCH] sky2: Fix WARNING: at lib/dma-debug.c:902 check_sync
From: Alan Cox <alan@...rguk.ukuu.org.uk>
Date: Wed, 20 Jan 2010 22:24:14 +0000
>> > Seems like an underlying bug in the DMA api. Maybe it just can't
>> > handle operations on partial mapping.
>> >
>> > Other drivers with same problem:
>> > bnx2, cassini, pcnet32, r8169, rrunner, skge, sungem, tg3,
>>
>> It seems using the same length (even without pci_unmap_len()) is
>> crucial here, but I hope maintainers (added to CC) will take care.
>
> The API needs fixing - if you've got a large mapping and you want to sync
> part of it then we need to support that. Now it might well be that the
> implementation on some braindead platform has to sync the entire thing,
> and some implementations entire pages or cache lines.
>
> You can't fix this in the drivers, they requested a service and they
> don't have enough information nor is it their job to know about all the
> platform specific rules.
Absolutely and %100 agreed, the DMA debugging layer and documentation
are both buggy.
The intention from the beginning was always to allow partial SYNCs
exactly for the reasons Alan and myself are mentioning here.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists