drbd_main.c 92 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441
  1. /*
  2. drbd.c
  3. This file is part of DRBD by Philipp Reisner and Lars Ellenberg.
  4. Copyright (C) 2001-2008, LINBIT Information Technologies GmbH.
  5. Copyright (C) 1999-2008, Philipp Reisner <philipp.reisner@linbit.com>.
  6. Copyright (C) 2002-2008, Lars Ellenberg <lars.ellenberg@linbit.com>.
  7. Thanks to Carter Burden, Bart Grantham and Gennadiy Nerubayev
  8. from Logicworks, Inc. for making SDP replication support possible.
  9. drbd is free software; you can redistribute it and/or modify
  10. it under the terms of the GNU General Public License as published by
  11. the Free Software Foundation; either version 2, or (at your option)
  12. any later version.
  13. drbd is distributed in the hope that it will be useful,
  14. but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. GNU General Public License for more details.
  17. You should have received a copy of the GNU General Public License
  18. along with drbd; see the file COPYING. If not, write to
  19. the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
  20. */
  21. #include <linux/module.h>
  22. #include <linux/drbd.h>
  23. #include <asm/uaccess.h>
  24. #include <asm/types.h>
  25. #include <net/sock.h>
  26. #include <linux/ctype.h>
  27. #include <linux/mutex.h>
  28. #include <linux/fs.h>
  29. #include <linux/file.h>
  30. #include <linux/proc_fs.h>
  31. #include <linux/init.h>
  32. #include <linux/mm.h>
  33. #include <linux/memcontrol.h>
  34. #include <linux/mm_inline.h>
  35. #include <linux/slab.h>
  36. #include <linux/random.h>
  37. #include <linux/reboot.h>
  38. #include <linux/notifier.h>
  39. #include <linux/kthread.h>
  40. #define __KERNEL_SYSCALLS__
  41. #include <linux/unistd.h>
  42. #include <linux/vmalloc.h>
  43. #include <linux/drbd_limits.h>
  44. #include "drbd_int.h"
  45. #include "drbd_req.h" /* only for _req_mod in tl_release and tl_clear */
  46. #include "drbd_vli.h"
  47. static DEFINE_MUTEX(drbd_main_mutex);
  48. int drbdd_init(struct drbd_thread *);
  49. int drbd_worker(struct drbd_thread *);
  50. int drbd_asender(struct drbd_thread *);
  51. int drbd_init(void);
  52. static int drbd_open(struct block_device *bdev, fmode_t mode);
  53. static int drbd_release(struct gendisk *gd, fmode_t mode);
  54. static int w_md_sync(struct drbd_work *w, int unused);
  55. static void md_sync_timer_fn(unsigned long data);
  56. static int w_bitmap_io(struct drbd_work *w, int unused);
  57. static int w_go_diskless(struct drbd_work *w, int unused);
  58. MODULE_AUTHOR("Philipp Reisner <phil@linbit.com>, "
  59. "Lars Ellenberg <lars@linbit.com>");
  60. MODULE_DESCRIPTION("drbd - Distributed Replicated Block Device v" REL_VERSION);
  61. MODULE_VERSION(REL_VERSION);
  62. MODULE_LICENSE("GPL");
  63. MODULE_PARM_DESC(minor_count, "Approximate number of drbd devices ("
  64. __stringify(DRBD_MINOR_COUNT_MIN) "-" __stringify(DRBD_MINOR_COUNT_MAX) ")");
  65. MODULE_ALIAS_BLOCKDEV_MAJOR(DRBD_MAJOR);
  66. #include <linux/moduleparam.h>
  67. /* allow_open_on_secondary */
  68. MODULE_PARM_DESC(allow_oos, "DONT USE!");
  69. /* thanks to these macros, if compiled into the kernel (not-module),
  70. * this becomes the boot parameter drbd.minor_count */
  71. module_param(minor_count, uint, 0444);
  72. module_param(disable_sendpage, bool, 0644);
  73. module_param(allow_oos, bool, 0);
  74. module_param(proc_details, int, 0644);
  75. #ifdef CONFIG_DRBD_FAULT_INJECTION
  76. int enable_faults;
  77. int fault_rate;
  78. static int fault_count;
  79. int fault_devs;
  80. /* bitmap of enabled faults */
  81. module_param(enable_faults, int, 0664);
  82. /* fault rate % value - applies to all enabled faults */
  83. module_param(fault_rate, int, 0664);
  84. /* count of faults inserted */
  85. module_param(fault_count, int, 0664);
  86. /* bitmap of devices to insert faults on */
  87. module_param(fault_devs, int, 0644);
  88. #endif
  89. /* module parameter, defined */
  90. unsigned int minor_count = DRBD_MINOR_COUNT_DEF;
  91. int disable_sendpage;
  92. int allow_oos;
  93. int proc_details; /* Detail level in proc drbd*/
  94. /* Module parameter for setting the user mode helper program
  95. * to run. Default is /sbin/drbdadm */
  96. char usermode_helper[80] = "/sbin/drbdadm";
  97. module_param_string(usermode_helper, usermode_helper, sizeof(usermode_helper), 0644);
  98. /* in 2.6.x, our device mapping and config info contains our virtual gendisks
  99. * as member "struct gendisk *vdisk;"
  100. */
  101. struct idr minors;
  102. struct list_head drbd_tconns; /* list of struct drbd_tconn */
  103. struct kmem_cache *drbd_request_cache;
  104. struct kmem_cache *drbd_ee_cache; /* peer requests */
  105. struct kmem_cache *drbd_bm_ext_cache; /* bitmap extents */
  106. struct kmem_cache *drbd_al_ext_cache; /* activity log extents */
  107. mempool_t *drbd_request_mempool;
  108. mempool_t *drbd_ee_mempool;
  109. mempool_t *drbd_md_io_page_pool;
  110. struct bio_set *drbd_md_io_bio_set;
  111. /* I do not use a standard mempool, because:
  112. 1) I want to hand out the pre-allocated objects first.
  113. 2) I want to be able to interrupt sleeping allocation with a signal.
  114. Note: This is a single linked list, the next pointer is the private
  115. member of struct page.
  116. */
  117. struct page *drbd_pp_pool;
  118. spinlock_t drbd_pp_lock;
  119. int drbd_pp_vacant;
  120. wait_queue_head_t drbd_pp_wait;
  121. DEFINE_RATELIMIT_STATE(drbd_ratelimit_state, 5 * HZ, 5);
  122. static const struct block_device_operations drbd_ops = {
  123. .owner = THIS_MODULE,
  124. .open = drbd_open,
  125. .release = drbd_release,
  126. };
  127. static void bio_destructor_drbd(struct bio *bio)
  128. {
  129. bio_free(bio, drbd_md_io_bio_set);
  130. }
  131. struct bio *bio_alloc_drbd(gfp_t gfp_mask)
  132. {
  133. struct bio *bio;
  134. if (!drbd_md_io_bio_set)
  135. return bio_alloc(gfp_mask, 1);
  136. bio = bio_alloc_bioset(gfp_mask, 1, drbd_md_io_bio_set);
  137. if (!bio)
  138. return NULL;
  139. bio->bi_destructor = bio_destructor_drbd;
  140. return bio;
  141. }
  142. #ifdef __CHECKER__
  143. /* When checking with sparse, and this is an inline function, sparse will
  144. give tons of false positives. When this is a real functions sparse works.
  145. */
  146. int _get_ldev_if_state(struct drbd_conf *mdev, enum drbd_disk_state mins)
  147. {
  148. int io_allowed;
  149. atomic_inc(&mdev->local_cnt);
  150. io_allowed = (mdev->state.disk >= mins);
  151. if (!io_allowed) {
  152. if (atomic_dec_and_test(&mdev->local_cnt))
  153. wake_up(&mdev->misc_wait);
  154. }
  155. return io_allowed;
  156. }
  157. #endif
  158. /**
  159. * DOC: The transfer log
  160. *
  161. * The transfer log is a single linked list of &struct drbd_tl_epoch objects.
  162. * mdev->tconn->newest_tle points to the head, mdev->tconn->oldest_tle points to the tail
  163. * of the list. There is always at least one &struct drbd_tl_epoch object.
  164. *
  165. * Each &struct drbd_tl_epoch has a circular double linked list of requests
  166. * attached.
  167. */
  168. static int tl_init(struct drbd_tconn *tconn)
  169. {
  170. struct drbd_tl_epoch *b;
  171. /* during device minor initialization, we may well use GFP_KERNEL */
  172. b = kmalloc(sizeof(struct drbd_tl_epoch), GFP_KERNEL);
  173. if (!b)
  174. return 0;
  175. INIT_LIST_HEAD(&b->requests);
  176. INIT_LIST_HEAD(&b->w.list);
  177. b->next = NULL;
  178. b->br_number = 4711;
  179. b->n_writes = 0;
  180. b->w.cb = NULL; /* if this is != NULL, we need to dec_ap_pending in tl_clear */
  181. tconn->oldest_tle = b;
  182. tconn->newest_tle = b;
  183. INIT_LIST_HEAD(&tconn->out_of_sequence_requests);
  184. return 1;
  185. }
  186. static void tl_cleanup(struct drbd_tconn *tconn)
  187. {
  188. if (tconn->oldest_tle != tconn->newest_tle)
  189. conn_err(tconn, "ASSERT FAILED: oldest_tle == newest_tle\n");
  190. if (!list_empty(&tconn->out_of_sequence_requests))
  191. conn_err(tconn, "ASSERT FAILED: list_empty(out_of_sequence_requests)\n");
  192. kfree(tconn->oldest_tle);
  193. tconn->oldest_tle = NULL;
  194. kfree(tconn->unused_spare_tle);
  195. tconn->unused_spare_tle = NULL;
  196. }
  197. /**
  198. * _tl_add_barrier() - Adds a barrier to the transfer log
  199. * @mdev: DRBD device.
  200. * @new: Barrier to be added before the current head of the TL.
  201. *
  202. * The caller must hold the req_lock.
  203. */
  204. void _tl_add_barrier(struct drbd_tconn *tconn, struct drbd_tl_epoch *new)
  205. {
  206. struct drbd_tl_epoch *newest_before;
  207. INIT_LIST_HEAD(&new->requests);
  208. INIT_LIST_HEAD(&new->w.list);
  209. new->w.cb = NULL; /* if this is != NULL, we need to dec_ap_pending in tl_clear */
  210. new->next = NULL;
  211. new->n_writes = 0;
  212. newest_before = tconn->newest_tle;
  213. /* never send a barrier number == 0, because that is special-cased
  214. * when using TCQ for our write ordering code */
  215. new->br_number = (newest_before->br_number+1) ?: 1;
  216. if (tconn->newest_tle != new) {
  217. tconn->newest_tle->next = new;
  218. tconn->newest_tle = new;
  219. }
  220. }
  221. /**
  222. * tl_release() - Free or recycle the oldest &struct drbd_tl_epoch object of the TL
  223. * @mdev: DRBD device.
  224. * @barrier_nr: Expected identifier of the DRBD write barrier packet.
  225. * @set_size: Expected number of requests before that barrier.
  226. *
  227. * In case the passed barrier_nr or set_size does not match the oldest
  228. * &struct drbd_tl_epoch objects this function will cause a termination
  229. * of the connection.
  230. */
  231. void tl_release(struct drbd_tconn *tconn, unsigned int barrier_nr,
  232. unsigned int set_size)
  233. {
  234. struct drbd_conf *mdev;
  235. struct drbd_tl_epoch *b, *nob; /* next old barrier */
  236. struct list_head *le, *tle;
  237. struct drbd_request *r;
  238. spin_lock_irq(&tconn->req_lock);
  239. b = tconn->oldest_tle;
  240. /* first some paranoia code */
  241. if (b == NULL) {
  242. conn_err(tconn, "BAD! BarrierAck #%u received, but no epoch in tl!?\n",
  243. barrier_nr);
  244. goto bail;
  245. }
  246. if (b->br_number != barrier_nr) {
  247. conn_err(tconn, "BAD! BarrierAck #%u received, expected #%u!\n",
  248. barrier_nr, b->br_number);
  249. goto bail;
  250. }
  251. if (b->n_writes != set_size) {
  252. conn_err(tconn, "BAD! BarrierAck #%u received with n_writes=%u, expected n_writes=%u!\n",
  253. barrier_nr, set_size, b->n_writes);
  254. goto bail;
  255. }
  256. /* Clean up list of requests processed during current epoch */
  257. list_for_each_safe(le, tle, &b->requests) {
  258. r = list_entry(le, struct drbd_request, tl_requests);
  259. _req_mod(r, BARRIER_ACKED);
  260. }
  261. /* There could be requests on the list waiting for completion
  262. of the write to the local disk. To avoid corruptions of
  263. slab's data structures we have to remove the lists head.
  264. Also there could have been a barrier ack out of sequence, overtaking
  265. the write acks - which would be a bug and violating write ordering.
  266. To not deadlock in case we lose connection while such requests are
  267. still pending, we need some way to find them for the
  268. _req_mode(CONNECTION_LOST_WHILE_PENDING).
  269. These have been list_move'd to the out_of_sequence_requests list in
  270. _req_mod(, BARRIER_ACKED) above.
  271. */
  272. list_del_init(&b->requests);
  273. mdev = b->w.mdev;
  274. nob = b->next;
  275. if (test_and_clear_bit(CREATE_BARRIER, &mdev->flags)) {
  276. _tl_add_barrier(tconn, b);
  277. if (nob)
  278. tconn->oldest_tle = nob;
  279. /* if nob == NULL b was the only barrier, and becomes the new
  280. barrier. Therefore tconn->oldest_tle points already to b */
  281. } else {
  282. D_ASSERT(nob != NULL);
  283. tconn->oldest_tle = nob;
  284. kfree(b);
  285. }
  286. spin_unlock_irq(&tconn->req_lock);
  287. dec_ap_pending(mdev);
  288. return;
  289. bail:
  290. spin_unlock_irq(&tconn->req_lock);
  291. conn_request_state(tconn, NS(conn, C_PROTOCOL_ERROR), CS_HARD);
  292. }
  293. /**
  294. * _tl_restart() - Walks the transfer log, and applies an action to all requests
  295. * @mdev: DRBD device.
  296. * @what: The action/event to perform with all request objects
  297. *
  298. * @what might be one of CONNECTION_LOST_WHILE_PENDING, RESEND, FAIL_FROZEN_DISK_IO,
  299. * RESTART_FROZEN_DISK_IO.
  300. */
  301. void _tl_restart(struct drbd_tconn *tconn, enum drbd_req_event what)
  302. {
  303. struct drbd_tl_epoch *b, *tmp, **pn;
  304. struct list_head *le, *tle, carry_reads;
  305. struct drbd_request *req;
  306. int rv, n_writes, n_reads;
  307. b = tconn->oldest_tle;
  308. pn = &tconn->oldest_tle;
  309. while (b) {
  310. n_writes = 0;
  311. n_reads = 0;
  312. INIT_LIST_HEAD(&carry_reads);
  313. list_for_each_safe(le, tle, &b->requests) {
  314. req = list_entry(le, struct drbd_request, tl_requests);
  315. rv = _req_mod(req, what);
  316. n_writes += (rv & MR_WRITE) >> MR_WRITE_SHIFT;
  317. n_reads += (rv & MR_READ) >> MR_READ_SHIFT;
  318. }
  319. tmp = b->next;
  320. if (n_writes) {
  321. if (what == RESEND) {
  322. b->n_writes = n_writes;
  323. if (b->w.cb == NULL) {
  324. b->w.cb = w_send_barrier;
  325. inc_ap_pending(b->w.mdev);
  326. set_bit(CREATE_BARRIER, &b->w.mdev->flags);
  327. }
  328. drbd_queue_work(&tconn->data.work, &b->w);
  329. }
  330. pn = &b->next;
  331. } else {
  332. if (n_reads)
  333. list_add(&carry_reads, &b->requests);
  334. /* there could still be requests on that ring list,
  335. * in case local io is still pending */
  336. list_del(&b->requests);
  337. /* dec_ap_pending corresponding to queue_barrier.
  338. * the newest barrier may not have been queued yet,
  339. * in which case w.cb is still NULL. */
  340. if (b->w.cb != NULL)
  341. dec_ap_pending(b->w.mdev);
  342. if (b == tconn->newest_tle) {
  343. /* recycle, but reinit! */
  344. if (tmp != NULL)
  345. conn_err(tconn, "ASSERT FAILED tmp == NULL");
  346. INIT_LIST_HEAD(&b->requests);
  347. list_splice(&carry_reads, &b->requests);
  348. INIT_LIST_HEAD(&b->w.list);
  349. b->w.cb = NULL;
  350. b->br_number = net_random();
  351. b->n_writes = 0;
  352. *pn = b;
  353. break;
  354. }
  355. *pn = tmp;
  356. kfree(b);
  357. }
  358. b = tmp;
  359. list_splice(&carry_reads, &b->requests);
  360. }
  361. }
  362. /**
  363. * tl_clear() - Clears all requests and &struct drbd_tl_epoch objects out of the TL
  364. * @mdev: DRBD device.
  365. *
  366. * This is called after the connection to the peer was lost. The storage covered
  367. * by the requests on the transfer gets marked as our of sync. Called from the
  368. * receiver thread and the worker thread.
  369. */
  370. void tl_clear(struct drbd_tconn *tconn)
  371. {
  372. struct drbd_conf *mdev;
  373. struct list_head *le, *tle;
  374. struct drbd_request *r;
  375. int vnr;
  376. spin_lock_irq(&tconn->req_lock);
  377. _tl_restart(tconn, CONNECTION_LOST_WHILE_PENDING);
  378. /* we expect this list to be empty. */
  379. if (!list_empty(&tconn->out_of_sequence_requests))
  380. conn_err(tconn, "ASSERT FAILED list_empty(&out_of_sequence_requests)\n");
  381. /* but just in case, clean it up anyways! */
  382. list_for_each_safe(le, tle, &tconn->out_of_sequence_requests) {
  383. r = list_entry(le, struct drbd_request, tl_requests);
  384. /* It would be nice to complete outside of spinlock.
  385. * But this is easier for now. */
  386. _req_mod(r, CONNECTION_LOST_WHILE_PENDING);
  387. }
  388. /* ensure bit indicating barrier is required is clear */
  389. rcu_read_lock();
  390. idr_for_each_entry(&tconn->volumes, mdev, vnr)
  391. clear_bit(CREATE_BARRIER, &mdev->flags);
  392. rcu_read_unlock();
  393. spin_unlock_irq(&tconn->req_lock);
  394. }
  395. void tl_restart(struct drbd_tconn *tconn, enum drbd_req_event what)
  396. {
  397. spin_lock_irq(&tconn->req_lock);
  398. _tl_restart(tconn, what);
  399. spin_unlock_irq(&tconn->req_lock);
  400. }
  401. static int drbd_thread_setup(void *arg)
  402. {
  403. struct drbd_thread *thi = (struct drbd_thread *) arg;
  404. struct drbd_tconn *tconn = thi->tconn;
  405. unsigned long flags;
  406. int retval;
  407. snprintf(current->comm, sizeof(current->comm), "drbd_%c_%s",
  408. thi->name[0], thi->tconn->name);
  409. restart:
  410. retval = thi->function(thi);
  411. spin_lock_irqsave(&thi->t_lock, flags);
  412. /* if the receiver has been "EXITING", the last thing it did
  413. * was set the conn state to "StandAlone",
  414. * if now a re-connect request comes in, conn state goes C_UNCONNECTED,
  415. * and receiver thread will be "started".
  416. * drbd_thread_start needs to set "RESTARTING" in that case.
  417. * t_state check and assignment needs to be within the same spinlock,
  418. * so either thread_start sees EXITING, and can remap to RESTARTING,
  419. * or thread_start see NONE, and can proceed as normal.
  420. */
  421. if (thi->t_state == RESTARTING) {
  422. conn_info(tconn, "Restarting %s thread\n", thi->name);
  423. thi->t_state = RUNNING;
  424. spin_unlock_irqrestore(&thi->t_lock, flags);
  425. goto restart;
  426. }
  427. thi->task = NULL;
  428. thi->t_state = NONE;
  429. smp_mb();
  430. complete_all(&thi->stop);
  431. spin_unlock_irqrestore(&thi->t_lock, flags);
  432. conn_info(tconn, "Terminating %s\n", current->comm);
  433. /* Release mod reference taken when thread was started */
  434. kref_put(&tconn->kref, &conn_destroy);
  435. module_put(THIS_MODULE);
  436. return retval;
  437. }
  438. static void drbd_thread_init(struct drbd_tconn *tconn, struct drbd_thread *thi,
  439. int (*func) (struct drbd_thread *), char *name)
  440. {
  441. spin_lock_init(&thi->t_lock);
  442. thi->task = NULL;
  443. thi->t_state = NONE;
  444. thi->function = func;
  445. thi->tconn = tconn;
  446. strncpy(thi->name, name, ARRAY_SIZE(thi->name));
  447. }
  448. int drbd_thread_start(struct drbd_thread *thi)
  449. {
  450. struct drbd_tconn *tconn = thi->tconn;
  451. struct task_struct *nt;
  452. unsigned long flags;
  453. /* is used from state engine doing drbd_thread_stop_nowait,
  454. * while holding the req lock irqsave */
  455. spin_lock_irqsave(&thi->t_lock, flags);
  456. switch (thi->t_state) {
  457. case NONE:
  458. conn_info(tconn, "Starting %s thread (from %s [%d])\n",
  459. thi->name, current->comm, current->pid);
  460. /* Get ref on module for thread - this is released when thread exits */
  461. if (!try_module_get(THIS_MODULE)) {
  462. conn_err(tconn, "Failed to get module reference in drbd_thread_start\n");
  463. spin_unlock_irqrestore(&thi->t_lock, flags);
  464. return false;
  465. }
  466. kref_get(&thi->tconn->kref);
  467. init_completion(&thi->stop);
  468. thi->reset_cpu_mask = 1;
  469. thi->t_state = RUNNING;
  470. spin_unlock_irqrestore(&thi->t_lock, flags);
  471. flush_signals(current); /* otherw. may get -ERESTARTNOINTR */
  472. nt = kthread_create(drbd_thread_setup, (void *) thi,
  473. "drbd_%c_%s", thi->name[0], thi->tconn->name);
  474. if (IS_ERR(nt)) {
  475. conn_err(tconn, "Couldn't start thread\n");
  476. kref_put(&tconn->kref, &conn_destroy);
  477. module_put(THIS_MODULE);
  478. return false;
  479. }
  480. spin_lock_irqsave(&thi->t_lock, flags);
  481. thi->task = nt;
  482. thi->t_state = RUNNING;
  483. spin_unlock_irqrestore(&thi->t_lock, flags);
  484. wake_up_process(nt);
  485. break;
  486. case EXITING:
  487. thi->t_state = RESTARTING;
  488. conn_info(tconn, "Restarting %s thread (from %s [%d])\n",
  489. thi->name, current->comm, current->pid);
  490. /* fall through */
  491. case RUNNING:
  492. case RESTARTING:
  493. default:
  494. spin_unlock_irqrestore(&thi->t_lock, flags);
  495. break;
  496. }
  497. return true;
  498. }
  499. void _drbd_thread_stop(struct drbd_thread *thi, int restart, int wait)
  500. {
  501. unsigned long flags;
  502. enum drbd_thread_state ns = restart ? RESTARTING : EXITING;
  503. /* may be called from state engine, holding the req lock irqsave */
  504. spin_lock_irqsave(&thi->t_lock, flags);
  505. if (thi->t_state == NONE) {
  506. spin_unlock_irqrestore(&thi->t_lock, flags);
  507. if (restart)
  508. drbd_thread_start(thi);
  509. return;
  510. }
  511. if (thi->t_state != ns) {
  512. if (thi->task == NULL) {
  513. spin_unlock_irqrestore(&thi->t_lock, flags);
  514. return;
  515. }
  516. thi->t_state = ns;
  517. smp_mb();
  518. init_completion(&thi->stop);
  519. if (thi->task != current)
  520. force_sig(DRBD_SIGKILL, thi->task);
  521. }
  522. spin_unlock_irqrestore(&thi->t_lock, flags);
  523. if (wait)
  524. wait_for_completion(&thi->stop);
  525. }
  526. static struct drbd_thread *drbd_task_to_thread(struct drbd_tconn *tconn, struct task_struct *task)
  527. {
  528. struct drbd_thread *thi =
  529. task == tconn->receiver.task ? &tconn->receiver :
  530. task == tconn->asender.task ? &tconn->asender :
  531. task == tconn->worker.task ? &tconn->worker : NULL;
  532. return thi;
  533. }
  534. char *drbd_task_to_thread_name(struct drbd_tconn *tconn, struct task_struct *task)
  535. {
  536. struct drbd_thread *thi = drbd_task_to_thread(tconn, task);
  537. return thi ? thi->name : task->comm;
  538. }
  539. int conn_lowest_minor(struct drbd_tconn *tconn)
  540. {
  541. struct drbd_conf *mdev;
  542. int vnr = 0, m;
  543. rcu_read_lock();
  544. mdev = idr_get_next(&tconn->volumes, &vnr);
  545. m = mdev ? mdev_to_minor(mdev) : -1;
  546. rcu_read_unlock();
  547. return m;
  548. }
  549. #ifdef CONFIG_SMP
  550. /**
  551. * drbd_calc_cpu_mask() - Generate CPU masks, spread over all CPUs
  552. * @mdev: DRBD device.
  553. *
  554. * Forces all threads of a device onto the same CPU. This is beneficial for
  555. * DRBD's performance. May be overwritten by user's configuration.
  556. */
  557. void drbd_calc_cpu_mask(struct drbd_tconn *tconn)
  558. {
  559. int ord, cpu;
  560. /* user override. */
  561. if (cpumask_weight(tconn->cpu_mask))
  562. return;
  563. ord = conn_lowest_minor(tconn) % cpumask_weight(cpu_online_mask);
  564. for_each_online_cpu(cpu) {
  565. if (ord-- == 0) {
  566. cpumask_set_cpu(cpu, tconn->cpu_mask);
  567. return;
  568. }
  569. }
  570. /* should not be reached */
  571. cpumask_setall(tconn->cpu_mask);
  572. }
  573. /**
  574. * drbd_thread_current_set_cpu() - modifies the cpu mask of the _current_ thread
  575. * @mdev: DRBD device.
  576. * @thi: drbd_thread object
  577. *
  578. * call in the "main loop" of _all_ threads, no need for any mutex, current won't die
  579. * prematurely.
  580. */
  581. void drbd_thread_current_set_cpu(struct drbd_thread *thi)
  582. {
  583. struct task_struct *p = current;
  584. if (!thi->reset_cpu_mask)
  585. return;
  586. thi->reset_cpu_mask = 0;
  587. set_cpus_allowed_ptr(p, thi->tconn->cpu_mask);
  588. }
  589. #endif
  590. /**
  591. * drbd_header_size - size of a packet header
  592. *
  593. * The header size is a multiple of 8, so any payload following the header is
  594. * word aligned on 64-bit architectures. (The bitmap send and receive code
  595. * relies on this.)
  596. */
  597. unsigned int drbd_header_size(struct drbd_tconn *tconn)
  598. {
  599. if (tconn->agreed_pro_version >= 100) {
  600. BUILD_BUG_ON(!IS_ALIGNED(sizeof(struct p_header100), 8));
  601. return sizeof(struct p_header100);
  602. } else {
  603. BUILD_BUG_ON(sizeof(struct p_header80) !=
  604. sizeof(struct p_header95));
  605. BUILD_BUG_ON(!IS_ALIGNED(sizeof(struct p_header80), 8));
  606. return sizeof(struct p_header80);
  607. }
  608. }
  609. static unsigned int prepare_header80(struct p_header80 *h, enum drbd_packet cmd, int size)
  610. {
  611. h->magic = cpu_to_be32(DRBD_MAGIC);
  612. h->command = cpu_to_be16(cmd);
  613. h->length = cpu_to_be16(size);
  614. return sizeof(struct p_header80);
  615. }
  616. static unsigned int prepare_header95(struct p_header95 *h, enum drbd_packet cmd, int size)
  617. {
  618. h->magic = cpu_to_be16(DRBD_MAGIC_BIG);
  619. h->command = cpu_to_be16(cmd);
  620. h->length = cpu_to_be32(size);
  621. return sizeof(struct p_header95);
  622. }
  623. static unsigned int prepare_header100(struct p_header100 *h, enum drbd_packet cmd,
  624. int size, int vnr)
  625. {
  626. h->magic = cpu_to_be32(DRBD_MAGIC_100);
  627. h->volume = cpu_to_be16(vnr);
  628. h->command = cpu_to_be16(cmd);
  629. h->length = cpu_to_be32(size);
  630. h->pad = 0;
  631. return sizeof(struct p_header100);
  632. }
  633. static unsigned int prepare_header(struct drbd_tconn *tconn, int vnr,
  634. void *buffer, enum drbd_packet cmd, int size)
  635. {
  636. if (tconn->agreed_pro_version >= 100)
  637. return prepare_header100(buffer, cmd, size, vnr);
  638. else if (tconn->agreed_pro_version >= 95 &&
  639. size > DRBD_MAX_SIZE_H80_PACKET)
  640. return prepare_header95(buffer, cmd, size);
  641. else
  642. return prepare_header80(buffer, cmd, size);
  643. }
  644. static void *__conn_prepare_command(struct drbd_tconn *tconn,
  645. struct drbd_socket *sock)
  646. {
  647. if (!sock->socket)
  648. return NULL;
  649. return sock->sbuf + drbd_header_size(tconn);
  650. }
  651. void *conn_prepare_command(struct drbd_tconn *tconn, struct drbd_socket *sock)
  652. {
  653. void *p;
  654. mutex_lock(&sock->mutex);
  655. p = __conn_prepare_command(tconn, sock);
  656. if (!p)
  657. mutex_unlock(&sock->mutex);
  658. return p;
  659. }
  660. void *drbd_prepare_command(struct drbd_conf *mdev, struct drbd_socket *sock)
  661. {
  662. return conn_prepare_command(mdev->tconn, sock);
  663. }
  664. static int __send_command(struct drbd_tconn *tconn, int vnr,
  665. struct drbd_socket *sock, enum drbd_packet cmd,
  666. unsigned int header_size, void *data,
  667. unsigned int size)
  668. {
  669. int msg_flags;
  670. int err;
  671. /*
  672. * Called with @data == NULL and the size of the data blocks in @size
  673. * for commands that send data blocks. For those commands, omit the
  674. * MSG_MORE flag: this will increase the likelihood that data blocks
  675. * which are page aligned on the sender will end up page aligned on the
  676. * receiver.
  677. */
  678. msg_flags = data ? MSG_MORE : 0;
  679. header_size += prepare_header(tconn, vnr, sock->sbuf, cmd,
  680. header_size + size);
  681. err = drbd_send_all(tconn, sock->socket, sock->sbuf, header_size,
  682. msg_flags);
  683. if (data && !err)
  684. err = drbd_send_all(tconn, sock->socket, data, size, 0);
  685. return err;
  686. }
  687. static int __conn_send_command(struct drbd_tconn *tconn, struct drbd_socket *sock,
  688. enum drbd_packet cmd, unsigned int header_size,
  689. void *data, unsigned int size)
  690. {
  691. return __send_command(tconn, 0, sock, cmd, header_size, data, size);
  692. }
  693. int conn_send_command(struct drbd_tconn *tconn, struct drbd_socket *sock,
  694. enum drbd_packet cmd, unsigned int header_size,
  695. void *data, unsigned int size)
  696. {
  697. int err;
  698. err = __conn_send_command(tconn, sock, cmd, header_size, data, size);
  699. mutex_unlock(&sock->mutex);
  700. return err;
  701. }
  702. int drbd_send_command(struct drbd_conf *mdev, struct drbd_socket *sock,
  703. enum drbd_packet cmd, unsigned int header_size,
  704. void *data, unsigned int size)
  705. {
  706. int err;
  707. err = __send_command(mdev->tconn, mdev->vnr, sock, cmd, header_size,
  708. data, size);
  709. mutex_unlock(&sock->mutex);
  710. return err;
  711. }
  712. int drbd_send_ping(struct drbd_tconn *tconn)
  713. {
  714. struct drbd_socket *sock;
  715. sock = &tconn->meta;
  716. if (!conn_prepare_command(tconn, sock))
  717. return -EIO;
  718. return conn_send_command(tconn, sock, P_PING, 0, NULL, 0);
  719. }
  720. int drbd_send_ping_ack(struct drbd_tconn *tconn)
  721. {
  722. struct drbd_socket *sock;
  723. sock = &tconn->meta;
  724. if (!conn_prepare_command(tconn, sock))
  725. return -EIO;
  726. return conn_send_command(tconn, sock, P_PING_ACK, 0, NULL, 0);
  727. }
  728. int drbd_send_sync_param(struct drbd_conf *mdev)
  729. {
  730. struct drbd_socket *sock;
  731. struct p_rs_param_95 *p;
  732. int size;
  733. const int apv = mdev->tconn->agreed_pro_version;
  734. enum drbd_packet cmd;
  735. struct net_conf *nc;
  736. struct disk_conf *dc;
  737. sock = &mdev->tconn->data;
  738. p = drbd_prepare_command(mdev, sock);
  739. if (!p)
  740. return -EIO;
  741. rcu_read_lock();
  742. nc = rcu_dereference(mdev->tconn->net_conf);
  743. size = apv <= 87 ? sizeof(struct p_rs_param)
  744. : apv == 88 ? sizeof(struct p_rs_param)
  745. + strlen(nc->verify_alg) + 1
  746. : apv <= 94 ? sizeof(struct p_rs_param_89)
  747. : /* apv >= 95 */ sizeof(struct p_rs_param_95);
  748. cmd = apv >= 89 ? P_SYNC_PARAM89 : P_SYNC_PARAM;
  749. /* initialize verify_alg and csums_alg */
  750. memset(p->verify_alg, 0, 2 * SHARED_SECRET_MAX);
  751. if (get_ldev(mdev)) {
  752. dc = rcu_dereference(mdev->ldev->disk_conf);
  753. p->rate = cpu_to_be32(dc->resync_rate);
  754. p->c_plan_ahead = cpu_to_be32(dc->c_plan_ahead);
  755. p->c_delay_target = cpu_to_be32(dc->c_delay_target);
  756. p->c_fill_target = cpu_to_be32(dc->c_fill_target);
  757. p->c_max_rate = cpu_to_be32(dc->c_max_rate);
  758. put_ldev(mdev);
  759. } else {
  760. p->rate = cpu_to_be32(DRBD_RATE_DEF);
  761. p->c_plan_ahead = cpu_to_be32(DRBD_C_PLAN_AHEAD_DEF);
  762. p->c_delay_target = cpu_to_be32(DRBD_C_DELAY_TARGET_DEF);
  763. p->c_fill_target = cpu_to_be32(DRBD_C_FILL_TARGET_DEF);
  764. p->c_max_rate = cpu_to_be32(DRBD_C_MAX_RATE_DEF);
  765. }
  766. if (apv >= 88)
  767. strcpy(p->verify_alg, nc->verify_alg);
  768. if (apv >= 89)
  769. strcpy(p->csums_alg, nc->csums_alg);
  770. rcu_read_unlock();
  771. return drbd_send_command(mdev, sock, cmd, size, NULL, 0);
  772. }
  773. int __drbd_send_protocol(struct drbd_tconn *tconn)
  774. {
  775. struct drbd_socket *sock;
  776. struct p_protocol *p;
  777. struct net_conf *nc;
  778. int size, cf;
  779. sock = &tconn->data;
  780. p = __conn_prepare_command(tconn, sock);
  781. if (!p)
  782. return -EIO;
  783. rcu_read_lock();
  784. nc = rcu_dereference(tconn->net_conf);
  785. if (nc->dry_run && tconn->agreed_pro_version < 92) {
  786. rcu_read_unlock();
  787. mutex_unlock(&sock->mutex);
  788. conn_err(tconn, "--dry-run is not supported by peer");
  789. return -EOPNOTSUPP;
  790. }
  791. size = sizeof(*p);
  792. if (tconn->agreed_pro_version >= 87)
  793. size += strlen(nc->integrity_alg) + 1;
  794. p->protocol = cpu_to_be32(nc->wire_protocol);
  795. p->after_sb_0p = cpu_to_be32(nc->after_sb_0p);
  796. p->after_sb_1p = cpu_to_be32(nc->after_sb_1p);
  797. p->after_sb_2p = cpu_to_be32(nc->after_sb_2p);
  798. p->two_primaries = cpu_to_be32(nc->two_primaries);
  799. cf = 0;
  800. if (nc->want_lose)
  801. cf |= CF_WANT_LOSE;
  802. if (nc->dry_run)
  803. cf |= CF_DRY_RUN;
  804. p->conn_flags = cpu_to_be32(cf);
  805. if (tconn->agreed_pro_version >= 87)
  806. strcpy(p->integrity_alg, nc->integrity_alg);
  807. rcu_read_unlock();
  808. return __conn_send_command(tconn, sock, P_PROTOCOL, size, NULL, 0);
  809. }
  810. int drbd_send_protocol(struct drbd_tconn *tconn)
  811. {
  812. int err;
  813. mutex_lock(&tconn->data.mutex);
  814. err = __drbd_send_protocol(tconn);
  815. mutex_unlock(&tconn->data.mutex);
  816. return err;
  817. }
  818. int _drbd_send_uuids(struct drbd_conf *mdev, u64 uuid_flags)
  819. {
  820. struct drbd_socket *sock;
  821. struct p_uuids *p;
  822. int i;
  823. if (!get_ldev_if_state(mdev, D_NEGOTIATING))
  824. return 0;
  825. sock = &mdev->tconn->data;
  826. p = drbd_prepare_command(mdev, sock);
  827. if (!p) {
  828. put_ldev(mdev);
  829. return -EIO;
  830. }
  831. for (i = UI_CURRENT; i < UI_SIZE; i++)
  832. p->uuid[i] = mdev->ldev ? cpu_to_be64(mdev->ldev->md.uuid[i]) : 0;
  833. mdev->comm_bm_set = drbd_bm_total_weight(mdev);
  834. p->uuid[UI_SIZE] = cpu_to_be64(mdev->comm_bm_set);
  835. rcu_read_lock();
  836. uuid_flags |= rcu_dereference(mdev->tconn->net_conf)->want_lose ? 1 : 0;
  837. rcu_read_unlock();
  838. uuid_flags |= test_bit(CRASHED_PRIMARY, &mdev->flags) ? 2 : 0;
  839. uuid_flags |= mdev->new_state_tmp.disk == D_INCONSISTENT ? 4 : 0;
  840. p->uuid[UI_FLAGS] = cpu_to_be64(uuid_flags);
  841. put_ldev(mdev);
  842. return drbd_send_command(mdev, sock, P_UUIDS, sizeof(*p), NULL, 0);
  843. }
  844. int drbd_send_uuids(struct drbd_conf *mdev)
  845. {
  846. return _drbd_send_uuids(mdev, 0);
  847. }
  848. int drbd_send_uuids_skip_initial_sync(struct drbd_conf *mdev)
  849. {
  850. return _drbd_send_uuids(mdev, 8);
  851. }
  852. void drbd_print_uuids(struct drbd_conf *mdev, const char *text)
  853. {
  854. if (get_ldev_if_state(mdev, D_NEGOTIATING)) {
  855. u64 *uuid = mdev->ldev->md.uuid;
  856. dev_info(DEV, "%s %016llX:%016llX:%016llX:%016llX\n",
  857. text,
  858. (unsigned long long)uuid[UI_CURRENT],
  859. (unsigned long long)uuid[UI_BITMAP],
  860. (unsigned long long)uuid[UI_HISTORY_START],
  861. (unsigned long long)uuid[UI_HISTORY_END]);
  862. put_ldev(mdev);
  863. } else {
  864. dev_info(DEV, "%s effective data uuid: %016llX\n",
  865. text,
  866. (unsigned long long)mdev->ed_uuid);
  867. }
  868. }
  869. void drbd_gen_and_send_sync_uuid(struct drbd_conf *mdev)
  870. {
  871. struct drbd_socket *sock;
  872. struct p_rs_uuid *p;
  873. u64 uuid;
  874. D_ASSERT(mdev->state.disk == D_UP_TO_DATE);
  875. uuid = mdev->ldev->md.uuid[UI_BITMAP] + UUID_NEW_BM_OFFSET;
  876. drbd_uuid_set(mdev, UI_BITMAP, uuid);
  877. drbd_print_uuids(mdev, "updated sync UUID");
  878. drbd_md_sync(mdev);
  879. sock = &mdev->tconn->data;
  880. p = drbd_prepare_command(mdev, sock);
  881. if (p) {
  882. p->uuid = cpu_to_be64(uuid);
  883. drbd_send_command(mdev, sock, P_SYNC_UUID, sizeof(*p), NULL, 0);
  884. }
  885. }
  886. int drbd_send_sizes(struct drbd_conf *mdev, int trigger_reply, enum dds_flags flags)
  887. {
  888. struct drbd_socket *sock;
  889. struct p_sizes *p;
  890. sector_t d_size, u_size;
  891. int q_order_type, max_bio_size;
  892. if (get_ldev_if_state(mdev, D_NEGOTIATING)) {
  893. D_ASSERT(mdev->ldev->backing_bdev);
  894. d_size = drbd_get_max_capacity(mdev->ldev);
  895. rcu_read_lock();
  896. u_size = rcu_dereference(mdev->ldev->disk_conf)->disk_size;
  897. rcu_read_unlock();
  898. q_order_type = drbd_queue_order_type(mdev);
  899. max_bio_size = queue_max_hw_sectors(mdev->ldev->backing_bdev->bd_disk->queue) << 9;
  900. max_bio_size = min_t(int, max_bio_size, DRBD_MAX_BIO_SIZE);
  901. put_ldev(mdev);
  902. } else {
  903. d_size = 0;
  904. u_size = 0;
  905. q_order_type = QUEUE_ORDERED_NONE;
  906. max_bio_size = DRBD_MAX_BIO_SIZE; /* ... multiple BIOs per peer_request */
  907. }
  908. sock = &mdev->tconn->data;
  909. p = drbd_prepare_command(mdev, sock);
  910. if (!p)
  911. return -EIO;
  912. p->d_size = cpu_to_be64(d_size);
  913. p->u_size = cpu_to_be64(u_size);
  914. p->c_size = cpu_to_be64(trigger_reply ? 0 : drbd_get_capacity(mdev->this_bdev));
  915. p->max_bio_size = cpu_to_be32(max_bio_size);
  916. p->queue_order_type = cpu_to_be16(q_order_type);
  917. p->dds_flags = cpu_to_be16(flags);
  918. return drbd_send_command(mdev, sock, P_SIZES, sizeof(*p), NULL, 0);
  919. }
  920. /**
  921. * drbd_send_state() - Sends the drbd state to the peer
  922. * @mdev: DRBD device.
  923. */
  924. int drbd_send_state(struct drbd_conf *mdev)
  925. {
  926. struct drbd_socket *sock;
  927. struct p_state *p;
  928. sock = &mdev->tconn->data;
  929. p = drbd_prepare_command(mdev, sock);
  930. if (!p)
  931. return -EIO;
  932. p->state = cpu_to_be32(mdev->state.i); /* Within the send mutex */
  933. return drbd_send_command(mdev, sock, P_STATE, sizeof(*p), NULL, 0);
  934. }
  935. int drbd_send_state_req(struct drbd_conf *mdev, union drbd_state mask, union drbd_state val)
  936. {
  937. struct drbd_socket *sock;
  938. struct p_req_state *p;
  939. sock = &mdev->tconn->data;
  940. p = drbd_prepare_command(mdev, sock);
  941. if (!p)
  942. return -EIO;
  943. p->mask = cpu_to_be32(mask.i);
  944. p->val = cpu_to_be32(val.i);
  945. return drbd_send_command(mdev, sock, P_STATE_CHG_REQ, sizeof(*p), NULL, 0);
  946. }
  947. int conn_send_state_req(struct drbd_tconn *tconn, union drbd_state mask, union drbd_state val)
  948. {
  949. enum drbd_packet cmd;
  950. struct drbd_socket *sock;
  951. struct p_req_state *p;
  952. cmd = tconn->agreed_pro_version < 100 ? P_STATE_CHG_REQ : P_CONN_ST_CHG_REQ;
  953. sock = &tconn->data;
  954. p = conn_prepare_command(tconn, sock);
  955. if (!p)
  956. return -EIO;
  957. p->mask = cpu_to_be32(mask.i);
  958. p->val = cpu_to_be32(val.i);
  959. return conn_send_command(tconn, sock, cmd, sizeof(*p), NULL, 0);
  960. }
  961. void drbd_send_sr_reply(struct drbd_conf *mdev, enum drbd_state_rv retcode)
  962. {
  963. struct drbd_socket *sock;
  964. struct p_req_state_reply *p;
  965. sock = &mdev->tconn->meta;
  966. p = drbd_prepare_command(mdev, sock);
  967. if (p) {
  968. p->retcode = cpu_to_be32(retcode);
  969. drbd_send_command(mdev, sock, P_STATE_CHG_REPLY, sizeof(*p), NULL, 0);
  970. }
  971. }
  972. void conn_send_sr_reply(struct drbd_tconn *tconn, enum drbd_state_rv retcode)
  973. {
  974. struct drbd_socket *sock;
  975. struct p_req_state_reply *p;
  976. enum drbd_packet cmd = tconn->agreed_pro_version < 100 ? P_STATE_CHG_REPLY : P_CONN_ST_CHG_REPLY;
  977. sock = &tconn->meta;
  978. p = conn_prepare_command(tconn, sock);
  979. if (p) {
  980. p->retcode = cpu_to_be32(retcode);
  981. conn_send_command(tconn, sock, cmd, sizeof(*p), NULL, 0);
  982. }
  983. }
  984. static void dcbp_set_code(struct p_compressed_bm *p, enum drbd_bitmap_code code)
  985. {
  986. BUG_ON(code & ~0xf);
  987. p->encoding = (p->encoding & ~0xf) | code;
  988. }
  989. static void dcbp_set_start(struct p_compressed_bm *p, int set)
  990. {
  991. p->encoding = (p->encoding & ~0x80) | (set ? 0x80 : 0);
  992. }
  993. static void dcbp_set_pad_bits(struct p_compressed_bm *p, int n)
  994. {
  995. BUG_ON(n & ~0x7);
  996. p->encoding = (p->encoding & (~0x7 << 4)) | (n << 4);
  997. }
  998. int fill_bitmap_rle_bits(struct drbd_conf *mdev,
  999. struct p_compressed_bm *p,
  1000. unsigned int size,
  1001. struct bm_xfer_ctx *c)
  1002. {
  1003. struct bitstream bs;
  1004. unsigned long plain_bits;
  1005. unsigned long tmp;
  1006. unsigned long rl;
  1007. unsigned len;
  1008. unsigned toggle;
  1009. int bits, use_rle;
  1010. /* may we use this feature? */
  1011. rcu_read_lock();
  1012. use_rle = rcu_dereference(mdev->tconn->net_conf)->use_rle;
  1013. rcu_read_unlock();
  1014. if (!use_rle || mdev->tconn->agreed_pro_version < 90)
  1015. return 0;
  1016. if (c->bit_offset >= c->bm_bits)
  1017. return 0; /* nothing to do. */
  1018. /* use at most thus many bytes */
  1019. bitstream_init(&bs, p->code, size, 0);
  1020. memset(p->code, 0, size);
  1021. /* plain bits covered in this code string */
  1022. plain_bits = 0;
  1023. /* p->encoding & 0x80 stores whether the first run length is set.
  1024. * bit offset is implicit.
  1025. * start with toggle == 2 to be able to tell the first iteration */
  1026. toggle = 2;
  1027. /* see how much plain bits we can stuff into one packet
  1028. * using RLE and VLI. */
  1029. do {
  1030. tmp = (toggle == 0) ? _drbd_bm_find_next_zero(mdev, c->bit_offset)
  1031. : _drbd_bm_find_next(mdev, c->bit_offset);
  1032. if (tmp == -1UL)
  1033. tmp = c->bm_bits;
  1034. rl = tmp - c->bit_offset;
  1035. if (toggle == 2) { /* first iteration */
  1036. if (rl == 0) {
  1037. /* the first checked bit was set,
  1038. * store start value, */
  1039. dcbp_set_start(p, 1);
  1040. /* but skip encoding of zero run length */
  1041. toggle = !toggle;
  1042. continue;
  1043. }
  1044. dcbp_set_start(p, 0);
  1045. }
  1046. /* paranoia: catch zero runlength.
  1047. * can only happen if bitmap is modified while we scan it. */
  1048. if (rl == 0) {
  1049. dev_err(DEV, "unexpected zero runlength while encoding bitmap "
  1050. "t:%u bo:%lu\n", toggle, c->bit_offset);
  1051. return -1;
  1052. }
  1053. bits = vli_encode_bits(&bs, rl);
  1054. if (bits == -ENOBUFS) /* buffer full */
  1055. break;
  1056. if (bits <= 0) {
  1057. dev_err(DEV, "error while encoding bitmap: %d\n", bits);
  1058. return 0;
  1059. }
  1060. toggle = !toggle;
  1061. plain_bits += rl;
  1062. c->bit_offset = tmp;
  1063. } while (c->bit_offset < c->bm_bits);
  1064. len = bs.cur.b - p->code + !!bs.cur.bit;
  1065. if (plain_bits < (len << 3)) {
  1066. /* incompressible with this method.
  1067. * we need to rewind both word and bit position. */
  1068. c->bit_offset -= plain_bits;
  1069. bm_xfer_ctx_bit_to_word_offset(c);
  1070. c->bit_offset = c->word_offset * BITS_PER_LONG;
  1071. return 0;
  1072. }
  1073. /* RLE + VLI was able to compress it just fine.
  1074. * update c->word_offset. */
  1075. bm_xfer_ctx_bit_to_word_offset(c);
  1076. /* store pad_bits */
  1077. dcbp_set_pad_bits(p, (8 - bs.cur.bit) & 0x7);
  1078. return len;
  1079. }
  1080. /**
  1081. * send_bitmap_rle_or_plain
  1082. *
  1083. * Return 0 when done, 1 when another iteration is needed, and a negative error
  1084. * code upon failure.
  1085. */
  1086. static int
  1087. send_bitmap_rle_or_plain(struct drbd_conf *mdev, struct bm_xfer_ctx *c)
  1088. {
  1089. struct drbd_socket *sock = &mdev->tconn->data;
  1090. unsigned int header_size = drbd_header_size(mdev->tconn);
  1091. struct p_compressed_bm *p = sock->sbuf + header_size;
  1092. int len, err;
  1093. len = fill_bitmap_rle_bits(mdev, p,
  1094. DRBD_SOCKET_BUFFER_SIZE - header_size - sizeof(*p), c);
  1095. if (len < 0)
  1096. return -EIO;
  1097. if (len) {
  1098. dcbp_set_code(p, RLE_VLI_Bits);
  1099. err = __send_command(mdev->tconn, mdev->vnr, sock,
  1100. P_COMPRESSED_BITMAP, sizeof(*p) + len,
  1101. NULL, 0);
  1102. c->packets[0]++;
  1103. c->bytes[0] += header_size + sizeof(*p) + len;
  1104. if (c->bit_offset >= c->bm_bits)
  1105. len = 0; /* DONE */
  1106. } else {
  1107. /* was not compressible.
  1108. * send a buffer full of plain text bits instead. */
  1109. unsigned int data_size;
  1110. unsigned long num_words;
  1111. unsigned long *p = sock->sbuf + header_size;
  1112. data_size = DRBD_SOCKET_BUFFER_SIZE - header_size;
  1113. num_words = min_t(size_t, data_size / sizeof(*p),
  1114. c->bm_words - c->word_offset);
  1115. len = num_words * sizeof(*p);
  1116. if (len)
  1117. drbd_bm_get_lel(mdev, c->word_offset, num_words, p);
  1118. err = __send_command(mdev->tconn, mdev->vnr, sock, P_BITMAP, len, NULL, 0);
  1119. c->word_offset += num_words;
  1120. c->bit_offset = c->word_offset * BITS_PER_LONG;
  1121. c->packets[1]++;
  1122. c->bytes[1] += header_size + len;
  1123. if (c->bit_offset > c->bm_bits)
  1124. c->bit_offset = c->bm_bits;
  1125. }
  1126. if (!err) {
  1127. if (len == 0) {
  1128. INFO_bm_xfer_stats(mdev, "send", c);
  1129. return 0;
  1130. } else
  1131. return 1;
  1132. }
  1133. return -EIO;
  1134. }
  1135. /* See the comment at receive_bitmap() */
  1136. static int _drbd_send_bitmap(struct drbd_conf *mdev)
  1137. {
  1138. struct bm_xfer_ctx c;
  1139. int err;
  1140. if (!expect(mdev->bitmap))
  1141. return false;
  1142. if (get_ldev(mdev)) {
  1143. if (drbd_md_test_flag(mdev->ldev, MDF_FULL_SYNC)) {
  1144. dev_info(DEV, "Writing the whole bitmap, MDF_FullSync was set.\n");
  1145. drbd_bm_set_all(mdev);
  1146. if (drbd_bm_write(mdev)) {
  1147. /* write_bm did fail! Leave full sync flag set in Meta P_DATA
  1148. * but otherwise process as per normal - need to tell other
  1149. * side that a full resync is required! */
  1150. dev_err(DEV, "Failed to write bitmap to disk!\n");
  1151. } else {
  1152. drbd_md_clear_flag(mdev, MDF_FULL_SYNC);
  1153. drbd_md_sync(mdev);
  1154. }
  1155. }
  1156. put_ldev(mdev);
  1157. }
  1158. c = (struct bm_xfer_ctx) {
  1159. .bm_bits = drbd_bm_bits(mdev),
  1160. .bm_words = drbd_bm_words(mdev),
  1161. };
  1162. do {
  1163. err = send_bitmap_rle_or_plain(mdev, &c);
  1164. } while (err > 0);
  1165. return err == 0;
  1166. }
  1167. int drbd_send_bitmap(struct drbd_conf *mdev)
  1168. {
  1169. struct drbd_socket *sock = &mdev->tconn->data;
  1170. int err = -1;
  1171. mutex_lock(&sock->mutex);
  1172. if (sock->socket)
  1173. err = !_drbd_send_bitmap(mdev);
  1174. mutex_unlock(&sock->mutex);
  1175. return err;
  1176. }
  1177. void drbd_send_b_ack(struct drbd_conf *mdev, u32 barrier_nr, u32 set_size)
  1178. {
  1179. struct drbd_socket *sock;
  1180. struct p_barrier_ack *p;
  1181. if (mdev->state.conn < C_CONNECTED)
  1182. return;
  1183. sock = &mdev->tconn->meta;
  1184. p = drbd_prepare_command(mdev, sock);
  1185. if (!p)
  1186. return;
  1187. p->barrier = barrier_nr;
  1188. p->set_size = cpu_to_be32(set_size);
  1189. drbd_send_command(mdev, sock, P_BARRIER_ACK, sizeof(*p), NULL, 0);
  1190. }
  1191. /**
  1192. * _drbd_send_ack() - Sends an ack packet
  1193. * @mdev: DRBD device.
  1194. * @cmd: Packet command code.
  1195. * @sector: sector, needs to be in big endian byte order
  1196. * @blksize: size in byte, needs to be in big endian byte order
  1197. * @block_id: Id, big endian byte order
  1198. */
  1199. static int _drbd_send_ack(struct drbd_conf *mdev, enum drbd_packet cmd,
  1200. u64 sector, u32 blksize, u64 block_id)
  1201. {
  1202. struct drbd_socket *sock;
  1203. struct p_block_ack *p;
  1204. if (mdev->state.conn < C_CONNECTED)
  1205. return -EIO;
  1206. sock = &mdev->tconn->meta;
  1207. p = drbd_prepare_command(mdev, sock);
  1208. if (!p)
  1209. return -EIO;
  1210. p->sector = sector;
  1211. p->block_id = block_id;
  1212. p->blksize = blksize;
  1213. p->seq_num = cpu_to_be32(atomic_inc_return(&mdev->packet_seq));
  1214. return drbd_send_command(mdev, sock, cmd, sizeof(*p), NULL, 0);
  1215. }
  1216. /* dp->sector and dp->block_id already/still in network byte order,
  1217. * data_size is payload size according to dp->head,
  1218. * and may need to be corrected for digest size. */
  1219. void drbd_send_ack_dp(struct drbd_conf *mdev, enum drbd_packet cmd,
  1220. struct p_data *dp, int data_size)
  1221. {
  1222. if (mdev->tconn->peer_integrity_tfm)
  1223. data_size -= crypto_hash_digestsize(mdev->tconn->peer_integrity_tfm);
  1224. _drbd_send_ack(mdev, cmd, dp->sector, cpu_to_be32(data_size),
  1225. dp->block_id);
  1226. }
  1227. void drbd_send_ack_rp(struct drbd_conf *mdev, enum drbd_packet cmd,
  1228. struct p_block_req *rp)
  1229. {
  1230. _drbd_send_ack(mdev, cmd, rp->sector, rp->blksize, rp->block_id);
  1231. }
  1232. /**
  1233. * drbd_send_ack() - Sends an ack packet
  1234. * @mdev: DRBD device
  1235. * @cmd: packet command code
  1236. * @peer_req: peer request
  1237. */
  1238. int drbd_send_ack(struct drbd_conf *mdev, enum drbd_packet cmd,
  1239. struct drbd_peer_request *peer_req)
  1240. {
  1241. return _drbd_send_ack(mdev, cmd,
  1242. cpu_to_be64(peer_req->i.sector),
  1243. cpu_to_be32(peer_req->i.size),
  1244. peer_req->block_id);
  1245. }
  1246. /* This function misuses the block_id field to signal if the blocks
  1247. * are is sync or not. */
  1248. int drbd_send_ack_ex(struct drbd_conf *mdev, enum drbd_packet cmd,
  1249. sector_t sector, int blksize, u64 block_id)
  1250. {
  1251. return _drbd_send_ack(mdev, cmd,
  1252. cpu_to_be64(sector),
  1253. cpu_to_be32(blksize),
  1254. cpu_to_be64(block_id));
  1255. }
  1256. int drbd_send_drequest(struct drbd_conf *mdev, int cmd,
  1257. sector_t sector, int size, u64 block_id)
  1258. {
  1259. struct drbd_socket *sock;
  1260. struct p_block_req *p;
  1261. sock = &mdev->tconn->data;
  1262. p = drbd_prepare_command(mdev, sock);
  1263. if (!p)
  1264. return -EIO;
  1265. p->sector = cpu_to_be64(sector);
  1266. p->block_id = block_id;
  1267. p->blksize = cpu_to_be32(size);
  1268. return drbd_send_command(mdev, sock, cmd, sizeof(*p), NULL, 0);
  1269. }
  1270. int drbd_send_drequest_csum(struct drbd_conf *mdev, sector_t sector, int size,
  1271. void *digest, int digest_size, enum drbd_packet cmd)
  1272. {
  1273. struct drbd_socket *sock;
  1274. struct p_block_req *p;
  1275. /* FIXME: Put the digest into the preallocated socket buffer. */
  1276. sock = &mdev->tconn->data;
  1277. p = drbd_prepare_command(mdev, sock);
  1278. if (!p)
  1279. return -EIO;
  1280. p->sector = cpu_to_be64(sector);
  1281. p->block_id = ID_SYNCER /* unused */;
  1282. p->blksize = cpu_to_be32(size);
  1283. return drbd_send_command(mdev, sock, cmd, sizeof(*p),
  1284. digest, digest_size);
  1285. }
  1286. int drbd_send_ov_request(struct drbd_conf *mdev, sector_t sector, int size)
  1287. {
  1288. struct drbd_socket *sock;
  1289. struct p_block_req *p;
  1290. sock = &mdev->tconn->data;
  1291. p = drbd_prepare_command(mdev, sock);
  1292. if (!p)
  1293. return -EIO;
  1294. p->sector = cpu_to_be64(sector);
  1295. p->block_id = ID_SYNCER /* unused */;
  1296. p->blksize = cpu_to_be32(size);
  1297. return drbd_send_command(mdev, sock, P_OV_REQUEST, sizeof(*p), NULL, 0);
  1298. }
  1299. /* called on sndtimeo
  1300. * returns false if we should retry,
  1301. * true if we think connection is dead
  1302. */
  1303. static int we_should_drop_the_connection(struct drbd_tconn *tconn, struct socket *sock)
  1304. {
  1305. int drop_it;
  1306. /* long elapsed = (long)(jiffies - mdev->last_received); */
  1307. drop_it = tconn->meta.socket == sock
  1308. || !tconn->asender.task
  1309. || get_t_state(&tconn->asender) != RUNNING
  1310. || tconn->cstate < C_WF_REPORT_PARAMS;
  1311. if (drop_it)
  1312. return true;
  1313. drop_it = !--tconn->ko_count;
  1314. if (!drop_it) {
  1315. conn_err(tconn, "[%s/%d] sock_sendmsg time expired, ko = %u\n",
  1316. current->comm, current->pid, tconn->ko_count);
  1317. request_ping(tconn);
  1318. }
  1319. return drop_it; /* && (mdev->state == R_PRIMARY) */;
  1320. }
  1321. static void drbd_update_congested(struct drbd_tconn *tconn)
  1322. {
  1323. struct sock *sk = tconn->data.socket->sk;
  1324. if (sk->sk_wmem_queued > sk->sk_sndbuf * 4 / 5)
  1325. set_bit(NET_CONGESTED, &tconn->flags);
  1326. }
  1327. /* The idea of sendpage seems to be to put some kind of reference
  1328. * to the page into the skb, and to hand it over to the NIC. In
  1329. * this process get_page() gets called.
  1330. *
  1331. * As soon as the page was really sent over the network put_page()
  1332. * gets called by some part of the network layer. [ NIC driver? ]
  1333. *
  1334. * [ get_page() / put_page() increment/decrement the count. If count
  1335. * reaches 0 the page will be freed. ]
  1336. *
  1337. * This works nicely with pages from FSs.
  1338. * But this means that in protocol A we might signal IO completion too early!
  1339. *
  1340. * In order not to corrupt data during a resync we must make sure
  1341. * that we do not reuse our own buffer pages (EEs) to early, therefore
  1342. * we have the net_ee list.
  1343. *
  1344. * XFS seems to have problems, still, it submits pages with page_count == 0!
  1345. * As a workaround, we disable sendpage on pages
  1346. * with page_count == 0 or PageSlab.
  1347. */
  1348. static int _drbd_no_send_page(struct drbd_conf *mdev, struct page *page,
  1349. int offset, size_t size, unsigned msg_flags)
  1350. {
  1351. struct socket *socket;
  1352. void *addr;
  1353. int err;
  1354. socket = mdev->tconn->data.socket;
  1355. addr = kmap(page) + offset;
  1356. err = drbd_send_all(mdev->tconn, socket, addr, size, msg_flags);
  1357. kunmap(page);
  1358. if (!err)
  1359. mdev->send_cnt += size >> 9;
  1360. return err;
  1361. }
  1362. static int _drbd_send_page(struct drbd_conf *mdev, struct page *page,
  1363. int offset, size_t size, unsigned msg_flags)
  1364. {
  1365. struct socket *socket = mdev->tconn->data.socket;
  1366. mm_segment_t oldfs = get_fs();
  1367. int len = size;
  1368. int err = -EIO;
  1369. /* e.g. XFS meta- & log-data is in slab pages, which have a
  1370. * page_count of 0 and/or have PageSlab() set.
  1371. * we cannot use send_page for those, as that does get_page();
  1372. * put_page(); and would cause either a VM_BUG directly, or
  1373. * __page_cache_release a page that would actually still be referenced
  1374. * by someone, leading to some obscure delayed Oops somewhere else. */
  1375. if (disable_sendpage || (page_count(page) < 1) || PageSlab(page))
  1376. return _drbd_no_send_page(mdev, page, offset, size, msg_flags);
  1377. msg_flags |= MSG_NOSIGNAL;
  1378. drbd_update_congested(mdev->tconn);
  1379. set_fs(KERNEL_DS);
  1380. do {
  1381. int sent;
  1382. sent = socket->ops->sendpage(socket, page, offset, len, msg_flags);
  1383. if (sent <= 0) {
  1384. if (sent == -EAGAIN) {
  1385. if (we_should_drop_the_connection(mdev->tconn, socket))
  1386. break;
  1387. continue;
  1388. }
  1389. dev_warn(DEV, "%s: size=%d len=%d sent=%d\n",
  1390. __func__, (int)size, len, sent);
  1391. if (sent < 0)
  1392. err = sent;
  1393. break;
  1394. }
  1395. len -= sent;
  1396. offset += sent;
  1397. } while (len > 0 /* THINK && mdev->cstate >= C_CONNECTED*/);
  1398. set_fs(oldfs);
  1399. clear_bit(NET_CONGESTED, &mdev->tconn->flags);
  1400. if (len == 0) {
  1401. err = 0;
  1402. mdev->send_cnt += size >> 9;
  1403. }
  1404. return err;
  1405. }
  1406. static int _drbd_send_bio(struct drbd_conf *mdev, struct bio *bio)
  1407. {
  1408. struct bio_vec *bvec;
  1409. int i;
  1410. /* hint all but last page with MSG_MORE */
  1411. __bio_for_each_segment(bvec, bio, i, 0) {
  1412. int err;
  1413. err = _drbd_no_send_page(mdev, bvec->bv_page,
  1414. bvec->bv_offset, bvec->bv_len,
  1415. i == bio->bi_vcnt - 1 ? 0 : MSG_MORE);
  1416. if (err)
  1417. return err;
  1418. }
  1419. return 0;
  1420. }
  1421. static int _drbd_send_zc_bio(struct drbd_conf *mdev, struct bio *bio)
  1422. {
  1423. struct bio_vec *bvec;
  1424. int i;
  1425. /* hint all but last page with MSG_MORE */
  1426. __bio_for_each_segment(bvec, bio, i, 0) {
  1427. int err;
  1428. err = _drbd_send_page(mdev, bvec->bv_page,
  1429. bvec->bv_offset, bvec->bv_len,
  1430. i == bio->bi_vcnt - 1 ? 0 : MSG_MORE);
  1431. if (err)
  1432. return err;
  1433. }
  1434. return 0;
  1435. }
  1436. static int _drbd_send_zc_ee(struct drbd_conf *mdev,
  1437. struct drbd_peer_request *peer_req)
  1438. {
  1439. struct page *page = peer_req->pages;
  1440. unsigned len = peer_req->i.size;
  1441. int err;
  1442. /* hint all but last page with MSG_MORE */
  1443. page_chain_for_each(page) {
  1444. unsigned l = min_t(unsigned, len, PAGE_SIZE);
  1445. err = _drbd_send_page(mdev, page, 0, l,
  1446. page_chain_next(page) ? MSG_MORE : 0);
  1447. if (err)
  1448. return err;
  1449. len -= l;
  1450. }
  1451. return 0;
  1452. }
  1453. static u32 bio_flags_to_wire(struct drbd_conf *mdev, unsigned long bi_rw)
  1454. {
  1455. if (mdev->tconn->agreed_pro_version >= 95)
  1456. return (bi_rw & REQ_SYNC ? DP_RW_SYNC : 0) |
  1457. (bi_rw & REQ_FUA ? DP_FUA : 0) |
  1458. (bi_rw & REQ_FLUSH ? DP_FLUSH : 0) |
  1459. (bi_rw & REQ_DISCARD ? DP_DISCARD : 0);
  1460. else
  1461. return bi_rw & REQ_SYNC ? DP_RW_SYNC : 0;
  1462. }
  1463. /* Used to send write requests
  1464. * R_PRIMARY -> Peer (P_DATA)
  1465. */
  1466. int drbd_send_dblock(struct drbd_conf *mdev, struct drbd_request *req)
  1467. {
  1468. struct drbd_socket *sock;
  1469. struct p_data *p;
  1470. unsigned int dp_flags = 0;
  1471. int dgs;
  1472. int err;
  1473. dgs = (mdev->tconn->agreed_pro_version >= 87 && mdev->tconn->integrity_tfm) ?
  1474. crypto_hash_digestsize(mdev->tconn->integrity_tfm) : 0;
  1475. sock = &mdev->tconn->data;
  1476. p = drbd_prepare_command(mdev, sock);
  1477. if (!p)
  1478. return -EIO;
  1479. p->sector = cpu_to_be64(req->i.sector);
  1480. p->block_id = (unsigned long)req;
  1481. p->seq_num = cpu_to_be32(req->seq_num = atomic_inc_return(&mdev->packet_seq));
  1482. dp_flags = bio_flags_to_wire(mdev, req->master_bio->bi_rw);
  1483. if (mdev->state.conn >= C_SYNC_SOURCE &&
  1484. mdev->state.conn <= C_PAUSED_SYNC_T)
  1485. dp_flags |= DP_MAY_SET_IN_SYNC;
  1486. if (mdev->tconn->agreed_pro_version >= 100) {
  1487. if (req->rq_state & RQ_EXP_RECEIVE_ACK)
  1488. dp_flags |= DP_SEND_RECEIVE_ACK;
  1489. if (req->rq_state & RQ_EXP_WRITE_ACK)
  1490. dp_flags |= DP_SEND_WRITE_ACK;
  1491. }
  1492. p->dp_flags = cpu_to_be32(dp_flags);
  1493. if (dgs)
  1494. drbd_csum_bio(mdev, mdev->tconn->integrity_tfm, req->master_bio, p + 1);
  1495. err = __send_command(mdev->tconn, mdev->vnr, sock, P_DATA, sizeof(*p) + dgs, NULL, req->i.size);
  1496. if (!err) {
  1497. /* For protocol A, we have to memcpy the payload into
  1498. * socket buffers, as we may complete right away
  1499. * as soon as we handed it over to tcp, at which point the data
  1500. * pages may become invalid.
  1501. *
  1502. * For data-integrity enabled, we copy it as well, so we can be
  1503. * sure that even if the bio pages may still be modified, it
  1504. * won't change the data on the wire, thus if the digest checks
  1505. * out ok after sending on this side, but does not fit on the
  1506. * receiving side, we sure have detected corruption elsewhere.
  1507. */
  1508. if (!(req->rq_state & (RQ_EXP_RECEIVE_ACK | RQ_EXP_WRITE_ACK)) || dgs)
  1509. err = _drbd_send_bio(mdev, req->master_bio);
  1510. else
  1511. err = _drbd_send_zc_bio(mdev, req->master_bio);
  1512. /* double check digest, sometimes buffers have been modified in flight. */
  1513. if (dgs > 0 && dgs <= 64) {
  1514. /* 64 byte, 512 bit, is the largest digest size
  1515. * currently supported in kernel crypto. */
  1516. unsigned char digest[64];
  1517. drbd_csum_bio(mdev, mdev->tconn->integrity_tfm, req->master_bio, digest);
  1518. if (memcmp(p + 1, digest, dgs)) {
  1519. dev_warn(DEV,
  1520. "Digest mismatch, buffer modified by upper layers during write: %llus +%u\n",
  1521. (unsigned long long)req->i.sector, req->i.size);
  1522. }
  1523. } /* else if (dgs > 64) {
  1524. ... Be noisy about digest too large ...
  1525. } */
  1526. }
  1527. mutex_unlock(&sock->mutex); /* locked by drbd_prepare_command() */
  1528. return err;
  1529. }
  1530. /* answer packet, used to send data back for read requests:
  1531. * Peer -> (diskless) R_PRIMARY (P_DATA_REPLY)
  1532. * C_SYNC_SOURCE -> C_SYNC_TARGET (P_RS_DATA_REPLY)
  1533. */
  1534. int drbd_send_block(struct drbd_conf *mdev, enum drbd_packet cmd,
  1535. struct drbd_peer_request *peer_req)
  1536. {
  1537. struct drbd_socket *sock;
  1538. struct p_data *p;
  1539. int err;
  1540. int dgs;
  1541. dgs = (mdev->tconn->agreed_pro_version >= 87 && mdev->tconn->integrity_tfm) ?
  1542. crypto_hash_digestsize(mdev->tconn->integrity_tfm) : 0;
  1543. sock = &mdev->tconn->data;
  1544. p = drbd_prepare_command(mdev, sock);
  1545. if (!p)
  1546. return -EIO;
  1547. p->sector = cpu_to_be64(peer_req->i.sector);
  1548. p->block_id = peer_req->block_id;
  1549. p->seq_num = 0; /* unused */
  1550. if (dgs)
  1551. drbd_csum_ee(mdev, mdev->tconn->integrity_tfm, peer_req, p + 1);
  1552. err = __send_command(mdev->tconn, mdev->vnr, sock, cmd, sizeof(*p) + dgs, NULL, peer_req->i.size);
  1553. if (!err)
  1554. err = _drbd_send_zc_ee(mdev, peer_req);
  1555. mutex_unlock(&sock->mutex); /* locked by drbd_prepare_command() */
  1556. return err;
  1557. }
  1558. int drbd_send_out_of_sync(struct drbd_conf *mdev, struct drbd_request *req)
  1559. {
  1560. struct drbd_socket *sock;
  1561. struct p_block_desc *p;
  1562. sock = &mdev->tconn->data;
  1563. p = drbd_prepare_command(mdev, sock);
  1564. if (!p)
  1565. return -EIO;
  1566. p->sector = cpu_to_be64(req->i.sector);
  1567. p->blksize = cpu_to_be32(req->i.size);
  1568. return drbd_send_command(mdev, sock, P_OUT_OF_SYNC, sizeof(*p), NULL, 0);
  1569. }
  1570. /*
  1571. drbd_send distinguishes two cases:
  1572. Packets sent via the data socket "sock"
  1573. and packets sent via the meta data socket "msock"
  1574. sock msock
  1575. -----------------+-------------------------+------------------------------
  1576. timeout conf.timeout / 2 conf.timeout / 2
  1577. timeout action send a ping via msock Abort communication
  1578. and close all sockets
  1579. */
  1580. /*
  1581. * you must have down()ed the appropriate [m]sock_mutex elsewhere!
  1582. */
  1583. int drbd_send(struct drbd_tconn *tconn, struct socket *sock,
  1584. void *buf, size_t size, unsigned msg_flags)
  1585. {
  1586. struct kvec iov;
  1587. struct msghdr msg;
  1588. int rv, sent = 0;
  1589. if (!sock)
  1590. return -EBADR;
  1591. /* THINK if (signal_pending) return ... ? */
  1592. iov.iov_base = buf;
  1593. iov.iov_len = size;
  1594. msg.msg_name = NULL;
  1595. msg.msg_namelen = 0;
  1596. msg.msg_control = NULL;
  1597. msg.msg_controllen = 0;
  1598. msg.msg_flags = msg_flags | MSG_NOSIGNAL;
  1599. if (sock == tconn->data.socket) {
  1600. rcu_read_lock();
  1601. tconn->ko_count = rcu_dereference(tconn->net_conf)->ko_count;
  1602. rcu_read_unlock();
  1603. drbd_update_congested(tconn);
  1604. }
  1605. do {
  1606. /* STRANGE
  1607. * tcp_sendmsg does _not_ use its size parameter at all ?
  1608. *
  1609. * -EAGAIN on timeout, -EINTR on signal.
  1610. */
  1611. /* THINK
  1612. * do we need to block DRBD_SIG if sock == &meta.socket ??
  1613. * otherwise wake_asender() might interrupt some send_*Ack !
  1614. */
  1615. rv = kernel_sendmsg(sock, &msg, &iov, 1, size);
  1616. if (rv == -EAGAIN) {
  1617. if (we_should_drop_the_connection(tconn, sock))
  1618. break;
  1619. else
  1620. continue;
  1621. }
  1622. if (rv == -EINTR) {
  1623. flush_signals(current);
  1624. rv = 0;
  1625. }
  1626. if (rv < 0)
  1627. break;
  1628. sent += rv;
  1629. iov.iov_base += rv;
  1630. iov.iov_len -= rv;
  1631. } while (sent < size);
  1632. if (sock == tconn->data.socket)
  1633. clear_bit(NET_CONGESTED, &tconn->flags);
  1634. if (rv <= 0) {
  1635. if (rv != -EAGAIN) {
  1636. conn_err(tconn, "%s_sendmsg returned %d\n",
  1637. sock == tconn->meta.socket ? "msock" : "sock",
  1638. rv);
  1639. conn_request_state(tconn, NS(conn, C_BROKEN_PIPE), CS_HARD);
  1640. } else
  1641. conn_request_state(tconn, NS(conn, C_TIMEOUT), CS_HARD);
  1642. }
  1643. return sent;
  1644. }
  1645. /**
  1646. * drbd_send_all - Send an entire buffer
  1647. *
  1648. * Returns 0 upon success and a negative error value otherwise.
  1649. */
  1650. int drbd_send_all(struct drbd_tconn *tconn, struct socket *sock, void *buffer,
  1651. size_t size, unsigned msg_flags)
  1652. {
  1653. int err;
  1654. err = drbd_send(tconn, sock, buffer, size, msg_flags);
  1655. if (err < 0)
  1656. return err;
  1657. if (err != size)
  1658. return -EIO;
  1659. return 0;
  1660. }
  1661. static int drbd_open(struct block_device *bdev, fmode_t mode)
  1662. {
  1663. struct drbd_conf *mdev = bdev->bd_disk->private_data;
  1664. unsigned long flags;
  1665. int rv = 0;
  1666. mutex_lock(&drbd_main_mutex);
  1667. spin_lock_irqsave(&mdev->tconn->req_lock, flags);
  1668. /* to have a stable mdev->state.role
  1669. * and no race with updating open_cnt */
  1670. if (mdev->state.role != R_PRIMARY) {
  1671. if (mode & FMODE_WRITE)
  1672. rv = -EROFS;
  1673. else if (!allow_oos)
  1674. rv = -EMEDIUMTYPE;
  1675. }
  1676. if (!rv)
  1677. mdev->open_cnt++;
  1678. spin_unlock_irqrestore(&mdev->tconn->req_lock, flags);
  1679. mutex_unlock(&drbd_main_mutex);
  1680. return rv;
  1681. }
  1682. static int drbd_release(struct gendisk *gd, fmode_t mode)
  1683. {
  1684. struct drbd_conf *mdev = gd->private_data;
  1685. mutex_lock(&drbd_main_mutex);
  1686. mdev->open_cnt--;
  1687. mutex_unlock(&drbd_main_mutex);
  1688. return 0;
  1689. }
  1690. static void drbd_set_defaults(struct drbd_conf *mdev)
  1691. {
  1692. /* Beware! The actual layout differs
  1693. * between big endian and little endian */
  1694. mdev->state = (union drbd_dev_state) {
  1695. { .role = R_SECONDARY,
  1696. .peer = R_UNKNOWN,
  1697. .conn = C_STANDALONE,
  1698. .disk = D_DISKLESS,
  1699. .pdsk = D_UNKNOWN,
  1700. } };
  1701. }
  1702. void drbd_init_set_defaults(struct drbd_conf *mdev)
  1703. {
  1704. /* the memset(,0,) did most of this.
  1705. * note: only assignments, no allocation in here */
  1706. drbd_set_defaults(mdev);
  1707. atomic_set(&mdev->ap_bio_cnt, 0);
  1708. atomic_set(&mdev->ap_pending_cnt, 0);
  1709. atomic_set(&mdev->rs_pending_cnt, 0);
  1710. atomic_set(&mdev->unacked_cnt, 0);
  1711. atomic_set(&mdev->local_cnt, 0);
  1712. atomic_set(&mdev->pp_in_use_by_net, 0);
  1713. atomic_set(&mdev->rs_sect_in, 0);
  1714. atomic_set(&mdev->rs_sect_ev, 0);
  1715. atomic_set(&mdev->ap_in_flight, 0);
  1716. mutex_init(&mdev->md_io_mutex);
  1717. mutex_init(&mdev->own_state_mutex);
  1718. mdev->state_mutex = &mdev->own_state_mutex;
  1719. spin_lock_init(&mdev->al_lock);
  1720. spin_lock_init(&mdev->peer_seq_lock);
  1721. spin_lock_init(&mdev->epoch_lock);
  1722. INIT_LIST_HEAD(&mdev->active_ee);
  1723. INIT_LIST_HEAD(&mdev->sync_ee);
  1724. INIT_LIST_HEAD(&mdev->done_ee);
  1725. INIT_LIST_HEAD(&mdev->read_ee);
  1726. INIT_LIST_HEAD(&mdev->net_ee);
  1727. INIT_LIST_HEAD(&mdev->resync_reads);
  1728. INIT_LIST_HEAD(&mdev->resync_work.list);
  1729. INIT_LIST_HEAD(&mdev->unplug_work.list);
  1730. INIT_LIST_HEAD(&mdev->go_diskless.list);
  1731. INIT_LIST_HEAD(&mdev->md_sync_work.list);
  1732. INIT_LIST_HEAD(&mdev->start_resync_work.list);
  1733. INIT_LIST_HEAD(&mdev->bm_io_work.w.list);
  1734. mdev->resync_work.cb = w_resync_timer;
  1735. mdev->unplug_work.cb = w_send_write_hint;
  1736. mdev->go_diskless.cb = w_go_diskless;
  1737. mdev->md_sync_work.cb = w_md_sync;
  1738. mdev->bm_io_work.w.cb = w_bitmap_io;
  1739. mdev->start_resync_work.cb = w_start_resync;
  1740. mdev->resync_work.mdev = mdev;
  1741. mdev->unplug_work.mdev = mdev;
  1742. mdev->go_diskless.mdev = mdev;
  1743. mdev->md_sync_work.mdev = mdev;
  1744. mdev->bm_io_work.w.mdev = mdev;
  1745. mdev->start_resync_work.mdev = mdev;
  1746. init_timer(&mdev->resync_timer);
  1747. init_timer(&mdev->md_sync_timer);
  1748. init_timer(&mdev->start_resync_timer);
  1749. init_timer(&mdev->request_timer);
  1750. mdev->resync_timer.function = resync_timer_fn;
  1751. mdev->resync_timer.data = (unsigned long) mdev;
  1752. mdev->md_sync_timer.function = md_sync_timer_fn;
  1753. mdev->md_sync_timer.data = (unsigned long) mdev;
  1754. mdev->start_resync_timer.function = start_resync_timer_fn;
  1755. mdev->start_resync_timer.data = (unsigned long) mdev;
  1756. mdev->request_timer.function = request_timer_fn;
  1757. mdev->request_timer.data = (unsigned long) mdev;
  1758. init_waitqueue_head(&mdev->misc_wait);
  1759. init_waitqueue_head(&mdev->state_wait);
  1760. init_waitqueue_head(&mdev->ee_wait);
  1761. init_waitqueue_head(&mdev->al_wait);
  1762. init_waitqueue_head(&mdev->seq_wait);
  1763. mdev->write_ordering = WO_bdev_flush;
  1764. mdev->resync_wenr = LC_FREE;
  1765. mdev->peer_max_bio_size = DRBD_MAX_BIO_SIZE_SAFE;
  1766. mdev->local_max_bio_size = DRBD_MAX_BIO_SIZE_SAFE;
  1767. }
  1768. void drbd_mdev_cleanup(struct drbd_conf *mdev)
  1769. {
  1770. int i;
  1771. if (mdev->tconn->receiver.t_state != NONE)
  1772. dev_err(DEV, "ASSERT FAILED: receiver t_state == %d expected 0.\n",
  1773. mdev->tconn->receiver.t_state);
  1774. /* no need to lock it, I'm the only thread alive */
  1775. if (atomic_read(&mdev->current_epoch->epoch_size) != 0)
  1776. dev_err(DEV, "epoch_size:%d\n", atomic_read(&mdev->current_epoch->epoch_size));
  1777. mdev->al_writ_cnt =
  1778. mdev->bm_writ_cnt =
  1779. mdev->read_cnt =
  1780. mdev->recv_cnt =
  1781. mdev->send_cnt =
  1782. mdev->writ_cnt =
  1783. mdev->p_size =
  1784. mdev->rs_start =
  1785. mdev->rs_total =
  1786. mdev->rs_failed = 0;
  1787. mdev->rs_last_events = 0;
  1788. mdev->rs_last_sect_ev = 0;
  1789. for (i = 0; i < DRBD_SYNC_MARKS; i++) {
  1790. mdev->rs_mark_left[i] = 0;
  1791. mdev->rs_mark_time[i] = 0;
  1792. }
  1793. D_ASSERT(mdev->tconn->net_conf == NULL);
  1794. drbd_set_my_capacity(mdev, 0);
  1795. if (mdev->bitmap) {
  1796. /* maybe never allocated. */
  1797. drbd_bm_resize(mdev, 0, 1);
  1798. drbd_bm_cleanup(mdev);
  1799. }
  1800. drbd_free_bc(mdev->ldev);
  1801. mdev->ldev = NULL;
  1802. clear_bit(AL_SUSPENDED, &mdev->flags);
  1803. D_ASSERT(list_empty(&mdev->active_ee));
  1804. D_ASSERT(list_empty(&mdev->sync_ee));
  1805. D_ASSERT(list_empty(&mdev->done_ee));
  1806. D_ASSERT(list_empty(&mdev->read_ee));
  1807. D_ASSERT(list_empty(&mdev->net_ee));
  1808. D_ASSERT(list_empty(&mdev->resync_reads));
  1809. D_ASSERT(list_empty(&mdev->tconn->data.work.q));
  1810. D_ASSERT(list_empty(&mdev->tconn->meta.work.q));
  1811. D_ASSERT(list_empty(&mdev->resync_work.list));
  1812. D_ASSERT(list_empty(&mdev->unplug_work.list));
  1813. D_ASSERT(list_empty(&mdev->go_diskless.list));
  1814. drbd_set_defaults(mdev);
  1815. }
  1816. static void drbd_destroy_mempools(void)
  1817. {
  1818. struct page *page;
  1819. while (drbd_pp_pool) {
  1820. page = drbd_pp_pool;
  1821. drbd_pp_pool = (struct page *)page_private(page);
  1822. __free_page(page);
  1823. drbd_pp_vacant--;
  1824. }
  1825. /* D_ASSERT(atomic_read(&drbd_pp_vacant)==0); */
  1826. if (drbd_md_io_bio_set)
  1827. bioset_free(drbd_md_io_bio_set);
  1828. if (drbd_md_io_page_pool)
  1829. mempool_destroy(drbd_md_io_page_pool);
  1830. if (drbd_ee_mempool)
  1831. mempool_destroy(drbd_ee_mempool);
  1832. if (drbd_request_mempool)
  1833. mempool_destroy(drbd_request_mempool);
  1834. if (drbd_ee_cache)
  1835. kmem_cache_destroy(drbd_ee_cache);
  1836. if (drbd_request_cache)
  1837. kmem_cache_destroy(drbd_request_cache);
  1838. if (drbd_bm_ext_cache)
  1839. kmem_cache_destroy(drbd_bm_ext_cache);
  1840. if (drbd_al_ext_cache)
  1841. kmem_cache_destroy(drbd_al_ext_cache);
  1842. drbd_md_io_bio_set = NULL;
  1843. drbd_md_io_page_pool = NULL;
  1844. drbd_ee_mempool = NULL;
  1845. drbd_request_mempool = NULL;
  1846. drbd_ee_cache = NULL;
  1847. drbd_request_cache = NULL;
  1848. drbd_bm_ext_cache = NULL;
  1849. drbd_al_ext_cache = NULL;
  1850. return;
  1851. }
  1852. static int drbd_create_mempools(void)
  1853. {
  1854. struct page *page;
  1855. const int number = (DRBD_MAX_BIO_SIZE/PAGE_SIZE) * minor_count;
  1856. int i;
  1857. /* prepare our caches and mempools */
  1858. drbd_request_mempool = NULL;
  1859. drbd_ee_cache = NULL;
  1860. drbd_request_cache = NULL;
  1861. drbd_bm_ext_cache = NULL;
  1862. drbd_al_ext_cache = NULL;
  1863. drbd_pp_pool = NULL;
  1864. drbd_md_io_page_pool = NULL;
  1865. drbd_md_io_bio_set = NULL;
  1866. /* caches */
  1867. drbd_request_cache = kmem_cache_create(
  1868. "drbd_req", sizeof(struct drbd_request), 0, 0, NULL);
  1869. if (drbd_request_cache == NULL)
  1870. goto Enomem;
  1871. drbd_ee_cache = kmem_cache_create(
  1872. "drbd_ee", sizeof(struct drbd_peer_request), 0, 0, NULL);
  1873. if (drbd_ee_cache == NULL)
  1874. goto Enomem;
  1875. drbd_bm_ext_cache = kmem_cache_create(
  1876. "drbd_bm", sizeof(struct bm_extent), 0, 0, NULL);
  1877. if (drbd_bm_ext_cache == NULL)
  1878. goto Enomem;
  1879. drbd_al_ext_cache = kmem_cache_create(
  1880. "drbd_al", sizeof(struct lc_element), 0, 0, NULL);
  1881. if (drbd_al_ext_cache == NULL)
  1882. goto Enomem;
  1883. /* mempools */
  1884. drbd_md_io_bio_set = bioset_create(DRBD_MIN_POOL_PAGES, 0);
  1885. if (drbd_md_io_bio_set == NULL)
  1886. goto Enomem;
  1887. drbd_md_io_page_pool = mempool_create_page_pool(DRBD_MIN_POOL_PAGES, 0);
  1888. if (drbd_md_io_page_pool == NULL)
  1889. goto Enomem;
  1890. drbd_request_mempool = mempool_create(number,
  1891. mempool_alloc_slab, mempool_free_slab, drbd_request_cache);
  1892. if (drbd_request_mempool == NULL)
  1893. goto Enomem;
  1894. drbd_ee_mempool = mempool_create(number,
  1895. mempool_alloc_slab, mempool_free_slab, drbd_ee_cache);
  1896. if (drbd_ee_mempool == NULL)
  1897. goto Enomem;
  1898. /* drbd's page pool */
  1899. spin_lock_init(&drbd_pp_lock);
  1900. for (i = 0; i < number; i++) {
  1901. page = alloc_page(GFP_HIGHUSER);
  1902. if (!page)
  1903. goto Enomem;
  1904. set_page_private(page, (unsigned long)drbd_pp_pool);
  1905. drbd_pp_pool = page;
  1906. }
  1907. drbd_pp_vacant = number;
  1908. return 0;
  1909. Enomem:
  1910. drbd_destroy_mempools(); /* in case we allocated some */
  1911. return -ENOMEM;
  1912. }
  1913. static int drbd_notify_sys(struct notifier_block *this, unsigned long code,
  1914. void *unused)
  1915. {
  1916. /* just so we have it. you never know what interesting things we
  1917. * might want to do here some day...
  1918. */
  1919. return NOTIFY_DONE;
  1920. }
  1921. static struct notifier_block drbd_notifier = {
  1922. .notifier_call = drbd_notify_sys,
  1923. };
  1924. static void drbd_release_all_peer_reqs(struct drbd_conf *mdev)
  1925. {
  1926. int rr;
  1927. rr = drbd_free_peer_reqs(mdev, &mdev->active_ee);
  1928. if (rr)
  1929. dev_err(DEV, "%d EEs in active list found!\n", rr);
  1930. rr = drbd_free_peer_reqs(mdev, &mdev->sync_ee);
  1931. if (rr)
  1932. dev_err(DEV, "%d EEs in sync list found!\n", rr);
  1933. rr = drbd_free_peer_reqs(mdev, &mdev->read_ee);
  1934. if (rr)
  1935. dev_err(DEV, "%d EEs in read list found!\n", rr);
  1936. rr = drbd_free_peer_reqs(mdev, &mdev->done_ee);
  1937. if (rr)
  1938. dev_err(DEV, "%d EEs in done list found!\n", rr);
  1939. rr = drbd_free_peer_reqs(mdev, &mdev->net_ee);
  1940. if (rr)
  1941. dev_err(DEV, "%d EEs in net list found!\n", rr);
  1942. }
  1943. /* caution. no locking. */
  1944. void drbd_minor_destroy(struct kref *kref)
  1945. {
  1946. struct drbd_conf *mdev = container_of(kref, struct drbd_conf, kref);
  1947. struct drbd_tconn *tconn = mdev->tconn;
  1948. /* paranoia asserts */
  1949. D_ASSERT(mdev->open_cnt == 0);
  1950. D_ASSERT(list_empty(&mdev->tconn->data.work.q));
  1951. /* end paranoia asserts */
  1952. /* cleanup stuff that may have been allocated during
  1953. * device (re-)configuration or state changes */
  1954. if (mdev->this_bdev)
  1955. bdput(mdev->this_bdev);
  1956. drbd_free_bc(mdev->ldev);
  1957. mdev->ldev = NULL;
  1958. drbd_release_all_peer_reqs(mdev);
  1959. lc_destroy(mdev->act_log);
  1960. lc_destroy(mdev->resync);
  1961. kfree(mdev->p_uuid);
  1962. /* mdev->p_uuid = NULL; */
  1963. kfree(mdev->current_epoch);
  1964. if (mdev->bitmap) /* should no longer be there. */
  1965. drbd_bm_cleanup(mdev);
  1966. __free_page(mdev->md_io_page);
  1967. put_disk(mdev->vdisk);
  1968. blk_cleanup_queue(mdev->rq_queue);
  1969. kfree(mdev->rs_plan_s);
  1970. kfree(mdev);
  1971. kref_put(&tconn->kref, &conn_destroy);
  1972. }
  1973. static void drbd_cleanup(void)
  1974. {
  1975. unsigned int i;
  1976. struct drbd_conf *mdev;
  1977. struct drbd_tconn *tconn, *tmp;
  1978. unregister_reboot_notifier(&drbd_notifier);
  1979. /* first remove proc,
  1980. * drbdsetup uses it's presence to detect
  1981. * whether DRBD is loaded.
  1982. * If we would get stuck in proc removal,
  1983. * but have netlink already deregistered,
  1984. * some drbdsetup commands may wait forever
  1985. * for an answer.
  1986. */
  1987. if (drbd_proc)
  1988. remove_proc_entry("drbd", NULL);
  1989. drbd_genl_unregister();
  1990. idr_for_each_entry(&minors, mdev, i) {
  1991. idr_remove(&minors, mdev_to_minor(mdev));
  1992. idr_remove(&mdev->tconn->volumes, mdev->vnr);
  1993. del_gendisk(mdev->vdisk);
  1994. /* synchronize_rcu(); No other threads running at this point */
  1995. kref_put(&mdev->kref, &drbd_minor_destroy);
  1996. }
  1997. /* not _rcu since, no other updater anymore. Genl already unregistered */
  1998. list_for_each_entry_safe(tconn, tmp, &drbd_tconns, all_tconn) {
  1999. list_del(&tconn->all_tconn); /* not _rcu no proc, not other threads */
  2000. /* synchronize_rcu(); */
  2001. kref_put(&tconn->kref, &conn_destroy);
  2002. }
  2003. drbd_destroy_mempools();
  2004. unregister_blkdev(DRBD_MAJOR, "drbd");
  2005. idr_destroy(&minors);
  2006. printk(KERN_INFO "drbd: module cleanup done.\n");
  2007. }
  2008. /**
  2009. * drbd_congested() - Callback for pdflush
  2010. * @congested_data: User data
  2011. * @bdi_bits: Bits pdflush is currently interested in
  2012. *
  2013. * Returns 1<<BDI_async_congested and/or 1<<BDI_sync_congested if we are congested.
  2014. */
  2015. static int drbd_congested(void *congested_data, int bdi_bits)
  2016. {
  2017. struct drbd_conf *mdev = congested_data;
  2018. struct request_queue *q;
  2019. char reason = '-';
  2020. int r = 0;
  2021. if (!may_inc_ap_bio(mdev)) {
  2022. /* DRBD has frozen IO */
  2023. r = bdi_bits;
  2024. reason = 'd';
  2025. goto out;
  2026. }
  2027. if (get_ldev(mdev)) {
  2028. q = bdev_get_queue(mdev->ldev->backing_bdev);
  2029. r = bdi_congested(&q->backing_dev_info, bdi_bits);
  2030. put_ldev(mdev);
  2031. if (r)
  2032. reason = 'b';
  2033. }
  2034. if (bdi_bits & (1 << BDI_async_congested) && test_bit(NET_CONGESTED, &mdev->tconn->flags)) {
  2035. r |= (1 << BDI_async_congested);
  2036. reason = reason == 'b' ? 'a' : 'n';
  2037. }
  2038. out:
  2039. mdev->congestion_reason = reason;
  2040. return r;
  2041. }
  2042. static void drbd_init_workqueue(struct drbd_work_queue* wq)
  2043. {
  2044. sema_init(&wq->s, 0);
  2045. spin_lock_init(&wq->q_lock);
  2046. INIT_LIST_HEAD(&wq->q);
  2047. }
  2048. struct drbd_tconn *conn_get_by_name(const char *name)
  2049. {
  2050. struct drbd_tconn *tconn;
  2051. if (!name || !name[0])
  2052. return NULL;
  2053. rcu_read_lock();
  2054. list_for_each_entry_rcu(tconn, &drbd_tconns, all_tconn) {
  2055. if (!strcmp(tconn->name, name)) {
  2056. kref_get(&tconn->kref);
  2057. goto found;
  2058. }
  2059. }
  2060. tconn = NULL;
  2061. found:
  2062. rcu_read_unlock();
  2063. return tconn;
  2064. }
  2065. static int drbd_alloc_socket(struct drbd_socket *socket)
  2066. {
  2067. socket->rbuf = (void *) __get_free_page(GFP_KERNEL);
  2068. if (!socket->rbuf)
  2069. return -ENOMEM;
  2070. socket->sbuf = (void *) __get_free_page(GFP_KERNEL);
  2071. if (!socket->sbuf)
  2072. return -ENOMEM;
  2073. return 0;
  2074. }
  2075. static void drbd_free_socket(struct drbd_socket *socket)
  2076. {
  2077. free_page((unsigned long) socket->sbuf);
  2078. free_page((unsigned long) socket->rbuf);
  2079. }
  2080. void conn_free_crypto(struct drbd_tconn *tconn)
  2081. {
  2082. drbd_free_sock(tconn);
  2083. crypto_free_hash(tconn->csums_tfm);
  2084. crypto_free_hash(tconn->verify_tfm);
  2085. crypto_free_hash(tconn->cram_hmac_tfm);
  2086. crypto_free_hash(tconn->integrity_tfm);
  2087. crypto_free_hash(tconn->peer_integrity_tfm);
  2088. kfree(tconn->int_dig_in);
  2089. kfree(tconn->int_dig_vv);
  2090. tconn->csums_tfm = NULL;
  2091. tconn->verify_tfm = NULL;
  2092. tconn->cram_hmac_tfm = NULL;
  2093. tconn->integrity_tfm = NULL;
  2094. tconn->peer_integrity_tfm = NULL;
  2095. tconn->int_dig_in = NULL;
  2096. tconn->int_dig_vv = NULL;
  2097. }
  2098. /* caller must be under genl_lock() */
  2099. struct drbd_tconn *conn_create(const char *name)
  2100. {
  2101. struct drbd_tconn *tconn;
  2102. tconn = kzalloc(sizeof(struct drbd_tconn), GFP_KERNEL);
  2103. if (!tconn)
  2104. return NULL;
  2105. tconn->name = kstrdup(name, GFP_KERNEL);
  2106. if (!tconn->name)
  2107. goto fail;
  2108. if (drbd_alloc_socket(&tconn->data))
  2109. goto fail;
  2110. if (drbd_alloc_socket(&tconn->meta))
  2111. goto fail;
  2112. if (!zalloc_cpumask_var(&tconn->cpu_mask, GFP_KERNEL))
  2113. goto fail;
  2114. if (!tl_init(tconn))
  2115. goto fail;
  2116. tconn->cstate = C_STANDALONE;
  2117. mutex_init(&tconn->cstate_mutex);
  2118. spin_lock_init(&tconn->req_lock);
  2119. mutex_init(&tconn->conf_update);
  2120. init_waitqueue_head(&tconn->ping_wait);
  2121. idr_init(&tconn->volumes);
  2122. drbd_init_workqueue(&tconn->data.work);
  2123. mutex_init(&tconn->data.mutex);
  2124. drbd_init_workqueue(&tconn->meta.work);
  2125. mutex_init(&tconn->meta.mutex);
  2126. drbd_thread_init(tconn, &tconn->receiver, drbdd_init, "receiver");
  2127. drbd_thread_init(tconn, &tconn->worker, drbd_worker, "worker");
  2128. drbd_thread_init(tconn, &tconn->asender, drbd_asender, "asender");
  2129. drbd_set_res_opts_defaults(&tconn->res_opts);
  2130. kref_init(&tconn->kref);
  2131. list_add_tail_rcu(&tconn->all_tconn, &drbd_tconns);
  2132. return tconn;
  2133. fail:
  2134. tl_cleanup(tconn);
  2135. free_cpumask_var(tconn->cpu_mask);
  2136. drbd_free_socket(&tconn->meta);
  2137. drbd_free_socket(&tconn->data);
  2138. kfree(tconn->name);
  2139. kfree(tconn);
  2140. return NULL;
  2141. }
  2142. void conn_destroy(struct kref *kref)
  2143. {
  2144. struct drbd_tconn *tconn = container_of(kref, struct drbd_tconn, kref);
  2145. idr_destroy(&tconn->volumes);
  2146. free_cpumask_var(tconn->cpu_mask);
  2147. drbd_free_socket(&tconn->meta);
  2148. drbd_free_socket(&tconn->data);
  2149. kfree(tconn->name);
  2150. kfree(tconn->int_dig_in);
  2151. kfree(tconn->int_dig_vv);
  2152. kfree(tconn);
  2153. }
  2154. enum drbd_ret_code conn_new_minor(struct drbd_tconn *tconn, unsigned int minor, int vnr)
  2155. {
  2156. struct drbd_conf *mdev;
  2157. struct gendisk *disk;
  2158. struct request_queue *q;
  2159. int vnr_got = vnr;
  2160. int minor_got = minor;
  2161. enum drbd_ret_code err = ERR_NOMEM;
  2162. mdev = minor_to_mdev(minor);
  2163. if (mdev)
  2164. return ERR_MINOR_EXISTS;
  2165. /* GFP_KERNEL, we are outside of all write-out paths */
  2166. mdev = kzalloc(sizeof(struct drbd_conf), GFP_KERNEL);
  2167. if (!mdev)
  2168. return ERR_NOMEM;
  2169. kref_get(&tconn->kref);
  2170. mdev->tconn = tconn;
  2171. mdev->minor = minor;
  2172. mdev->vnr = vnr;
  2173. drbd_init_set_defaults(mdev);
  2174. q = blk_alloc_queue(GFP_KERNEL);
  2175. if (!q)
  2176. goto out_no_q;
  2177. mdev->rq_queue = q;
  2178. q->queuedata = mdev;
  2179. disk = alloc_disk(1);
  2180. if (!disk)
  2181. goto out_no_disk;
  2182. mdev->vdisk = disk;
  2183. set_disk_ro(disk, true);
  2184. disk->queue = q;
  2185. disk->major = DRBD_MAJOR;
  2186. disk->first_minor = minor;
  2187. disk->fops = &drbd_ops;
  2188. sprintf(disk->disk_name, "drbd%d", minor);
  2189. disk->private_data = mdev;
  2190. mdev->this_bdev = bdget(MKDEV(DRBD_MAJOR, minor));
  2191. /* we have no partitions. we contain only ourselves. */
  2192. mdev->this_bdev->bd_contains = mdev->this_bdev;
  2193. q->backing_dev_info.congested_fn = drbd_congested;
  2194. q->backing_dev_info.congested_data = mdev;
  2195. blk_queue_make_request(q, drbd_make_request);
  2196. /* Setting the max_hw_sectors to an odd value of 8kibyte here
  2197. This triggers a max_bio_size message upon first attach or connect */
  2198. blk_queue_max_hw_sectors(q, DRBD_MAX_BIO_SIZE_SAFE >> 8);
  2199. blk_queue_bounce_limit(q, BLK_BOUNCE_ANY);
  2200. blk_queue_merge_bvec(q, drbd_merge_bvec);
  2201. q->queue_lock = &mdev->tconn->req_lock; /* needed since we use */
  2202. mdev->md_io_page = alloc_page(GFP_KERNEL);
  2203. if (!mdev->md_io_page)
  2204. goto out_no_io_page;
  2205. if (drbd_bm_init(mdev))
  2206. goto out_no_bitmap;
  2207. mdev->read_requests = RB_ROOT;
  2208. mdev->write_requests = RB_ROOT;
  2209. mdev->current_epoch = kzalloc(sizeof(struct drbd_epoch), GFP_KERNEL);
  2210. if (!mdev->current_epoch)
  2211. goto out_no_epoch;
  2212. INIT_LIST_HEAD(&mdev->current_epoch->list);
  2213. mdev->epochs = 1;
  2214. if (!idr_pre_get(&minors, GFP_KERNEL))
  2215. goto out_no_minor_idr;
  2216. if (idr_get_new_above(&minors, mdev, minor, &minor_got))
  2217. goto out_no_minor_idr;
  2218. if (minor_got != minor) {
  2219. err = ERR_MINOR_EXISTS;
  2220. drbd_msg_put_info("requested minor exists already");
  2221. goto out_idr_remove_minor;
  2222. }
  2223. if (!idr_pre_get(&tconn->volumes, GFP_KERNEL))
  2224. goto out_idr_remove_minor;
  2225. if (idr_get_new_above(&tconn->volumes, mdev, vnr, &vnr_got))
  2226. goto out_idr_remove_minor;
  2227. if (vnr_got != vnr) {
  2228. err = ERR_INVALID_REQUEST;
  2229. drbd_msg_put_info("requested volume exists already");
  2230. goto out_idr_remove_vol;
  2231. }
  2232. add_disk(disk);
  2233. kref_init(&mdev->kref); /* one ref for both idrs and the the add_disk */
  2234. /* inherit the connection state */
  2235. mdev->state.conn = tconn->cstate;
  2236. if (mdev->state.conn == C_WF_REPORT_PARAMS)
  2237. drbd_connected(mdev);
  2238. return NO_ERROR;
  2239. out_idr_remove_vol:
  2240. idr_remove(&tconn->volumes, vnr_got);
  2241. out_idr_remove_minor:
  2242. idr_remove(&minors, minor_got);
  2243. synchronize_rcu();
  2244. out_no_minor_idr:
  2245. kfree(mdev->current_epoch);
  2246. out_no_epoch:
  2247. drbd_bm_cleanup(mdev);
  2248. out_no_bitmap:
  2249. __free_page(mdev->md_io_page);
  2250. out_no_io_page:
  2251. put_disk(disk);
  2252. out_no_disk:
  2253. blk_cleanup_queue(q);
  2254. out_no_q:
  2255. kfree(mdev);
  2256. kref_put(&tconn->kref, &conn_destroy);
  2257. return err;
  2258. }
  2259. int __init drbd_init(void)
  2260. {
  2261. int err;
  2262. if (minor_count < DRBD_MINOR_COUNT_MIN || minor_count > DRBD_MINOR_COUNT_MAX) {
  2263. printk(KERN_ERR
  2264. "drbd: invalid minor_count (%d)\n", minor_count);
  2265. #ifdef MODULE
  2266. return -EINVAL;
  2267. #else
  2268. minor_count = 8;
  2269. #endif
  2270. }
  2271. err = register_blkdev(DRBD_MAJOR, "drbd");
  2272. if (err) {
  2273. printk(KERN_ERR
  2274. "drbd: unable to register block device major %d\n",
  2275. DRBD_MAJOR);
  2276. return err;
  2277. }
  2278. err = drbd_genl_register();
  2279. if (err) {
  2280. printk(KERN_ERR "drbd: unable to register generic netlink family\n");
  2281. goto fail;
  2282. }
  2283. register_reboot_notifier(&drbd_notifier);
  2284. /*
  2285. * allocate all necessary structs
  2286. */
  2287. err = -ENOMEM;
  2288. init_waitqueue_head(&drbd_pp_wait);
  2289. drbd_proc = NULL; /* play safe for drbd_cleanup */
  2290. idr_init(&minors);
  2291. err = drbd_create_mempools();
  2292. if (err)
  2293. goto fail;
  2294. drbd_proc = proc_create_data("drbd", S_IFREG | S_IRUGO , NULL, &drbd_proc_fops, NULL);
  2295. if (!drbd_proc) {
  2296. printk(KERN_ERR "drbd: unable to register proc file\n");
  2297. goto fail;
  2298. }
  2299. rwlock_init(&global_state_lock);
  2300. INIT_LIST_HEAD(&drbd_tconns);
  2301. printk(KERN_INFO "drbd: initialized. "
  2302. "Version: " REL_VERSION " (api:%d/proto:%d-%d)\n",
  2303. API_VERSION, PRO_VERSION_MIN, PRO_VERSION_MAX);
  2304. printk(KERN_INFO "drbd: %s\n", drbd_buildtag());
  2305. printk(KERN_INFO "drbd: registered as block device major %d\n",
  2306. DRBD_MAJOR);
  2307. return 0; /* Success! */
  2308. fail:
  2309. drbd_cleanup();
  2310. if (err == -ENOMEM)
  2311. /* currently always the case */
  2312. printk(KERN_ERR "drbd: ran out of memory\n");
  2313. else
  2314. printk(KERN_ERR "drbd: initialization failure\n");
  2315. return err;
  2316. }
  2317. void drbd_free_bc(struct drbd_backing_dev *ldev)
  2318. {
  2319. if (ldev == NULL)
  2320. return;
  2321. blkdev_put(ldev->backing_bdev, FMODE_READ | FMODE_WRITE | FMODE_EXCL);
  2322. blkdev_put(ldev->md_bdev, FMODE_READ | FMODE_WRITE | FMODE_EXCL);
  2323. kfree(ldev);
  2324. }
  2325. void drbd_free_sock(struct drbd_tconn *tconn)
  2326. {
  2327. if (tconn->data.socket) {
  2328. mutex_lock(&tconn->data.mutex);
  2329. kernel_sock_shutdown(tconn->data.socket, SHUT_RDWR);
  2330. sock_release(tconn->data.socket);
  2331. tconn->data.socket = NULL;
  2332. mutex_unlock(&tconn->data.mutex);
  2333. }
  2334. if (tconn->meta.socket) {
  2335. mutex_lock(&tconn->meta.mutex);
  2336. kernel_sock_shutdown(tconn->meta.socket, SHUT_RDWR);
  2337. sock_release(tconn->meta.socket);
  2338. tconn->meta.socket = NULL;
  2339. mutex_unlock(&tconn->meta.mutex);
  2340. }
  2341. }
  2342. /* meta data management */
  2343. struct meta_data_on_disk {
  2344. u64 la_size; /* last agreed size. */
  2345. u64 uuid[UI_SIZE]; /* UUIDs. */
  2346. u64 device_uuid;
  2347. u64 reserved_u64_1;
  2348. u32 flags; /* MDF */
  2349. u32 magic;
  2350. u32 md_size_sect;
  2351. u32 al_offset; /* offset to this block */
  2352. u32 al_nr_extents; /* important for restoring the AL */
  2353. /* `-- act_log->nr_elements <-- ldev->dc.al_extents */
  2354. u32 bm_offset; /* offset to the bitmap, from here */
  2355. u32 bm_bytes_per_bit; /* BM_BLOCK_SIZE */
  2356. u32 la_peer_max_bio_size; /* last peer max_bio_size */
  2357. u32 reserved_u32[3];
  2358. } __packed;
  2359. /**
  2360. * drbd_md_sync() - Writes the meta data super block if the MD_DIRTY flag bit is set
  2361. * @mdev: DRBD device.
  2362. */
  2363. void drbd_md_sync(struct drbd_conf *mdev)
  2364. {
  2365. struct meta_data_on_disk *buffer;
  2366. sector_t sector;
  2367. int i;
  2368. del_timer(&mdev->md_sync_timer);
  2369. /* timer may be rearmed by drbd_md_mark_dirty() now. */
  2370. if (!test_and_clear_bit(MD_DIRTY, &mdev->flags))
  2371. return;
  2372. /* We use here D_FAILED and not D_ATTACHING because we try to write
  2373. * metadata even if we detach due to a disk failure! */
  2374. if (!get_ldev_if_state(mdev, D_FAILED))
  2375. return;
  2376. mutex_lock(&mdev->md_io_mutex);
  2377. buffer = (struct meta_data_on_disk *)page_address(mdev->md_io_page);
  2378. memset(buffer, 0, 512);
  2379. buffer->la_size = cpu_to_be64(drbd_get_capacity(mdev->this_bdev));
  2380. for (i = UI_CURRENT; i < UI_SIZE; i++)
  2381. buffer->uuid[i] = cpu_to_be64(mdev->ldev->md.uuid[i]);
  2382. buffer->flags = cpu_to_be32(mdev->ldev->md.flags);
  2383. buffer->magic = cpu_to_be32(DRBD_MD_MAGIC);
  2384. buffer->md_size_sect = cpu_to_be32(mdev->ldev->md.md_size_sect);
  2385. buffer->al_offset = cpu_to_be32(mdev->ldev->md.al_offset);
  2386. buffer->al_nr_extents = cpu_to_be32(mdev->act_log->nr_elements);
  2387. buffer->bm_bytes_per_bit = cpu_to_be32(BM_BLOCK_SIZE);
  2388. buffer->device_uuid = cpu_to_be64(mdev->ldev->md.device_uuid);
  2389. buffer->bm_offset = cpu_to_be32(mdev->ldev->md.bm_offset);
  2390. buffer->la_peer_max_bio_size = cpu_to_be32(mdev->peer_max_bio_size);
  2391. D_ASSERT(drbd_md_ss__(mdev, mdev->ldev) == mdev->ldev->md.md_offset);
  2392. sector = mdev->ldev->md.md_offset;
  2393. if (drbd_md_sync_page_io(mdev, mdev->ldev, sector, WRITE)) {
  2394. /* this was a try anyways ... */
  2395. dev_err(DEV, "meta data update failed!\n");
  2396. drbd_chk_io_error(mdev, 1, true);
  2397. }
  2398. /* Update mdev->ldev->md.la_size_sect,
  2399. * since we updated it on metadata. */
  2400. mdev->ldev->md.la_size_sect = drbd_get_capacity(mdev->this_bdev);
  2401. mutex_unlock(&mdev->md_io_mutex);
  2402. put_ldev(mdev);
  2403. }
  2404. /**
  2405. * drbd_md_read() - Reads in the meta data super block
  2406. * @mdev: DRBD device.
  2407. * @bdev: Device from which the meta data should be read in.
  2408. *
  2409. * Return 0 (NO_ERROR) on success, and an enum drbd_ret_code in case
  2410. * something goes wrong. Currently only: ERR_IO_MD_DISK, ERR_MD_INVALID.
  2411. */
  2412. int drbd_md_read(struct drbd_conf *mdev, struct drbd_backing_dev *bdev)
  2413. {
  2414. struct meta_data_on_disk *buffer;
  2415. int i, rv = NO_ERROR;
  2416. if (!get_ldev_if_state(mdev, D_ATTACHING))
  2417. return ERR_IO_MD_DISK;
  2418. mutex_lock(&mdev->md_io_mutex);
  2419. buffer = (struct meta_data_on_disk *)page_address(mdev->md_io_page);
  2420. if (drbd_md_sync_page_io(mdev, bdev, bdev->md.md_offset, READ)) {
  2421. /* NOTE: can't do normal error processing here as this is
  2422. called BEFORE disk is attached */
  2423. dev_err(DEV, "Error while reading metadata.\n");
  2424. rv = ERR_IO_MD_DISK;
  2425. goto err;
  2426. }
  2427. if (buffer->magic != cpu_to_be32(DRBD_MD_MAGIC)) {
  2428. dev_err(DEV, "Error while reading metadata, magic not found.\n");
  2429. rv = ERR_MD_INVALID;
  2430. goto err;
  2431. }
  2432. if (be32_to_cpu(buffer->al_offset) != bdev->md.al_offset) {
  2433. dev_err(DEV, "unexpected al_offset: %d (expected %d)\n",
  2434. be32_to_cpu(buffer->al_offset), bdev->md.al_offset);
  2435. rv = ERR_MD_INVALID;
  2436. goto err;
  2437. }
  2438. if (be32_to_cpu(buffer->bm_offset) != bdev->md.bm_offset) {
  2439. dev_err(DEV, "unexpected bm_offset: %d (expected %d)\n",
  2440. be32_to_cpu(buffer->bm_offset), bdev->md.bm_offset);
  2441. rv = ERR_MD_INVALID;
  2442. goto err;
  2443. }
  2444. if (be32_to_cpu(buffer->md_size_sect) != bdev->md.md_size_sect) {
  2445. dev_err(DEV, "unexpected md_size: %u (expected %u)\n",
  2446. be32_to_cpu(buffer->md_size_sect), bdev->md.md_size_sect);
  2447. rv = ERR_MD_INVALID;
  2448. goto err;
  2449. }
  2450. if (be32_to_cpu(buffer->bm_bytes_per_bit) != BM_BLOCK_SIZE) {
  2451. dev_err(DEV, "unexpected bm_bytes_per_bit: %u (expected %u)\n",
  2452. be32_to_cpu(buffer->bm_bytes_per_bit), BM_BLOCK_SIZE);
  2453. rv = ERR_MD_INVALID;
  2454. goto err;
  2455. }
  2456. bdev->md.la_size_sect = be64_to_cpu(buffer->la_size);
  2457. for (i = UI_CURRENT; i < UI_SIZE; i++)
  2458. bdev->md.uuid[i] = be64_to_cpu(buffer->uuid[i]);
  2459. bdev->md.flags = be32_to_cpu(buffer->flags);
  2460. bdev->md.device_uuid = be64_to_cpu(buffer->device_uuid);
  2461. spin_lock_irq(&mdev->tconn->req_lock);
  2462. if (mdev->state.conn < C_CONNECTED) {
  2463. int peer;
  2464. peer = be32_to_cpu(buffer->la_peer_max_bio_size);
  2465. peer = max_t(int, peer, DRBD_MAX_BIO_SIZE_SAFE);
  2466. mdev->peer_max_bio_size = peer;
  2467. }
  2468. spin_unlock_irq(&mdev->tconn->req_lock);
  2469. /* This blocks wants to be get removed... */
  2470. bdev->disk_conf->al_extents = be32_to_cpu(buffer->al_nr_extents);
  2471. if (bdev->disk_conf->al_extents < DRBD_AL_EXTENTS_MIN)
  2472. bdev->disk_conf->al_extents = DRBD_AL_EXTENTS_DEF;
  2473. err:
  2474. mutex_unlock(&mdev->md_io_mutex);
  2475. put_ldev(mdev);
  2476. return rv;
  2477. }
  2478. /**
  2479. * drbd_md_mark_dirty() - Mark meta data super block as dirty
  2480. * @mdev: DRBD device.
  2481. *
  2482. * Call this function if you change anything that should be written to
  2483. * the meta-data super block. This function sets MD_DIRTY, and starts a
  2484. * timer that ensures that within five seconds you have to call drbd_md_sync().
  2485. */
  2486. #ifdef DEBUG
  2487. void drbd_md_mark_dirty_(struct drbd_conf *mdev, unsigned int line, const char *func)
  2488. {
  2489. if (!test_and_set_bit(MD_DIRTY, &mdev->flags)) {
  2490. mod_timer(&mdev->md_sync_timer, jiffies + HZ);
  2491. mdev->last_md_mark_dirty.line = line;
  2492. mdev->last_md_mark_dirty.func = func;
  2493. }
  2494. }
  2495. #else
  2496. void drbd_md_mark_dirty(struct drbd_conf *mdev)
  2497. {
  2498. if (!test_and_set_bit(MD_DIRTY, &mdev->flags))
  2499. mod_timer(&mdev->md_sync_timer, jiffies + 5*HZ);
  2500. }
  2501. #endif
  2502. static void drbd_uuid_move_history(struct drbd_conf *mdev) __must_hold(local)
  2503. {
  2504. int i;
  2505. for (i = UI_HISTORY_START; i < UI_HISTORY_END; i++)
  2506. mdev->ldev->md.uuid[i+1] = mdev->ldev->md.uuid[i];
  2507. }
  2508. void _drbd_uuid_set(struct drbd_conf *mdev, int idx, u64 val) __must_hold(local)
  2509. {
  2510. if (idx == UI_CURRENT) {
  2511. if (mdev->state.role == R_PRIMARY)
  2512. val |= 1;
  2513. else
  2514. val &= ~((u64)1);
  2515. drbd_set_ed_uuid(mdev, val);
  2516. }
  2517. mdev->ldev->md.uuid[idx] = val;
  2518. drbd_md_mark_dirty(mdev);
  2519. }
  2520. void drbd_uuid_set(struct drbd_conf *mdev, int idx, u64 val) __must_hold(local)
  2521. {
  2522. if (mdev->ldev->md.uuid[idx]) {
  2523. drbd_uuid_move_history(mdev);
  2524. mdev->ldev->md.uuid[UI_HISTORY_START] = mdev->ldev->md.uuid[idx];
  2525. }
  2526. _drbd_uuid_set(mdev, idx, val);
  2527. }
  2528. /**
  2529. * drbd_uuid_new_current() - Creates a new current UUID
  2530. * @mdev: DRBD device.
  2531. *
  2532. * Creates a new current UUID, and rotates the old current UUID into
  2533. * the bitmap slot. Causes an incremental resync upon next connect.
  2534. */
  2535. void drbd_uuid_new_current(struct drbd_conf *mdev) __must_hold(local)
  2536. {
  2537. u64 val;
  2538. unsigned long long bm_uuid = mdev->ldev->md.uuid[UI_BITMAP];
  2539. if (bm_uuid)
  2540. dev_warn(DEV, "bm UUID was already set: %llX\n", bm_uuid);
  2541. mdev->ldev->md.uuid[UI_BITMAP] = mdev->ldev->md.uuid[UI_CURRENT];
  2542. get_random_bytes(&val, sizeof(u64));
  2543. _drbd_uuid_set(mdev, UI_CURRENT, val);
  2544. drbd_print_uuids(mdev, "new current UUID");
  2545. /* get it to stable storage _now_ */
  2546. drbd_md_sync(mdev);
  2547. }
  2548. void drbd_uuid_set_bm(struct drbd_conf *mdev, u64 val) __must_hold(local)
  2549. {
  2550. if (mdev->ldev->md.uuid[UI_BITMAP] == 0 && val == 0)
  2551. return;
  2552. if (val == 0) {
  2553. drbd_uuid_move_history(mdev);
  2554. mdev->ldev->md.uuid[UI_HISTORY_START] = mdev->ldev->md.uuid[UI_BITMAP];
  2555. mdev->ldev->md.uuid[UI_BITMAP] = 0;
  2556. } else {
  2557. unsigned long long bm_uuid = mdev->ldev->md.uuid[UI_BITMAP];
  2558. if (bm_uuid)
  2559. dev_warn(DEV, "bm UUID was already set: %llX\n", bm_uuid);
  2560. mdev->ldev->md.uuid[UI_BITMAP] = val & ~((u64)1);
  2561. }
  2562. drbd_md_mark_dirty(mdev);
  2563. }
  2564. /**
  2565. * drbd_bmio_set_n_write() - io_fn for drbd_queue_bitmap_io() or drbd_bitmap_io()
  2566. * @mdev: DRBD device.
  2567. *
  2568. * Sets all bits in the bitmap and writes the whole bitmap to stable storage.
  2569. */
  2570. int drbd_bmio_set_n_write(struct drbd_conf *mdev)
  2571. {
  2572. int rv = -EIO;
  2573. if (get_ldev_if_state(mdev, D_ATTACHING)) {
  2574. drbd_md_set_flag(mdev, MDF_FULL_SYNC);
  2575. drbd_md_sync(mdev);
  2576. drbd_bm_set_all(mdev);
  2577. rv = drbd_bm_write(mdev);
  2578. if (!rv) {
  2579. drbd_md_clear_flag(mdev, MDF_FULL_SYNC);
  2580. drbd_md_sync(mdev);
  2581. }
  2582. put_ldev(mdev);
  2583. }
  2584. return rv;
  2585. }
  2586. /**
  2587. * drbd_bmio_clear_n_write() - io_fn for drbd_queue_bitmap_io() or drbd_bitmap_io()
  2588. * @mdev: DRBD device.
  2589. *
  2590. * Clears all bits in the bitmap and writes the whole bitmap to stable storage.
  2591. */
  2592. int drbd_bmio_clear_n_write(struct drbd_conf *mdev)
  2593. {
  2594. int rv = -EIO;
  2595. drbd_resume_al(mdev);
  2596. if (get_ldev_if_state(mdev, D_ATTACHING)) {
  2597. drbd_bm_clear_all(mdev);
  2598. rv = drbd_bm_write(mdev);
  2599. put_ldev(mdev);
  2600. }
  2601. return rv;
  2602. }
  2603. static int w_bitmap_io(struct drbd_work *w, int unused)
  2604. {
  2605. struct bm_io_work *work = container_of(w, struct bm_io_work, w);
  2606. struct drbd_conf *mdev = w->mdev;
  2607. int rv = -EIO;
  2608. D_ASSERT(atomic_read(&mdev->ap_bio_cnt) == 0);
  2609. if (get_ldev(mdev)) {
  2610. drbd_bm_lock(mdev, work->why, work->flags);
  2611. rv = work->io_fn(mdev);
  2612. drbd_bm_unlock(mdev);
  2613. put_ldev(mdev);
  2614. }
  2615. clear_bit_unlock(BITMAP_IO, &mdev->flags);
  2616. wake_up(&mdev->misc_wait);
  2617. if (work->done)
  2618. work->done(mdev, rv);
  2619. clear_bit(BITMAP_IO_QUEUED, &mdev->flags);
  2620. work->why = NULL;
  2621. work->flags = 0;
  2622. return 0;
  2623. }
  2624. void drbd_ldev_destroy(struct drbd_conf *mdev)
  2625. {
  2626. lc_destroy(mdev->resync);
  2627. mdev->resync = NULL;
  2628. lc_destroy(mdev->act_log);
  2629. mdev->act_log = NULL;
  2630. __no_warn(local,
  2631. drbd_free_bc(mdev->ldev);
  2632. mdev->ldev = NULL;);
  2633. clear_bit(GO_DISKLESS, &mdev->flags);
  2634. }
  2635. static int w_go_diskless(struct drbd_work *w, int unused)
  2636. {
  2637. struct drbd_conf *mdev = w->mdev;
  2638. D_ASSERT(mdev->state.disk == D_FAILED);
  2639. /* we cannot assert local_cnt == 0 here, as get_ldev_if_state will
  2640. * inc/dec it frequently. Once we are D_DISKLESS, no one will touch
  2641. * the protected members anymore, though, so once put_ldev reaches zero
  2642. * again, it will be safe to free them. */
  2643. drbd_force_state(mdev, NS(disk, D_DISKLESS));
  2644. return 0;
  2645. }
  2646. void drbd_go_diskless(struct drbd_conf *mdev)
  2647. {
  2648. D_ASSERT(mdev->state.disk == D_FAILED);
  2649. if (!test_and_set_bit(GO_DISKLESS, &mdev->flags))
  2650. drbd_queue_work(&mdev->tconn->data.work, &mdev->go_diskless);
  2651. }
  2652. /**
  2653. * drbd_queue_bitmap_io() - Queues an IO operation on the whole bitmap
  2654. * @mdev: DRBD device.
  2655. * @io_fn: IO callback to be called when bitmap IO is possible
  2656. * @done: callback to be called after the bitmap IO was performed
  2657. * @why: Descriptive text of the reason for doing the IO
  2658. *
  2659. * While IO on the bitmap happens we freeze application IO thus we ensure
  2660. * that drbd_set_out_of_sync() can not be called. This function MAY ONLY be
  2661. * called from worker context. It MUST NOT be used while a previous such
  2662. * work is still pending!
  2663. */
  2664. void drbd_queue_bitmap_io(struct drbd_conf *mdev,
  2665. int (*io_fn)(struct drbd_conf *),
  2666. void (*done)(struct drbd_conf *, int),
  2667. char *why, enum bm_flag flags)
  2668. {
  2669. D_ASSERT(current == mdev->tconn->worker.task);
  2670. D_ASSERT(!test_bit(BITMAP_IO_QUEUED, &mdev->flags));
  2671. D_ASSERT(!test_bit(BITMAP_IO, &mdev->flags));
  2672. D_ASSERT(list_empty(&mdev->bm_io_work.w.list));
  2673. if (mdev->bm_io_work.why)
  2674. dev_err(DEV, "FIXME going to queue '%s' but '%s' still pending?\n",
  2675. why, mdev->bm_io_work.why);
  2676. mdev->bm_io_work.io_fn = io_fn;
  2677. mdev->bm_io_work.done = done;
  2678. mdev->bm_io_work.why = why;
  2679. mdev->bm_io_work.flags = flags;
  2680. spin_lock_irq(&mdev->tconn->req_lock);
  2681. set_bit(BITMAP_IO, &mdev->flags);
  2682. if (atomic_read(&mdev->ap_bio_cnt) == 0) {
  2683. if (!test_and_set_bit(BITMAP_IO_QUEUED, &mdev->flags))
  2684. drbd_queue_work(&mdev->tconn->data.work, &mdev->bm_io_work.w);
  2685. }
  2686. spin_unlock_irq(&mdev->tconn->req_lock);
  2687. }
  2688. /**
  2689. * drbd_bitmap_io() - Does an IO operation on the whole bitmap
  2690. * @mdev: DRBD device.
  2691. * @io_fn: IO callback to be called when bitmap IO is possible
  2692. * @why: Descriptive text of the reason for doing the IO
  2693. *
  2694. * freezes application IO while that the actual IO operations runs. This
  2695. * functions MAY NOT be called from worker context.
  2696. */
  2697. int drbd_bitmap_io(struct drbd_conf *mdev, int (*io_fn)(struct drbd_conf *),
  2698. char *why, enum bm_flag flags)
  2699. {
  2700. int rv;
  2701. D_ASSERT(current != mdev->tconn->worker.task);
  2702. if ((flags & BM_LOCKED_SET_ALLOWED) == 0)
  2703. drbd_suspend_io(mdev);
  2704. drbd_bm_lock(mdev, why, flags);
  2705. rv = io_fn(mdev);
  2706. drbd_bm_unlock(mdev);
  2707. if ((flags & BM_LOCKED_SET_ALLOWED) == 0)
  2708. drbd_resume_io(mdev);
  2709. return rv;
  2710. }
  2711. void drbd_md_set_flag(struct drbd_conf *mdev, int flag) __must_hold(local)
  2712. {
  2713. if ((mdev->ldev->md.flags & flag) != flag) {
  2714. drbd_md_mark_dirty(mdev);
  2715. mdev->ldev->md.flags |= flag;
  2716. }
  2717. }
  2718. void drbd_md_clear_flag(struct drbd_conf *mdev, int flag) __must_hold(local)
  2719. {
  2720. if ((mdev->ldev->md.flags & flag) != 0) {
  2721. drbd_md_mark_dirty(mdev);
  2722. mdev->ldev->md.flags &= ~flag;
  2723. }
  2724. }
  2725. int drbd_md_test_flag(struct drbd_backing_dev *bdev, int flag)
  2726. {
  2727. return (bdev->md.flags & flag) != 0;
  2728. }
  2729. static void md_sync_timer_fn(unsigned long data)
  2730. {
  2731. struct drbd_conf *mdev = (struct drbd_conf *) data;
  2732. drbd_queue_work_front(&mdev->tconn->data.work, &mdev->md_sync_work);
  2733. }
  2734. static int w_md_sync(struct drbd_work *w, int unused)
  2735. {
  2736. struct drbd_conf *mdev = w->mdev;
  2737. dev_warn(DEV, "md_sync_timer expired! Worker calls drbd_md_sync().\n");
  2738. #ifdef DEBUG
  2739. dev_warn(DEV, "last md_mark_dirty: %s:%u\n",
  2740. mdev->last_md_mark_dirty.func, mdev->last_md_mark_dirty.line);
  2741. #endif
  2742. drbd_md_sync(mdev);
  2743. return 0;
  2744. }
  2745. const char *cmdname(enum drbd_packet cmd)
  2746. {
  2747. /* THINK may need to become several global tables
  2748. * when we want to support more than
  2749. * one PRO_VERSION */
  2750. static const char *cmdnames[] = {
  2751. [P_DATA] = "Data",
  2752. [P_DATA_REPLY] = "DataReply",
  2753. [P_RS_DATA_REPLY] = "RSDataReply",
  2754. [P_BARRIER] = "Barrier",
  2755. [P_BITMAP] = "ReportBitMap",
  2756. [P_BECOME_SYNC_TARGET] = "BecomeSyncTarget",
  2757. [P_BECOME_SYNC_SOURCE] = "BecomeSyncSource",
  2758. [P_UNPLUG_REMOTE] = "UnplugRemote",
  2759. [P_DATA_REQUEST] = "DataRequest",
  2760. [P_RS_DATA_REQUEST] = "RSDataRequest",
  2761. [P_SYNC_PARAM] = "SyncParam",
  2762. [P_SYNC_PARAM89] = "SyncParam89",
  2763. [P_PROTOCOL] = "ReportProtocol",
  2764. [P_UUIDS] = "ReportUUIDs",
  2765. [P_SIZES] = "ReportSizes",
  2766. [P_STATE] = "ReportState",
  2767. [P_SYNC_UUID] = "ReportSyncUUID",
  2768. [P_AUTH_CHALLENGE] = "AuthChallenge",
  2769. [P_AUTH_RESPONSE] = "AuthResponse",
  2770. [P_PING] = "Ping",
  2771. [P_PING_ACK] = "PingAck",
  2772. [P_RECV_ACK] = "RecvAck",
  2773. [P_WRITE_ACK] = "WriteAck",
  2774. [P_RS_WRITE_ACK] = "RSWriteAck",
  2775. [P_DISCARD_WRITE] = "DiscardWrite",
  2776. [P_NEG_ACK] = "NegAck",
  2777. [P_NEG_DREPLY] = "NegDReply",
  2778. [P_NEG_RS_DREPLY] = "NegRSDReply",
  2779. [P_BARRIER_ACK] = "BarrierAck",
  2780. [P_STATE_CHG_REQ] = "StateChgRequest",
  2781. [P_STATE_CHG_REPLY] = "StateChgReply",
  2782. [P_OV_REQUEST] = "OVRequest",
  2783. [P_OV_REPLY] = "OVReply",
  2784. [P_OV_RESULT] = "OVResult",
  2785. [P_CSUM_RS_REQUEST] = "CsumRSRequest",
  2786. [P_RS_IS_IN_SYNC] = "CsumRSIsInSync",
  2787. [P_COMPRESSED_BITMAP] = "CBitmap",
  2788. [P_DELAY_PROBE] = "DelayProbe",
  2789. [P_OUT_OF_SYNC] = "OutOfSync",
  2790. [P_RETRY_WRITE] = "RetryWrite",
  2791. [P_RS_CANCEL] = "RSCancel",
  2792. [P_CONN_ST_CHG_REQ] = "conn_st_chg_req",
  2793. [P_CONN_ST_CHG_REPLY] = "conn_st_chg_reply",
  2794. /* enum drbd_packet, but not commands - obsoleted flags:
  2795. * P_MAY_IGNORE
  2796. * P_MAX_OPT_CMD
  2797. */
  2798. };
  2799. /* too big for the array: 0xfffX */
  2800. if (cmd == P_INITIAL_META)
  2801. return "InitialMeta";
  2802. if (cmd == P_INITIAL_DATA)
  2803. return "InitialData";
  2804. if (cmd == P_CONNECTION_FEATURES)
  2805. return "ConnectionFeatures";
  2806. if (cmd >= ARRAY_SIZE(cmdnames))
  2807. return "Unknown";
  2808. return cmdnames[cmd];
  2809. }
  2810. /**
  2811. * drbd_wait_misc - wait for a request to make progress
  2812. * @mdev: device associated with the request
  2813. * @i: the struct drbd_interval embedded in struct drbd_request or
  2814. * struct drbd_peer_request
  2815. */
  2816. int drbd_wait_misc(struct drbd_conf *mdev, struct drbd_interval *i)
  2817. {
  2818. struct net_conf *nc;
  2819. DEFINE_WAIT(wait);
  2820. long timeout;
  2821. rcu_read_lock();
  2822. nc = rcu_dereference(mdev->tconn->net_conf);
  2823. if (!nc) {
  2824. rcu_read_unlock();
  2825. return -ETIMEDOUT;
  2826. }
  2827. timeout = nc->ko_count ? nc->timeout * HZ / 10 * nc->ko_count : MAX_SCHEDULE_TIMEOUT;
  2828. rcu_read_unlock();
  2829. /* Indicate to wake up mdev->misc_wait on progress. */
  2830. i->waiting = true;
  2831. prepare_to_wait(&mdev->misc_wait, &wait, TASK_INTERRUPTIBLE);
  2832. spin_unlock_irq(&mdev->tconn->req_lock);
  2833. timeout = schedule_timeout(timeout);
  2834. finish_wait(&mdev->misc_wait, &wait);
  2835. spin_lock_irq(&mdev->tconn->req_lock);
  2836. if (!timeout || mdev->state.conn < C_CONNECTED)
  2837. return -ETIMEDOUT;
  2838. if (signal_pending(current))
  2839. return -ERESTARTSYS;
  2840. return 0;
  2841. }
  2842. #ifdef CONFIG_DRBD_FAULT_INJECTION
  2843. /* Fault insertion support including random number generator shamelessly
  2844. * stolen from kernel/rcutorture.c */
  2845. struct fault_random_state {
  2846. unsigned long state;
  2847. unsigned long count;
  2848. };
  2849. #define FAULT_RANDOM_MULT 39916801 /* prime */
  2850. #define FAULT_RANDOM_ADD 479001701 /* prime */
  2851. #define FAULT_RANDOM_REFRESH 10000
  2852. /*
  2853. * Crude but fast random-number generator. Uses a linear congruential
  2854. * generator, with occasional help from get_random_bytes().
  2855. */
  2856. static unsigned long
  2857. _drbd_fault_random(struct fault_random_state *rsp)
  2858. {
  2859. long refresh;
  2860. if (!rsp->count--) {
  2861. get_random_bytes(&refresh, sizeof(refresh));
  2862. rsp->state += refresh;
  2863. rsp->count = FAULT_RANDOM_REFRESH;
  2864. }
  2865. rsp->state = rsp->state * FAULT_RANDOM_MULT + FAULT_RANDOM_ADD;
  2866. return swahw32(rsp->state);
  2867. }
  2868. static char *
  2869. _drbd_fault_str(unsigned int type) {
  2870. static char *_faults[] = {
  2871. [DRBD_FAULT_MD_WR] = "Meta-data write",
  2872. [DRBD_FAULT_MD_RD] = "Meta-data read",
  2873. [DRBD_FAULT_RS_WR] = "Resync write",
  2874. [DRBD_FAULT_RS_RD] = "Resync read",
  2875. [DRBD_FAULT_DT_WR] = "Data write",
  2876. [DRBD_FAULT_DT_RD] = "Data read",
  2877. [DRBD_FAULT_DT_RA] = "Data read ahead",
  2878. [DRBD_FAULT_BM_ALLOC] = "BM allocation",
  2879. [DRBD_FAULT_AL_EE] = "EE allocation",
  2880. [DRBD_FAULT_RECEIVE] = "receive data corruption",
  2881. };
  2882. return (type < DRBD_FAULT_MAX) ? _faults[type] : "**Unknown**";
  2883. }
  2884. unsigned int
  2885. _drbd_insert_fault(struct drbd_conf *mdev, unsigned int type)
  2886. {
  2887. static struct fault_random_state rrs = {0, 0};
  2888. unsigned int ret = (
  2889. (fault_devs == 0 ||
  2890. ((1 << mdev_to_minor(mdev)) & fault_devs) != 0) &&
  2891. (((_drbd_fault_random(&rrs) % 100) + 1) <= fault_rate));
  2892. if (ret) {
  2893. fault_count++;
  2894. if (__ratelimit(&drbd_ratelimit_state))
  2895. dev_warn(DEV, "***Simulating %s failure\n",
  2896. _drbd_fault_str(type));
  2897. }
  2898. return ret;
  2899. }
  2900. #endif
  2901. const char *drbd_buildtag(void)
  2902. {
  2903. /* DRBD built from external sources has here a reference to the
  2904. git hash of the source code. */
  2905. static char buildtag[38] = "\0uilt-in";
  2906. if (buildtag[0] == 0) {
  2907. #ifdef CONFIG_MODULES
  2908. if (THIS_MODULE != NULL)
  2909. sprintf(buildtag, "srcversion: %-24s", THIS_MODULE->srcversion);
  2910. else
  2911. #endif
  2912. buildtag[0] = 'b';
  2913. }
  2914. return buildtag;
  2915. }
  2916. module_init(drbd_init)
  2917. module_exit(drbd_cleanup)
  2918. EXPORT_SYMBOL(drbd_conn_str);
  2919. EXPORT_SYMBOL(drbd_role_str);
  2920. EXPORT_SYMBOL(drbd_disk_str);
  2921. EXPORT_SYMBOL(drbd_set_st_err_str);