~ubuntu-branches/debian/wheezy/linux-2.6/wheezy

« back to all changes in this revision

Viewing changes to arch/m68k/kernel/dma_no.c

  • Committer: Bazaar Package Importer
  • Author(s): Ben Hutchings, Ben Hutchings, Aurelien Jarno
  • Date: 2011-06-07 12:14:05 UTC
  • mfrom: (43.1.9 sid)
  • Revision ID: james.westby@ubuntu.com-20110607121405-i3h1rd7nrnd2b73h
Tags: 2.6.39-2
[ Ben Hutchings ]
* [x86] Enable BACKLIGHT_APPLE, replacing BACKLIGHT_MBP_NVIDIA
  (Closes: #627492)
* cgroups: Disable memory resource controller by default. Allow it
  to be enabled using kernel parameter 'cgroup_enable=memory'.
* rt2800usb: Enable support for more USB devices including
  Linksys WUSB600N (Closes: #596626) (this change was accidentally
  omitted from 2.6.39-1)
* [x86] Remove Celeron from list of processors supporting PAE. Most
  'Celeron M' models do not.
* Update debconf template translations:
  - Swedish (Martin Bagge) (Closes: #628932)
  - French (David Prévot) (Closes: #628191)
* aufs: Update for 2.6.39 (Closes: #627837)
* Add stable 2.6.39.1, including:
  - ext4: dont set PageUptodate in ext4_end_bio()
  - pata_cmd64x: fix boot crash on parisc (Closes: #622997, #622745)
  - ext3: Fix fs corruption when make_indexed_dir() fails
  - netfilter: nf_ct_sip: validate Content-Length in TCP SIP messages
  - sctp: fix race between sctp_bind_addr_free() and
    sctp_bind_addr_conflict()
  - sctp: fix memory leak of the ASCONF queue when free asoc
  - md/bitmap: fix saving of events_cleared and other state
  - cdc_acm: Fix oops when Droids MuIn LCD is connected
  - cx88: Fix conversion from BKL to fine-grained locks (Closes: #619827)
  - keys: Set cred->user_ns in key_replace_session_keyring (CVE-2011-2184)
  - tmpfs: fix race between truncate and writepage
  - nfs41: Correct offset for LAYOUTCOMMIT
  - xen/mmu: fix a race window causing leave_mm BUG()
  - ext4: fix possible use-after-free in ext4_remove_li_request()
  For the complete list of changes, see:
   http://www.kernel.org/pub/linux/kernel/v2.6/ChangeLog-2.6.39.1
* Bump ABI to 2
* netfilter: Enable IP_SET, IP_SET_BITMAP_IP, IP_SET_BITMAP_IPMAC,
  IP_SET_BITMAP_PORT, IP_SET_HASH_IP, IP_SET_HASH_IPPORT,
  IP_SET_HASH_IPPORTIP, IP_SET_HASH_IPPORTNET, IP_SET_HASH_NET,
  IP_SET_HASH_NETPORT, IP_SET_LIST_SET, NETFILTER_XT_SET as modules
  (Closes: #629401)

[ Aurelien Jarno ]
* [mipsel/loongson-2f] Disable_SCSI_LPFC to workaround GCC ICE.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 * Dynamic DMA mapping support.
 
3
 *
 
4
 * We never have any address translations to worry about, so this
 
5
 * is just alloc/free.
 
6
 */
 
7
 
 
8
#include <linux/types.h>
 
9
#include <linux/gfp.h>
 
10
#include <linux/mm.h>
 
11
#include <linux/device.h>
 
12
#include <linux/dma-mapping.h>
 
13
#include <asm/cacheflush.h>
 
14
 
 
15
void *dma_alloc_coherent(struct device *dev, size_t size,
 
16
                           dma_addr_t *dma_handle, gfp_t gfp)
 
17
{
 
18
        void *ret;
 
19
        /* ignore region specifiers */
 
20
        gfp &= ~(__GFP_DMA | __GFP_HIGHMEM);
 
21
 
 
22
        if (dev == NULL || (*dev->dma_mask < 0xffffffff))
 
23
                gfp |= GFP_DMA;
 
24
        ret = (void *)__get_free_pages(gfp, get_order(size));
 
25
 
 
26
        if (ret != NULL) {
 
27
                memset(ret, 0, size);
 
28
                *dma_handle = virt_to_phys(ret);
 
29
        }
 
30
        return ret;
 
31
}
 
32
 
 
33
void dma_free_coherent(struct device *dev, size_t size,
 
34
                         void *vaddr, dma_addr_t dma_handle)
 
35
{
 
36
        free_pages((unsigned long)vaddr, get_order(size));
 
37
}
 
38
 
 
39
void dma_sync_single_for_device(struct device *dev, dma_addr_t handle,
 
40
                                size_t size, enum dma_data_direction dir)
 
41
{
 
42
        switch (dir) {
 
43
        case DMA_TO_DEVICE:
 
44
                flush_dcache_range(handle, size);
 
45
                break;
 
46
        case DMA_FROM_DEVICE:
 
47
                /* Should be clear already */
 
48
                break;
 
49
        default:
 
50
                if (printk_ratelimit())
 
51
                        printk("dma_sync_single_for_device: unsupported dir %u\n", dir);
 
52
                break;
 
53
        }
 
54
}
 
55
 
 
56
EXPORT_SYMBOL(dma_sync_single_for_device);
 
57
dma_addr_t dma_map_single(struct device *dev, void *addr, size_t size,
 
58
                          enum dma_data_direction dir)
 
59
{
 
60
        dma_addr_t handle = virt_to_phys(addr);
 
61
        flush_dcache_range(handle, size);
 
62
        return handle;
 
63
}
 
64
EXPORT_SYMBOL(dma_map_single);
 
65
 
 
66
dma_addr_t dma_map_page(struct device *dev, struct page *page,
 
67
                        unsigned long offset, size_t size,
 
68
                        enum dma_data_direction dir)
 
69
{
 
70
        dma_addr_t handle = page_to_phys(page) + offset;
 
71
        dma_sync_single_for_device(dev, handle, size, dir);
 
72
        return handle;
 
73
}
 
74
EXPORT_SYMBOL(dma_map_page);