EditorsAbout the SiteComes vs. MicrosoftUsing This Web SiteSite ArchivesCredibility IndexOOXMLOpenDocumentPatentsNovellNews DigestSite NewsRSS

06.25.09

Microsoft on “Embrace and Extend”, the “Windows API Franchise”

Posted in FUD, Java, Microsoft, Mono, Open XML, OpenDocument, Oracle, Patents, SUN at 12:39 pm by Dr. Roy Schestowitz

Summary: Old lessons about Microsoft’s intentional sabotage through “embrace and extend”; use of the Windows API with software patents (like Mono’s problem)

T

ODAY’S INTERESTING exhibit arrives after a lot of work on the Wiki. We have hundreds more coming. We will summarise key observations drawn from Exhibit plex_5906 (1997) [PDF], which contains an E-mail from Aaron Contorer to Bill Gates. The full exhibit is available as plain text at the bottom, but here are the bits worth paying attention to, as well as corresponding background.

We start with the realisation — as Microsoft confesses to it — that Windows is at great risk.

Today we face the largest threat Microsoft has faced since the success of Windows For the first time, there is a really credible threat to our position as the leading platform for ISVs to write to.

Fear of Java comes into play:

There are three possible ways to address the threat of the Java platform. One is to do nothing and gradually die as others innovate around us. The second is to join the parade of people who are saying “let’s kill Microsoft and share their market among us” – good for everyone else, but reducing us to the much smaller role of a common software company like Lotus or Borland or even Symantec. Thats a great way to make all our stock options worth zero, even If we would not technically be out of business. The third choice is to make major innovations to our platform so people still prefer to write to us instead of some tepid cross-platform Java layer. This is our only real option.

We have already revealed the gory details about Microsoft’s attack on NetPC (sometimes referred to as “NC”). The Gartner Group helped Microsoft's attack, as always. Here is some more information from Microsoft:

Our competitors are not stupid, so they are pushing the Java platform as the solution for programs that really need to run closer to the user. Sure, its a half-assed solution and isn’t compatible with anything and in fact scarcely exists, but hey, at least it’s not Windows. With Oracle and HTML-generating code on the server and a browser with Java on the client, you have a very crude, complicated, but functional platform for developing line-of-business applications more specifically distributed applications which take advantage of all the interactivity and media-richness that purely centralized mainframe apps never had

Microsoft is then defining “Embrace and Extend”:

In economics there is a well-understood concept called switching costs – how much it costs for a trading partner to change partners. Our philosophy on switching costs is very clear: we want low switching costs for customers who want to start using our platform, and we want to provide so much unique value that there are in effect high costs of deciding to move to a different platform. There is a name for this: it is called Embrace and Extend.

Embrace means we are compatible with what’s out there, so you can switch to our platform without a lot of obstacles and rework. You can switch from someone else’s Java compiler to ours; from someone else’s Web server to ours; etc. Customers love when we do this (as long as we don’t spend our energy embracing extra standards no one really cares about); our competitors are not so sure they like It because they prefer us to screw up.

Extend means we provide tremendous value that nobody else does, so (A) you really want to switch to our software, and (B) once you try our software you would never want to go back to some inferior junk from our competitors. Customers usually like when we do this, since by definition it’s only an extension if it adds value. Competitors hate when we do this, because by adding new value we make our products much harder to clone – this is the difference between innovation and just being a commodity like corn where suppliers compete on price alone. Nobody builds or sustains a business as successful as Microsoft by producing trivial products that are easy to clone – that would be a strategy for failure.

If we fail to embrace, we can lose because there are big barriers to buying our products. But if we Fail to extend, or do only humble work that is easy to clone or to surpass, we automatically lose because our competitors will spend literally billions of dollars to clone our work and replace us.

With that in sight, think about MSODF and how Microsoft broke interoperability in other malicious ways [1, 2, 3, 4, 5, 6, 7].

The “Windows API” is then described as “Embrace and Extend” against NC specifically:

Windows was a very successful embrace-and-extend move. People already had DOS machines and DOS apps, and we were able to go in and say “add this to your machine and it wLll just get better.” Wow! What a deal! It seems to have worked out all right so far. NT is a very similar move; although It’s not trivial to upgrade from Win95 to NT. in general you can use the same computer, same apps. and same APIs as before, plus more.

