)]}'
{
  "log": [
    {
      "commit": "be71aa29a3c86d2e01cd17839d2a72ab09a1bce5",
      "tree": "ca29cd10f78ff053761eb809c391019180836742",
      "parents": [
        "f62a067a5b21c840c915d36392679346ac0abfd7"
      ],
      "author": {
        "name": "Svet Ganov",
        "email": "svetoslavganov@google.com",
        "time": "Tue Apr 28 12:06:02 2015 -0700"
      },
      "committer": {
        "name": "Svetoslav Ganov",
        "email": "svetoslavganov@google.com",
        "time": "Wed Apr 29 19:06:41 2015 +0000"
      },
      "message": "Respect the record audio app op - media\n\nChange-Id: I3a97977b6e9a09355e2008f780d22d480fb7308b\n"
    },
    {
      "commit": "980b106908cb8e105bb8849749722c5088e2f6eb",
      "tree": "0e5e837bd3f127e7af4caffc0e2ec83444466a83",
      "parents": [
        "5c2be9eddba74a503c55808816aa37cc8ce18c50",
        "9391844deb3f6a442745cea62f78aca2cea19e50"
      ],
      "author": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Tue Jan 27 15:38:17 2015 -0800"
      },
      "committer": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Tue Jan 27 15:38:17 2015 -0800"
      },
      "message": "resolved conflicts for merge of 9391844d to master\n\nChange-Id: I348a71d1b3e3238bc3871a69454edc8247d03111\n"
    },
    {
      "commit": "b7848f1c442bc8c71020957948d1b003a62a25b7",
      "tree": "b0a1dfd418429171c0af5379a1820569775a840b",
      "parents": [
        "1ed13b3b443735e7f7b5002954f31741b0b1c572"
      ],
      "author": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Thu Dec 04 08:57:56 2014 -0800"
      },
      "committer": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Mon Jan 26 07:57:39 2015 -0800"
      },
      "message": "Remove MediaPlayerService::decode()\n\nand make SoundPool use MediaCodec for decoding files to PCM.\n\nBug: 18239054\nChange-Id: Ia144fc1bbb0d2787638ee972e2224339b4965310\n"
    },
    {
      "commit": "b187de1ada34a9023c05d020a4592686ba761278",
      "tree": "31dea84d078f6198ce17ca856fcbb76c402f37b6",
      "parents": [
        "64cbdee08a18b25448a5fb0b058d3b83d5630d7f"
      ],
      "author": {
        "name": "Glenn Kasten",
        "email": "gkasten@google.com",
        "time": "Tue Dec 30 08:18:15 2014 -0800"
      },
      "committer": {
        "name": "Glenn Kasten",
        "email": "gkasten@google.com",
        "time": "Tue Dec 30 08:18:15 2014 -0800"
      },
      "message": "Line length 100\n\nChange-Id: I6c8fe626a3825fa9e139319656d682a57b887c97\n"
    },
    {
      "commit": "1381d4b5c0385aec3741073e5998773b064c1fb0",
      "tree": "6087b737255d34703a90d1952d48bb97646e492a",
      "parents": [
        "60b1c0e79d12a1c70758bc8d060156924635f8ba"
      ],
      "author": {
        "name": "Lajos Molnar",
        "email": "lajos@google.com",
        "time": "Thu Aug 07 15:18:35 2014 -0700"
      },
      "committer": {
        "name": "Lajos Molnar",
        "email": "lajos@google.com",
        "time": "Thu Aug 07 17:40:13 2014 -0700"
      },
      "message": "media/playerservice: add getCodecList() to MediaPlayerService\n\nBug: 11990470\nChange-Id: I8fa45946fd9b76f9b975fc59062819c57e6881ef\n"
    },
    {
      "commit": "81e68448f3361eaf8618930471fdc3c21bdf5cbc",
      "tree": "afc00a9a35746f18f85200755870067b4d63dd80",
      "parents": [
        "412d4744efae64083e4f99a664e3efaba031af48"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Feb 05 11:52:33 2014 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Feb 05 12:27:54 2014 -0800"
      },
      "message": "Remove no longer needed http proxy handling code, it\u0027s obsolete now\n\nsince we started to use java\u0027s HTTPConnection instead of the native\nimplementation. Also remove other remnants of the previous http implementation,\nsuch as accounting for the http user\u0027s uid.\n\nChange-Id: I60bfd31381ea40d2220db587ec5c433093b60034\n"
    },
    {
      "commit": "1b86fe063badb5f28c467ade39be0f4008688947",
      "tree": "d88660112d407540184ad8e1292ed8aa98fae317",
      "parents": [
        "5ce88270eb2d41462de8c4155673b802b2ca48cb"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Jan 29 11:13:26 2014 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Feb 04 15:11:53 2014 -0800"
      },
      "message": "FINAL ATTEMPT: HTTP services are now provided from JAVA and made available to media code\n\nChange-Id: I9f74a86e70422187c9cf0ca1318a29019700192d\n"
    },
    {
      "commit": "3d00aa6de95fb46e36f2bab4e3facdf0b96acf06",
      "tree": "1ad12df4c11ca37280cbe6850eed9bff1e0a2f35",
      "parents": [
        "402dfba6dcd68f5fd8d8921f9751f3e47eb1449d"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Tue Sep 24 09:53:27 2013 -0700"
      },
      "committer": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Tue Sep 24 11:59:59 2013 -0700"
      },
      "message": "soundpool: allocate shared memory heap by client\n\nCurrent SoundPool implementation allocates the shared memory heap\ncontaining decoded PCM samples in mediaserver process.\nWhen mediaserver process crashes, the shared memory heaps allocated by\nAudioCache cannot be mapped anymore in the new instance of mediaserver.\nThis causes a silent failure to end playback of new sounds because\nAudioFlinger believes the new AudioTracks are opened in streaming mode\nand not static mode: it sees a NULL shared memory pointer when the track\nis created.\n\nThe fix consists in allocating the memory heap in the client process. Thus\nthe heap is not lost when mediaserver restarts. The global memory usage is\nthe same as this is shared memory.\n\nAlso added a way to detect that a shared memory is passed when the track is\ncreated but cannot be mapped on mediaserver side.\n\nAlso fix a crash in SoundPool when ALOGV is enabled.\n\nBug: 10894793.\nChange-Id: Ice6c66ec3b2a409d75dc903a508b6c6fbfb2e8a7\n"
    },
    {
      "commit": "b7319a7eb0a06ef4fd3a0c9157ee63e637ad7aa1",
      "tree": "6dc90cde609f708f45ae08af2bdc5f9cd2df4bb3",
      "parents": [
        "41688da226e91c97ea3b2fe096044e1e5b0520bc"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed May 29 14:20:52 2013 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri May 31 15:31:56 2013 -0700"
      },
      "message": "Update HTTP proxy configuration for all media playback inside stagefright.\n\nChange-Id: Ie0dd00045aba668d8b49da73224e7a7c9c04f69b\nrelated-to-bug: 8873723\n(cherry picked from commit 2704965b8a1ff3b7450ff58ccecf86d8ec688c40)\n"
    },
    {
      "commit": "cc82dc6d500023eba6048616301a4b12682458db",
      "tree": "1f36f887af92cb4bee147e962b85ce10f35d587a",
      "parents": [
        "c93484ab9fdf044fd32f2388a3ce29040d2ba319"
      ],
      "author": {
        "name": "Jeff Tinker",
        "email": "jtinker@google.com",
        "time": "Fri Feb 08 10:18:35 2013 -0800"
      },
      "committer": {
        "name": "Jeff Tinker",
        "email": "jtinker@google.com",
        "time": "Wed Mar 13 13:39:48 2013 -0700"
      },
      "message": "Implementing MediaDrm APIs\n\nChange-Id: I9ff8eeb7d0c383b5c0c68cd54eb54ce7d2d22fe6\n"
    },
    {
      "commit": "279dcd89ab1d2de91dfe95e461412a0f577a6891",
      "tree": "fa0ae875d3404f6fae47823e4c3b2d09207dae9b",
      "parents": [
        "150a516ce434bd1df81e3c3070915e3f549bca59"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Jan 30 10:41:25 2013 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Jan 30 10:41:25 2013 -0800"
      },
      "message": "Plumbing to reflect minor changes in the HDCP module API that allow for\n\nsupport of _decryption_ modules in addition to what we already supported.\n\nChange-Id: Ic37b87dc170ba8def3817991d25df798f21e950b\n"
    },
    {
      "commit": "f37971f624164c3ed185d3f976404a6f60f49b9a",
      "tree": "e3455056e9e0512786cfdd832e1fd8bba765bc7c",
      "parents": [
        "34d7db5dd43000cac7e8e156d79e9f97ccbb8990"
      ],
      "author": {
        "name": "Glenn Kasten",
        "email": "gkasten@google.com",
        "time": "Fri Feb 03 11:06:53 2012 -0800"
      },
      "committer": {
        "name": "Glenn Kasten",
        "email": "gkasten@google.com",
        "time": "Tue Dec 18 16:16:30 2012 -0800"
      },
      "message": "Remove unnecessary parameter\n\nJust get the parameter on server side\n\nChange-Id: I433a63104dbb257e0d862be2ab61847cb36d1c15\n"
    },
    {
      "commit": "45d76bb6c8f15335f89c287dbae04cc38f79d0a8",
      "tree": "baeb6a730e64585729fec469290541b38da1199c",
      "parents": [
        "8fdd88b073275812ccd2279e3f657a4b5960bfa3"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Sep 20 16:00:17 2012 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Sep 21 09:24:08 2012 -0700"
      },
      "message": "Remove legacy code and APIs in wifi display related code.\n\nChange-Id: Ia010e7a00534f9356b3247369d0ffd65591d91aa\n"
    },
    {
      "commit": "59451f8ced48874427ff1550391c4f3cd2ba2e35",
      "tree": "157c7a66a42dee041738de4cd88c9b185ad686bd",
      "parents": [
        "d5a9ae029b50678de3b468d8324728a73ff5b0aa"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Sep 18 10:36:32 2012 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Sep 19 09:28:08 2012 -0700"
      },
      "message": "HDCP module binderized\n\nChange-Id: I866768b1e3f3b232f1934a35b65f66befc12f3f6\n"
    },
    {
      "commit": "2013a54981d4ffb036dff279b88cc9f08c0ee1c2",
      "tree": "0be5853ec89f5d075763a8228513a6e98a27a30e",
      "parents": [
        "62a1904e6beaa8848eddd2b635053536fbe5e804"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Tue Sep 04 21:38:42 2012 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Sep 05 08:47:36 2012 -0700"
      },
      "message": "Implement remote display service stubs.\n\nChange-Id: I582ed000026bba6d116db8304e15a3c52f8a9a01\n"
    },
    {
      "commit": "ab1bd84889273bc21efdabe5ff6f4633eb918a85",
      "tree": "c7b13774524756c1add0ebf76de25be2ff8244e9",
      "parents": [
        "c869702b6aa0c4af48226c7385eee60a1642761c"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Aug 30 14:51:40 2012 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Aug 30 14:51:40 2012 -0700"
      },
      "message": "Only run the wifi display RTSP server on demand, and only on the wifi direct\n\ninterface.\n\nChange-Id: I7d3c44cb79cd40e73499f2d7ccf35c69b628e6d7\n"
    },
    {
      "commit": "35213f1420c669f43314cb75eadea450d21a75cb",
      "tree": "6869bbe05a695fbb1df99b339e869652142ed3fb",
      "parents": [
        "f8b8f6f8738b9780067e9e56bac8c1de9449b94c"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Aug 29 11:41:50 2012 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Aug 29 15:06:57 2012 -0700"
      },
      "message": "Initial checkin of support for acting as a wifi display source\n\nChange-Id: I08f17efa0c7d007e17408feb7d4fbef0a19f531a\n"
    },
    {
      "commit": "ed3e3e046840d5bf1ca84a8c0cc097425e89d6d6",
      "tree": "99d5bb3a2f48f9a3ba3eaaf17e630b589e97bef1",
      "parents": [
        "cc1110dc92e53e9cc0afbb043e6ef8295bd9c5d5"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon Mar 26 11:13:27 2012 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon Mar 26 11:24:04 2012 -0700"
      },
      "message": "Provisional support for secure decryption of media streams.\n\nChange-Id: Ib3982a9c960bfdb0cb7e1b174440b141b194cfbe\n"
    },
    {
      "commit": "e1c3962e268ffc12bfd1bd9ea84da1f135f36960",
      "tree": "d24fac9434dbe5808a6c31a50414da7b5ce47c9a",
      "parents": [
        "a2a0a5d7d56baa831870f4bf2a0d942a477d92ef"
      ],
      "author": {
        "name": "Glenn Kasten",
        "email": "gkasten@google.com",
        "time": "Wed Jan 04 09:36:37 2012 -0800"
      },
      "committer": {
        "name": "Glenn Kasten",
        "email": "gkasten@google.com",
        "time": "Thu Jan 05 13:34:54 2012 -0800"
      },
      "message": "Use audio_format_t consistently\n\nWas int, uint32_t, uint16_t, and uint8_t with 2-bit bitfield.\nAlso replace 0 by AUDIO_FORMAT_DEFAULT and replace 1 by\nAUDIO_FORMAT_PCM_16_BIT.\n\nChange-Id: Ia8804f53f1725669e368857d5bb2044917e17975\n"
    },
    {
      "commit": "d681bbb1767bed09415e050ba78975df214bcd68",
      "tree": "2030c617c61bbf7b6cd8c6bafab601a99b1ac83d",
      "parents": [
        "d942202ee0c92608c648735c3ad0f1bab4312420"
      ],
      "author": {
        "name": "Dave Burke",
        "email": "daveburke@google.com",
        "time": "Tue Aug 30 14:39:17 2011 +0100"
      },
      "committer": {
        "name": "Dave Burke",
        "email": "daveburke@google.com",
        "time": "Fri Sep 02 11:26:59 2011 +0100"
      },
      "message": "Require INTERNET permission for network-based content.\nBug #1870981\n\nChange-Id: Ia3ad166390c4d60cea19c3783895b078a2c4c15f\n"
    },
    {
      "commit": "9ee159b79022b2e1a050acb3890ce948e99e9ccb",
      "tree": "3f8c908cd6d5a69f1f6c5eb7c4e0a833890107e9",
      "parents": [
        "5f5354e35ab3b2a0cb4cabb6d0aa5a160225ccc8"
      ],
      "author": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Thu Feb 24 14:51:45 2011 -0800"
      },
      "committer": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Wed Mar 02 16:53:24 2011 -0800"
      },
      "message": "- To track the usage of all audio output devices\n- To track the currently used audio device\n- The devices are separated as speaker and other audio devices\n- Provide the collected data to battery application through pullBatteryData()\n\nChange-Id: I374c755266b5ac6b1c6c630400f4daf901ea8acc\n"
    },
    {
      "commit": "7cf180c9bff69e5cc4a2f4e53b432db45ebbebab",
      "tree": "05d25862b1e1f30ffc31fe2ca2128ff68810df1b",
      "parents": [
        "1de41a66e3e7b548ee44e6654580e5f6f7265b11"
      ],
      "author": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Sat Feb 19 18:37:57 2011 -0800"
      },
      "committer": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Tue Feb 22 22:42:05 2011 -0800"
      },
      "message": "- Add method in MediaPlayerService to collect and pull\n  codec usage (duration) for the battery app\n- Collect MediaPlayer decoding usage data\n\nChange-Id: I0ef4e32b6a041ba1fe73c19f9c67185c61d03965\n"
    },
    {
      "commit": "e2b1028852120bcfded33b8f06f66b780437fe92",
      "tree": "a524b579935df0a8773e780299e31b590d1bdb44",
      "parents": [
        "31d7235c79667f88002d9ad87207099ed438a197"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Nov 23 11:41:34 2010 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Nov 23 14:46:13 2010 -0800"
      },
      "message": "Support streaming data across binder boundaries.\n\nChange-Id: Ifbac61406dcb81343765f99ccba08bd90f9274cc\n"
    },
    {
      "commit": "da7581b7b61b84f15e8d671c86fd117c322b009e",
      "tree": "61fb39ca1eaa0a5b8a71d70683f32d238a8e74e7",
      "parents": [
        "215381ea729086b8359b7f59bdc2bd7cf55a0c45"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Fri Jul 02 08:12:41 2010 -0700"
      },
      "committer": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Wed Jul 07 11:00:28 2010 -0700"
      },
      "message": "Added Visualizer effect.\n\nThe visualizer enables application to retrieve part of the currently playing audio for visualization purpose.\nIt is not an audio recording interface and only returns partial and low quality audio content as a waveform or\na frequency representation (FFT).\n\nRemoved temporary hack made in MediaPlayer for animated wall papers based on audio visualization (snoop() method.\n\nThis commit also includes a change in AudioEffect class:\n - the enable()/disable() methods have been replaced bya more standard setEnabled() method.\n - some fixes in javadoc\n\nChange-Id: Id092a1340e9e38dae68646ade7be054e3a36980e\n"
    },
    {
      "commit": "a514bdb58b5de4986679f72b7204b4764f7a2778",
      "tree": "84b1ebf0c2b500bfb4995e373f8fee5b63b6c9fd",
      "parents": [
        "58ae9c530247668f8af36e30d228c716c226b3d4"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Mon Jun 21 09:27:30 2010 -0700"
      },
      "committer": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Tue Jun 22 17:14:04 2010 -0700"
      },
      "message": "Added support for audio sessions in MediaPlayer and AudioTrack.\n\nAudio sessions are used to associate audio effects to particular instances (or groups) of MediaPlayers or AudioTracks.\n\nChange-Id: Ib94eec43241cfcb416590f435ddce7ab39a07640\n"
    },
    {
      "commit": "2db8455d8f4468a637109d31f319ce02d9d743ec",
      "tree": "7f3418b24ec0779af3ab25202eb5063e860610d5",
      "parents": [
        "8566a635aa4bf6d2e908f0bc64d4fb8917025b58"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Jan 28 11:19:57 2010 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Jan 28 11:52:43 2010 -0800"
      },
      "message": "API Extension: Support for optionally specifying a map of extra request headers when specifying the uri of media data to be played.\n\nrelated-to-bug: 2393577\n\nOriginal change by Andrei Popescu \u003candreip@google.com\u003e\n"
    },
    {
      "commit": "318ad9c1d9d6515026dfc2c021359d27decaa7a1",
      "tree": "28a58c4e3f20528b01c2abd08ba5f62d8755650c",
      "parents": [
        "89e69da4d86348409994c9dafbbb2634ccd7c196"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Oct 15 13:46:54 2009 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Oct 16 11:22:43 2009 -0700"
      },
      "message": "Reimplement the OMX backend for stagefright.\n\nBesides a major cleanup and refactoring, OMX is now a singleton living in the media server, it listens for death notifications of node observers/clients that allocated OMX nodes and performs/attempts cleanup.\n\nChanged APIs to conform to the rest of the system.\n"
    },
    {
      "commit": "10dbb8e97e7a81ca4867663b5517f048820b3094",
      "tree": "8a85a3f2c3547afc82a7ab1f92bed562ab980102",
      "parents": [
        "defd1bd08aaf7edc1918108419cf3f9d185c22f9"
      ],
      "author": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Sun Sep 20 10:42:13 2009 -0700"
      },
      "committer": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Tue Oct 06 08:51:16 2009 -0700"
      },
      "message": "Music visualizer support hack.\nThis currently assumes 44k stereo (won\u0027t crash on other formats, but won\u0027t give the correct results either), and links statically with libspeex to get FFT data, increasing the size of libmedia by about 45kb.\n"
    },
    {
      "commit": "20111aa043c5f404472bc63b90bc5aad906b1101",
      "tree": "b8c69d66954b3bf1aee4f12d05deb387e38a9282",
      "parents": [
        "508a3b61c4bce835f721237ddd40922b61f069d7"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Jul 14 16:56:47 2009 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Jul 16 09:49:14 2009 -0700"
      },
      "message": "Squashed commit of the following:\n\ncommit 8d179995654c19d9094e51989dc84ed0deba6e04\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue Jul 14 16:30:40 2009 -0700\n\n    Protect stagefright code with BUILD_WITH_STAGEFRIGHT build-define.\n\ncommit 99b41acb58c34e8f024c30c833a09fd7b31c4e1f\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue Jul 14 14:06:00 2009 -0700\n\n    OMX::list_nodes API, stagefright --list now lists all available OMX components.\n\ncommit 94a74c5b24aae6d7e446fff83d62ae3a57dc351b\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Jul 13 16:04:29 2009 -0700\n\n    Reenabled \"record\" commandline application to test encoding, support for h263 codec specific data when writing to .mp4.\n\ncommit d363dd74f611577567c66d25900d6264c306468c\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Jul 13 10:59:58 2009 -0700\n\n    Make non-socket communication in IOMX the default.\n\ncommit e89fc82c4fd138c88339887baf72f1d0e67f8660\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Jul 13 10:32:33 2009 -0700\n\n    The OMX interface now optionally supports communication through the binder only (no sockets involved)\n\ncommit 28611de11223fba65299787cdd33f7fdbd6a60a3\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri Jul 10 15:09:13 2009 -0700\n\n    Split off the logic to render to a Surface (not ISurface!) into SurfaceRender.{cpp,h}\n\ncommit c0cfa885faaeb17d3fc5436f6447b61708bd6fe1\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri Jul 10 12:21:46 2009 -0700\n\n    Fix display dimensions vs. decoded dimensions display issues, unfortunately breaks software rendering a bit...\n\ncommit ae209a2b5d09caed5dd383c910f238926aaa8fc6\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri Jul 10 09:33:29 2009 -0700\n\n    Simple video decoder performance test in \"stagefright\" commandline tool.\n\ncommit 59fe7840111d6f46dd3c48f4950146aed962dbd2\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Jul 9 16:05:12 2009 -0700\n\n    StagefrightPlayer: Properly publish video dimensions by notifying the listener.\n\ncommit 51b6598f0e47be5e12d77f1d14e111e71c593638\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Jul 9 11:38:15 2009 -0700\n\n    MediaPlayerInterface::AudioSink now supports the specification of a callback for pull-based audio.\n\ncommit 31ce53375d748da3e7d30e993ce89dae97fd65ea\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jul 8 17:23:37 2009 -0700\n\n    Proper support for pushing audio to a specified AudioSink interface. Still not bulletproof: video falls behind frequently.\n\ncommit a23e312b10631a5d47f5c9831205beac6b84ab36\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jul 8 15:10:13 2009 -0700\n\n    IGenesisPlayer and friends are no more, java interface now uses local playback instead\n    of playing inside the media server process.\n\ncommit 42ee5c06ab5ba1c16f50472b0b26a0526635c73c\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jul 8 13:17:03 2009 -0700\n\n    MP3 extractor now supports seeking (only fixed bitrate files currently supported)\n\ncommit 96a790405763bfa738d1c6845c99a9fdf579b66f\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue Jul 7 10:53:54 2009 -0700\n\n    Keeping up-to-date with new master-gl changes, removing CameraSource for now, removing unnecessary commandline utilities from the build.\n\ncommit 6c9dcb7c628c0347154dd7f37913a3a5f04deb99\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Jul 6 16:40:02 2009 -0700\n\n    Finally take advantage of the fact that the Qcom OMX decoders already place the output buffers into memory accessible by the hardware yuv converter and avoid extra allocations and memcpys in that case. Split of the render logic into subclasses of VideoRenderer.\n\ncommit e8d46e81cffc15ffb0bdf03f511e4a4497ca7621\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Jul 6 12:18:29 2009 -0700\n\n    Added a few more cases of valid MPEG4 files to the sniffer, fixed end of stream notifications in MPEG4 files.\n\ncommit 88bffc5ed4033a607080f8777a1c0ec9e3e079de\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Jul 2 12:25:03 2009 -0700\n\n    MediaPlayerImpl now properly pauses/resumes instead of tearing down the decoder chains and starting back up from the beginning.\n\ncommit 732aa0a87c7e8d8a10776b275712649954962414\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jul 1 14:58:56 2009 -0700\n\n    Remove pthread_mutex_* and pthread_cond_* in favour of Mutex and Condition.\n\ncommit 669e5944b2fe0542a3b8dba0c441a94503e99fb0\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jul 1 14:43:02 2009 -0700\n\n    Proper support for end-of-stream signalling of MediaSources.\n\ncommit afb038f2dc594c742e554b2d42b86ffc7434e3fc\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue Jun 30 16:48:03 2009 -0700\n\n    Support for the \"sniffing\" of datasources to determine their probable mime type (along with confidence). Slightly refactored the MP3Extractor to share common code with the sniffer.\n\ncommit ed3644b8bd56807e1db4b32433a93a2467f1f3c5\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri Jun 26 13:27:52 2009 -0700\n\n    I don\u0027t think prepare should automatically start the player.\n\ncommit 11eb9b49dc4a0819d366682817cba68613f4fe12\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri Jun 26 11:09:22 2009 -0700\n\n    Somewhat better timing information implemented in the MP3Extractor.\n\ncommit cab023a1751735c0ed26c8493498a91d8644c6c9\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Jun 25 15:41:56 2009 -0700\n\n    Initial checkin for support of mp3 content, extraction and playback. Media extractors now abstracted in MediaExtractor baseclass.\n\ncommit 40f4146bb3c647e56690dd9b0fa3ffdea60030dc\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jun 24 10:41:12 2009 -0700\n\n    Make sure we only allocate surface buffers if there is video to be played.\n\ncommit 7f85e7d92fe81740e102e09905b19354f4ac178e\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jun 24 10:19:32 2009 -0700\n\n    Clean up a failed merge and implement stub for new API in MediaPlayerBase.\n\ncommit f0e9d494a4c03402ea7b54891848ca5a50c421b2\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri Jun 12 15:38:03 2009 -0700\n\n    Support yuv420-\u003ergb565 conversion if hardware color conversion is unavailable.\n\ncommit 87223248b3099cd5261b94169f84cfd1eba56a8f\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri Jun 12 09:35:56 2009 -0700\n\n    Remove unimplemented and currently unnecessary blocking option from MediaSource::ReadOptions.\n\ncommit e07e651f0325892b797f3eb64dbeca0f317afdfd\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jun 10 16:26:42 2009 -0700\n\n    Enable assertions in HTTPDataSource.\n\ncommit 0dc97adebea1721156880f4b3d5c70f8d50c53b2\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jun 10 12:34:39 2009 -0700\n\n    delete foo.\n\ncommit 7f05845dda496e7defee284d32509d127e785784\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jun 10 12:34:08 2009 -0700\n\n    added foo.\n\ncommit e432970c51eeec4e5d549bdb3e2d3e48ffb4f0e7\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jun 10 11:44:31 2009 -0700\n\n    Make sure to initialize all fields in _all_ constructors... Use a Mutex instead of the raw pthread_mutex_t.\n\ncommit d6286a6bbca639952491448fa3e609b775a8a814\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue Jun 9 17:11:49 2009 -0700\n\n    send_command is now implemented twice... ugly hack to get both shutdown working correctly and startup as well... playback now \"works\" on the emulator, too.\n\ncommit 8d657e004677a7c5dae4479e8519bcaa94c18aad\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue Jun 9 11:58:55 2009 -0700\n\n    Instead of erasing codec specific data once it\u0027s been output to the omx node, retain the data and just rewind after a stop.\n\ncommit 279fede6ba35cbc37c35616c53406bf2c9720202\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue Jun 9 10:58:11 2009 -0700\n\n    Various fixes related to play/pause. Decoder now properly frees OMXMediaBuffers, made MemoryDealer destructor protected instead of public to prevent accidental stack-allocation of MemoryDealer objects.\n\ncommit 0f717f15a6328efd3f34082929cd8ad2351095a9\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue Jun 9 08:44:12 2009 -0700\n\n    Make sure to rewind codec specific data on OMXDecoder::stop and reset AudioPlayer\u0027s notion of time mapping.\n\ncommit 0cfb63e33270daf9b215214608ab383f93a31823\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Jun 8 14:25:48 2009 -0700\n\n    Massive rename.\n\ncommit 30ed8f476c4431a5275538958b3e281bd17d5eab\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Jun 8 13:52:41 2009 -0700\n\n    send_command and fill/empty buffer commands must be executed in sequence, send_command is now dispatched over the socket instead of through the binder interface to ensure this.\n\ncommit b832d04011b2dd8a9632eb7e575bfe1addd1270d\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Jun 8 10:21:17 2009 -0700\n\n    MediaBuffers can now be \"clone()\", they sit on top of the same data but have their own range and metadata. Once a clone\u0027s refcount drops to 0 it decrements the refcount on the original buffer.\n\ncommit 4e944672808bdf1ed40a69f3f602f93ebf7b4049\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Jun 8 10:01:01 2009 -0700\n\n    Split MediaBuffer.h into MediaBufferGroup.h and MediaBuffer.h, same with their respective source files.\n\ncommit ddb7529b4de4828db51432bd405fddd76cfa3b6a\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri Jun 5 16:30:25 2009 -0700\n\n    More fudging with A/V sync...\n\ncommit 1e5a4d8df08237b58c06c6527a33152ae931addf\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri Jun 5 11:54:20 2009 -0700\n\n    API cleanup of MediaSource. Got rid of MediaRing as it really doesn\u0027t serve a purpose if OMX decoders are used.\n\ncommit 0953c65232aa9753d17d2e25c5f5526eb810cf13\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Jun 4 16:59:19 2009 -0700\n\n    Experimental TimedEventQueue and an attempt at a cleaner player implementation using it, OMXDecoder is now a little less verbose.\n\ncommit 2085b8ea9484a21fa11f94194a27405d413aeecc\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Jun 4 10:17:01 2009 -0700\n\n    Properly bail out of the AV sync loop if the MediaPlayerImpl is stopped.\n\ncommit 471f143458a8a0d93cb1bf9568c63c3967279dc6\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jun 3 17:32:27 2009 -0700\n\n    Now this is much better AV sync, defer seeking the audio source until we know where the video source synced to.\n\ncommit 4010d371dbe62ce4971e13437776cba32cb0bb3d\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jun 3 16:01:07 2009 -0700\n\n    Tweaked some of the heuristics in AV sync, OMXDecoder is now a little less verbose, seek to a sync sample at or _after_ the requested position.\n\ncommit f3d4af1d5a4ac31fa02271b000f6c7ec593f0da9\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jun 3 15:33:58 2009 -0700\n\n    Change the TimeSource interface\u0027s APIs, prefer microseconds over milliseconds now, changed the way MediaPlayerImpl does AV sync.\n\ncommit 08bb46fa61d12e852a424698ddb0c90700328f6e\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Jun 3 11:57:24 2009 -0700\n\n    Using framework\u0027s Mutex and Condition classes instead of pthread functions, much saner locking in OMXDecoder.\n\ncommit 4d77b4e09e59bbf8c1af009ae7dc62b10af52fd6\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue Jun 2 17:12:03 2009 -0700\n\n    MediaSources now publish their format.\n\ncommit 7e429a26c57bf936e1a08035d2d11839f9f00310\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue Jun 2 16:38:29 2009 -0700\n\n    MetaData is now implemented in terms of KeyedVector, MetaData is now reference counted.\n\ncommit 0fa957aa5c9bcb6ec122ed7b5b97430039be6797\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Jun 1 14:39:55 2009 -0700\n\n    Sync sample seek support.\n\ncommit 78a5f090d02e7e6e1a146b29bdb7771eecaa2f86\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Jun 1 13:51:11 2009 -0700\n\n    Distinguish shutdown from port-flush since one requires buffers to be freed and the other one doesn\u0027t. Fixes a problem with seek.\n\ncommit e57781d3b2c985a74cd8b60e7c8f2d576459d038\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Jun 1 10:52:20 2009 -0700\n\n    First shot at support for seeking a MediaSource. Sync frames are not properly handled yet.\n\ncommit 0551cd78fda78bf66877fb26c5a55e5ae23d8367\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu May 28 16:23:38 2009 -0700\n\n    Preliminary support for camera input.\n\ncommit f8ebafa65d10d5a06944de6b2e2992a33121b857\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu May 28 12:13:47 2009 -0700\n\n    Allow NativeMediaPlayer access to Surface\u0027s getISurface() method.\n\ncommit b1a9fb36eeccd9f49d28c1c64b31fccbd6506eeb\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu May 28 11:38:25 2009 -0700\n\n    Header files are now in their own genesis2 hierarchy below frameworks/base/include.\n\ncommit f49b8b234b8f6ce83148787eef540dd920f04aa6\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu May 28 11:22:03 2009 -0700\n\n    moved MPEG4Writer into libgenesis2.\n\ncommit 5224254919dac4728677335ea60429fa16f518b4\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu May 28 11:13:38 2009 -0700\n\n    Everything now lives in the android namespace, integrated errors with android errors, renamed MediaPlayer to MediaPlayerImpl.\n\ncommit f9a9d84f7e0465ef5d1938a068655ba39527cf99\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed May 27 16:43:11 2009 -0700\n\n    Support for getPosition() and getDuration().\n\ncommit 3206cc5140bcbc88be039f8d94b954af63e69752\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed May 27 15:37:45 2009 -0700\n\n    Support for {MediaPlayer, GenesisPlayer, Genesis2Player}::isPlaying()\n\ncommit 9f41b248e0dfce71bbc50f883750cec52ebfd1fe\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed May 27 13:49:50 2009 -0700\n\n    Proper disconnection from the OMX service.\n\ncommit cdcf47a2c31599109ee42277c7fa14af3c600091\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue May 26 17:27:06 2009 -0700\n\n    New player type for the genesis player in libmediaplayerservice. Playing video through an ISurface now.\n\ncommit 0586af20ac9ae0403dd190bafd290b0f90549723\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri May 22 15:53:19 2009 -0700\n\n    Fix a buffer overflow error by adding padding in case we need to de-frame AVC data.\n\ncommit eac62fff6ad2ffb7b75c0d4a1b9620d33e93fb9b\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri May 22 13:35:30 2009 -0700\n\n    Support for http URIs in MediaPlayer, compensate for AudioTrack latency.\n\ncommit a7db456e3173d94d6b5e457547e2a6a5f7a8e1cc\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri May 22 11:33:25 2009 -0700\n\n    Support for URIs in MediaPlayer class, support for shoutcast streams in MediaPlayer, force shutdown of OMX nodes if they don\u0027t shutdown cleanly within a second.\n\ncommit 1f0268f4f14ad5215668f34e06a420850174d665\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri May 22 08:33:16 2009 -0700\n\n    and foo.txt is gone again.\n\ncommit 0feca4e0919f345704d78ec78894bac5027bd5ed\nAuthor: Andreas Huber \u003candih@dhcp-172-19-27-148.mtv.corp.google.com\u003e\nDate:   Fri May 22 08:28:49 2009 -0700\n\n    added foo.txt\n\ncommit 9c7d04b35cdc895a2de3602dc46522f608bd205f\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri May 22 08:28:04 2009 -0700\n\n    delete foo again\n\ncommit fec3ca1720992cce51b9a92b86b945da88a6b16c\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri May 22 08:27:45 2009 -0700\n\n    weird\n\ncommit 30a6571302333146e537e537a3a8986245cca87c\nAuthor: Andreas Huber \u003candih@dhcp-172-19-27-148.mtv.corp.google.com\u003e\nDate:   Fri May 22 08:18:55 2009 -0700\n\n    reverse test\n\ncommit dea3d99dd0fe9386e8a3c51954d9d0fe2be09d38\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri May 22 08:18:22 2009 -0700\n\n    test\n\ncommit a9eeafec6e46072cac41e54ebdbd153cb7ae7518\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu May 21 16:37:50 2009 -0700\n\n    Use the video ring again for now.\n\ncommit e05ff3d3c1c4f89ef499a2b172138a775fd694e3\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu May 21 15:42:19 2009 -0700\n\n    Export to .mp4 now works for MPEG4 video content. Fixed a bug in the sample table wrt co64 chunks.\n\ncommit 5c44c540374a4e50c4e8aaab2b7a34aed6e1391e\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu May 21 09:56:11 2009 -0700\n\n    Fix the build, all binder-related headers have moved and there\u0027s a new library libbinde\n    r to link against now.\n\ncommit 23e0a24404d16c898c2c6b3c7495ad303844bc71\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu May 21 08:42:04 2009 -0700\n\n    Initial checkin of MPEG4Writer, a class to export media sources into an mpeg4 file. MPEG4/AVC metadata (efss \u0026 friends) not currently working.\n\ncommit 9cd77adb1ac194197364ffad00a0d7215f458e1a\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed May 20 12:31:45 2009 -0700\n\n    New shell command to test recording/encoding. Various changes to OMXDecoder to support encoding properly. Now each OMXDecoder needs a dedicated thread on the client side since onEvent responses could block which would cause deadlocks if a node depends on the output of another node for example.\n\ncommit 5c510fb55ffed7ec25305999ed9b6c1eec48d503\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon May 18 15:40:06 2009 -0700\n\n    Make media decoding the default in the genesis2 commandline app instead of shoutcast playback.\n\ncommit f6c7a2040b8eb43326621f12c3a936e09b3a70e3\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon May 18 11:03:04 2009 -0700\n\n    The king is dead, long live the kind... Replaced old OMX binder interface with new OMX binder interface/socket hybrid.\n\ncommit 0d4955eb5df9bfafb576d22f2ed572644d6d69ac\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu May 14 12:39:34 2009 -0700\n\n    dynamic negotiation of NAL framing with the MPEG4Source, removed stale code from genesis2 commandline tool. Enable support form PV H264 software decoder.\n\ncommit 380369f54a8027cbc9349305184d6bf527a24efe\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed May 13 17:32:00 2009 -0700\n\n    Explore the option of running everything inside the mediaserver process by encapsulating the player in an IGenesisPlayer binder interface.\n\ncommit b5cada56b9089a23e0c461352a97dc71e08b424d\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed May 13 12:11:06 2009 -0700\n\n    Introduction of TimeSource class, clean shutdown of OMX Nodes.\n\ncommit 89f6e582e605dcb2149eb67f73fe9345d4b9be2e\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue May 12 17:11:56 2009 -0700\n\n    Helper classes MediaRing and MediaPlayer.\n\ncommit 9aaed8739b4bb941473da367fb88f63224d2f1b7\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue May 12 14:19:18 2009 -0700\n\n    Using mmap to map a file instead of going through FILE* improves performance, who knew?\n\ncommit ad097a78bbd002c59193ffdc39b64935928426c7\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon May 11 16:42:42 2009 -0700\n\n    Added a performance test, refactored AudioDecoder a little.\n\ncommit bdd1b80ab3f3ba43e04f1f996e7fa84ed2e2728a\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri May 8 16:19:29 2009 -0700\n\n    No more copying the output buffers coming out of the decoder, NAL separation also done in the extractor to avoid copying the data.\n\ncommit 858955b42c29b8033841a8caaa56c2a449810ef3\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri May 8 14:02:38 2009 -0700\n\n    Change from a model in which the caller specifies the destination buffer to one where the MediaSource returns a buffer.\n\ncommit 95098b6d4f8bdc37dfb6a109ca58db4d9e414e2d\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri May 8 13:21:45 2009 -0700\n\n    Changes to support multiple pieces of codec specific data to the decoder, de-frame nal units from the h.264 stream and insert start codes\n\ncommit 3941fcf87a48dda81683df727dfb1381f62d9184\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu May 7 16:37:45 2009 -0700\n\n    some refactoring. Most streams play now.\n\ncommit d3152862840d4dd39068e5197bec8674f3d55dd5\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu May 7 15:37:32 2009 -0700\n\n    Misc. changes to support H264 decoding using the qcom hardware decoder\n\ncommit d4ecdfe7af36e7468270d1c2cbbdc540efe0351e\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu May 7 09:28:18 2009 -0700\n\n    Timestamps are now stored as a fraction, i.e. units and scale, also, PV appears to violate OMX specs by assuming timestamps are in milliseconds instead of microseconds.\n\ncommit fe6a50943f885e065d4061aa727a54417e9f36db\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed May 6 14:18:27 2009 -0700\n\n    Refactored commandline app instantiation of the decoder.\n\ncommit da1ff2724d0e78e8b360d9a2c34c55dd0e2c0492\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed May 6 10:41:14 2009 -0700\n\n    Proper audio/video synchronization.\n\ncommit 569ee3a23f600f4b6b87c6178c0223b06e97f201\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed May 6 09:17:20 2009 -0700\n\n    Preliminary support for timestamps.\n\ncommit e4e302a89207550d8a7170d8c0afbd9c15047c84\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue May 5 15:13:12 2009 -0700\n\n    Another quick hack job to make CachingDataSource thread-safe as well.\n\ncommit dfb376a58bd7c09aa04e89558186fcfe13fe696c\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue May 5 15:08:14 2009 -0700\n\n    Quick rushjob to make FileSource and SampleTable thread safe.\n\ncommit 02b29e7ebdab1f8b959b6c177ceb3b89d998f375\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon May 4 17:22:04 2009 -0700\n\n    Made video decoding work for mpeg4/h263 and mostly(?) with AVC content.\n\ncommit 3a57b8ff15e48f5a0af03bf0a99c32e240dbb7ef\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon May 4 09:26:42 2009 -0700\n\n    Getting rid of old sample code to drive the OMXNode binder interface.\n\ncommit 5b046aed0cf524a57ea711bc1e43ea80e57b2cb3\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri May 1 16:21:11 2009 -0700\n\n    Moved files from the commandline utility into the framework, renamed MP3Decoder to AudioDecoder\n\ncommit 7f3fbba21512a078b732cc52c7bd5ba5acb9a317\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri May 1 15:56:19 2009 -0700\n\n    Fixed buffer ordering and an off-by-1 error in the SampleTable code. Plays all AACs now :)\n\ncommit 024d06baab8f2c540dde16f7e7a4b6dd57f638c7\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri May 1 11:52:48 2009 -0700\n\n    Some AAC content in .3gp or .mp4 files plays correctly now, other does not. Implemented ESFS parser.\n\ncommit 1470427866b0d3e0ce6848b4edc01c13a09be289\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Apr 30 15:19:31 2009 -0700\n\n    Another checkpoint, amr decoding now functional.\n\ncommit e612d044439f56331b6a2bc4a88622e04d4d42e7\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Apr 29 12:11:29 2009 -0700\n\n    string wrapper around String8, various fixes, shoutcast now works again.\n\ncommit 2ea52dfb1a39bf3a223ffc87855e54919e2daff7\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Apr 29 11:08:18 2009 -0700\n\n    Initial check-in of OMXNode binder interface.\n\ncommit 7880d2957f74c0d7fba7679431ff5adb3780543b\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Apr 29 10:05:01 2009 -0700\n\n    Initial check-in of both libgenesis2 and the genesis2 commandline tool.\n"
    },
    {
      "commit": "1d187f1a86855f5f0694d7ec30efc9833bf7c589",
      "tree": "3bca2771fc58c5e6dcc79178902db5a439bb7492",
      "parents": [
        "3d59a4b99937a7d0dc07eec2574cc8a98cc99fdd"
      ],
      "author": {
        "name": "Nicolas Catania",
        "email": "niko@google.com",
        "time": "Tue May 12 23:25:55 2009 -0700"
      },
      "committer": {
        "name": "niko",
        "email": "niko@google.com",
        "time": "Wed Jun 24 08:22:52 2009 -0700"
      },
      "message": "Direct api to the native media player.\n\nMediaPlayer.java has 3 new methods:\n* newRequest creates a Parcel that can be used to send data to the\n  native player using invoke.\n* invoke issues synchronous calls to the native player using opaque\n  parcels for the request and reply.\n\nIMediaPlayer.h has 1 new abstract method:\n* invoke\n\nThe Midi and Vorbis players have a stub for these. So far only PV\nmakes use of that new feature.\n\nTo avoid any copy overhead, the JNI interface uses Parcel as a java\nobject (no serialization/copy happens at the JNI layer).\n\nThe remote interface token is inserted when the Parcel is constructed\nin java. That way the parcel is already routable when it reaches\n IMediaPlayer.cpp (proxy). No extra copy is needed there.\n"
    },
    {
      "commit": "4710a1f6c9800dae90f9e2702ba2b5b54c095eae",
      "tree": "094cd3463052fa129012540ce0073705cc62866f",
      "parents": [
        "2a7d5b3c1a3749db7c4ace34bf1253c44967e843",
        "660951867e959ebe98612742ef1f72d33ea7e9a3"
      ],
      "author": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Fri Jun 12 11:43:55 2009 -0700"
      },
      "committer": {
        "name": "The Android Open Source Project",
        "email": "initial-contribution@android.com",
        "time": "Fri Jun 12 11:43:55 2009 -0700"
      },
      "message": "am d670b8c6: Merge change 3981 into donut\n\nMerge commit \u0027d670b8c61ebd13324ac21bdbc08d8a02fc0a765a\u0027\n\n* commit \u0027d670b8c61ebd13324ac21bdbc08d8a02fc0a765a\u0027:\n  Removed trailing whitespaces.\n"
    },
    {
      "commit": "660951867e959ebe98612742ef1f72d33ea7e9a3",
      "tree": "76d9e5cf11c5aab642f479bfb5e5a28acd834e08",
      "parents": [
        "9747c5a1f5e51fab72169767972bf55f73711000"
      ],
      "author": {
        "name": "Nicolas Catania",
        "email": "niko@google.com",
        "time": "Thu Jun 11 16:33:49 2009 -0700"
      },
      "committer": {
        "name": "Nicolas Catania",
        "email": "niko@google.com",
        "time": "Thu Jun 11 16:54:48 2009 -0700"
      },
      "message": "Removed trailing whitespaces.\n"
    },
    {
      "commit": "7562408b2261d38415453378b6188f74fda99d88",
      "tree": "6b2ac284c1b721385d695045357d9e1d60ece03a",
      "parents": [
        "615a9bfbd98b90e09d868c128db84836feb658e4"
      ],
      "author": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Tue May 19 19:08:10 2009 -0700"
      },
      "committer": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Wed May 20 12:55:03 2009 -0700"
      },
      "message": "move libbinder\u0027s header files under includes/binder\n"
    },
    {
      "commit": "89fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5",
      "tree": "28d26f7b71e943e25c7da6e8043d79b7b8d9cf7b",
      "parents": [
        "15f767b960b38059a74a42a33e16d8df2aec8bc1"
      ],
      "author": {
        "name": "The Android Open Source Project",
        "email": "initial-contribution@android.com",
        "time": "Tue Mar 03 19:31:44 2009 -0800"
      },
      "committer": {
        "name": "The Android Open Source Project",
        "email": "initial-contribution@android.com",
        "time": "Tue Mar 03 19:31:44 2009 -0800"
      },
      "message": "auto import from //depot/cupcake/@135843\n"
    },
    {
      "commit": "15f767b960b38059a74a42a33e16d8df2aec8bc1",
      "tree": "4b825dc642cb6eb9a060e54bf8d69288fbee4904",
      "parents": [
        "ad04d9201452001dbaac4349f084cc9316190b89"
      ],
      "author": {
        "name": "The Android Open Source Project",
        "email": "initial-contribution@android.com",
        "time": "Tue Mar 03 18:28:45 2009 -0800"
      },
      "committer": {
        "name": "The Android Open Source Project",
        "email": "initial-contribution@android.com",
        "time": "Tue Mar 03 18:28:45 2009 -0800"
      },
      "message": "auto import from //depot/cupcake/@135843\n"
    },
    {
      "commit": "7b5eb023f8d87cca6d830ae6c11c6aadbe02aca8",
      "tree": "d9838a098f868ee2fcffc20627a8c9a33cb23377",
      "parents": [
        "2729ea9262ca60d93047e984739887cfc89e82eb"
      ],
      "author": {
        "name": "The Android Open Source Project",
        "email": "initial-contribution@android.com",
        "time": "Wed Dec 17 18:05:43 2008 -0800"
      },
      "committer": {
        "name": "The Android Open Source Project",
        "email": "initial-contribution@android.com",
        "time": "Wed Dec 17 18:05:43 2008 -0800"
      },
      "message": "Code drop from //branches/cupcake/...@124589\n"
    },
    {
      "commit": "2729ea9262ca60d93047e984739887cfc89e82eb",
      "tree": "25962a3f1c5f70586af45c926c037e03c643857f",
      "parents": [],
      "author": {
        "name": "The Android Open Source Project",
        "email": "initial-contribution@android.com",
        "time": "Tue Oct 21 07:00:00 2008 -0700"
      },
      "committer": {
        "name": "The Android Open Source Project",
        "email": "initial-contribution@android.com",
        "time": "Tue Oct 21 07:00:00 2008 -0700"
      },
      "message": "Initial Contribution\n"
    }
  ]
}
