)]}'
{
  "log": [
    {
      "commit": "1e1d44924a334637f9fb47ca8796625bd86cb66a",
      "tree": "d09c9832af259c4541eaaecd32c34f3b68150028",
      "parents": [
        "c267c90100ff09ab1ca6b09d6eae23594d699536",
        "218aa94581293876a4283f8d5908843c8f818e3a"
      ],
      "author": {
        "name": "Kenny Root",
        "email": "kroot@google.com",
        "time": "Thu Dec 10 18:10:33 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Dec 10 18:10:33 2009 -0800"
      },
      "message": "am 218aa945: Merge change I6478884a into eclair-mr2\n\nMerge commit \u0027218aa94581293876a4283f8d5908843c8f818e3a\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027218aa94581293876a4283f8d5908843c8f818e3a\u0027:\n  Add string resource type inspection\n"
    },
    {
      "commit": "218aa94581293876a4283f8d5908843c8f818e3a",
      "tree": "b76fdd7443fc8055786b7461701ab027a0e195d6",
      "parents": [
        "9de0dba37cdb74a21e561c5235757318f1812e3d",
        "bb79f64b89bd7be7019035a0347c681e6f39fe6b"
      ],
      "author": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Dec 10 18:05:19 2009 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Dec 10 18:05:19 2009 -0800"
      },
      "message": "Merge change I6478884a into eclair-mr2\n\n* changes:\n  Add string resource type inspection\n"
    },
    {
      "commit": "899858a39647803c0cb506d2320fdaf2e4d3b8b9",
      "tree": "afdd725eeec7ec04bd261d330e3de931500c9e34",
      "parents": [
        "b62954b66542e3e2654d97a81123c51805bceca7",
        "6608bd0d3af3f9c365b73f8b19d9ec0b7d5ee70b"
      ],
      "author": {
        "name": "Jean-Michel Trivi",
        "email": "jmtrivi@google.com",
        "time": "Thu Dec 10 16:58:35 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Dec 10 16:58:35 2009 -0800"
      },
      "message": "am 6608bd0d: am 86ed86d2: Merge change I0f73439a into eclair\n\nMerge commit \u00276608bd0d3af3f9c365b73f8b19d9ec0b7d5ee70b\u0027 into eclair-mr2-plus-aosp\n\n* commit \u00276608bd0d3af3f9c365b73f8b19d9ec0b7d5ee70b\u0027:\n  Partially fix bug 2111240 Detect docking / undocking event by reporting\n"
    },
    {
      "commit": "6608bd0d3af3f9c365b73f8b19d9ec0b7d5ee70b",
      "tree": "7e910c16a5c3278b3d636948446bf382fa44cb21",
      "parents": [
        "8f31c23021a3f8164eee08cf904c3f083ddfc3d2",
        "86ed86d2260932bdf2217b1d8431ac9e04d47534"
      ],
      "author": {
        "name": "Jean-Michel Trivi",
        "email": "jmtrivi@google.com",
        "time": "Thu Dec 10 16:46:13 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Dec 10 16:46:13 2009 -0800"
      },
      "message": "am 86ed86d2: Merge change I0f73439a into eclair\n\nMerge commit \u002786ed86d2260932bdf2217b1d8431ac9e04d47534\u0027 into eclair-mr2\n\n* commit \u002786ed86d2260932bdf2217b1d8431ac9e04d47534\u0027:\n  Partially fix bug 2111240 Detect docking / undocking event by reporting\n"
    },
    {
      "commit": "bb79f64b89bd7be7019035a0347c681e6f39fe6b",
      "tree": "d938e21a91d0d71dba49f89e36920f6654284536",
      "parents": [
        "159f0015418955501d8cf2744b0393db2e73f394"
      ],
      "author": {
        "name": "Kenny Root",
        "email": "kroot@google.com",
        "time": "Thu Dec 10 14:20:15 2009 -0800"
      },
      "committer": {
        "name": "Kenny Root",
        "email": "kroot@google.com",
        "time": "Thu Dec 10 14:22:08 2009 -0800"
      },
      "message": "Add string resource type inspection\n\nAllows \"aapt dump --values resource\" to print out whether a string in a\nResStringPool is in UTF-8 or UTF-16 encoding.\n\nChange-Id: I6478884a70a3b46fee862dece6cb33454fc34843\n"
    },
    {
      "commit": "5cd6fcd518d47d1974a10fccf3c3d5431a83307a",
      "tree": "513a7efe23cc172c9f863f1a28e96d53d7fc0461",
      "parents": [
        "d44c2f2c85c8720763837b89a8988b6e5cc248bf",
        "e6c0e99334bc2f47e5d36db253ac8f166047c03b"
      ],
      "author": {
        "name": "Kenny Root",
        "email": "kroot@google.com",
        "time": "Wed Dec 09 15:51:21 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Dec 09 15:51:21 2009 -0800"
      },
      "message": "am e6c0e993: Merge change I129483f8 into eclair-mr2\n\nMerge commit \u0027e6c0e99334bc2f47e5d36db253ac8f166047c03b\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027e6c0e99334bc2f47e5d36db253ac8f166047c03b\u0027:\n  Optional use of UTF-8 strings in resource bundles\n"
    },
    {
      "commit": "68a3b8b66044d0a9fa901ad306fc6db6d13f94d3",
      "tree": "dff67f3f793d42bb4da8f723afb904faa0101dff",
      "parents": [
        "9f1ea0d47f5aa18cf949593e6bfd36af9c6a55be",
        "24eca800d4b34e7d13fbcbc1ab74c9d91ff6a4e1"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Wed Dec 09 15:49:02 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Dec 09 15:49:02 2009 -0800"
      },
      "message": "am 24eca800: Merge change I887f355f into eclair-mr2\n\nMerge commit \u002724eca800d4b34e7d13fbcbc1ab74c9d91ff6a4e1\u0027 into eclair-mr2-plus-aosp\n\n* commit \u002724eca800d4b34e7d13fbcbc1ab74c9d91ff6a4e1\u0027:\n  Propagate background scheduling class across processes.\n"
    },
    {
      "commit": "e6c0e99334bc2f47e5d36db253ac8f166047c03b",
      "tree": "67a2ab651f0bb32587d2b074e45a7095630fb07d",
      "parents": [
        "1270e2e22b0b3f0705cee2b82788d8dc3fb03cdb",
        "19138468caf7050d482dc15f35a344eab11bb756"
      ],
      "author": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Dec 08 13:41:38 2009 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Dec 08 13:41:38 2009 -0800"
      },
      "message": "Merge change I129483f8 into eclair-mr2\n\n* changes:\n  Optional use of UTF-8 strings in resource bundles\n"
    },
    {
      "commit": "6154412ee8e07e9cde129cccb944dd7ed9dcef53",
      "tree": "bb568c3907b2da5ae9098457ec19ec80762b8036",
      "parents": [
        "6d42d80653f2c41f3e72a878a1d9a6f9693b89f7"
      ],
      "author": {
        "name": "Jean-Michel Trivi",
        "email": "jmtrivi@google.com",
        "time": "Mon Dec 07 18:40:56 2009 -0800"
      },
      "committer": {
        "name": "Jean-Michel Trivi",
        "email": "jmtrivi@google.com",
        "time": "Mon Dec 07 20:42:52 2009 -0800"
      },
      "message": "Partially fix bug 2111240 Detect docking / undocking event by reporting\nto the AudioPolicyManager a new forced usage AudioSystem::FOR_DOCK\nwhich can take the FORCE_NONE, FORCE_BT_DOCK or FORCE_WIRED_ACCESSORY\nvalues. This CL is complemented by an update of the APM to take into\naccount the FOR_DOCK usage.\n"
    },
    {
      "commit": "887f355f99ff83d568ef2885a4fdcaae475583df",
      "tree": "c4788aa9ac8f37c6a02fc6b3a6874b71efb0f759",
      "parents": [
        "259e3384face72ea8e30696d7bae492d37d44e8b"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Mon Dec 07 17:59:37 2009 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Mon Dec 07 19:11:14 2009 -0800"
      },
      "message": "Propagate background scheduling class across processes.\n\nThis is a very simply implementation: upon receiving an IPC, if the handling\nthread is at a background priority (the driver will have taken care of\npropagating this from the calling thread), then stick it in to the background\nscheduling group.  Plus an API to turn this off for the process, which is\nused by the system process.\n\nThis also pulls some of the code for managing scheduling classes out of\nthe Process JNI wrappers and in to some convenience methods in thread.h.\n"
    },
    {
      "commit": "19138468caf7050d482dc15f35a344eab11bb756",
      "tree": "ea1f96c5bcab356355ab05d315abfa66a7f888c4",
      "parents": [
        "6be01bf207077ffbdcd3879250171a26ec805835"
      ],
      "author": {
        "name": "Kenny Root",
        "email": "kroot@google.com",
        "time": "Fri Dec 04 09:38:48 2009 -0800"
      },
      "committer": {
        "name": "Kenny Root",
        "email": "kroot@google.com",
        "time": "Mon Dec 07 15:14:15 2009 -0800"
      },
      "message": "Optional use of UTF-8 strings in resource bundles\n\nAllows the use of UTF-8 for packing resources instead of the\ndefault of UTF-16 for Java. When strings are extracted from the\nResStringPool, they are converted to UTF-16 and the result is\ncached for subsequent calls.\n\nWhen using aapt to package, add in the \"-8\" switch to pack the\nresources using UTF-8. This will result in the value, key, and\ntype strings as well as the compiled XML string values taking\nsignificantly less space in the final application package in\nmost scenarios.\n\nChange-Id: I129483f8b3d3b1c5869dced05cb525e494a6c83a\n"
    },
    {
      "commit": "f553a58425c66a990dbc5f4579c976a0636fc573",
      "tree": "3934713b8fb374bf07efa2bc1574f8a77e2f1f5c",
      "parents": [
        "0b1a9f7648a9e57b0eaf6766f73810de94136669",
        "5921fb51e0219ddd7cad439a73495f320c57d50e"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon Dec 07 10:01:06 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Dec 07 10:01:06 2009 -0800"
      },
      "message": "am 5921fb51: Merge change I91eb0354 into eclair-mr2\n\nMerge commit \u00275921fb51e0219ddd7cad439a73495f320c57d50e\u0027 into eclair-mr2-plus-aosp\n\n* commit \u00275921fb51e0219ddd7cad439a73495f320c57d50e\u0027:\n  Change OMXCodec::Create to return an sp\u003cMediaSource\u003e instead of an sp\u003cOMXCodec\u003e, this is more general and does not sacrifice any functionality as the remaining OMXCodec APIs are not meant to be public anyway.\n"
    },
    {
      "commit": "91eb0354043842d96bf3ef201ce68046db70df74",
      "tree": "b09f35a1f7887ef25af837d000bd041176368f3b",
      "parents": [
        "52f410e2ebba103220cffce05b895f0c38a56665"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon Dec 07 09:43:00 2009 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon Dec 07 09:43:00 2009 -0800"
      },
      "message": "Change OMXCodec::Create to return an sp\u003cMediaSource\u003e instead of an sp\u003cOMXCodec\u003e, this is more general and does not sacrifice any functionality as the remaining OMXCodec APIs are not meant to be public anyway.\n"
    },
    {
      "commit": "5d676ad5d94c3d4f831c2084012f955fe56a8af8",
      "tree": "63aa60a7cc858c9f2bb0329d7d66eaa15129ed18",
      "parents": [
        "a26b0a401b6aadb45fa58d1d05b3112fbfda3fba",
        "52f410e2ebba103220cffce05b895f0c38a56665"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Dec 04 13:41:15 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Dec 04 13:41:15 2009 -0800"
      },
      "message": "am 52f410e2: Merge change Ifef6435a into eclair-mr2\n\nMerge commit \u002752f410e2ebba103220cffce05b895f0c38a56665\u0027 into eclair-mr2-plus-aosp\n\n* commit \u002752f410e2ebba103220cffce05b895f0c38a56665\u0027:\n  Enable proper cleanup of OMX nodes managed through stagefright.\n"
    },
    {
      "commit": "fef6435a0692f3c9b6055903dfb7699e90e19d46",
      "tree": "fa8756a53bac8564a0b133056ed5e49d71367e8c",
      "parents": [
        "8280c2b15f6875b2d387c05df23d264864eb9cd5"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Dec 04 12:52:40 2009 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Dec 04 12:52:40 2009 -0800"
      },
      "message": "Enable proper cleanup of OMX nodes managed through stagefright.\n"
    },
    {
      "commit": "9ee55cc1bc6878b243134a558d583786d9215958",
      "tree": "c9c1e43e5bcf5baa160bba6e91c8aba06969a670",
      "parents": [
        "874c508c5352936c0640317ef44b81c9b632dfd6",
        "2d6d609c9ede7ed8924001df00af9c13effab8ad"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Dec 03 16:40:04 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Dec 03 16:40:04 2009 -0800"
      },
      "message": "am 2d6d609c: Merge change I74bf38a0 into eclair-mr2\n\nMerge commit \u00272d6d609c9ede7ed8924001df00af9c13effab8ad\u0027 into eclair-mr2-plus-aosp\n\n* commit \u00272d6d609c9ede7ed8924001df00af9c13effab8ad\u0027:\n  Squashed commit of the following:\n"
    },
    {
      "commit": "874c508c5352936c0640317ef44b81c9b632dfd6",
      "tree": "224e055763eb5abe5f20c4c48dcb3b1fded8392f",
      "parents": [
        "ca84ac88c7f6940677f9b796b21779e53965bf06",
        "bfb9fb143b67c2d0307af2bce9af3c08f362b29a"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Dec 03 16:39:27 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Dec 03 16:39:27 2009 -0800"
      },
      "message": "am bfb9fb14: Refactor MediaScanner. Some steps on the way towards being able to build the tree without OpenCore.\n\nMerge commit \u0027bfb9fb143b67c2d0307af2bce9af3c08f362b29a\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027bfb9fb143b67c2d0307af2bce9af3c08f362b29a\u0027:\n  Refactor MediaScanner. Some steps on the way towards being able to build the tree without OpenCore.\n"
    },
    {
      "commit": "2d6d609c9ede7ed8924001df00af9c13effab8ad",
      "tree": "1839095bd156d22f04683e9d97d805e44f3d7ba3",
      "parents": [
        "bfb9fb143b67c2d0307af2bce9af3c08f362b29a",
        "b0caf946b7ae9be519c0cede935ea2ecb44f9bd0"
      ],
      "author": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Dec 03 13:27:08 2009 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Dec 03 13:27:08 2009 -0800"
      },
      "message": "Merge change I74bf38a0 into eclair-mr2\n\n* changes:\n  Squashed commit of the following:\n"
    },
    {
      "commit": "bfb9fb143b67c2d0307af2bce9af3c08f362b29a",
      "tree": "6b22297ab9749e2c86d3ae4844a7bad884027118",
      "parents": [
        "d345c6acedb22c9408553ef9f38c196984177e6b"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Dec 03 11:31:19 2009 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Dec 03 13:21:54 2009 -0800"
      },
      "message": "Refactor MediaScanner. Some steps on the way towards being able to build the tree without OpenCore.\n"
    },
    {
      "commit": "b0caf946b7ae9be519c0cede935ea2ecb44f9bd0",
      "tree": "aa8315ada7a14c5f0b516c7dd7361d7accbda662",
      "parents": [
        "4eeace3db541bd6fa0034a996630768cb521f2eb"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Dec 03 11:39:54 2009 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Dec 03 12:49:09 2009 -0800"
      },
      "message": "Squashed commit of the following:\n\ncommit 543e192bf2ae13f573dc4c4e53b239ed4ea00e81\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Dec 3 11:33:57 2009 -0800\n\n    stagefright now acts as the OMX Master, vendors supply their own plugins through libstagefrighthw. In OpenCore-enabled builds we now sit on top of PVMaster...\n\ncommit 3cbfdbd9cecadbb77b63125c62883bf1065884fe\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Dec 2 12:39:07 2009 -0800\n\n    More OMX infrastructure, stagefright is now taking over the OMX Master, multiplexing all contributing OMX implementations under a common interface.\n"
    },
    {
      "commit": "ae34cf92db9c54ba72fdcac33a8ba855a2215e4e",
      "tree": "5cc9bae71d0cc0ab6a9f86456ca1bc0b77589fbe",
      "parents": [
        "3414c67afaf745400735f27eb1aad7dbf5e79423",
        "781ac16283574ec07cd7b13d67b54b7b4c2c15cb"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Dec 01 17:10:19 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Tue Dec 01 17:10:19 2009 -0800"
      },
      "message": "am 781ac162: Merge change I8768f2cc into eclair-mr2\n\nMerge commit \u0027781ac16283574ec07cd7b13d67b54b7b4c2c15cb\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027781ac16283574ec07cd7b13d67b54b7b4c2c15cb\u0027:\n  A small sample tool to encode pcm audio data to amr, decode it again and play it. Some changes to OMXCodec to properly configure the AMR decoder(s).\n"
    },
    {
      "commit": "8768f2ccefdd7862a248995055aa04fd2d5a4dfe",
      "tree": "889d228a9857efec02281f1536b11699dfa2a6f6",
      "parents": [
        "ed90811e711065bcc82a45f4173587cd95ef6b6f"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Dec 01 15:26:54 2009 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Dec 01 15:26:54 2009 -0800"
      },
      "message": "A small sample tool to encode pcm audio data to amr, decode it again and play it. Some changes to OMXCodec to properly configure the AMR decoder(s).\n"
    },
    {
      "commit": "5493df919b01952857eb3b78fad3fe2cff573935",
      "tree": "d3174c7a59eaade19930e0a03444cc66a1b4f28c",
      "parents": [
        "1866591c192a434c3edcafb808e31b8262cadeb2",
        "bbd6cb463b405fc90912dee470fe6c7b8c6b1f54"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon Nov 23 10:51:41 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Nov 23 10:51:41 2009 -0800"
      },
      "message": "am bbd6cb46: Merge change Ib1b7bce4 into eclair-mr2\n\nMerge commit \u0027bbd6cb463b405fc90912dee470fe6c7b8c6b1f54\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027bbd6cb463b405fc90912dee470fe6c7b8c6b1f54\u0027:\n  Squashed commit of the following:\n"
    },
    {
      "commit": "27366fc9540cb642ee4856957dabffe7ddf1f901",
      "tree": "b3509359b040abfe0055af4345a01520453d112c",
      "parents": [
        "40c1dbf081035f878b96dd67ef112eb49001c087"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Nov 20 09:32:46 2009 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon Nov 23 10:44:30 2009 -0800"
      },
      "message": "Squashed commit of the following:\n\ncommit 1efc38dc3c33fef57b759002db3965ed07a28cb0\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Nov 19 14:36:14 2009 -0800\n\n    Sending the SEEK-COMPLETE notification temporarily broke seeking backwards in time behaviour. This is now fixed.\n\n    Also, get rid of the semi-random delay after posting buffers to surface flinger in favour of delaying the buffer release until the next frame is displayed.\n\ncommit 51973062eb5ee63fd64b845d72bac517cc3369cf\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Nov 18 14:01:43 2009 -0800\n\n    Fix one more unit test, properly send seek-complete notification only after seek actually completed.\n\ncommit cb22250b34b1fcfe1bf459723a761fd003950229\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Nov 18 12:31:36 2009 -0800\n\n    Fix seek-while-paused in AwesomePlayer, revert to using FileSource if MmapSource fails.\n\ncommit 25eb9241138ddf7bb27ce90657116c5f8a94d880\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Nov 18 12:30:40 2009 -0800\n\n    Support seeking and duration in AMRExtractor, assuming all frames are the same size.\n\ncommit 44192f2ebb7ea3bbd3ba5910025692dbc6a08faa\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Nov 18 10:21:44 2009 -0800\n\n    MediaPlayerImpl is dead, long live AwesomePlayer.\n\ncommit c5b52d3c0674f5dc94db506afbce52401cceddac\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Nov 18 09:42:23 2009 -0800\n\n    New implementation of the stagefright mediaplayer.\n"
    },
    {
      "commit": "8652646105a6ace559280b579ee8935541ada6c1",
      "tree": "178a60adc376ac3402c557180008b48e85950ce3",
      "parents": [
        "acedb7d0c3452ff7347fec8f643034e938a55137",
        "949c572a16881aa40079a42bf7682637b23eb16a"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Sat Nov 21 00:26:09 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Sat Nov 21 00:26:09 2009 -0800"
      },
      "message": "am 949c572a: am e7800946: Merge change I49f02be9 into eclair\n\nMerge commit \u0027949c572a16881aa40079a42bf7682637b23eb16a\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027949c572a16881aa40079a42bf7682637b23eb16a\u0027:\n  Issue 2265163: Audio still reported routed through earpiece on sholes\n"
    },
    {
      "commit": "949c572a16881aa40079a42bf7682637b23eb16a",
      "tree": "5bfc9099a3b1745168a44c2469ecc175d48932e8",
      "parents": [
        "30a4b8a180813ae9a1846fdd7219ebe5592eb06b",
        "e7800946a42c0ebe8e0b3f6eba04a96a9641aaff"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Sat Nov 21 00:21:15 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Sat Nov 21 00:21:15 2009 -0800"
      },
      "message": "am e7800946: Merge change I49f02be9 into eclair\n\nMerge commit \u0027e7800946a42c0ebe8e0b3f6eba04a96a9641aaff\u0027 into eclair-mr2\n\n* commit \u0027e7800946a42c0ebe8e0b3f6eba04a96a9641aaff\u0027:\n  Issue 2265163: Audio still reported routed through earpiece on sholes\n"
    },
    {
      "commit": "e7800946a42c0ebe8e0b3f6eba04a96a9641aaff",
      "tree": "4761b4ea0b5fb01d1a90eb069a1839e6c6445ab4",
      "parents": [
        "256da9fb007ac0722a5b1854befda7e7bed2564e",
        "49f02be9d7fafb8841f75394a90f1409c6f82c1f"
      ],
      "author": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Sat Nov 21 00:18:24 2009 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Sat Nov 21 00:18:24 2009 -0800"
      },
      "message": "Merge change I49f02be9 into eclair\n\n* changes:\n  Issue 2265163: Audio still reported routed through earpiece on sholes\n"
    },
    {
      "commit": "49f02be9d7fafb8841f75394a90f1409c6f82c1f",
      "tree": "610ce96e47ae1e2c8ead39ba58e43380b6537633",
      "parents": [
        "e4260f4e7da4da32bfab2737018cf9cf75215894"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Thu Nov 19 09:00:56 2009 -0800"
      },
      "committer": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Thu Nov 19 23:57:45 2009 -0800"
      },
      "message": "Issue 2265163: Audio still reported routed through earpiece on sholes\n\nThis is a second attempt to fix the audio routed to earpiece syndrom.\nThe root cause identified this time is the crash of an application having an active AudioTrack playing on the VOICE_CALL stream type.\nWhen this happens, the AudioTrack destructor is not called and the audio policy manager is not notified of the track stop.\nResults a situation where the VOICE_CALL stream is considered as always in use by audio policy manager which makes that audio is routed to earpiece.\n\nThe fix consists in moving the track start/stop/close notification to audio policiy manager from AudioTrack to AudioFlinger Track objet.\nThe net result is that in the case of a client application crash, the AudioFlinger TrackHandle object (which implements the remote side of the IAudioTrack binder interface) destructor is called which in turn destroys the Track object and we can notify the audio policy manager of the track stop and removal.\n\nThe same modification is made for AudioRecord although no bug related to record has been reported yet.\nAlso fixed a potential problem if record stop is called while the record thread is exiting.\n"
    },
    {
      "commit": "d66a901e6a932e62358ee963831e663a8c655b8e",
      "tree": "0a93a1a9a8ccef2299c00fc70622b0f80b3d0b87",
      "parents": [
        "e4260f4e7da4da32bfab2737018cf9cf75215894"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Nov 19 11:22:36 2009 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Nov 19 11:24:18 2009 -0800"
      },
      "message": "DO NOT MERGE: Instead of inserting semi-random delays after submission to surface flinger, delay releasing buffers to the next display time to avoid flickering.\n"
    },
    {
      "commit": "39dc51040f9b766adaa9ee487bb0568a2ed1c916",
      "tree": "4acfd242fca71ecd17a8b82e49d302e2b922327d",
      "parents": [
        "ed9880f399015782c9f635db744d25281d0deeb4",
        "2c7664989f7388c0c6cf0ec7d80ffa2704c8c2be"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Nov 17 10:50:22 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Tue Nov 17 10:50:22 2009 -0800"
      },
      "message": "am 2c766498: Merge change Iea6a38c6 into eclair-mr2\n\nMerge commit \u00272c7664989f7388c0c6cf0ec7d80ffa2704c8c2be\u0027 into eclair-mr2-plus-aosp\n\n* commit \u00272c7664989f7388c0c6cf0ec7d80ffa2704c8c2be\u0027:\n  Squashed commit of the following:\n"
    },
    {
      "commit": "2c7664989f7388c0c6cf0ec7d80ffa2704c8c2be",
      "tree": "eca65a517e48f75ff22ea7d60a0a42553cc5f889",
      "parents": [
        "a35f1c63a67df0832d9b3f1aed3e2376367d4398",
        "ea6a38c63b9e9aeb45aa22587c069bd3c5d83df8"
      ],
      "author": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Nov 17 10:46:41 2009 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Nov 17 10:46:41 2009 -0800"
      },
      "message": "Merge change Iea6a38c6 into eclair-mr2\n\n* changes:\n  Squashed commit of the following:\n"
    },
    {
      "commit": "775508d97f709e621f9d1540aca819224fbdcebf",
      "tree": "5d93568bb639f19009ddc2334fb03c9cf1765ded",
      "parents": [
        "50963b1aa5c2828b46a4e0acf7626b8aef83ef68",
        "744043fcbf48c32c2051f222eca552fa2df5dfcb"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Nov 17 10:36:27 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Tue Nov 17 10:36:27 2009 -0800"
      },
      "message": "am 744043fc: Update FileSource to also accept a file descriptor and a range.\n\nMerge commit \u0027744043fcbf48c32c2051f222eca552fa2df5dfcb\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027744043fcbf48c32c2051f222eca552fa2df5dfcb\u0027:\n  Update FileSource to also accept a file descriptor and a range.\n"
    },
    {
      "commit": "744043fcbf48c32c2051f222eca552fa2df5dfcb",
      "tree": "bc84dc8cc46fe0b7a7b9ec21228eaf040d3152bb",
      "parents": [
        "8c808187249f473702e0f4bee2147da292490963"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon Nov 16 15:34:01 2009 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Nov 17 10:21:03 2009 -0800"
      },
      "message": "Update FileSource to also accept a file descriptor and a range.\n"
    },
    {
      "commit": "ea6a38c63b9e9aeb45aa22587c069bd3c5d83df8",
      "tree": "a24b9b97b20d16f5343923c4245c4b19985e8717",
      "parents": [
        "a57632fee792d6078a7a61006f5a866c38addd33"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon Nov 16 15:43:38 2009 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon Nov 16 15:43:38 2009 -0800"
      },
      "message": "Squashed commit of the following:\n\ncommit 333057b355f8c260c549553b9a0634755c838b6a\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri Nov 13 15:35:48 2009 -0800\n\n    Some more tweaks to AVC encoding on sholes.\n\ncommit 9981d0ee52ec5b8b0182aae733d1571e3ebb8390\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Nov 12 16:36:57 2009 -0800\n\n    Support for avc encoding, including sholes specific tweaks to pick the right colorspace for the camera to not require transcoding.\n\ncommit 5ba0ebbbd4efca51f3ae1f60e2ca31e7d2cf136d\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Wed Nov 11 09:50:03 2009 -0800\n\n    Enable actual (camera) video-only recording using h.263 or mpeg4 encoding.\n\ncommit 3fd59c3526a37fe7c696f4a978925d1831c09313\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Tue Nov 10 14:57:48 2009 -0800\n\n    Allow switching between the PV recorder implementation and one supported by stagefright.\n\n    This is controlled through the property \"media.stagefright.enable-record\".\n"
    },
    {
      "commit": "70a37eac62e887d16c4964b805a612d41254ca7f",
      "tree": "9e056699d6a09f81c50d5c07e5f9aeeb369f58c4",
      "parents": [
        "c0355905414c330c7fe7fe64f82fcd90c0675d7e",
        "35ede78ede13fc2c4e7d343f50ca20372a404e06"
      ],
      "author": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Fri Nov 13 17:37:42 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Nov 13 17:37:42 2009 -0800"
      },
      "message": "am 35ede78e: am 91e40e78: Merge change I18e02606 into eclair\n\nMerge commit \u002735ede78ede13fc2c4e7d343f50ca20372a404e06\u0027 into eclair-mr2-plus-aosp\n\n* commit \u002735ede78ede13fc2c4e7d343f50ca20372a404e06\u0027:\n  fix some aspects of [2258746] native crash in launcher2\n"
    },
    {
      "commit": "35ede78ede13fc2c4e7d343f50ca20372a404e06",
      "tree": "2d5bfea1c668196ea7caa827e0107accc8987388",
      "parents": [
        "0a27865a015d9e0401b6b3bff9eedd06d59043b3",
        "91e40e7838d183cb2a9e750edf0a6572f21da21d"
      ],
      "author": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Fri Nov 13 17:33:52 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Nov 13 17:33:52 2009 -0800"
      },
      "message": "am 91e40e78: Merge change I18e02606 into eclair\n\nMerge commit \u002791e40e7838d183cb2a9e750edf0a6572f21da21d\u0027 into eclair-mr2\n\n* commit \u002791e40e7838d183cb2a9e750edf0a6572f21da21d\u0027:\n  fix some aspects of [2258746] native crash in launcher2\n"
    },
    {
      "commit": "18e026066a95e5d63c2ece8007883b46599373ca",
      "tree": "e7c8d0f1e1cc5283222d635c595da3a2ce1bfc5f",
      "parents": [
        "73f8aa678055598738dfba54c60a1674bcbf02b1"
      ],
      "author": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Fri Nov 13 15:26:29 2009 -0800"
      },
      "committer": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Fri Nov 13 15:26:29 2009 -0800"
      },
      "message": "fix some aspects of [2258746] native crash in launcher2\n\nSurface::validate() could sometimes dereference a null pointer before checking it wasn\u0027t null.\nThis will prevent the application to crash when given bad parameters or used incorrectly.\nHowever, the bug above probably has another cause.\n"
    },
    {
      "commit": "355743c70d9810fda3e59d718d055f9513fb05b7",
      "tree": "95f8413571006e79872cfbd5fdadb2070e665eaf",
      "parents": [
        "bd328d0113ae29bd351d39faedc6c4e7957db4ad",
        "609acfd2a1067f49e51925776484b070a24d8301"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Fri Nov 13 09:27:55 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Nov 13 09:27:55 2009 -0800"
      },
      "message": "am 609acfd2: am 1aa9f3ca: Merge change I923d7d72 into eclair\n\nMerge commit \u0027609acfd2a1067f49e51925776484b070a24d8301\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027609acfd2a1067f49e51925776484b070a24d8301\u0027:\n  Fix issue 2242614: Wired headset not recognized: bogus \"state\" in ACTION_HEADSET_PLUG broadcast.\n"
    },
    {
      "commit": "609acfd2a1067f49e51925776484b070a24d8301",
      "tree": "e4aa99e7087476b09fad41c9ef1a30828e979181",
      "parents": [
        "9b94211787b237fd59153f58dd41d738290866c4",
        "1aa9f3cac31a7c2b50fcb3c9259cead8d638ae54"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Thu Nov 12 23:10:18 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Nov 12 23:10:18 2009 -0800"
      },
      "message": "am 1aa9f3ca: Merge change I923d7d72 into eclair\n\nMerge commit \u00271aa9f3cac31a7c2b50fcb3c9259cead8d638ae54\u0027 into eclair-mr2\n\n* commit \u00271aa9f3cac31a7c2b50fcb3c9259cead8d638ae54\u0027:\n  Fix issue 2242614: Wired headset not recognized: bogus \"state\" in ACTION_HEADSET_PLUG broadcast.\n"
    },
    {
      "commit": "1aa9f3cac31a7c2b50fcb3c9259cead8d638ae54",
      "tree": "e98594a27996fdf11fa7a643895e513b28c7ba7d",
      "parents": [
        "5f8f1487be78064e8d653dd2d105d8dd444d6a35",
        "923d7d721d37f6ba5148e7d79d61a4fa48e79df2"
      ],
      "author": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Nov 12 22:45:50 2009 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Nov 12 22:45:50 2009 -0800"
      },
      "message": "Merge change I923d7d72 into eclair\n\n* changes:\n  Fix issue 2242614: Wired headset not recognized: bogus \"state\" in ACTION_HEADSET_PLUG broadcast.\n"
    },
    {
      "commit": "923d7d721d37f6ba5148e7d79d61a4fa48e79df2",
      "tree": "79d0aae61449c8c048cfc494cf5a3354174749dc",
      "parents": [
        "3c58d279abed1da56b0ece74ded5854c509a42a4"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Thu Nov 12 12:09:06 2009 -0800"
      },
      "committer": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Thu Nov 12 12:09:06 2009 -0800"
      },
      "message": "Fix issue 2242614: Wired headset not recognized: bogus \"state\" in ACTION_HEADSET_PLUG broadcast.\n\nThe headset state indicated by HeadsetObserver in the broadcast intent ACTION_HEADSET_PLUG was not 0 or 1 as specified in the java doc but contained a bit field indicating the type of headset connected.\n\nModified HeadsetObserver to broacast a state conforming to java doc.\nAdded an extra to intent ACTION_HEADSET_PLUG to indicate if headset has a microphone or not.\nRemoved handling of non standard headset indications from HeadsetObserver.\nRemoved platform specific devices from output devices defined in AudioSystem.\nModified AudioService to use new ACTION_HEADSET_PLUG intent extra instead of bitfield in state.\n"
    },
    {
      "commit": "bfdb1e88ef796969efc906e7648b552078c82aee",
      "tree": "5549561501a8a8b27263ae9650a8cd56f1ac75bb",
      "parents": [
        "cd90b2773e81b337436e71717cb6c8b5704af5c8",
        "d0f3228daa9ea26ec959cb79451e6f150648bce8"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Nov 12 10:43:31 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Nov 12 10:43:31 2009 -0800"
      },
      "message": "am d0f3228d: resolved conflicts for merge of c66d53f9 to eclair-mr2\n\nMerge commit \u0027d0f3228daa9ea26ec959cb79451e6f150648bce8\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027d0f3228daa9ea26ec959cb79451e6f150648bce8\u0027:\n  Delegate the platform dependent hardware renderer implementation to a shared library provided by the vendor.\n"
    },
    {
      "commit": "d0f3228daa9ea26ec959cb79451e6f150648bce8",
      "tree": "40f970764ab4a09055eae27a3166c6a1fbf689bf",
      "parents": [
        "17d176d8570f7d76532afee43853339c60fc9850",
        "c66d53f97b1fe635f576642d5720dcd441e34cce"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Nov 12 10:32:26 2009 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Nov 12 10:32:26 2009 -0800"
      },
      "message": "resolved conflicts for merge of c66d53f9 to eclair-mr2\n"
    },
    {
      "commit": "c8d7c1492eece9fb382424dfe63dcd1387c43314",
      "tree": "58382df5057496afd093677e4ead5e14cf137e6a",
      "parents": [
        "3e584fc944e3d694b4233450f386bd2a930420bf"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Nov 11 16:33:17 2009 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Nov 12 09:36:10 2009 -0800"
      },
      "message": "Delegate the platform dependent hardware renderer implementation to a shared library provided by the vendor.\n"
    },
    {
      "commit": "dcaa220ff5f360a29ac8be0eb12a8238ecaa080f",
      "tree": "8af64f607838fa0af5c45057b518c76b552cb0a4",
      "parents": [
        "818a9cf827f282addbf7c8ee23534e08a3aaa358"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Nov 05 12:04:22 2009 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Nov 05 13:06:17 2009 -0800"
      },
      "message": "DO NOT MERGE: Squashed commit of the following:\n\ncommit 08259dd3dc9026887f9bbfedaf45866eb56ea9bc\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Nov 5 12:02:31 2009 -0800\n\n    DO NOT MERGE: Use PV for metadata extraction even if stagefright is used for playback.\n\ncommit 991832fe4dc012e51d3d9ed8d647c7f09991858f\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Nov 5 11:24:11 2009 -0800\n\n    DO NOT MERGE: Do not assert if we encounter OMX_StateInvalid. All bets are off though.\n\ncommit cec45cf302d9218fe79956cbe8a462d7ca3a10bb\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Oct 26 16:11:54 2009 -0700\n\n    DO NOT MERGE: When freeing an OMX node, attempt to transition it from its current state all the way to \"Loaded\" in order to properly free any allocated buffers.\n\ncommit 34a1e885ef9113d68acbc26d36fcc47fdebbed84\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Nov 5 11:10:49 2009 -0800\n\n    DO NOT MERGE: Fix heap corruptin in OMXNodeInstance.\n\ncommit 5a47f7439a1298b330541a7e4e647a8b44487388\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Nov 5 11:08:19 2009 -0800\n\n    DO NOT MERGE: Fix seek-on-initial-read behaviour of OMXCodec.\n\ncommit 45bed64722501b9f411a2940aff5aff4cc4d2e98\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Nov 5 11:02:23 2009 -0800\n\n    DO NOT MERGE: Renaming string.h to stagefright_string.h to avoid conflicts.\n\ncommit 6738e306a50196f31a73d4fc7b7c45faff639903\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Oct 15 13:46:54 2009 -0700\n\n    DO NOT MERGE: Reimplement the OMX backend for stagefright.\n\n    Besides 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\n    Changed APIs to conform to the rest of the system.\n"
    },
    {
      "commit": "653d5d415c3447a4250120548bf32d1ee63fe36f",
      "tree": "98dd9b275c2965b6b724e84a2a1fc93da71541c3",
      "parents": [
        "931203d4052ad9e02cc0a49b5d6b68c44e4d4072",
        "fcae6c71794696a074cabf20beeb02fd87853e30"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Thu Nov 05 01:55:51 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Nov 05 01:55:51 2009 -0800"
      },
      "message": "am fcae6c71: am 67b69292: Merge change I93f500a5 into eclair\n\nMerge commit \u0027fcae6c71794696a074cabf20beeb02fd87853e30\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027fcae6c71794696a074cabf20beeb02fd87853e30\u0027:\n  Fix issue 2203561: Sholes: audio playing out of earpiece.\n"
    },
    {
      "commit": "fcae6c71794696a074cabf20beeb02fd87853e30",
      "tree": "681e88f22ffa0855ac5a75a049beb223d6a4d96f",
      "parents": [
        "dc0f9efd356e5f212c54f87c7a7ddde5d28046d3",
        "67b692920c18f99b096dce285adc6f7439fa866c"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Thu Nov 05 00:01:33 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Nov 05 00:01:33 2009 -0800"
      },
      "message": "am 67b69292: Merge change I93f500a5 into eclair\n\nMerge commit \u002767b692920c18f99b096dce285adc6f7439fa866c\u0027 into eclair-mr2\n\n* commit \u002767b692920c18f99b096dce285adc6f7439fa866c\u0027:\n  Fix issue 2203561: Sholes: audio playing out of earpiece.\n"
    },
    {
      "commit": "67b692920c18f99b096dce285adc6f7439fa866c",
      "tree": "e8461fd50578bf3f4ad828fc8ae553893603121f",
      "parents": [
        "584bce31b62cdf3efd8a9eb40442c4cc612ce1e6",
        "bda7469d9b1ec6d9c9d6da40ddf64dc39ff271a9"
      ],
      "author": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Nov 05 02:55:26 2009 -0500"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Nov 05 02:55:26 2009 -0500"
      },
      "message": "Merge change I93f500a5 into eclair\n\n* changes:\n  Fix issue 2203561: Sholes: audio playing out of earpiece.\n"
    },
    {
      "commit": "bda7469d9b1ec6d9c9d6da40ddf64dc39ff271a9",
      "tree": "b89b73e6feeadefb4ad958c0359789cf0ae5b90f",
      "parents": [
        "e1e0dc8e6eaec052ebb6b88f5b1223075ce5a356"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Wed Nov 04 08:27:26 2009 -0800"
      },
      "committer": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Wed Nov 04 23:47:21 2009 -0800"
      },
      "message": "Fix issue 2203561: Sholes: audio playing out of earpiece.\n\nCreate a new IAudioTrack interface to AudioFlinger when start() fails due to a broken pipe error.\nDo the same if start fails due to the same error after time out in obtainBuffer().\nDo not indicate that the AudioTrack is started to AudioPolicyManager if IAudioTrack start fails.\nThis avoids that an AudioTrack keeps a dead IAudioTrack after a media server crash.\n\nSame modifications for AudioRecord.\n\nAdd a flag to ToneGenerator indicating that the callback thread can call Java. Without it, when the media server crashes and restarts, the AudioSystem error callback will crash in JNI if the IAudiotrack is created from AudioTrack callback thread.\n"
    },
    {
      "commit": "bd38397bc4f754c040d4abf5435c2469c3357924",
      "tree": "e1a224a6cfb0af068037491a02e562eaf371804e",
      "parents": [
        "8495359382bc7c94a776e51c596e807448796476",
        "3d2d155a87cdd3038a2e6df8741181431cb250e1"
      ],
      "author": {
        "name": "Jean-Michel Trivi",
        "email": "jmtrivi@google.com",
        "time": "Wed Nov 04 13:23:00 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 04 13:23:00 2009 -0800"
      },
      "message": "am 3d2d155a: am 7ed0ceeb: Merge change I6869df3a into eclair\n\nMerge commit \u00273d2d155a87cdd3038a2e6df8741181431cb250e1\u0027 into eclair-mr2-plus-aosp\n\n* commit \u00273d2d155a87cdd3038a2e6df8741181431cb250e1\u0027:\n  Add new audio sources to support the A1026 recording configurations.\n"
    },
    {
      "commit": "3d2d155a87cdd3038a2e6df8741181431cb250e1",
      "tree": "1937cbac3e457fa89938037ae2fbc573ded394c9",
      "parents": [
        "ad278f2276de23197571e486ad387dacc7f346ee",
        "7ed0ceeba54712f76e9a4f2dd4c9197d76813488"
      ],
      "author": {
        "name": "Jean-Michel Trivi",
        "email": "jmtrivi@google.com",
        "time": "Wed Nov 04 12:05:34 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 04 12:05:34 2009 -0800"
      },
      "message": "am 7ed0ceeb: Merge change I6869df3a into eclair\n\nMerge commit \u00277ed0ceeba54712f76e9a4f2dd4c9197d76813488\u0027 into eclair-mr2\n\n* commit \u00277ed0ceeba54712f76e9a4f2dd4c9197d76813488\u0027:\n  Add new audio sources to support the A1026 recording configurations.\n"
    },
    {
      "commit": "8495359382bc7c94a776e51c596e807448796476",
      "tree": "5208ba5efa55b4ef2b321e78b512611d59b65fa8",
      "parents": [
        "7146332e9999443e22296d6d0968f95b80e79af6",
        "ad278f2276de23197571e486ad387dacc7f346ee"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Nov 04 10:43:01 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 04 10:43:01 2009 -0800"
      },
      "message": "am ad278f22: Merge change I6bce6d87 into eclair-mr2\n\nMerge commit \u0027ad278f2276de23197571e486ad387dacc7f346ee\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027ad278f2276de23197571e486ad387dacc7f346ee\u0027:\n  Adds a WAVExtractor for 16-bit signed PCM audio wave files.\n"
    },
    {
      "commit": "6869df3a5db0ca0037394f0fd14aecc1d80b5b42",
      "tree": "1d2c10ca2bd9fb71002375c8f9f3d61a9dfa2506",
      "parents": [
        "b96a9d9296925fef6a1c0e5ad4d847d96bf9acb5"
      ],
      "author": {
        "name": "Jean-Michel Trivi",
        "email": "jmtrivi@google.com",
        "time": "Tue Nov 03 19:43:21 2009 -0800"
      },
      "committer": {
        "name": "Jean-Michel Trivi",
        "email": "jmtrivi@google.com",
        "time": "Tue Nov 03 19:43:21 2009 -0800"
      },
      "message": "Add new audio sources to support the A1026 recording configurations.\n"
    },
    {
      "commit": "6bce6d87b3fd98e68fb54328fb4dc8e40cd2c293",
      "tree": "d1db8e33e22af4a4906f8f2c48492f1feed338cf",
      "parents": [
        "313953dccb55987d519281990f274d4c1c0d21a5"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Nov 03 16:00:58 2009 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Nov 03 16:00:58 2009 -0800"
      },
      "message": "Adds a WAVExtractor for 16-bit signed PCM audio wave files.\n"
    },
    {
      "commit": "d1d744cdf4b08c8ef969790bae305c82ae783f4e",
      "tree": "762ea10c48d0b35074c79b2074f5f916e47a2577",
      "parents": [
        "c4bbb9144d1955340d69548e7245417cbe862d3c",
        "07d38c66692b7d87415667010c0658202b5a7f39"
      ],
      "author": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Tue Nov 03 09:47:31 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Tue Nov 03 09:47:31 2009 -0800"
      },
      "message": "am 07d38c66: am 8637759a: Merge change I36d0184e into eclair\n\nMerge commit \u002707d38c66692b7d87415667010c0658202b5a7f39\u0027 into eclair-mr2-plus-aosp\n\n* commit \u002707d38c66692b7d87415667010c0658202b5a7f39\u0027:\n  fix[2228133] pixelflinger ignores the \"vertical stride\" leading to artifacts when playing back video\n"
    },
    {
      "commit": "07d38c66692b7d87415667010c0658202b5a7f39",
      "tree": "e9571801445894dac9baa92d15aa153f18d65973",
      "parents": [
        "6cb76ac37f1b4a36d81db7d7e8652d82b6f1b8b5",
        "8637759a1d34a4adda292579d5f8790587659235"
      ],
      "author": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Tue Nov 03 09:34:40 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Tue Nov 03 09:34:40 2009 -0800"
      },
      "message": "am 8637759a: Merge change I36d0184e into eclair\n\nMerge commit \u00278637759a1d34a4adda292579d5f8790587659235\u0027 into eclair-mr2\n\n* commit \u00278637759a1d34a4adda292579d5f8790587659235\u0027:\n  fix[2228133] pixelflinger ignores the \"vertical stride\" leading to artifacts when playing back video\n"
    },
    {
      "commit": "8637759a1d34a4adda292579d5f8790587659235",
      "tree": "5146d928142d0c3f246d9cb968db8f5302767bab",
      "parents": [
        "483d29c0ddc9f4c110a8a8788ccd978010d55aa4",
        "36d0184e089831b74de6005f01da9e7b26679bb9"
      ],
      "author": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Mon Nov 02 21:26:54 2009 -0500"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Mon Nov 02 21:26:54 2009 -0500"
      },
      "message": "Merge change I36d0184e into eclair\n\n* changes:\n  fix[2228133] pixelflinger ignores the \"vertical stride\" leading to artifacts when playing back video\n"
    },
    {
      "commit": "36d0184e089831b74de6005f01da9e7b26679bb9",
      "tree": "8a6cb7b2f9e5c53db29bc818a403b26add0c66fe",
      "parents": [
        "989b76aadd92538c7ab4ca00c34508b42fda8cef"
      ],
      "author": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Mon Nov 02 17:48:33 2009 -0800"
      },
      "committer": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Mon Nov 02 17:48:33 2009 -0800"
      },
      "message": "fix[2228133] pixelflinger ignores the \"vertical stride\" leading to artifacts when playing back video\n\nwe lost the concept of vertical stride when moving video playback to EGLImage.\nHere we bring it back in a somewhat hacky-way that will work only for the\nsoftgl/mdp backend.\n"
    },
    {
      "commit": "8ba42ba83b206929c4c13c0b8ef24de87a92f42c",
      "tree": "e1c4b46396275be44634ed090e0b2f867c8f48bc",
      "parents": [
        "fb1d992f4b8addad729a94cb006a732a40b62756",
        "cd767bfd1c8e3103f99207ecfa34385e76518e82"
      ],
      "author": {
        "name": "Iliyan Malchev",
        "email": "malchev@google.com",
        "time": "Mon Nov 02 15:07:04 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Nov 02 15:07:04 2009 -0800"
      },
      "message": "am cd767bfd: am d4649b2f: Merge change Ibaef6141 into eclair\n\nMerge commit \u0027cd767bfd1c8e3103f99207ecfa34385e76518e82\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027cd767bfd1c8e3103f99207ecfa34385e76518e82\u0027:\n  libbinder: add a NO_CACHING flag to MemoryHeapBase\n"
    },
    {
      "commit": "cd767bfd1c8e3103f99207ecfa34385e76518e82",
      "tree": "533445ad1d5185881897b0c4261a8f56bfa7775b",
      "parents": [
        "1166ff76eb3dbb5304dc40b3056e48c2c9dc7577",
        "d4649b2f8ea8285a4eb3c47e87520c7835e6c672"
      ],
      "author": {
        "name": "Iliyan Malchev",
        "email": "malchev@google.com",
        "time": "Mon Nov 02 15:01:36 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Nov 02 15:01:36 2009 -0800"
      },
      "message": "am d4649b2f: Merge change Ibaef6141 into eclair\n\nMerge commit \u0027d4649b2f8ea8285a4eb3c47e87520c7835e6c672\u0027 into eclair-mr2\n\n* commit \u0027d4649b2f8ea8285a4eb3c47e87520c7835e6c672\u0027:\n  libbinder: add a NO_CACHING flag to MemoryHeapBase\n"
    },
    {
      "commit": "d4649b2f8ea8285a4eb3c47e87520c7835e6c672",
      "tree": "989351c280eca4db14de2ddc069bd03c230b0d5b",
      "parents": [
        "1d9246e8bb8de624e14c55dce57e93da18cfd7a8",
        "baef6141a3239c7dd9bad0e2cd8a9ece5eef5a7e"
      ],
      "author": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Mon Nov 02 17:55:43 2009 -0500"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Mon Nov 02 17:55:43 2009 -0500"
      },
      "message": "Merge change Ibaef6141 into eclair\n\n* changes:\n  libbinder: add a NO_CACHING flag to MemoryHeapBase\n"
    },
    {
      "commit": "2926bf7d9aca0097a347ce6b77fc762f309a597b",
      "tree": "1fe3ce59f1d7c9f31a526b1af7f81cf4ffa44cdf",
      "parents": [
        "a94da0e7d98cdeae65cd48d4e7cfcf8f8b9aacfb",
        "c69e7516482aae626eb550f5dd99f0f2f7a45909"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Mon Nov 02 12:51:05 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Nov 02 12:51:05 2009 -0800"
      },
      "message": "am c69e7516: am ee98c240: Merge change I73680cd9 into eclair\n\nMerge commit \u0027c69e7516482aae626eb550f5dd99f0f2f7a45909\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027c69e7516482aae626eb550f5dd99f0f2f7a45909\u0027:\n  Fix 2194140: [Passion] Support Audience chip.\n"
    },
    {
      "commit": "c69e7516482aae626eb550f5dd99f0f2f7a45909",
      "tree": "02e60056aa34474490320d1064a0724efa67851c",
      "parents": [
        "e94261b874b7d0704dade14540dbb9477a828163",
        "ee98c24020c1634b02cde6d333968f04a0de941f"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Mon Nov 02 12:40:34 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Nov 02 12:40:34 2009 -0800"
      },
      "message": "am ee98c240: Merge change I73680cd9 into eclair\n\nMerge commit \u0027ee98c24020c1634b02cde6d333968f04a0de941f\u0027 into eclair-mr2\n\n* commit \u0027ee98c24020c1634b02cde6d333968f04a0de941f\u0027:\n  Fix 2194140: [Passion] Support Audience chip.\n"
    },
    {
      "commit": "ee98c24020c1634b02cde6d333968f04a0de941f",
      "tree": "c5335abd97474e43b86c4b7fb78e7ddc8a6969b6",
      "parents": [
        "989b76aadd92538c7ab4ca00c34508b42fda8cef",
        "f22a0975c442f1f216f16db3ddb27015d72c6532"
      ],
      "author": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Mon Nov 02 15:34:28 2009 -0500"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Mon Nov 02 15:34:28 2009 -0500"
      },
      "message": "Merge change I73680cd9 into eclair\n\n* changes:\n  Fix 2194140: [Passion] Support Audience chip.\n"
    },
    {
      "commit": "50bb2643a5cb28c4e013eceb15c23288c85e0350",
      "tree": "f4f32b14186e51bd1d5b5009a27c3d910d59218e",
      "parents": [
        "80164966d087388ac0192caf7270158dea22444e",
        "d62b063fd4ac0ae1419348ac62c55527cb398fd9"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Mon Nov 02 11:04:56 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Nov 02 11:04:56 2009 -0800"
      },
      "message": "am d62b063f: am b6a6791f: Merge change I60413727 into eclair\n\nMerge commit \u0027d62b063fd4ac0ae1419348ac62c55527cb398fd9\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027d62b063fd4ac0ae1419348ac62c55527cb398fd9\u0027:\n  Fix issue #2226370: Resource versions match with equality\n"
    },
    {
      "commit": "d62b063fd4ac0ae1419348ac62c55527cb398fd9",
      "tree": "be6455a28904a8c00fd01a32e8fb3b40874bd49b",
      "parents": [
        "a86861a8684809bf3e3b877a20852483bc889742",
        "b6a6791f381691d4a58fe6972eb9f0b65308ac1f"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Mon Nov 02 10:52:22 2009 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Nov 02 10:52:22 2009 -0800"
      },
      "message": "am b6a6791f: Merge change I60413727 into eclair\n\nMerge commit \u0027b6a6791f381691d4a58fe6972eb9f0b65308ac1f\u0027 into eclair-mr2\n\n* commit \u0027b6a6791f381691d4a58fe6972eb9f0b65308ac1f\u0027:\n  Fix issue #2226370: Resource versions match with equality\n"
    },
    {
      "commit": "f22a0975c442f1f216f16db3ddb27015d72c6532",
      "tree": "d335d2d1232687c9e96253ceb4ba0a3e13f13ab8",
      "parents": [
        "31f62008db4b2c3bfd24379b76570fd9bd1de2b3"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Mon Nov 02 05:31:33 2009 -0800"
      },
      "committer": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Mon Nov 02 10:38:22 2009 -0800"
      },
      "message": "Fix 2194140: [Passion] Support Audience chip.\n\nAdded new input device DEVICE_IN_BACK_MIC.\nAdded new audio source AUDIO_SOURCE_CAMCORDER.\n"
    },
    {
      "commit": "553399518f39cd9f31f2bb6f502866c3c9d6d1a5",
      "tree": "0142f759466336e32bccab5ba2fe7c7341ef5318",
      "parents": [
        "824838d74eb0316f6987a1d98d2d9e9fa8d4e15b"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Sun Nov 01 21:16:59 2009 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Sun Nov 01 21:16:59 2009 -0800"
      },
      "message": "Fix issue #2226370: Resource versions match with equality\n\nAlso fixed turned-around increment of version number for resources. :(\n\nChange-Id: I604137272da984bcd69cee4f174e6b7f2c786e46\n"
    },
    {
      "commit": "baef6141a3239c7dd9bad0e2cd8a9ece5eef5a7e",
      "tree": "50df32f2a31006f4ea4572cffdf390012541027b",
      "parents": [
        "05cb5610fdfb7b69cf90a9230853e59b4ae5e219"
      ],
      "author": {
        "name": "Iliyan Malchev",
        "email": "malchev@google.com",
        "time": "Thu Oct 29 22:55:00 2009 -0700"
      },
      "committer": {
        "name": "Iliyan Malchev",
        "email": "malchev@google.com",
        "time": "Fri Oct 30 18:35:47 2009 -0700"
      },
      "message": "libbinder: add a NO_CACHING flag to MemoryHeapBase\n\nThe NO_CACHING flag translates to opening a memory region with O_SYNC.\n\nSigned-off-by: Iliyan Malchev \u003cmalchev@google.com\u003e\n"
    },
    {
      "commit": "874762f760270694be4fe5d65e6ed65bc79bb846",
      "tree": "f158d1cf704910b0db823a03d14b8a4862c1815d",
      "parents": [
        "faa7c8151851f0717d673071c5a6321384a6b7af",
        "16d8f10ebf75e809cc14d866fded7749363b9d8f"
      ],
      "author": {
        "name": "Wu-cheng Li",
        "email": "wuchengli@google.com",
        "time": "Thu Oct 29 19:55:41 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Oct 29 19:55:41 2009 -0700"
      },
      "message": "am 16d8f10e: am 4cb04c46: Use image rect information to display zoomed picture.\n\nMerge commit \u002716d8f10ebf75e809cc14d866fded7749363b9d8f\u0027 into eclair-mr2-plus-aosp\n\n* commit \u002716d8f10ebf75e809cc14d866fded7749363b9d8f\u0027:\n  Use image rect information to display zoomed picture.\n"
    },
    {
      "commit": "16d8f10ebf75e809cc14d866fded7749363b9d8f",
      "tree": "250d3c87bbd9509501cf386bd03b6f92fbd8135e",
      "parents": [
        "5cecf74138ea56842463ec384ff04610c1247920",
        "4cb04c4654e9718a73b378e7b9962dee454efa8d"
      ],
      "author": {
        "name": "Wu-cheng Li",
        "email": "wuchengli@google.com",
        "time": "Thu Oct 29 19:26:04 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Oct 29 19:26:04 2009 -0700"
      },
      "message": "am 4cb04c46: Use image rect information to display zoomed picture.\n\nMerge commit \u00274cb04c4654e9718a73b378e7b9962dee454efa8d\u0027 into eclair-mr2\n\n* commit \u00274cb04c4654e9718a73b378e7b9962dee454efa8d\u0027:\n  Use image rect information to display zoomed picture.\n"
    },
    {
      "commit": "5647eebc3aeef6e644b8c7587a36206d8f0d6314",
      "tree": "625e585b362639d2e020f9d319c3387bffd95550",
      "parents": [
        "cad9a4b0468eb9611cc9b7d7b380d8af3fff8588",
        "9dba1f928021450f101013e03deacc9a0506772e"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Oct 29 14:00:16 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Oct 29 14:00:16 2009 -0700"
      },
      "message": "am 9dba1f92: Merge change Ib482ce88 into eclair-mr2\n\nMerge commit \u00279dba1f928021450f101013e03deacc9a0506772e\u0027 into eclair-mr2-plus-aosp\n\n* commit \u00279dba1f928021450f101013e03deacc9a0506772e\u0027:\n  Revive support for video encoding in OMXCodec.\n"
    },
    {
      "commit": "9dba1f928021450f101013e03deacc9a0506772e",
      "tree": "e7d8d656f4a546662ccade6f6569c6516b65be97",
      "parents": [
        "66e06205030cfc72f9aeeac57acfd6cbff0c1b8a",
        "b482ce8837a2d85a2a907d7ea89deaa6610a8333"
      ],
      "author": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Oct 29 16:20:43 2009 -0400"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Oct 29 16:20:43 2009 -0400"
      },
      "message": "Merge change Ib482ce88 into eclair-mr2\n\n* changes:\n  Revive support for video encoding in OMXCodec.\n"
    },
    {
      "commit": "b482ce8837a2d85a2a907d7ea89deaa6610a8333",
      "tree": "d290027d3cfb697d0d2abfcccafd5d7337cd5e76",
      "parents": [
        "10d32a338d5400786e784a0d6f51b53acea76b44"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Oct 29 12:02:48 2009 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Oct 29 12:02:48 2009 -0700"
      },
      "message": "Revive support for video encoding in OMXCodec.\n"
    },
    {
      "commit": "64d3f44c7bf5a6e80be419df5850ef60fec216b5",
      "tree": "c3085258ac4641e0551082014aab99d458788019",
      "parents": [
        "0200ec3eb4c9c11cc8f9e3db5a1a51f5db840524",
        "893cb4da1034870a8814394a1c3bdac10ca6cadf"
      ],
      "author": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Thu Oct 29 01:46:16 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Oct 29 01:46:16 2009 -0700"
      },
      "message": "am 893cb4da: am 73e17015: Merge change I8d2de438 into eclair\n\nMerge commit \u0027893cb4da1034870a8814394a1c3bdac10ca6cadf\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027893cb4da1034870a8814394a1c3bdac10ca6cadf\u0027:\n  fix [2143798] Need to figure out how to do video\n"
    },
    {
      "commit": "893cb4da1034870a8814394a1c3bdac10ca6cadf",
      "tree": "f4ba2333222c80a64c263cc58ad574433bc77952",
      "parents": [
        "b07d14c26ef33b8aa94a815273d6cb2caac180f5",
        "73e17015d3cd67c93ccad5d63d31c439ff6fa694"
      ],
      "author": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Thu Oct 29 01:26:48 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Oct 29 01:26:48 2009 -0700"
      },
      "message": "am 73e17015: Merge change I8d2de438 into eclair\n\nMerge commit \u002773e17015d3cd67c93ccad5d63d31c439ff6fa694\u0027 into eclair-mr2\n\n* commit \u002773e17015d3cd67c93ccad5d63d31c439ff6fa694\u0027:\n  fix [2143798] Need to figure out how to do video\n"
    },
    {
      "commit": "4cb04c4654e9718a73b378e7b9962dee454efa8d",
      "tree": "b0ca9496027477f28833f0f85288bb6611f80c52",
      "parents": [
        "38a9becfdd23e582571f624b624680cc5938d423"
      ],
      "author": {
        "name": "Wu-cheng Li",
        "email": "wuchengli@google.com",
        "time": "Fri Oct 23 17:39:46 2009 +0800"
      },
      "committer": {
        "name": "Wu-cheng Li",
        "email": "wuchengli@google.com",
        "time": "Thu Oct 29 13:20:26 2009 +0800"
      },
      "message": "Use image rect information to display zoomed picture.\n"
    },
    {
      "commit": "e113d6af6204dac03b13b324852fe7f741ebb3d3",
      "tree": "cef084d5e4967a3659d5f0ecf4910d05ce78b724",
      "parents": [
        "b1a8f54bf62c3974831bf3c866275425127cf7b6",
        "76a5429407e821c22508eca92e7475b6433cd668"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Oct 28 10:36:57 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Oct 28 10:36:57 2009 -0700"
      },
      "message": "am 76a54294: Merge change I155e2ad0 into eclair-mr2\n\nMerge commit \u002776a5429407e821c22508eca92e7475b6433cd668\u0027 into eclair-mr2-plus-aosp\n\n* commit \u002776a5429407e821c22508eca92e7475b6433cd668\u0027:\n  Re-enable CameraSource.\n"
    },
    {
      "commit": "76a5429407e821c22508eca92e7475b6433cd668",
      "tree": "5bd7d26be381153f31e9792c65151c303de26d2d",
      "parents": [
        "27123468b33cb61a1600079d583302b1b078b2ee",
        "155e2ad04c9e15562149772fbbaa39004d4778a7"
      ],
      "author": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Oct 28 13:25:09 2009 -0400"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Oct 28 13:25:09 2009 -0400"
      },
      "message": "Merge change I155e2ad0 into eclair-mr2\n\n* changes:\n  Re-enable CameraSource.\n"
    },
    {
      "commit": "155e2ad04c9e15562149772fbbaa39004d4778a7",
      "tree": "40f5ec10cd1c147fecf2dd88aa7baee1b72b2bbf",
      "parents": [
        "d9f3d60df9317f15a7f26bc050f51b53b46898ff"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Oct 13 17:08:31 2009 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Oct 28 10:15:07 2009 -0700"
      },
      "message": "Re-enable CameraSource.\n"
    },
    {
      "commit": "9042b4564de5477b18e680c7dce13b587a681dd9",
      "tree": "04872061371527ef76dbfff6ee0d6c8fdadb99bc",
      "parents": [
        "678cdbe55e0de71436f8aad5f139eafc2ab6f937"
      ],
      "author": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Mon Oct 26 20:12:37 2009 -0700"
      },
      "committer": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Tue Oct 27 13:13:29 2009 -0700"
      },
      "message": "    fix [2143798] Need to figure out how to do video\n\n    Use EGLImageKHR instead of copybit directly.\n    We now have the basis to use streaming YUV textures (well, in fact\n    we already are). When/if we use the GPU instead of the MDP we\u0027ll\n    need to make sure it supports the appropriate YUV format.\n\n    Also make sure we compile if EGL_ANDROID_image_native_buffer is not supported\n"
    },
    {
      "commit": "848f9c99af9c1f3fe0cc30717ea4c73e6fefb527",
      "tree": "3dc0a67a36ebbc3e3c4eff050320f3442cb07f85",
      "parents": [
        "fb324e706e487738b3edbaca67bdf459fafcd4ea",
        "7ed70c9515fe3df6eb1796717d73f23e7286b3e6"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Sat Oct 24 01:47:59 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Sat Oct 24 01:47:59 2009 -0700"
      },
      "message": "am 7ed70c95: am bf96aaad: Merge change Icf10db28 into eclair\n\nMerge commit \u00277ed70c9515fe3df6eb1796717d73f23e7286b3e6\u0027 into eclair-mr2-plus-aosp\n\n* commit \u00277ed70c9515fe3df6eb1796717d73f23e7286b3e6\u0027:\n  Fix issue 2192181: AudioFlinger must provide separated methods to set VOICE_CALL stream volume and down link audio volume.\n"
    },
    {
      "commit": "7ed70c9515fe3df6eb1796717d73f23e7286b3e6",
      "tree": "ca15e2090451457b722bb524c5f2c75421477c9f",
      "parents": [
        "adddd24f31291f733cd5f72898b92f13f37ae37c",
        "bf96aaadd46fb5b0884070177faa16ec4f22e2ba"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Sat Oct 24 01:38:58 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Sat Oct 24 01:38:58 2009 -0700"
      },
      "message": "am bf96aaad: Merge change Icf10db28 into eclair\n\nMerge commit \u0027bf96aaadd46fb5b0884070177faa16ec4f22e2ba\u0027 into eclair-mr2\n\n* commit \u0027bf96aaadd46fb5b0884070177faa16ec4f22e2ba\u0027:\n  Fix issue 2192181: AudioFlinger must provide separated methods to set VOICE_CALL stream volume and down link audio volume.\n"
    },
    {
      "commit": "c91e3d8d897f7299269e177c2891fde31cfc6ae1",
      "tree": "a8d4def70bab5e06b72fdb5db942d1c4a399c61e",
      "parents": [
        "23546ac55d3196fa93786018230f3e4a30e2dc2c",
        "d9f3d60df9317f15a7f26bc050f51b53b46898ff"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Oct 23 13:00:43 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Oct 23 13:00:43 2009 -0700"
      },
      "message": "am d9f3d60d: Merge change I3b1b7873 into eclair-mr2\n\nMerge commit \u0027d9f3d60df9317f15a7f26bc050f51b53b46898ff\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027d9f3d60df9317f15a7f26bc050f51b53b46898ff\u0027:\n  New API to instantiate a MediaExtractor given a URI and optional MIME type.\n"
    },
    {
      "commit": "9a12baf929ea803915d7ab626b200ffefb4fbac7",
      "tree": "12a3f70e5ef69e09ea9e9ca4e4dcd4949718e924",
      "parents": [
        "9069aa31accee9c23a4cf228ca27fe8fa8506a56"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Oct 23 10:22:30 2009 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Oct 23 10:35:08 2009 -0700"
      },
      "message": "New API to instantiate a MediaExtractor given a URI and optional MIME type.\n\nAlso DataSources now must provide a method initCheck()\nand DataSource::reat_at has been renamed to readAt to conform to\nstandard API naming guidelines.\n"
    },
    {
      "commit": "d919aa74927fcabd18a9ea14a57f44240aecc7af",
      "tree": "ce63ca089cd7eaaf1b4e7d7a520824675dc89ec0",
      "parents": [
        "79b609722ef2121368b2f40a0e67ac9fecc23b7c",
        "9069aa31accee9c23a4cf228ca27fe8fa8506a56"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Oct 23 10:26:18 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Oct 23 10:26:18 2009 -0700"
      },
      "message": "am 9069aa31: Merge change I57515f33 into eclair-mr2\n\nMerge commit \u00279069aa31accee9c23a4cf228ca27fe8fa8506a56\u0027 into eclair-mr2-plus-aosp\n\n* commit \u00279069aa31accee9c23a4cf228ca27fe8fa8506a56\u0027:\n  Moving the individual extractor headers files to the private include directory.\n"
    },
    {
      "commit": "57515f334bcc1f66f95e342bfcaa13bf9ca802ad",
      "tree": "6813dcb5c024e8198eeed71a5ed8afa954e2a477",
      "parents": [
        "ad28543022101d0b01845e3f53dcd57e524816ef"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Oct 23 09:55:10 2009 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Oct 23 09:55:10 2009 -0700"
      },
      "message": "Moving the individual extractor headers files to the private include directory.\n"
    },
    {
      "commit": "871e4ee81d6fa310dbfc5f6f37f3d8a780a28ddc",
      "tree": "f42e93d9fc9c977a0e6ff41dab67ab5917d98b93",
      "parents": [
        "1f04c83684cb1a0f1e5cc6100294d6c3bbb65d4c",
        "e84729002102622b40bd6efddffb76909615c12a"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Oct 23 08:51:19 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Oct 23 08:51:19 2009 -0700"
      },
      "message": "am e8472900: Merge change Ie13526ad into eclair-mr2\n\nMerge commit \u0027e84729002102622b40bd6efddffb76909615c12a\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027e84729002102622b40bd6efddffb76909615c12a\u0027:\n  Prefer software decoders over hardware for thumbnail extraction.\n"
    },
    {
      "commit": "e13526ad926bfee99778a4f21ea5e4f8a6c8984f",
      "tree": "e4ccf7eda0eab5d02c399e250ca1a52719ef8195",
      "parents": [
        "e981c33446a98d5ccc0d73c1a840696d77cf0732"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Oct 22 10:43:34 2009 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Oct 23 08:39:00 2009 -0700"
      },
      "message": "Prefer software decoders over hardware for thumbnail extraction.\n\nWhile our hardware decoders clearly outperform the software decoders in terms\nof raw throughput, their startup latency makes them less suitable for thumbnail\nextraction.\n"
    },
    {
      "commit": "7453da3f420b74f5bb135d5895b82dca9c015bb3",
      "tree": "b9198ddb8a99f5c0271223689dfaf237f62a7cc2",
      "parents": [
        "36cf8123d8cf9047c64633a963706f40cecc0bb1",
        "e981c33446a98d5ccc0d73c1a840696d77cf0732"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Oct 22 14:49:35 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Oct 22 14:49:35 2009 -0700"
      },
      "message": "am e981c334: Extract video thumbnails from the largest sync sample among the first 20.\n\nMerge commit \u0027e981c33446a98d5ccc0d73c1a840696d77cf0732\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027e981c33446a98d5ccc0d73c1a840696d77cf0732\u0027:\n  Extract video thumbnails from the largest sync sample among the first 20.\n"
    },
    {
      "commit": "e981c33446a98d5ccc0d73c1a840696d77cf0732",
      "tree": "e92d9cc3e468e3ef5a021d194d5a5de8f18fcf9c",
      "parents": [
        "d278ffc0984d730b333f53636a223eae6d9b7657"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Oct 22 13:49:30 2009 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Thu Oct 22 14:22:57 2009 -0700"
      },
      "message": "Extract video thumbnails from the largest sync sample among the first 20.\n\nAlso fixes OMXCodec seek behaviour on the very first call to OMXCodec::read()\n"
    },
    {
      "commit": "917d0aece5c9395892c3a8e7191f04a1e2ca6330",
      "tree": "e7f69f66e635c2d7a3317749ac44de15d163dab7",
      "parents": [
        "85356bac4a1246537d16e95b7929da5a4715ab1d",
        "bfd5b38673212c47f0e386c0a8370d4ff47bd2fe"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Oct 21 15:24:07 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Oct 21 15:24:07 2009 -0700"
      },
      "message": "am bfd5b386: Merge change If68c168d into eclair-mr2\n\nMerge commit \u0027bfd5b38673212c47f0e386c0a8370d4ff47bd2fe\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027bfd5b38673212c47f0e386c0a8370d4ff47bd2fe\u0027:\n  Some cleanup of OMXCodec code, make sure to ignore 0-length output buffers in the metadata retriever.\n"
    },
    {
      "commit": "f68c168d366e8aad58454917f96344398a02efd8",
      "tree": "13f7f5734703daff681fcb1a6ec7d2847fa595f0",
      "parents": [
        "dad4780bbd6be0891ea8745bd274fc8d6882f071"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Oct 21 14:01:30 2009 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Oct 21 14:01:30 2009 -0700"
      },
      "message": "Some cleanup of OMXCodec code, make sure to ignore 0-length output buffers in the metadata retriever.\n"
    },
    {
      "commit": "415f3e2875b8b0b860d0dd6a69ff6868571c36bb",
      "tree": "9ce2631d183fa93c398c4691bbb8dd9a220cb2af",
      "parents": [
        "6270d52c0dded8658733a392f3ef1f521bc5dbee"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Wed Oct 21 08:14:22 2009 -0700"
      },
      "committer": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Wed Oct 21 12:29:37 2009 -0700"
      },
      "message": "Fix issue 2192181: AudioFlinger must provide separated methods to set VOICE_CALL stream volume and down link audio volume.\n\nAdded setVoiceVolume() method to AudioSystem, AudioFlinger, IAudioFlinger, AudioPolicyService.\nRemoved call to AudioHardwareInterface::setVoiceVolume() from AudioFlinger::setStreamVolume().\n"
    },
    {
      "commit": "f16a0b73993c5a8cc14a36521abaa50d501d9044",
      "tree": "73f0bbc032c1dd1adc02178a3f9b84a7f8adf879",
      "parents": [
        "61462b437067a591bfc52c498ad964e566aaffac"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Oct 20 10:43:48 2009 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Oct 20 11:49:01 2009 -0700"
      },
      "message": "do not merge: The qcom video decoders always output yuv data after adjusting dimensions to be a multiple of 16.\n\nAdd a quirk mode to OMXCodec that makes it aware of this fact for proper display. Also integrate back a change from eclair-mr2 that delays releasing an output buffer briefly after posting it to surface flinger, as we don\u0027t know how long it\u0027ll take it to actually display the buffer\u0027s content.\n"
    },
    {
      "commit": "453b5ba21f1bf5ea6d046965a4b189c998e8cc37",
      "tree": "3fcf71b89e2889f7191f03eaf7e6c61f8c6ce464",
      "parents": [
        "0712f24dbf14473cb55e5b609c3418610b77d406",
        "fe50b63f9b5b7e05754e3fba3ccce69b710dbafe"
      ],
      "author": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Fri Oct 16 14:44:14 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Oct 16 14:44:14 2009 -0700"
      },
      "message": "am fe50b63f: am 7bb7e992: Merge change Ia8ac904d into eclair\n\nMerge commit \u0027fe50b63f9b5b7e05754e3fba3ccce69b710dbafe\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027fe50b63f9b5b7e05754e3fba3ccce69b710dbafe\u0027:\n  fix [2182249] [MR1] valgrind error in surface flinger\n"
    },
    {
      "commit": "fe50b63f9b5b7e05754e3fba3ccce69b710dbafe",
      "tree": "23ca3fee10850afd65f5303d9fa637fbe11e94d5",
      "parents": [
        "a486f554aa494dfeea4d63fde0d533ea9e1cfe2f",
        "7bb7e99216956d917af1786a3e02a92cac46fc84"
      ],
      "author": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Fri Oct 16 14:33:01 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Oct 16 14:33:01 2009 -0700"
      },
      "message": "am 7bb7e992: Merge change Ia8ac904d into eclair\n\nMerge commit \u00277bb7e99216956d917af1786a3e02a92cac46fc84\u0027 into eclair-mr2\n\n* commit \u00277bb7e99216956d917af1786a3e02a92cac46fc84\u0027:\n  fix [2182249] [MR1] valgrind error in surface flinger\n"
    },
    {
      "commit": "4b9dbdfa1805cfb5be1eca2d26ca18a01724839a",
      "tree": "a89b285626c26b4ba07c33df63f3d78d1682b377",
      "parents": [
        "d27d445af8ac4bddbd088ac3c19b59afc98e1b51",
        "d96f6e85931e3d4ac4a6dacbedc561e56c293b8d"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Oct 16 12:51:42 2009 -0700"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Oct 16 12:51:42 2009 -0700"
      },
      "message": "am d96f6e85: Merge change I8176f35e into eclair-mr2\n\nMerge commit \u0027d96f6e85931e3d4ac4a6dacbedc561e56c293b8d\u0027 into eclair-mr2-plus-aosp\n\n* commit \u0027d96f6e85931e3d4ac4a6dacbedc561e56c293b8d\u0027:\n  Reimplement the OMX backend for stagefright.\n"
    },
    {
      "commit": "784202ea115603004b067aacf6a57bf5d2a7d53b",
      "tree": "0e32ad4b315f936a80ac1af63ae2e919e6ffe090",
      "parents": [
        "d21b725627e68b8ffcae38729196e8c1bd5d0d15"
      ],
      "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": "a8ac904d97a008b346390c87e74d44df39b0f320",
      "tree": "542fe7fccb07a5d9f380c9d169680d38a4f5f445",
      "parents": [
        "53f33d84776a0bad668e361365a7049b16f8a929"
      ],
      "author": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Thu Oct 15 18:08:15 2009 -0700"
      },
      "committer": {
        "name": "Mathias Agopian",
        "email": "mathias@google.com",
        "time": "Thu Oct 15 18:08:15 2009 -0700"
      },
      "message": "fix [2182249] [MR1] valgrind error in surface flinger\n"
    }
  ],
  "next": "28af587a0587bc3975230a9ed4a2a44be1f31ad3"
}