The really big win in Windows is the API. An app that calls the Windows API is effectively calling upon thousands of person-years of engineering work to help their app get its job done in a very specific way. You could argue !hat the API is too hard to use, that not every library is as fast as it should be, or other serious imperfections, but the fact remains: if you took away Windows, that apphcation would no longer work.

The Windows API is so broad, so deep, and so functional that most ISVs would be crazy not to use it. And it is so deeply embedded in the source code of many Windows apps that there is a huge switching cast to using a different operating system Instead. You can’t just take a Windows app and stick it on some weird Java NC from Oracle, for example, and expect it to work – the guts just are not there. For many customers, the cast of reworking all their apps would be huge.

Watch this:

In short, without this exclusive franchise called the Windows API, we would have been dead a long time ago.

Think about the role of Mono and why it helps Microsoft. Remember that this whole memo is about fighting Sun’s NC and Java, which is cross-platform. Oracle, which now owns/buys Sun, was part of this programme at the time.

Watch how Microsoft intends to use software patents to shield its territory (it is just as though Mono is history repeating itself):

We are doing all of this. We are fixing TCO and further improving our dev tools. We are providing new value such as Viper and great multimedia and unified storage. We are making sure that Windows, not some new platform, is the most attractive place to run apps written in this now programming language. We are building the best virtual machine in the world, and optimizing it to run on Windows. We are even making sure you can run your Windows apps remotely on an NT server if all you have on your desk is a GUI terminal. As if all this work were not already hard to copy, we are also getting a bunch of patents to further protect It against cloning.

On the role of ActiveX and DirectX in merely preventing platforms from becoming a commodity, to use Bill Gates' explanation:

Let me be dear we have no problem with the Java language or with running Java apps really really well on our platform. But we are explicitly not in the business of making it easy for people to write apps that get all the features of Windows on a non-Windows platform. “Pure cross-platform portability” is another way of saying “commoditize the OS.” In this vision, every OS is just an engine for running this layer called Java as fast as possible, and adding any value below the Java layer Is explicitly against the rules.

Sun has already figured this out and has launched its 100% pure Java” marketing program, which literally certifies apps as running the same on any client OS. Programs that call a Windows API or use ActiveX or DirectX, or any platform-specific feature, are by definition not 100% Pure Java, and are therefore evil. Hey, If you were Sun, you would say this too!

As usual, there is a lot to be learned from this. Although it is over a decade old, this was not seen before in the public arena, just in courts for the most part. Microsoft settled to keep it away from the public eye.

“Those who do not learn from history are doomed to repeat it.”

                 – George Santayana


Appendix: Comes vs. Microsoft – exhibit plex_5906, as text


Erik Stevenson (LCA)
From: Aaron Contorer
Sent: Friday, February 21. 1997 12:47 PM
To: Bill Gates
Subject: Memo material

This is 1 page of new material, followed by some closely related material I wrote and sent you on 2/12.

Today we face the largest threat Microsoft has faced since the success of Windows For the first time, there is a really credible threat to our position as the leading platform for ISVs to write to. Windows faces challenges in satisfying end users and IT organizations, but we have a lot of smart work underway to address these problems. By contrast, we are not executing on a strategy that lets us maintain our leadership position as the people who define the platform for ISVs.

Owning this platform is the Microsoft asset. It is the difference between growing to twice our current size in the future, or shrinking to much less than the role we enjoy today.

There are three possible ways to address the threat of the Java platform. One is to do nothing and gradually die as others innovate around us. The second is to join the parade of people who are saying “let’s kill Microsoft and share their market among us” – good for everyone else, but reducing us to the much smaller role of a common software company like Lotus or Borland or even Symantec. Thats a great way to make all our stock options worth zero, even If we would not technically be out of business. The third choice is to make major innovations to our platform so people still prefer to write to us instead of some tepid cross-platform Java layer. This is our only real option.

For over half a year I have been upset that some people at Microsoft are apparently working hard on plan 2 to destroy the value of the Windows API. Of course I agree that we must win against the Java platform, but a belief that we have to just match everyone else’s actions one for one is fundamentally misguided and wrong it makes us a commodity player, one of the pack, instead of the leader.
-
Centralized Computing

