From: Greg KH <gregkh@suse.de>
To: linux-kernel@vger.kernel.org, stable@kernel.org
Cc: stable-review@kernel.org, torvalds@linux-foundation.org,
akpm@linux-foundation.org, alan@lxorguk.ukuu.org.uk,
Karsten Keil <keil@b1-systems.de>
Subject: [patch 038/108] ISDN: Fix DMA alloc for hfcpci
Date: Tue, 30 Jun 2009 17:23:27 -0700 [thread overview]
Message-ID: <20090701002424.978718378@mini.kroah.org> (raw)
In-Reply-To: <20090701002838.GA7100@kroah.com>
[-- Attachment #1: isdn-fix-dma-alloc-for-hfcpci.patch --]
[-- Type: text/plain, Size: 3895 bytes --]
2.6.30-stable review patch. If anyone has any objections, please let us know.
------------------
From: Karsten Keil <keil@b1-systems.de>
commit 8a745b9d91962991ce87a649a4dc3af3206c2c8b upstream.
Replace wrong code with correct DMA API functions.
Signed-off-by: Karsten Keil <keil@b1-systems.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
---
drivers/isdn/hisax/hfc_pci.c | 41 ++++++++++++++++++++++++++++++-----------
drivers/isdn/hisax/hisax.h | 2 +-
2 files changed, 31 insertions(+), 12 deletions(-)
--- a/drivers/isdn/hisax/hfc_pci.c
+++ b/drivers/isdn/hisax/hfc_pci.c
@@ -82,8 +82,9 @@ release_io_hfcpci(struct IsdnCardState *
Write_hfc(cs, HFCPCI_INT_M2, cs->hw.hfcpci.int_m2);
pci_write_config_word(cs->hw.hfcpci.dev, PCI_COMMAND, 0); /* disable memory mapped ports + busmaster */
del_timer(&cs->hw.hfcpci.timer);
- kfree(cs->hw.hfcpci.share_start);
- cs->hw.hfcpci.share_start = NULL;
+ pci_free_consistent(cs->hw.hfcpci.dev, 0x8000,
+ cs->hw.hfcpci.fifos, cs->hw.hfcpci.dma);
+ cs->hw.hfcpci.fifos = NULL;
iounmap((void *)cs->hw.hfcpci.pci_io);
}
@@ -1663,8 +1664,19 @@ setup_hfcpci(struct IsdnCard *card)
dev_hfcpci);
i++;
if (tmp_hfcpci) {
+ dma_addr_t dma_mask = DMA_BIT_MASK(32) & ~0x7fffUL;
if (pci_enable_device(tmp_hfcpci))
continue;
+ if (pci_set_dma_mask(tmp_hfcpci, dma_mask)) {
+ printk(KERN_WARNING
+ "HiSax hfc_pci: No suitable DMA available.\n");
+ continue;
+ }
+ if (pci_set_consistent_dma_mask(tmp_hfcpci, dma_mask)) {
+ printk(KERN_WARNING
+ "HiSax hfc_pci: No suitable consistent DMA available.\n");
+ continue;
+ }
pci_set_master(tmp_hfcpci);
if ((card->para[0]) && (card->para[0] != (tmp_hfcpci->resource[ 0].start & PCI_BASE_ADDRESS_IO_MASK)))
continue;
@@ -1693,22 +1705,29 @@ setup_hfcpci(struct IsdnCard *card)
printk(KERN_WARNING "HFC-PCI: No IO-Mem for PCI card found\n");
return (0);
}
+
/* Allocate memory for FIFOS */
- /* Because the HFC-PCI needs a 32K physical alignment, we */
- /* need to allocate the double mem and align the address */
- if (!(cs->hw.hfcpci.share_start = kmalloc(65536, GFP_KERNEL))) {
- printk(KERN_WARNING "HFC-PCI: Error allocating memory for FIFO!\n");
+ cs->hw.hfcpci.fifos = pci_alloc_consistent(cs->hw.hfcpci.dev,
+ 0x8000, &cs->hw.hfcpci.dma);
+ if (!cs->hw.hfcpci.fifos) {
+ printk(KERN_WARNING "HFC-PCI: Error allocating FIFO memory!\n");
+ return 0;
+ }
+ if (cs->hw.hfcpci.dma & 0x7fff) {
+ printk(KERN_WARNING
+ "HFC-PCI: Error DMA memory not on 32K boundary (%lx)\n",
+ (u_long)cs->hw.hfcpci.dma);
+ pci_free_consistent(cs->hw.hfcpci.dev, 0x8000,
+ cs->hw.hfcpci.fifos, cs->hw.hfcpci.dma);
return 0;
}
- cs->hw.hfcpci.fifos = (void *)
- (((ulong) cs->hw.hfcpci.share_start) & ~0x7FFF) + 0x8000;
- pci_write_config_dword(cs->hw.hfcpci.dev, 0x80, (u_int) virt_to_bus(cs->hw.hfcpci.fifos));
+ pci_write_config_dword(cs->hw.hfcpci.dev, 0x80, (u32)cs->hw.hfcpci.dma);
cs->hw.hfcpci.pci_io = ioremap((ulong) cs->hw.hfcpci.pci_io, 256);
printk(KERN_INFO
- "HFC-PCI: defined at mem %p fifo %p(%#x) IRQ %d HZ %d\n",
+ "HFC-PCI: defined at mem %p fifo %p(%lx) IRQ %d HZ %d\n",
cs->hw.hfcpci.pci_io,
cs->hw.hfcpci.fifos,
- (u_int) virt_to_bus(cs->hw.hfcpci.fifos),
+ (u_long)cs->hw.hfcpci.dma,
cs->irq, HZ);
spin_lock_irqsave(&cs->lock, flags);
--- a/drivers/isdn/hisax/hisax.h
+++ b/drivers/isdn/hisax/hisax.h
@@ -703,7 +703,7 @@ struct hfcPCI_hw {
int nt_timer;
struct pci_dev *dev;
unsigned char *pci_io; /* start of PCI IO memory */
- void *share_start; /* shared memory for Fifos start */
+ dma_addr_t dma; /* dma handle for Fifos */
void *fifos; /* FIFO memory */
int last_bfifo_cnt[2]; /* marker saving last b-fifo frame count */
struct timer_list timer;
next prev parent reply other threads:[~2009-07-01 0:57 UTC|newest]
Thread overview: 124+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <20090701002249.937782934@mini.kroah.org>
2009-07-01 0:28 ` [patch 000/108] 2.6.30-stable review Greg KH
2009-07-01 0:22 ` [patch 001/108] firmware_map: fix hang with x86/32bit Greg KH
2009-07-01 0:22 ` [patch 002/108] fs: remove incorrect I_NEW warnings Greg KH
2009-07-01 0:22 ` [patch 003/108] PCI: disable ASPM on VIA root-port-under-bridge configurations Greg KH
2009-07-01 0:22 ` [patch 004/108] KVM: VMX: Fix handling of a fault during NMI unblocked due to IRET Greg KH
2009-07-01 0:22 ` [patch 005/108] KVM: Move "exit due to NMI" handling into vmx_complete_interrupts() Greg KH
2009-07-01 0:22 ` [patch 006/108] KVM: Add VT-x machine check support Greg KH
2009-07-01 0:22 ` [patch 007/108] KVM: Disable large pages on misaligned memory slots Greg KH
2009-07-01 0:22 ` [patch 008/108] KVM: Prevent overflow in largepages calculation Greg KH
2009-07-01 0:22 ` [patch 009/108] KVM: x86: check for cr3 validity in ioctl_set_sregs Greg KH
2009-07-01 0:22 ` [patch 010/108] KVM: VMX: Handle vmx instruction vmexits Greg KH
2009-07-01 0:23 ` [patch 011/108] KVM: protect concurrent make_all_cpus_request Greg KH
2009-07-01 0:23 ` [patch 012/108] KVM: Fix dirty bit tracking for slots with large pages Greg KH
2009-07-01 0:23 ` [patch 013/108] IMA: use current_cred() instead of current->cred Greg KH
2009-07-01 0:23 ` [patch 014/108] IMA: Handle dentry_open failures Greg KH
2009-07-01 0:23 ` [patch 015/108] IMA: open all files O_LARGEFILE Greg KH
2009-07-01 0:23 ` [patch 016/108] e1000e: stop unnecessary polling when using msi-x Greg KH
2009-07-01 0:23 ` [patch 017/108] pegasus usb-net: Fix endianness bugs Greg KH
2009-07-01 0:23 ` [patch 018/108] ipv4: fix NULL pointer + success return in route lookup path Greg KH
2009-07-01 0:23 ` [patch 019/108] ipv4 routing: Ensure that route cache entries are usable and reclaimable with caching is off Greg KH
2009-07-01 0:23 ` [patch 020/108] sky2: dont look for VPD size Greg KH
2009-07-01 0:23 ` [patch 021/108] tun: Fix unregister race Greg KH
2009-07-01 0:23 ` [patch 022/108] via-velocity: Fix velocity driver unmapping incorrect size Greg KH
2009-07-01 0:23 ` [patch 023/108] x25: Fix sleep from timer on socket destroy Greg KH
2009-07-01 0:23 ` [patch 024/108] bonding: fix multiple module load problem Greg KH
2009-07-01 0:23 ` [patch 025/108] dma-debug: change hash_bucket_find from first-fit to best-fit Greg KH
2009-07-01 0:23 ` [patch 026/108] char: moxa, prevent opening unavailable ports Greg KH
2009-07-01 0:23 ` [patch 027/108] serial: refactor ASYNC_ flags Greg KH
2009-07-01 0:23 ` [patch 028/108] rocket: fix test_bit parameters Greg KH
2009-07-01 0:23 ` [patch 029/108] epca: " Greg KH
2009-07-01 0:23 ` [patch 030/108] x86: Detect use of extended APIC ID for AMD CPUs Greg KH
2009-07-01 0:23 ` [patch 031/108] USB: usbtmc: fix switch statment Greg KH
2009-07-01 0:23 ` [patch 032/108] DVB: lgdt3305: fix 64bit division in function lgdt3305_set_if Greg KH
2009-07-01 0:23 ` [patch 033/108] V4L: ivtv/cx18: fix regression: class controls are no longer seen Greg KH
2009-07-01 0:23 ` [patch 034/108] V4L: pvrusb2: Fix hardware scaling when used with cx25840 Greg KH
2009-07-01 0:23 ` [patch 035/108] V4L: pvrusb2: Re-fix hardware scaling on video standard change Greg KH
2009-07-01 0:23 ` [patch 036/108] V4L: i2c modules must be linked before the v4l2 drivers Greg KH
2009-07-01 0:23 ` [patch 037/108] sym53c8xx: ratelimit parity errors Greg KH
2009-07-01 0:23 ` Greg KH [this message]
2009-07-01 0:23 ` [patch 039/108] jfs: fix regression preventing coalescing of extents Greg KH
2009-07-01 0:23 ` [patch 040/108] spi: takes size of a pointer to determine the size of the pointed-to type Greg KH
2009-07-01 0:23 ` [patch 041/108] serial: bfin_5xx: add missing spin_lock init Greg KH
2009-07-01 0:23 ` [patch 042/108] x86: memtest: remove 64-bit division Greg KH
2009-07-01 0:23 ` [patch 043/108] x86: Fix UV BAU activation descriptor init Greg KH
2009-07-01 0:23 ` [patch 044/108] x86, UV: Fix macros for multiple coherency domains Greg KH
2009-07-01 0:23 ` [patch 045/108] x86: enable GART-IOMMU only after setting up protection methods Greg KH
2009-07-01 0:23 ` [patch 046/108] x86: move rdtsc_barrier() into the TSC vread method Greg KH
2009-07-01 0:23 ` [patch 047/108] x86: Fix uv bau sending buffer initialization Greg KH
2009-07-01 0:23 ` [patch 048/108] x86: Add quirk for reboot stalls on a Dell Optiplex 360 Greg KH
2009-07-01 0:23 ` [patch 049/108] x86: handle initrd that extends into unusable memory Greg KH
2009-07-01 0:23 ` [patch 050/108] ALSA: ca0106 - Add missing registrations of vmaster controls Greg KH
2009-07-01 0:23 ` [patch 051/108] ALSA: intel8x0 - Fix PCM position craziness Greg KH
2009-07-01 0:23 ` [patch 052/108] ALSA: hda - Get back Input Source for ALC262 toshiba-s06 model Greg KH
2009-07-01 0:23 ` [patch 053/108] ALSA: hda - Add quirk for Sony VAIO Z21MN Greg KH
2009-07-01 0:23 ` [patch 054/108] ALSA: cmi8330: fix MPU-401 PnP init copy&paste bug Greg KH
2009-07-01 0:23 ` [patch 055/108] x86: hpet: Mark per cpu interrupts IRQF_TIMER to prevent resume failure Greg KH
2009-07-01 0:23 ` [patch 056/108] ARM: 5545/2: add flush_kernel_dcache_page() for ARM Greg KH
2009-07-01 0:23 ` [patch 057/108] IB/mlx4: Add strong ordering to local inval and fast reg work requests Greg KH
2009-07-01 0:23 ` [patch 058/108] epoll: fix nested calls support Greg KH
2009-07-01 0:23 ` [patch 059/108] lockdep: Select frame pointers on x86 Greg KH
2009-07-01 0:23 ` [patch 060/108] ASoC: Remove odd bit clock ratios for WM8903 Greg KH
2009-07-01 0:23 ` [patch 061/108] ramfs: ignore unknown mount options Greg KH
2009-07-01 0:23 ` [patch 062/108] mac80211: fix minstrel single-rate memory corruption Greg KH
2009-07-01 0:23 ` [patch 063/108] cfg80211: fix for duplicate userspace replies Greg KH
2009-07-01 0:23 ` [patch 064/108] cfg80211: cleanup return calls on nl80211_set_reg() Greg KH
2009-07-01 0:23 ` [patch 065/108] cfg80211: return immediately if num reg rules > NL80211_MAX_SUPP_REG_RULES Greg KH
2009-07-01 0:23 ` [patch 066/108] cfg80211: fix in nl80211_set_reg() Greg KH
2009-07-01 0:23 ` [patch 067/108] ath9k: Fix bug when using a card with a busted EEPROM Greg KH
2009-07-01 0:23 ` [patch 068/108] ath9k: Fix bug in calibration initialization Greg KH
2009-07-01 0:23 ` [patch 069/108] ath9k: Fix bug in determining calibration support Greg KH
2009-07-01 0:23 ` [patch 070/108] ath9k: Fix bug in checking HT flag Greg KH
2009-07-01 0:24 ` [patch 071/108] ath9k: Fix bug in scan termination Greg KH
2009-07-01 0:24 ` [patch 072/108] ath9k: Fix memleak on TX DMA failure Greg KH
2009-07-01 0:24 ` [patch 073/108] ath9k: Initialize ANI timers Greg KH
2009-07-01 0:24 ` [patch 074/108] ath9k: Fix PCI FATAL interrupts by restoring RETRY_TIMEOUT disabling Greg KH
2009-07-01 0:24 ` [patch 075/108] crypto: aes-ni - Fix cbc mode IV saving Greg KH
2009-07-01 0:24 ` [patch 076/108] md/raid5: add missing call to schedule() after prepare_to_wait() Greg KH
2009-07-01 0:24 ` [patch 077/108] tracing/urgent: fix unbalanced ftrace_start_up Greg KH
2009-07-01 0:24 ` [patch 078/108] cifs: fix fh_mutex locking in cifs_reopen_file Greg KH
2009-07-01 0:24 ` [patch 079/108] vt_ioctl: fix lock imbalance Greg KH
2009-07-01 0:24 ` [patch 080/108] x86: Fix non-lazy GS handling in sys_vm86() Greg KH
2009-07-01 0:24 ` [patch 081/108] x86: Set cpu_llc_id on AMD CPUs Greg KH
2009-07-01 0:24 ` [patch 082/108] usb-serial: replace shutdown with disconnect, release Greg KH
2009-07-01 0:24 ` [patch 083/108] pcmcia/cm4000: fix lock imbalance Greg KH
2009-07-01 0:24 ` [patch 084/108] n_r3964: " Greg KH
2009-07-01 0:24 ` [patch 085/108] parport_pc: set properly the dma_mask for parport_pc device Greg KH
2009-07-01 0:24 ` [patch 086/108] parport_pc: after superio probing restore original register values Greg KH
2009-07-01 0:24 ` [patch 087/108] mv643xx_eth: fix unicast filter programming in promiscuous mode Greg KH
2009-07-01 0:24 ` [patch 088/108] ath5k: avoid PCI FATAL interrupts by restoring RETRY_TIMEOUT disabling Greg KH
2009-07-01 0:24 ` [patch 089/108] sound: seq_midi_event: fix decoding of (N)RPN events Greg KH
2009-07-01 0:24 ` [patch 090/108] PCI PM: Fix handling of devices without PM support by pci_target_state() Greg KH
2009-07-01 0:24 ` [patch 091/108] PCI PM: Follow PCI_PM_CTRL_NO_SOFT_RESET during transitions from D3 Greg KH
2009-07-01 0:24 ` [patch 092/108] qla2xxx: Correct (again) overflow during dump-processing on large-memory ISP23xx parts Greg KH
2009-07-01 0:24 ` [patch 093/108] mm: fix handling of pagesets for downed cpus Greg KH
2009-07-01 0:24 ` [patch 094/108] dm mpath: validate hw_handler argument count Greg KH
2009-07-01 0:24 ` [patch 095/108] dm mpath: validate table " Greg KH
2009-07-01 0:24 ` [patch 096/108] dm: sysfs skip output when device is being destroyed Greg KH
2009-07-01 0:24 ` [patch 097/108] dm mpath: flush keventd queue in destructor Greg KH
2009-07-01 0:24 ` [patch 098/108] dm exception store: fix exstore lookup to be case insensitive Greg KH
2009-07-01 7:11 ` Milan Broz
2009-07-01 17:26 ` [Stable-review] " Greg KH
2009-07-01 0:24 ` [patch 099/108] dm: use i_size_read Greg KH
2009-07-01 0:24 ` [patch 100/108] vmscan: properly account for the number of page cache pages zone_reclaim() can reclaim Greg KH
2009-07-01 0:24 ` [patch 101/108] vmscan: count the number of times zone_reclaim() scans and fails Greg KH
2009-07-01 0:24 ` [patch 102/108] lib/genalloc.c: remove unmatched write_lock() in gen_pool_destroy Greg KH
2009-07-01 0:24 ` [patch 103/108] CONFIG_FILE_LOCKING should not depend on CONFIG_BLOCK Greg KH
2009-07-01 0:24 ` [patch 104/108] serial: bfin_5xx: fix building as module when early printk is enabled Greg KH
2009-07-01 0:24 ` [patch 105/108] ocfs2: Fix ocfs2_osb_dump() Greg KH
2009-07-01 0:24 ` [patch 106/108] ide-cd: prevent null pointer deref via cdrom_newpc_intr Greg KH
2009-07-01 0:24 ` [patch 107/108] drm/i915: correct suspend/resume ordering Greg KH
2009-07-01 0:24 ` [patch 108/108] KVM: x86: silence preempt warning on kvm_write_guest_time Greg KH
2009-07-01 11:22 ` [patch 000/108] 2.6.30-stable review Julien BLACHE
2009-07-01 15:02 ` Stefan Richter
2009-07-01 15:41 ` Julien BLACHE
2009-07-01 16:22 ` [Stable-review] " Luis R. Rodriguez
2009-07-01 16:27 ` Julien BLACHE
2009-07-01 16:43 ` Stefan Richter
2009-07-01 17:21 ` Greg KH
2009-07-01 18:10 ` Greg KH
2009-07-01 18:12 ` [patch 109/108] bsdacct: fix access to invalid filp in acct_on() Greg KH
2009-07-01 18:13 ` [patch 110/108] dm exception store: really fix type lookup Greg KH
2009-07-01 18:14 ` [patch 111/108] xfs: fix freeing memory in xfs_getbmap() Greg KH
2009-07-01 18:33 ` [patch 000/108] 2.6.30-stable review Greg KH
2009-07-01 18:24 ` [Stable-review] " Luis R. Rodriguez
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20090701002424.978718378@mini.kroah.org \
--to=gregkh@suse.de \
--cc=akpm@linux-foundation.org \
--cc=alan@lxorguk.ukuu.org.uk \
--cc=keil@b1-systems.de \
--cc=linux-kernel@vger.kernel.org \
--cc=stable-review@kernel.org \
--cc=stable@kernel.org \
--cc=torvalds@linux-foundation.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox