ib_fmr_pool.h 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. /*
  2. * Copyright (c) 2004 Topspin Corporation. All rights reserved.
  3. *
  4. * This software is available to you under a choice of one of two
  5. * licenses. You may choose to be licensed under the terms of the GNU
  6. * General Public License (GPL) Version 2, available from the file
  7. * COPYING in the main directory of this source tree, or the
  8. * OpenIB.org BSD license below:
  9. *
  10. * Redistribution and use in source and binary forms, with or
  11. * without modification, are permitted provided that the following
  12. * conditions are met:
  13. *
  14. * - Redistributions of source code must retain the above
  15. * copyright notice, this list of conditions and the following
  16. * disclaimer.
  17. *
  18. * - Redistributions in binary form must reproduce the above
  19. * copyright notice, this list of conditions and the following
  20. * disclaimer in the documentation and/or other materials
  21. * provided with the distribution.
  22. *
  23. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  24. * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  25. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  26. * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
  27. * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
  28. * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  29. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  30. * SOFTWARE.
  31. *
  32. * $Id: ib_fmr_pool.h 1349 2004-12-16 21:09:43Z roland $
  33. */
  34. #if !defined(IB_FMR_POOL_H)
  35. #define IB_FMR_POOL_H
  36. #include <ib_verbs.h>
  37. struct ib_fmr_pool;
  38. /**
  39. * struct ib_fmr_pool_param - Parameters for creating FMR pool
  40. * @max_pages_per_fmr:Maximum number of pages per map request.
  41. * @access:Access flags for FMRs in pool.
  42. * @pool_size:Number of FMRs to allocate for pool.
  43. * @dirty_watermark:Flush is triggered when @dirty_watermark dirty
  44. * FMRs are present.
  45. * @flush_function:Callback called when unmapped FMRs are flushed and
  46. * more FMRs are possibly available for mapping
  47. * @flush_arg:Context passed to user's flush function.
  48. * @cache:If set, FMRs may be reused after unmapping for identical map
  49. * requests.
  50. */
  51. struct ib_fmr_pool_param {
  52. int max_pages_per_fmr;
  53. enum ib_access_flags access;
  54. int pool_size;
  55. int dirty_watermark;
  56. void (*flush_function)(struct ib_fmr_pool *pool,
  57. void * arg);
  58. void *flush_arg;
  59. unsigned cache:1;
  60. };
  61. struct ib_pool_fmr {
  62. struct ib_fmr *fmr;
  63. struct ib_fmr_pool *pool;
  64. struct list_head list;
  65. struct hlist_node cache_node;
  66. int ref_count;
  67. int remap_count;
  68. u64 io_virtual_address;
  69. int page_list_len;
  70. u64 page_list[0];
  71. };
  72. struct ib_fmr_pool *ib_create_fmr_pool(struct ib_pd *pd,
  73. struct ib_fmr_pool_param *params);
  74. int ib_destroy_fmr_pool(struct ib_fmr_pool *pool);
  75. int ib_flush_fmr_pool(struct ib_fmr_pool *pool);
  76. struct ib_pool_fmr *ib_fmr_pool_map_phys(struct ib_fmr_pool *pool_handle,
  77. u64 *page_list,
  78. int list_len,
  79. u64 *io_virtual_address);
  80. int ib_fmr_pool_unmap(struct ib_pool_fmr *fmr);
  81. #endif /* IB_FMR_POOL_H */