Sun, Oracle, and Netscape are all pushing a new model of [almost] centralized computing. They all acknowledge that Microsoft holds tremendous sway over the desktop platform, so they all want to quickly strip as much value and spending as possible off of the desktop and onto the server where they can charge premium prices and push their own platform offerings.

At the same time, they know this is fundamentally wrong. There are good reasons why a big company in the 1990’s uses thousands of small and midsize CPUs instead of one giant Cray supercomputer to do all the work. Centralized machines have poor price/performance when they get too large; they have high latency for ordinary interactive tasks like typing and even worse latency for multimedia (unless you literally spend a fortune on your network); and they fail to take advance of the principle of colocation putting the processor close to the inputs and outputs it needs to work with.

Our competitors are not stupid, so they are pushing the Java platform as the solution for programs that really need to run closer to the user. Sure, its a half-assed solution and isn’t compatible with anything and in fact scarcely exists, but hey, at least it’s not Windows. With Oracle and HTML-generating code on the server and a browser with Java on the client, you have a very crude, complicated, but functional platform for developing line-of-business applications more specifically distributed applications which take advantage of all the interactivity and media-richness that purely centralized mainframe apps never had

Fortunately for us, this solution is an incredible hack. Real applications require work in Oracle and Java HTML and Gci, and except perhaps for DNS, no unifying architecture ties the whole thing together, If you

Plaintiffs Exhibit 5906
Comes V. Microsoft

TXAG 0008204
CONFIDENTIAL

MS-CCPMDL 000000292576
CONFIDENTIAL

want to write an app like Amazon.com or a comparable intranet app, you are on your own. Even a cool tool like Visual InterDev merely serves to paper over this disastrous platform, not to fix It.

This situation leaves open a huge strategic opportunity: to provide a better way to write distributed applications.

We need to make clients and servers more powerful and functional. But more crucially, we need to ensure that our platform – the thousands of person-years of proprietary code that we license to customers – makes it incredibly easy to write real business applicat!ons in at their richness and complexity.

-end of brand-new material-

Switching Costs

In economics there is a well-understood concept called switching costs – how much it costs for a trading partner to change partners. Our philosophy on switching costs is very clear: we want low switching costs for customers who want to start using our platform, and we want to provide so much unique value that there are in effect high costs of deciding to move to a different platform. There is a name for this: it is called Embrace and Extend.

Embrace means we are compatible with what’s out there, so you can switch to our platform without a lot of obstacles and rework. You can switch from someone else’s Java compiler to ours; from someone else’s Web server to ours; etc. Customers love when we do this (as long as we don’t spend our energy embracing extra standards no one really cares about); our competitors are not so sure they like It because they prefer us to screw up.

Extend means we provide tremendous value that nobody else does, so (A) you really want to switch to our software, and (B) once you try our software you would never want to go back to some inferior junk from our competitors. Customers usually like when we do this, since by definition it’s only an extension if it adds value. Competitors hate when we do this, because by adding new value we make our products much harder to clone – this is the difference between innovation and just being a commodity like corn where suppliers compete on price alone. Nobody builds or sustains a business as successful as Microsoft by producing trivial products that are easy to clone – that would be a strategy for failure.

If we fail to embrace, we can lose because there are big barriers to buying our products. But if we Fail to extend, or do only humble work that is easy to clone or to surpass, we automatically lose because our competitors will spend literally billions of dollars to clone our work and replace us.

The Windows API

Windows was a very successful embrace-and-extend move. People already had DOS machines and DOS apps, and we were able to go in and say “add this to your machine and it wLll just get better.” Wow! What a deal! It seems to have worked out all right so far. NT is a very similar move; although It’s not trivial to upgrade from Win95 to NT. in general you can use the same computer, same apps. and same APIs as before, plus more.

The really big win in Windows is the API. An app that calls the Windows API is effectively calling upon thousands of person-years of engineering work to help their app get its job done in a very specific way. You could argue !hat the API is too hard to use, that not every library is as fast as it should be, or other serious imperfections, but the fact remains: if you took away Windows, that apphcation would no longer work.

