{"id":28933,"date":"2006-11-22T10:00:50","date_gmt":"2006-11-22T10:00:50","guid":{"rendered":"https:\/\/blogs.msdn.microsoft.com\/oldnewthing\/2006\/11\/22\/the-quiet-dream-of-placebo-settings\/"},"modified":"2006-11-22T10:00:50","modified_gmt":"2006-11-22T10:00:50","slug":"the-quiet-dream-of-placebo-settings","status":"publish","type":"post","link":"https:\/\/devblogs.microsoft.com\/oldnewthing\/20061122-50\/?p=28933","title":{"rendered":"The quiet dream of placebo settings"},"content":{"rendered":"<p>Back in the Windows&nbsp;95 days, people swore that increasing the value of <code>MaxBPs<\/code> in the <code>system.ini<\/code> file fixed application errors. People usually made up some pseudo-scientific explanation for why this fixed crashes. These explanations were complete rot.\n These breakpoints had nothing to do with Windows applications. They were used by 32-bit device drivers to communicate with code in MS-DOS boxes, typically the 16-bit driver they are trying to take over from or are otherwise coordinating their activities with. A bunch of these are allocated at system startup when drivers settle themselves in, and on occasion, a driver might patch a breakpoint temporarily into DOS memory, removing it when the breakpoint is hit (or when the breakpoint is no longer needed). Increasing this value had no effect on Windows application.\n I fantasized about adding a &#8220;Performance&#8221; page to Tweak&nbsp;UI with an option to increase the number of &#8220;<a href=\"http:\/\/skepdic.com\/placebo.html\">PlaceBOs<\/a>&#8220;. I would make up some nonsense text about this setting controlling how high in memory the system should place its &#8220;breakpoint opcodes&#8221;. Placing them higher will free up memory for other purposes and reduce the frequency of &#8220;Out of memory&#8221; errors. Or something like that.\n I was reminded of this story by my pals in products support who were trying to come up with a polite way of explaining to their customer that <a href=\"http:\/\/blogs.msdn.com\/oldnewthing\/archive\/2004\/08\/17\/215682.aspx\"> there is no \/7GB <code>boot.ini<\/code> switch<\/a>. In other situations, they sometimes dream of shipping <code>placebo.dll<\/code> to a customer to solve their problem.<\/p>\n<p> (And by the way, the technical reason why the user-mode address space is limited to eight terabytes <a href=\"http:\/\/blogs.msdn.com\/oldnewthing\/archive\/2004\/08\/17\/215682.aspx#217600\"> was given by commenter darwou<\/a>: The absence of a 16-byte atomic compare-and-exchange instruction means that bits need to be sacrificed to encode the sequence number which avoids the ABA problem.) <\/p>\n","protected":false},"excerpt":{"rendered":"<p>Back in the Windows&nbsp;95 days, people swore that increasing the value of MaxBPs in the system.ini file fixed application errors. People usually made up some pseudo-scientific explanation for why this fixed crashes. These explanations were complete rot. These breakpoints had nothing to do with Windows applications. They were used by 32-bit device drivers to communicate [&hellip;]<\/p>\n","protected":false},"author":1069,"featured_media":111744,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[1],"tags":[2],"class_list":["post-28933","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-oldnewthing","tag-history"],"acf":[],"blog_post_summary":"<p>Back in the Windows&nbsp;95 days, people swore that increasing the value of MaxBPs in the system.ini file fixed application errors. People usually made up some pseudo-scientific explanation for why this fixed crashes. These explanations were complete rot. These breakpoints had nothing to do with Windows applications. They were used by 32-bit device drivers to communicate [&hellip;]<\/p>\n","_links":{"self":[{"href":"https:\/\/devblogs.microsoft.com\/oldnewthing\/wp-json\/wp\/v2\/posts\/28933","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/devblogs.microsoft.com\/oldnewthing\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/devblogs.microsoft.com\/oldnewthing\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/devblogs.microsoft.com\/oldnewthing\/wp-json\/wp\/v2\/users\/1069"}],"replies":[{"embeddable":true,"href":"https:\/\/devblogs.microsoft.com\/oldnewthing\/wp-json\/wp\/v2\/comments?post=28933"}],"version-history":[{"count":0,"href":"https:\/\/devblogs.microsoft.com\/oldnewthing\/wp-json\/wp\/v2\/posts\/28933\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/devblogs.microsoft.com\/oldnewthing\/wp-json\/wp\/v2\/media\/111744"}],"wp:attachment":[{"href":"https:\/\/devblogs.microsoft.com\/oldnewthing\/wp-json\/wp\/v2\/media?parent=28933"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/devblogs.microsoft.com\/oldnewthing\/wp-json\/wp\/v2\/categories?post=28933"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/devblogs.microsoft.com\/oldnewthing\/wp-json\/wp\/v2\/tags?post=28933"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}