allocpercpu.c 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. /*
  2. * linux/mm/allocpercpu.c
  3. *
  4. * Separated from slab.c August 11, 2006 Christoph Lameter <clameter@sgi.com>
  5. */
  6. #include <linux/mm.h>
  7. #include <linux/module.h>
  8. /**
  9. * percpu_depopulate - depopulate per-cpu data for given cpu
  10. * @__pdata: per-cpu data to depopulate
  11. * @cpu: depopulate per-cpu data for this cpu
  12. *
  13. * Depopulating per-cpu data for a cpu going offline would be a typical
  14. * use case. You need to register a cpu hotplug handler for that purpose.
  15. */
  16. void percpu_depopulate(void *__pdata, int cpu)
  17. {
  18. struct percpu_data *pdata = __percpu_disguise(__pdata);
  19. kfree(pdata->ptrs[cpu]);
  20. pdata->ptrs[cpu] = NULL;
  21. }
  22. EXPORT_SYMBOL_GPL(percpu_depopulate);
  23. /**
  24. * percpu_depopulate_mask - depopulate per-cpu data for some cpu's
  25. * @__pdata: per-cpu data to depopulate
  26. * @mask: depopulate per-cpu data for cpu's selected through mask bits
  27. */
  28. void __percpu_depopulate_mask(void *__pdata, cpumask_t *mask)
  29. {
  30. int cpu;
  31. for_each_cpu_mask(cpu, *mask)
  32. percpu_depopulate(__pdata, cpu);
  33. }
  34. EXPORT_SYMBOL_GPL(__percpu_depopulate_mask);
  35. /**
  36. * percpu_populate - populate per-cpu data for given cpu
  37. * @__pdata: per-cpu data to populate further
  38. * @size: size of per-cpu object
  39. * @gfp: may sleep or not etc.
  40. * @cpu: populate per-data for this cpu
  41. *
  42. * Populating per-cpu data for a cpu coming online would be a typical
  43. * use case. You need to register a cpu hotplug handler for that purpose.
  44. * Per-cpu object is populated with zeroed buffer.
  45. */
  46. void *percpu_populate(void *__pdata, size_t size, gfp_t gfp, int cpu)
  47. {
  48. struct percpu_data *pdata = __percpu_disguise(__pdata);
  49. int node = cpu_to_node(cpu);
  50. BUG_ON(pdata->ptrs[cpu]);
  51. if (node_online(node))
  52. pdata->ptrs[cpu] = kmalloc_node(size, gfp|__GFP_ZERO, node);
  53. else
  54. pdata->ptrs[cpu] = kzalloc(size, gfp);
  55. return pdata->ptrs[cpu];
  56. }
  57. EXPORT_SYMBOL_GPL(percpu_populate);
  58. /**
  59. * percpu_populate_mask - populate per-cpu data for more cpu's
  60. * @__pdata: per-cpu data to populate further
  61. * @size: size of per-cpu object
  62. * @gfp: may sleep or not etc.
  63. * @mask: populate per-cpu data for cpu's selected through mask bits
  64. *
  65. * Per-cpu objects are populated with zeroed buffers.
  66. */
  67. int __percpu_populate_mask(void *__pdata, size_t size, gfp_t gfp,
  68. cpumask_t *mask)
  69. {
  70. cpumask_t populated = CPU_MASK_NONE;
  71. int cpu;
  72. for_each_cpu_mask(cpu, *mask)
  73. if (unlikely(!percpu_populate(__pdata, size, gfp, cpu))) {
  74. __percpu_depopulate_mask(__pdata, &populated);
  75. return -ENOMEM;
  76. } else
  77. cpu_set(cpu, populated);
  78. return 0;
  79. }
  80. EXPORT_SYMBOL_GPL(__percpu_populate_mask);
  81. /**
  82. * percpu_alloc_mask - initial setup of per-cpu data
  83. * @size: size of per-cpu object
  84. * @gfp: may sleep or not etc.
  85. * @mask: populate per-data for cpu's selected through mask bits
  86. *
  87. * Populating per-cpu data for all online cpu's would be a typical use case,
  88. * which is simplified by the percpu_alloc() wrapper.
  89. * Per-cpu objects are populated with zeroed buffers.
  90. */
  91. void *__percpu_alloc_mask(size_t size, gfp_t gfp, cpumask_t *mask)
  92. {
  93. void *pdata = kzalloc(sizeof(struct percpu_data), gfp);
  94. void *__pdata = __percpu_disguise(pdata);
  95. if (unlikely(!pdata))
  96. return NULL;
  97. if (likely(!__percpu_populate_mask(__pdata, size, gfp, mask)))
  98. return __pdata;
  99. kfree(pdata);
  100. return NULL;
  101. }
  102. EXPORT_SYMBOL_GPL(__percpu_alloc_mask);
  103. /**
  104. * percpu_free - final cleanup of per-cpu data
  105. * @__pdata: object to clean up
  106. *
  107. * We simply clean up any per-cpu object left. No need for the client to
  108. * track and specify through a bis mask which per-cpu objects are to free.
  109. */
  110. void percpu_free(void *__pdata)
  111. {
  112. if (unlikely(!__pdata))
  113. return;
  114. __percpu_depopulate_mask(__pdata, &cpu_possible_map);
  115. kfree(__percpu_disguise(__pdata));
  116. }
  117. EXPORT_SYMBOL_GPL(percpu_free);