The Windows API is so broad, so deep, and so functional that most ISVs would be crazy not to use it. And it is so deeply embedded in the source code of many Windows apps that there is a huge switching cast to using a different operating system Instead. You can’t just take a Windows app and stick it on some weird Java NC from Oracle, for example, and expect it to work – the guts just are not there. For many customers, the cast of reworking all their apps would be huge.

TXAG 0008205
CONFIDENTIAL

MS-CCPMDL 000000292577
CONFIDENTIAL

It is this switching cost that has given customers the patience to stick with Windows through all our mistakes, our buggy drivers, our high TCO, our lack of a sexy vision at times, and many other difficulties. People have tried to clone Windows, but it is just too hard to do well. Customers constantly evaluate other desktop platforms, bit it would be so much work to move over that they hope we just improve Windows rather than force them to move.

In short, without this exclusive franchise called the Windows API, we would have been dead a long time ago.

The Java Platform

So along come Scott McNealy and Larry Ellison, saying “hey, we’ve got a good new programming language called Java.” Fine, we like programming languages a lot. After all we are a software development company. The problem is that very quickly they also said, “we’ve got a whole new platform, a whole new set of runtime libraries and APIs, to go with it – so as long as you are writing your apps in a new language, you might as well write to this new platform that we say lacks the flaws of old Windows.’ In other words, they are saying, switching costs will never be lower than they are right now – the barriers are low so join us now.

You would think it would be our top priority at such a time to (A) fix any serious flaws In Windows which could push customers over to the Java platform, (B) add so much new and unique value that this vaporous “Java platform” doesn’t sound very attractive anyway, and (C) make damned sure that our new value is really hard to copy so it doesn’t show up tomorrow in Sun’s or Oracle’s offerings.

We are doing all of this. We are fixing TCO and further improving our dev tools. We are providing new value such as Viper and great multimedia and unified storage. We are making sure that Windows, not some new platform, is the most attractive place to run apps written in this now programming language. We are building the best virtual machine in the world, and optimizing it to run on Windows. We are even making sure you can run your Windows apps remotely on an NT server if all you have on your desk is a GUI terminal. As if all this work were not already hard to copy, we are also getting a bunch of patents to further protect It against cloning.

Following the Java Parade

So It is with some amazement that I listen to a number of people who just don’t get it who think we should do work that actually makes it easier to copy our work and to run apps written for Windows on other platforms. That flies in the face of everything we are trying to do – it’s almost like a suicide attempt. The philosophy here seems to be “our competitors’ products are getting more press than ours, so we should kill ours and build copies of theirs instead.” This is foolish. Since when did we start believing our competitors’ press releases instead of rebutting them?

Let me be dear we have no problem with the Java language or with running Java apps really really well on our platform. But we are explicitly not in the business of making it easy for people to write apps that get all the features of Windows on a non-Windows platform. “Pure cross-platform portability” is another way of saying “commoditize the OS.” In this vision, every OS is just an engine for running this layer called Java as fast as possible, and adding any value below the Java layer Is explicitly against the rules.

Sun has already figured this out and has launched its 100% pure Java” marketing program, which literally certifies apps as running the same on any client OS. Programs that call a Windows API or use ActiveX or DirectX, or any platform-specific feature, are by definition not 100% Pure Java, and are therefore evil. Hey, If you were Sun, you would say this too!

Both Sun and Oracle make their money primarily on servers. (Sun still has some workstation market share, but NT is inevitably eating away at their share and their profit margins on the desktop.) So these companies have every incentive to turn the desktop platform (aka Microsoft’s main business) into a cost-driven commodity and focus all the high-margin business onto servers where they (especially Oracle) have a real fighting chance against us.

This is all the exact opposite of what we want to happen. It is critical to us that application writers choose to take advantage of features that are (A) part of Windows, end (B) extremely hard to clone. Therefore it

TXAG 0008206
CONFIDENTIAL

MS-CCPMDL 000000292578
CONFIDENTIAL

would be a huge mistake if we (A) spent all of our energy just embracing other companies’ innovations, or (B) asked key groups to do extra work that makes it that much easier to replace Windows, such as making Visual Basic apps run on the Java virtual machine.

