ManagementStyle 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288
  1. .. _managementstyle:
  2. Linux kernel management style
  3. =============================
  4. This is a short document describing the preferred (or made up, depending
  5. on who you ask) management style for the linux kernel. It's meant to
  6. mirror the CodingStyle document to some degree, and mainly written to
  7. avoid answering [#f1]_ the same (or similar) questions over and over again.
  8. Management style is very personal and much harder to quantify than
  9. simple coding style rules, so this document may or may not have anything
  10. to do with reality. It started as a lark, but that doesn't mean that it
  11. might not actually be true. You'll have to decide for yourself.
  12. Btw, when talking about "kernel manager", it's all about the technical
  13. lead persons, not the people who do traditional management inside
  14. companies. If you sign purchase orders or you have any clue about the
  15. budget of your group, you're almost certainly not a kernel manager.
  16. These suggestions may or may not apply to you.
  17. First off, I'd suggest buying "Seven Habits of Highly Effective
  18. People", and NOT read it. Burn it, it's a great symbolic gesture.
  19. .. [#f1] This document does so not so much by answering the question, but by
  20. making it painfully obvious to the questioner that we don't have a clue
  21. to what the answer is.
  22. Anyway, here goes:
  23. .. _decisions:
  24. 1) Decisions
  25. ------------
  26. Everybody thinks managers make decisions, and that decision-making is
  27. important. The bigger and more painful the decision, the bigger the
  28. manager must be to make it. That's very deep and obvious, but it's not
  29. actually true.
  30. The name of the game is to **avoid** having to make a decision. In
  31. particular, if somebody tells you "choose (a) or (b), we really need you
  32. to decide on this", you're in trouble as a manager. The people you
  33. manage had better know the details better than you, so if they come to
  34. you for a technical decision, you're screwed. You're clearly not
  35. competent to make that decision for them.
  36. (Corollary:if the people you manage don't know the details better than
  37. you, you're also screwed, although for a totally different reason.
  38. Namely that you are in the wrong job, and that **they** should be managing
  39. your brilliance instead).
  40. So the name of the game is to **avoid** decisions, at least the big and
  41. painful ones. Making small and non-consequential decisions is fine, and
  42. makes you look like you know what you're doing, so what a kernel manager
  43. needs to do is to turn the big and painful ones into small things where
  44. nobody really cares.
  45. It helps to realize that the key difference between a big decision and a
  46. small one is whether you can fix your decision afterwards. Any decision
  47. can be made small by just always making sure that if you were wrong (and
  48. you **will** be wrong), you can always undo the damage later by
  49. backtracking. Suddenly, you get to be doubly managerial for making
  50. **two** inconsequential decisions - the wrong one **and** the right one.
  51. And people will even see that as true leadership (*cough* bullshit
  52. *cough*).
  53. Thus the key to avoiding big decisions becomes to just avoiding to do
  54. things that can't be undone. Don't get ushered into a corner from which
  55. you cannot escape. A cornered rat may be dangerous - a cornered manager
  56. is just pitiful.
  57. It turns out that since nobody would be stupid enough to ever really let
  58. a kernel manager have huge fiscal responsibility **anyway**, it's usually
  59. fairly easy to backtrack. Since you're not going to be able to waste
  60. huge amounts of money that you might not be able to repay, the only
  61. thing you can backtrack on is a technical decision, and there
  62. back-tracking is very easy: just tell everybody that you were an
  63. incompetent nincompoop, say you're sorry, and undo all the worthless
  64. work you had people work on for the last year. Suddenly the decision
  65. you made a year ago wasn't a big decision after all, since it could be
  66. easily undone.
  67. It turns out that some people have trouble with this approach, for two
  68. reasons:
  69. - admitting you were an idiot is harder than it looks. We all like to
  70. maintain appearances, and coming out in public to say that you were
  71. wrong is sometimes very hard indeed.
  72. - having somebody tell you that what you worked on for the last year
  73. wasn't worthwhile after all can be hard on the poor lowly engineers
  74. too, and while the actual **work** was easy enough to undo by just
  75. deleting it, you may have irrevocably lost the trust of that
  76. engineer. And remember: "irrevocable" was what we tried to avoid in
  77. the first place, and your decision ended up being a big one after
  78. all.
  79. Happily, both of these reasons can be mitigated effectively by just
  80. admitting up-front that you don't have a friggin' clue, and telling
  81. people ahead of the fact that your decision is purely preliminary, and
  82. might be the wrong thing. You should always reserve the right to change
  83. your mind, and make people very **aware** of that. And it's much easier
  84. to admit that you are stupid when you haven't **yet** done the really
  85. stupid thing.
  86. Then, when it really does turn out to be stupid, people just roll their
  87. eyes and say "Oops, he did it again".
  88. This preemptive admission of incompetence might also make the people who
  89. actually do the work also think twice about whether it's worth doing or
  90. not. After all, if **they** aren't certain whether it's a good idea, you
  91. sure as hell shouldn't encourage them by promising them that what they
  92. work on will be included. Make them at least think twice before they
  93. embark on a big endeavor.
  94. Remember: they'd better know more about the details than you do, and
  95. they usually already think they have the answer to everything. The best
  96. thing you can do as a manager is not to instill confidence, but rather a
  97. healthy dose of critical thinking on what they do.
  98. Btw, another way to avoid a decision is to plaintively just whine "can't
  99. we just do both?" and look pitiful. Trust me, it works. If it's not
  100. clear which approach is better, they'll eventually figure it out. The
  101. answer may end up being that both teams get so frustrated by the
  102. situation that they just give up.
  103. That may sound like a failure, but it's usually a sign that there was
  104. something wrong with both projects, and the reason the people involved
  105. couldn't decide was that they were both wrong. You end up coming up
  106. smelling like roses, and you avoided yet another decision that you could
  107. have screwed up on.
  108. 2) People
  109. ---------
  110. Most people are idiots, and being a manager means you'll have to deal
  111. with it, and perhaps more importantly, that **they** have to deal with
  112. **you**.
  113. It turns out that while it's easy to undo technical mistakes, it's not
  114. as easy to undo personality disorders. You just have to live with
  115. theirs - and yours.
  116. However, in order to prepare yourself as a kernel manager, it's best to
  117. remember not to burn any bridges, bomb any innocent villagers, or
  118. alienate too many kernel developers. It turns out that alienating people
  119. is fairly easy, and un-alienating them is hard. Thus "alienating"
  120. immediately falls under the heading of "not reversible", and becomes a
  121. no-no according to :ref:`decisions`.
  122. There's just a few simple rules here:
  123. (1) don't call people d*ckheads (at least not in public)
  124. (2) learn how to apologize when you forgot rule (1)
  125. The problem with #1 is that it's very easy to do, since you can say
  126. "you're a d*ckhead" in millions of different ways [#f2]_, sometimes without
  127. even realizing it, and almost always with a white-hot conviction that
  128. you are right.
  129. And the more convinced you are that you are right (and let's face it,
  130. you can call just about **anybody** a d*ckhead, and you often **will** be
  131. right), the harder it ends up being to apologize afterwards.
  132. To solve this problem, you really only have two options:
  133. - get really good at apologies
  134. - spread the "love" out so evenly that nobody really ends up feeling
  135. like they get unfairly targeted. Make it inventive enough, and they
  136. might even be amused.
  137. The option of being unfailingly polite really doesn't exist. Nobody will
  138. trust somebody who is so clearly hiding his true character.
  139. .. [#f2] Paul Simon sang "Fifty Ways to Leave Your Lover", because quite
  140. frankly, "A Million Ways to Tell a Developer He Is a D*ckhead" doesn't
  141. scan nearly as well. But I'm sure he thought about it.
  142. 3) People II - the Good Kind
  143. ----------------------------
  144. While it turns out that most people are idiots, the corollary to that is
  145. sadly that you are one too, and that while we can all bask in the secure
  146. knowledge that we're better than the average person (let's face it,
  147. nobody ever believes that they're average or below-average), we should
  148. also admit that we're not the sharpest knife around, and there will be
  149. other people that are less of an idiot than you are.
  150. Some people react badly to smart people. Others take advantage of them.
  151. Make sure that you, as a kernel maintainer, are in the second group.
  152. Suck up to them, because they are the people who will make your job
  153. easier. In particular, they'll be able to make your decisions for you,
  154. which is what the game is all about.
  155. So when you find somebody smarter than you are, just coast along. Your
  156. management responsibilities largely become ones of saying "Sounds like a
  157. good idea - go wild", or "That sounds good, but what about xxx?". The
  158. second version in particular is a great way to either learn something
  159. new about "xxx" or seem **extra** managerial by pointing out something the
  160. smarter person hadn't thought about. In either case, you win.
  161. One thing to look out for is to realize that greatness in one area does
  162. not necessarily translate to other areas. So you might prod people in
  163. specific directions, but let's face it, they might be good at what they
  164. do, and suck at everything else. The good news is that people tend to
  165. naturally gravitate back to what they are good at, so it's not like you
  166. are doing something irreversible when you **do** prod them in some
  167. direction, just don't push too hard.
  168. 4) Placing blame
  169. ----------------
  170. Things will go wrong, and people want somebody to blame. Tag, you're it.
  171. It's not actually that hard to accept the blame, especially if people
  172. kind of realize that it wasn't **all** your fault. Which brings us to the
  173. best way of taking the blame: do it for another guy. You'll feel good
  174. for taking the fall, he'll feel good about not getting blamed, and the
  175. guy who lost his whole 36GB porn-collection because of your incompetence
  176. will grudgingly admit that you at least didn't try to weasel out of it.
  177. Then make the developer who really screwed up (if you can find him) know
  178. **in_private** that he screwed up. Not just so he can avoid it in the
  179. future, but so that he knows he owes you one. And, perhaps even more
  180. importantly, he's also likely the person who can fix it. Because, let's
  181. face it, it sure ain't you.
  182. Taking the blame is also why you get to be manager in the first place.
  183. It's part of what makes people trust you, and allow you the potential
  184. glory, because you're the one who gets to say "I screwed up". And if
  185. you've followed the previous rules, you'll be pretty good at saying that
  186. by now.
  187. 5) Things to avoid
  188. ------------------
  189. There's one thing people hate even more than being called "d*ckhead",
  190. and that is being called a "d*ckhead" in a sanctimonious voice. The
  191. first you can apologize for, the second one you won't really get the
  192. chance. They likely will no longer be listening even if you otherwise
  193. do a good job.
  194. We all think we're better than anybody else, which means that when
  195. somebody else puts on airs, it **really** rubs us the wrong way. You may
  196. be morally and intellectually superior to everybody around you, but
  197. don't try to make it too obvious unless you really **intend** to irritate
  198. somebody [#f3]_.
  199. Similarly, don't be too polite or subtle about things. Politeness easily
  200. ends up going overboard and hiding the problem, and as they say, "On the
  201. internet, nobody can hear you being subtle". Use a big blunt object to
  202. hammer the point in, because you can't really depend on people getting
  203. your point otherwise.
  204. Some humor can help pad both the bluntness and the moralizing. Going
  205. overboard to the point of being ridiculous can drive a point home
  206. without making it painful to the recipient, who just thinks you're being
  207. silly. It can thus help get through the personal mental block we all
  208. have about criticism.
  209. .. [#f3] Hint: internet newsgroups that are not directly related to your work
  210. are great ways to take out your frustrations at other people. Write
  211. insulting posts with a sneer just to get into a good flame every once in
  212. a while, and you'll feel cleansed. Just don't crap too close to home.
  213. 6) Why me?
  214. ----------
  215. Since your main responsibility seems to be to take the blame for other
  216. peoples mistakes, and make it painfully obvious to everybody else that
  217. you're incompetent, the obvious question becomes one of why do it in the
  218. first place?
  219. First off, while you may or may not get screaming teenage girls (or
  220. boys, let's not be judgmental or sexist here) knocking on your dressing
  221. room door, you **will** get an immense feeling of personal accomplishment
  222. for being "in charge". Never mind the fact that you're really leading
  223. by trying to keep up with everybody else and running after them as fast
  224. as you can. Everybody will still think you're the person in charge.
  225. It's a great job if you can hack it.