aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/lpfc/lpfc_mem.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/scsi/lpfc/lpfc_mem.c')
-rw-r--r--drivers/scsi/lpfc/lpfc_mem.c115
1 files changed, 110 insertions, 5 deletions
diff --git a/drivers/scsi/lpfc/lpfc_mem.c b/drivers/scsi/lpfc/lpfc_mem.c
index 3c0cebc71800..50d9136a6e04 100644
--- a/drivers/scsi/lpfc/lpfc_mem.c
+++ b/drivers/scsi/lpfc/lpfc_mem.c
@@ -1,7 +1,7 @@
1/******************************************************************* 1/*******************************************************************
2 * This file is part of the Emulex Linux Device Driver for * 2 * This file is part of the Emulex Linux Device Driver for *
3 * Fibre Channel Host Bus Adapters. * 3 * Fibre Channel Host Bus Adapters. *
4 * Copyright (C) 2004-2006 Emulex. All rights reserved. * 4 * Copyright (C) 2004-2008 Emulex. All rights reserved. *
5 * EMULEX and SLI are trademarks of Emulex. * 5 * EMULEX and SLI are trademarks of Emulex. *
6 * www.emulex.com * 6 * www.emulex.com *
7 * Portions Copyright (C) 2004-2005 Christoph Hellwig * 7 * Portions Copyright (C) 2004-2005 Christoph Hellwig *
@@ -39,7 +39,21 @@
39#define LPFC_MEM_POOL_SIZE 64 /* max elem in non-DMA safety pool */ 39#define LPFC_MEM_POOL_SIZE 64 /* max elem in non-DMA safety pool */
40 40
41 41
42 42/**
43 * lpfc_mem_alloc: create and allocate all PCI and memory pools
44 * @phba: HBA to allocate pools for
45 *
46 * Description: Creates and allocates PCI pools lpfc_scsi_dma_buf_pool,
47 * lpfc_mbuf_pool, lpfc_hbq_pool. Creates and allocates kmalloc-backed mempools
48 * for LPFC_MBOXQ_t and lpfc_nodelist. Also allocates the VPI bitmask.
49 *
50 * Notes: Not interrupt-safe. Must be called with no locks held. If any
51 * allocation fails, frees all successfully allocated memory before returning.
52 *
53 * Returns:
54 * 0 on success
55 * -ENOMEM on failure (if any memory allocations fail)
56 **/
43int 57int
44lpfc_mem_alloc(struct lpfc_hba * phba) 58lpfc_mem_alloc(struct lpfc_hba * phba)
45{ 59{
@@ -120,6 +134,16 @@ lpfc_mem_alloc(struct lpfc_hba * phba)
120 return -ENOMEM; 134 return -ENOMEM;
121} 135}
122 136
137/**
138 * lpfc_mem_free: Frees all PCI and memory allocated by lpfc_mem_alloc
139 * @phba: HBA to free memory for
140 *
141 * Description: Frees PCI pools lpfc_scsi_dma_buf_pool, lpfc_mbuf_pool,
142 * lpfc_hbq_pool. Frees kmalloc-backed mempools for LPFC_MBOXQ_t and
143 * lpfc_nodelist. Also frees the VPI bitmask.
144 *
145 * Returns: None
146 **/
123void 147void
124lpfc_mem_free(struct lpfc_hba * phba) 148lpfc_mem_free(struct lpfc_hba * phba)
125{ 149{
@@ -181,12 +205,29 @@ lpfc_mem_free(struct lpfc_hba * phba)
181 phba->lpfc_scsi_dma_buf_pool = NULL; 205 phba->lpfc_scsi_dma_buf_pool = NULL;
182 phba->lpfc_mbuf_pool = NULL; 206 phba->lpfc_mbuf_pool = NULL;
183 207
184 /* Free the iocb lookup array */ 208 /* Free the iocb lookup array */
185 kfree(psli->iocbq_lookup); 209 kfree(psli->iocbq_lookup);
186 psli->iocbq_lookup = NULL; 210 psli->iocbq_lookup = NULL;
187
188} 211}
189 212
213/**
214 * lpfc_mbuf_alloc: Allocate an mbuf from the lpfc_mbuf_pool PCI pool
215 * @phba: HBA which owns the pool to allocate from
216 * @mem_flags: indicates if this is a priority (MEM_PRI) allocation
217 * @handle: used to return the DMA-mapped address of the mbuf
218 *
219 * Description: Allocates a DMA-mapped buffer from the lpfc_mbuf_pool PCI pool.
220 * Allocates from generic pci_pool_alloc function first and if that fails and
221 * mem_flags has MEM_PRI set (the only defined flag), returns an mbuf from the
222 * HBA's pool.
223 *
224 * Notes: Not interrupt-safe. Must be called with no locks held. Takes
225 * phba->hbalock.
226 *
227 * Returns:
228 * pointer to the allocated mbuf on success
229 * NULL on failure
230 **/
190void * 231void *
191lpfc_mbuf_alloc(struct lpfc_hba *phba, int mem_flags, dma_addr_t *handle) 232lpfc_mbuf_alloc(struct lpfc_hba *phba, int mem_flags, dma_addr_t *handle)
192{ 233{
@@ -206,6 +247,20 @@ lpfc_mbuf_alloc(struct lpfc_hba *phba, int mem_flags, dma_addr_t *handle)
206 return ret; 247 return ret;
207} 248}
208 249
250/**
251 * __lpfc_mem_free: Free an mbuf from the lpfc_mbuf_pool PCI pool (locked)
252 * @phba: HBA which owns the pool to return to
253 * @virt: mbuf to free
254 * @dma: the DMA-mapped address of the lpfc_mbuf_pool to be freed
255 *
256 * Description: Returns an mbuf lpfc_mbuf_pool to the lpfc_mbuf_safety_pool if
257 * it is below its max_count, frees the mbuf otherwise.
258 *
259 * Notes: Must be called with phba->hbalock held to synchronize access to
260 * lpfc_mbuf_safety_pool.
261 *
262 * Returns: None
263 **/
209void 264void
210__lpfc_mbuf_free(struct lpfc_hba * phba, void *virt, dma_addr_t dma) 265__lpfc_mbuf_free(struct lpfc_hba * phba, void *virt, dma_addr_t dma)
211{ 266{
@@ -221,7 +276,21 @@ __lpfc_mbuf_free(struct lpfc_hba * phba, void *virt, dma_addr_t dma)
221 return; 276 return;
222} 277}
223 278
279/**
280 * lpfc_mem_free: Free an mbuf from the lpfc_mbuf_pool PCI pool (unlocked)
281 * @phba: HBA which owns the pool to return to
282 * @virt: mbuf to free
283 * @dma: the DMA-mapped address of the lpfc_mbuf_pool to be freed
284 *
285 * Description: Returns an mbuf lpfc_mbuf_pool to the lpfc_mbuf_safety_pool if
286 * it is below its max_count, frees the mbuf otherwise.
287 *
288 * Notes: Takes phba->hbalock. Can be called with or without other locks held.
289 *
290 * Returns: None
291 **/
224void 292void
293
225lpfc_mbuf_free(struct lpfc_hba * phba, void *virt, dma_addr_t dma) 294lpfc_mbuf_free(struct lpfc_hba * phba, void *virt, dma_addr_t dma)
226{ 295{
227 unsigned long iflags; 296 unsigned long iflags;
@@ -232,6 +301,19 @@ lpfc_mbuf_free(struct lpfc_hba * phba, void *virt, dma_addr_t dma)
232 return; 301 return;
233} 302}
234 303
304/**
305 * lpfc_els_hbq_alloc: Allocate an HBQ buffer
306 * @phba: HBA to allocate HBQ buffer for
307 *
308 * Description: Allocates a DMA-mapped HBQ buffer from the lpfc_hbq_pool PCI
309 * pool along a non-DMA-mapped container for it.
310 *
311 * Notes: Not interrupt-safe. Must be called with no locks held.
312 *
313 * Returns:
314 * pointer to HBQ on success
315 * NULL on failure
316 **/
235struct hbq_dmabuf * 317struct hbq_dmabuf *
236lpfc_els_hbq_alloc(struct lpfc_hba *phba) 318lpfc_els_hbq_alloc(struct lpfc_hba *phba)
237{ 319{
@@ -251,6 +333,18 @@ lpfc_els_hbq_alloc(struct lpfc_hba *phba)
251 return hbqbp; 333 return hbqbp;
252} 334}
253 335
336/**
337 * lpfc_mem_hbq_free: Frees an HBQ buffer allocated with lpfc_els_hbq_alloc
338 * @phba: HBA buffer was allocated for
339 * @hbqbp: HBQ container returned by lpfc_els_hbq_alloc
340 *
341 * Description: Frees both the container and the DMA-mapped buffer returned by
342 * lpfc_els_hbq_alloc.
343 *
344 * Notes: Can be called with or without locks held.
345 *
346 * Returns: None
347 **/
254void 348void
255lpfc_els_hbq_free(struct lpfc_hba *phba, struct hbq_dmabuf *hbqbp) 349lpfc_els_hbq_free(struct lpfc_hba *phba, struct hbq_dmabuf *hbqbp)
256{ 350{
@@ -259,7 +353,18 @@ lpfc_els_hbq_free(struct lpfc_hba *phba, struct hbq_dmabuf *hbqbp)
259 return; 353 return;
260} 354}
261 355
262/* This is ONLY called for the LPFC_ELS_HBQ */ 356/**
357 * lpfc_in_buf_free: Free a DMA buffer
358 * @phba: HBA buffer is associated with
359 * @mp: Buffer to free
360 *
361 * Description: Frees the given DMA buffer in the appropriate way given if the
362 * HBA is running in SLI3 mode with HBQs enabled.
363 *
364 * Notes: Takes phba->hbalock. Can be called with or without other locks held.
365 *
366 * Returns: None
367 **/
263void 368void
264lpfc_in_buf_free(struct lpfc_hba *phba, struct lpfc_dmabuf *mp) 369lpfc_in_buf_free(struct lpfc_hba *phba, struct lpfc_dmabuf *mp)
265{ 370{