We have enough people trying to kill us without us helping! It is our goal to make them lose while making ISVs and customers very happy by delivering great benefits.

Making Real Progress

With technologies like DCOM, Viper, and client-side persistent caching, we are just starting down the long road to the distributed world. There is a lot of design work to do, and a lot of intelligence to build into the OS and the network and the tools, And critically, each part has to be managed be the person or program who knows how to make the best decisions. Web site designers should not have to design their whole site around the latest statistics art who has what browser. End users sitting at desktop machines should need to do nothing – no Setup or anything else – to get computation to happen on local machines, just as they do nothing to enable the server apps or Web sites they connect to today. Business system designers should not all have to be experts on variable-speed wide-area networking. Library administrators should not care if a student brings in an app from home and wants to run it on a public kiosk machine for a while. Users with laptop machines should not have to know or care how the right things from the server magically get replicated to their local disk before they leave for a trip. An engineer who needs a big calculation done should not have to care which machine has spare CPU space, and an artist who needs to save 800MB of images should not have to manually hunt around for disk space. The list of “shoulds” goes on and on.

None of this is provided today by the Java platform, but one by one each of these features in being worked on by many people at MS and at our competitors, and each will get property implemented by someone. We have an opportunity to make many of these advances part of the Windows platform we get paid for, or part of the Java platform that is given away for free. As a shareholder, which do you want?

12

TXAG 0008207
CONFIDENTIAL

MS—CCPMDL 000000292579
CONFIDENTIAL

Credit: wallclimber

Share this post: These icons link to social bookmarking sites where readers can share and discover new web pages.
  • Digg
  • del.icio.us
  • Reddit
  • co.mments
  • DZone
  • email
  • Google Bookmarks
  • LinkedIn
  • NewsVine
  • Print
  • Technorati
  • TwitThis
  • Facebook

If you liked this post, consider subscribing to the RSS feed or join us now at the IRC channels.

Pages that cross-reference this one

A Single Comment

  1. Jose_X said,

    June 25, 2009 at 9:15 pm

    Gravatar

    >> Of course I agree that we must win against the Java platform, but a belief that we have to just match everyone else’s actions one for one is fundamentally misguided and wrong it makes us a commodity player, one of the pack, instead of the leader.

    >> and (C) make damned sure that our new value is really hard to copy so it doesn’t show up tomorrow in Sun’s or Oracle’s offerings.

    >> So It is with some amazement that I listen to a number of people who just don’t get it who think we should do work that actually makes it easier to copy our work and to run apps written for Windows on other platforms. That flies in the face of everything we are trying to do – it’s almost like a suicide attempt. The philosophy here seems to be “our competitors’ products are getting more press than ours, so we should kill ours and build copies of theirs instead.” This is foolish.

    >> But we are explicitly not in the business of making it easy for people to write apps that get all the features of Windows on a non-Windows platform

    >> This is all the exact opposite of what we want to happen. It is critical to us that application writers choose to take advantage of features that are (A) part of Windows, end (B) extremely hard to clone. Therefore it …would be a huge mistake if we (A) spent all of our energy just embracing other companies’ innovations, or (B) asked key groups to do extra work that makes it that much easier to replace Windows, such as making Visual Basic apps run on the Java virtual machine.

    [Ignoring the patent issue..] Maybe the mono effort still has hope, but it would need to change priorities to focus on moving value unique to Windows onto Linux rather than making (subpar) value added to Linux be easy to be moved to Windows or winFOSS apps be easy and likely to be moved onto the more capable closed MSdotnet.

    Dotnet can’t be a better Java than Java (from the FOSS-friendly pov) because Sun “owned” and protected Java from Microsoft’s embrace/extend. MSdotnet/mono already comes with the extensions onto “Java” that Microsoft was not legally able to get away with adding to the real Java [Sun, Novell, Oracle.. no one can help us here from Microsoft]. Further, there are many patent advantages in Microsoft’s favor in the fake Java case. Further, Microsoft designed dotnet carefully to meet their needs and has a lot invested in that platform, more so than ever could have been the case for Java; dotnet was designed for extension and for every other need Microsoft would have.

    See also http://www.linuxtoday.com/news_story.php3?ltsn=2009-06-25-009-39-NW-MS-EV&tbovrmode=3#talkback_area

