ib_fmr_pool.h 3.4 KB

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