What Else is New


  1. Links 15/4/2014: Lots of PCLinuxOS Releases, Ukraine Updates

    Links for the day



  2. Apple and Microsoft Actively Lobbying Against Patent Reform in the US

    Apple and Microsoft are reportedly intervening/interfering with US law in order to ensure that the law is Free/libre software-hostile



  3. Lawsuit by Microsoft Shareholder Targets Fine for Crimes Rather Than the Crimes Themselves

    A new lawsuit by a Microsoft shareholder shows everything that's wrong with today's model of accountability, where those who are responsible for crimes are accused of not avoiding fines rather than committing the crimes



  4. Public Institutions Must Dump PRISM-Associated Software

    Another reminder that taxpayers-subsidised services should refuse, as a matter of principle, to pay anything for -- let alone deploy -- proprietary software with back doors



  5. GNU/Linux News: The Opportunities Amid XP EOL

    Links for the day



  6. Microsoft Gets Its Money's Worth From Xamarin: PlayStation 4 Now Polluted by Microsoft

    The Trojan horse of Microsoft, Xamarin, is pushing .NET into Microsoft's console competitor



  7. After Brendan Eich Comes Chris Beard

    Having removed Brendan Eich using bullying and blackmail tactics, his foes inside Mozilla achieved too little as we have yet another man (coming from inside Mozilla) acting as CEO



  8. Healthcare News: Free Software in Health, Humanitarian Causes

    Links for the day



  9. Links 14/4/2014: MakuluLinux, Many Games, More Privacy News and Pulitzer Prize for NSA Revelations

    Links for the day



  10. TechBytes Episode 87: Catching up With Surveillance (NSA, GCHQ et al.)

    The first audio episode in a very long time covers some of the latest happenings when it comes to privacy and, contrariwise, mass surveillance



  11. Server News: KVM, ElasticHosts, Other GNU/Linux Items, and Open Network Linux

    Links for the day



  12. Hardware News: Freedom, Modding, Hackability on the Rise

    Links for the day



  13. Distributions News: GNU/Linux Distros

    Links for the day



  14. GNOME News: Financial Issues, Mutter-Wayland, West Coast Summit, Community Participation

    Links for the day



  15. KDE News: Kubuntu at the Centre Again KDE Applications Updated

    Links for the day



  16. Techrights Rising

    Effective immediately, Techrights will do what it takes to bring back old volume and pace of publishing



  17. Links: Surveillance, Intervention, Torture and Drones

    Links for the day



  18. Mobile Linux Not Just Android: Jolla, WebOS, and Firefox OS News

    Links for the day



  19. Google's Linux Revolution: New Gains for Android, Chrome OS (GNU/Linux)

    Links for the day



  20. Free/Libre Databases News: MongoDB, NoSQL, and MySQL Branches/Forks

    Links for the day



  21. Open Access on the Rise: Textbooks, Journals, Etc.

    Links for the day



  22. Finance Watch (Watching What's Not Being Watched): Economic Warfare/Class Injustice

    Links for the day



  23. Climate and Ecology Watch: News About a World Being Destroyed

    Links for the day



  24. Copyright News: DRM, Censorship, Megaupload, Hypocrisy, and Impact on the Internet

    Links for the day



  25. Sharing Works: Latest News Stories About Crowd-sourcing, Sharing, Transparency

    Links for the day



  26. Links 12/4/2014: Games

    Links for the day



  27. Links 12/4/2014: Applications

    Links for the day



  28. Links 12/4/2014: Instructionals

    Links for the day



  29. Political News: Protests Face a Ban, Covert Actions Continue, Cold War Era Imperialism, Privacy, and War on Justice

    Links for the day



  30. Ubuntu News: Themes, Unity 8, Meizu Phone, Ubuntu Touch, and Elementary OS

    Links for the day


CoPilotCo

RSS 64x64RSS Feed: subscribe to the RSS feed for regular updates

Home iconSite Wiki: You can improve this site by helping the extension of the site's content

Home iconSite Home: Background about the site and some key features in the front page

Chat iconIRC Channel: Come and chat with us in real time

CoPilotCo

Recent Posts