)]}'
{
  "log": [
    {
      "commit": "d91c921c1575873acefdb79cc8401dc7903d1052",
      "tree": "4be2fd0031970efe1e99b443fe3d047fb356be14",
      "parents": [
        "2496ffbc450029ee9ec26980a101e71352b4f635"
      ],
      "author": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Thu Jan 30 15:52:23 2020 -0800"
      },
      "committer": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Thu Jan 30 15:52:23 2020 -0800"
      },
      "message": "Avoid reading at negative offsets\n\nAvoid making MPEG4Extractor read from negative data source offsets,\nbut also make FileSource::readAt() handle them gracefully.\n\nBug: 141242340\nTest: poc, manual\nChange-Id: If82dcaec43a63b71d24a5572eeea5e0685fb4a1c\n"
    },
    {
      "commit": "9c6f790843939700fa18779f14b1df5fa1161024",
      "tree": "fe8d8bac73ced833f9b8b1bf7758bc6bee7ff097",
      "parents": [
        "79b0c24b58af5fbfec814a2a11506ef0f72541c3"
      ],
      "author": {
        "name": "Dongwon Kang",
        "email": "dwkang@google.com",
        "time": "Mon Oct 14 11:16:39 2019 -0700"
      },
      "committer": {
        "name": "Dongwon Kang",
        "email": "dwkang@google.com",
        "time": "Tue Oct 15 17:38:17 2019 -0700"
      },
      "message": "Remove libdrmframework.so dependency from libdatasource.so\n\nName changes:\nClearFileSource -\u003e FileSource\nClearMediaHTTP -\u003e MediaHTTP\nFileSource -\u003e PlayerServiceFileSource\nMediaHTTP -\u003e PlayerServiceMediaHTTP\n\nPlayerServiceXXX are able to handle OMA(forward-lock) files and now\nmoved to media/libmediaplayerservice/datasource since they only work\non mediaserver process.\n\nBug: 142567168\nTest: build and DrmTest\n\nChange-Id: I9292dba33d149efe17cf566017dcce1710cc8c88\n"
    },
    {
      "commit": "fa8be7d2371d66db6c7838060d5729f6fd9374ef",
      "tree": "aa00504b96299a891446e46c81c6b0d72c9aae02",
      "parents": [
        "58ae37b5b34d6a2bddd46494230a58f5fcc3f5e3"
      ],
      "author": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Mon Sep 23 12:15:57 2019 -0700"
      },
      "committer": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Wed Oct 09 07:41:58 2019 -0700"
      },
      "message": "Split datasource out of libstagefright\n\ninto libdatasource, which contains:\n  DataSourceFactory\n  (Clear)FileSource\n  (Clear)MediaHTTP\n  DataURISource\n  HTTPBase\n  NuCachedSource2\n\nThis is needed to break a circular dependency in an upcoming CL.\n\nTest: build, boot\n\nChange-Id: I34d9937235c78f18f51b18945342a0743e209577\nMerged-In: I34d9937235c78f18f51b18945342a0743e209577\n"
    },
    {
      "commit": "1e1bcaae46b7901f095bc244d554692146deccf2",
      "tree": "899fb78a5c207c1d7bc5617ceee53a8d46150d0b",
      "parents": [
        "978dcac6101c416158ca234e6ef01baa861bbcd0"
      ],
      "author": {
        "name": "Dongwon Kang",
        "email": "dwkang@google.com",
        "time": "Wed Aug 01 12:44:46 2018 -0700"
      },
      "committer": {
        "name": "Dongwon Kang",
        "email": "dwkang@google.com",
        "time": "Fri Aug 03 19:18:15 2018 +0000"
      },
      "message": "MediaPlayer2: Remove libdrmframework.so dependency.\n\nlibdrmframework.so is being used in FileSource and MediaHTTP\nfor Forward Lock DRM use case.\nThis change removes this dependency from MediaPlayer2 by adding\nClearFileSource and ClearMediaHTTP.\nForward Lock DRM use case will be covered by MediaPlayer1.\n\nTest: build \u0026 MediaPlayerTest \u0026 DrmTest\nBug: 111406958\nChange-Id: I5cf51b2d6f477e8fa8950ac931c0142491baa747\n"
    },
    {
      "commit": "92541a351d8c5ca6aa0c1b3b0d40023ff2385645",
      "tree": "9157ede04bbea53d2c6b64558034be82d6d01714",
      "parents": [
        "2a8dbc7611d3861d696c167ebdced50158bbebe1"
      ],
      "author": {
        "name": "Dongwon Kang",
        "email": "dwkang@google.com",
        "time": "Fri Dec 15 15:26:14 2017 -0800"
      },
      "committer": {
        "name": "Dongwon Kang",
        "email": "dwkang@google.com",
        "time": "Fri Dec 15 17:37:54 2017 -0800"
      },
      "message": "Remove unused code DataSource::getDrmInfo\n\nThe method in question was added in I4b9ef19 with DRMExtractor.\nThe only use case of getDrmInfo(), in DRMExtractor, has been removed\nwith I4dd3f07ca.\n\nTest: build. post commit media cts test.\nBug: 65851881\nChange-Id: Ieb4d9d36c74efcfbfe690bcd09e1cd7e08ee3f1a\n"
    },
    {
      "commit": "d49dbd6b625cddb82f3f7bbeac62d48ef338ef0f",
      "tree": "297315edf06765b4b3b114aaf07499e52a53743c",
      "parents": [
        "6480d09eec2b8188b623030c971032334739b4e4"
      ],
      "author": {
        "name": "Andy Hung",
        "email": "hunga@google.com",
        "time": "Thu Jul 07 14:20:35 2016 -0700"
      },
      "committer": {
        "name": "Andy Hung",
        "email": "hunga@google.com",
        "time": "Wed Mar 29 17:52:51 2017 +0000"
      },
      "message": "Allow MediaExtractor to create FileSource\n\nRemove binder call to MediaServer for reading files.\n\nTest: Photos, Play Music, Play Movies, Youtube\nBug: 29125703\nChange-Id: Id6abf592bf6d70b81158f6038b1982f0a537b9b9\n"
    },
    {
      "commit": "69d3d8a9540b0da787ea0beccad2517f057dd54d",
      "tree": "d8a91e3ee2298b35c3aad167a4f5073225aeba3a",
      "parents": [
        "953c59c51da938fdcaf3801de89edb736c249c6f"
      ],
      "author": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Mon Mar 07 13:20:01 2016 -0800"
      },
      "committer": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Wed Apr 06 13:24:12 2016 -0700"
      },
      "message": "Expand mediaextractor dumpsys\n\nBug: 22775369\nChange-Id: I3366a52ba7a00d1685a2211465f2f18f143d0efc\n"
    },
    {
      "commit": "63690d1588cb24929da7ced24ec341ed2a003825",
      "tree": "03699a9ff99667f715fe3750e7807a079d2fb764",
      "parents": [
        "30ecc7a6a439ed9eae622b30d7e0a978ad69a944"
      ],
      "author": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Wed Apr 06 09:28:05 2016 -0700"
      },
      "committer": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Wed Apr 06 09:52:51 2016 -0700"
      },
      "message": "MP3Extractor: fix overflow on duration estimation\n\nalso make FileSource adjust offset and length to match the actual length\nof the file.\n\nBug: 27665235\nChange-Id: Ib08ee3bb30bc027adc9d3b1f5c88cd099fc4cf9e\n"
    },
    {
      "commit": "fbe7fcfe818b6f68e352c7c450d4fe15a543b801",
      "tree": "8a154d4ab88b82ba1d7f2895952a2a8395354191",
      "parents": [
        "1cf582cfc8e1082a0c37c25655a052c7a9185fe4"
      ],
      "author": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Tue Apr 05 07:37:58 2016 -0700"
      },
      "committer": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Tue Apr 05 16:16:21 2016 +0000"
      },
      "message": "Close MediaDataSource on extractor/retriever release\n\ninstead of waiting for garbage collection.\n\nBug: 26911216\nbug: 26741307\nChange-Id: I79010066962a1bdb9cb8bf74ba9a7997abb82fd4\n"
    },
    {
      "commit": "5f80c6f508ebafbe81d42177907035731e854c5b",
      "tree": "b121443943a9834c2e32067b8374c0bced5fc757",
      "parents": [
        "f4284584d6a12c19906d661e55163c0d90f83286",
        "3f27a44e8ee013527f927cc61f5d765c8b79c590"
      ],
      "author": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Mon Nov 30 19:36:41 2015 +0000"
      },
      "committer": {
        "name": "android-build-merger",
        "email": "android-build-merger@google.com",
        "time": "Mon Nov 30 19:36:41 2015 +0000"
      },
      "message": "Merge \"Handle error result from DrmManagerClient correctly\" am: f0d7854e93 am: b84a4f9d23\nam: 3f27a44e8e\n\n* commit \u00273f27a44e8ee013527f927cc61f5d765c8b79c590\u0027:\n  Handle error result from DrmManagerClient correctly\n"
    },
    {
      "commit": "d066bc8faf68b9fcb034ceb203e8d7e8213dc1ce",
      "tree": "56ed5e10dee23df0c40a0e7769eac8219b325cd3",
      "parents": [
        "2d772fd4afd1481a8cea5f59b890d771dbada2f6"
      ],
      "author": {
        "name": "Patrik Lindgren",
        "email": "patrik2.lindgren@sonymobile.com",
        "time": "Mon Dec 22 09:06:21 2014 +0100"
      },
      "committer": {
        "name": "Takahiro Aizawa",
        "email": "takahiro.aizawa@sonymobile.com",
        "time": "Fri Oct 23 21:01:12 2015 +0900"
      },
      "message": "Handle error result from DrmManagerClient correctly\n\nreadAtDRM() must handle the case when DrmManagerClient::pread()\nreturns an error (-1) correctly. This is a degrade in Android L.\n\nChange-Id: Id7ff124d178e26931dddac5ac73697cfe6da501c\n"
    },
    {
      "commit": "83b0fd9997b558f6c2ebf5e6e4db20570cb233b8",
      "tree": "fba92293da0dc6927954f6a99ada889eeefc4bc4",
      "parents": [
        "1277aea8405ea3256a2b0f730506c4610cadafa4"
      ],
      "author": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Wed Sep 16 13:48:07 2015 -0700"
      },
      "committer": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Wed Sep 16 14:18:27 2015 -0700"
      },
      "message": "Optionally print name for fd\n\nAdd utility function to get the file name for a file descriptor,\nand use it in various places.\n\nChange-Id: I196b557a56d5ef0ef89e2020aab2699eafae61b0\n"
    },
    {
      "commit": "0eaf820756bf584284f246b6ba79968efbd08faf",
      "tree": "a28c0159695911f5d117e14cc91b2c9705a8747f",
      "parents": [
        "11308153978c9cef2dc38a367ecb20e504340231"
      ],
      "author": {
        "name": "Wei Jia",
        "email": "wjia@google.com",
        "time": "Wed Aug 19 16:48:47 2015 -0700"
      },
      "committer": {
        "name": "Wei Jia",
        "email": "wjia@google.com",
        "time": "Thu Aug 20 03:39:37 2015 +0000"
      },
      "message": "libstagefright: fix overflow in FileSource::readAt.\n\nBug: 23275093\nChange-Id: I1826ff101a9a3da9f50cf4feaae8b5a0a29f98c2\n"
    },
    {
      "commit": "ee4e1b1a63758941460ae79a064249d3a5189443",
      "tree": "d27f03a73170da9cce96b6eae5b2ecd874eace22",
      "parents": [
        "2170233c49e50f3986cdc4f726016d6003cb5b8e"
      ],
      "author": {
        "name": "Lajos Molnar",
        "email": "lajos@google.com",
        "time": "Fri Apr 17 13:46:19 2015 -0700"
      },
      "committer": {
        "name": "Lajos Molnar",
        "email": "lajos@google.com",
        "time": "Fri Apr 17 13:46:43 2015 -0700"
      },
      "message": "stagefright: warnings be gone, some are now errors, use clang\n\nChange-Id: I81f438ae444f04c12ae27ae4ef6d073033de172c\n"
    },
    {
      "commit": "4f82a25c07c3ffc8d44d61797043f9864058afdf",
      "tree": "bd11203300c025681b8b1cd58391d248bdd727d4",
      "parents": [
        "8f26056ce83bc50da4751be20b8defc08f55294e"
      ],
      "author": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Mon Dec 22 10:18:15 2014 -0800"
      },
      "committer": {
        "name": "Marco Nelissen",
        "email": "marcone@google.com",
        "time": "Mon Dec 22 10:18:15 2014 -0800"
      },
      "message": "Add log tag to FileSource\n\nChange-Id: Id3435bbaede2fee0a780e7d7570218c5a9a1c4a0\n"
    },
    {
      "commit": "f4b7d94062c896dca565d849c6188cd3489be257",
      "tree": "b3bc6b1b2bc3641417e018a3235d144b1f8b285b",
      "parents": [
        "b3eb2b7e0ad11bc03344e10cc5204bdb71f0686e"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Apr 11 11:52:03 2012 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Apr 11 12:46:12 2012 -0700"
      },
      "message": "Better error logging during meta data retrieval. Fixed the stagefright\n\ncommandline tool to open the file to extract thumbnails from itself since\nmediaserver may not have permission to open files.\n\nChange-Id: Iabe16b3248e9bb0f266b0866a8d2ccba2ab7d2a8\nrelated-to-bug: 6321237\n"
    },
    {
      "commit": "4ee31e2603b4019e4ae76e027115f80b818527aa",
      "tree": "de19fad362c2250b08249c9dcb73a0bfad2d27c3",
      "parents": [
        "d2469c3fe382203eb7cd5060c94ed204bec98116"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Apr 11 09:22:52 2012 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Apr 11 09:22:52 2012 -0700"
      },
      "message": "Cache the file size in favour of extraneous seek requests.\n\nChange-Id: Ia922b13179c69749d09cd3fccbd5c30109c28bd7\nrelated-to-bug: 6321952\n"
    },
    {
      "commit": "f1d5aa162c02a16b7195a43a9bcea4d592600ac4",
      "tree": "dc270a6e1a4ee6695e309eeb29c4d9ed7f3a20a2",
      "parents": [
        "43089daaf82bd2b8e5f9a29b80af5abaae4657b3"
      ],
      "author": {
        "name": "James Dong",
        "email": "jdong@google.com",
        "time": "Mon Feb 06 23:46:37 2012 -0800"
      },
      "committer": {
        "name": "James Dong",
        "email": "jdong@google.com",
        "time": "Fri Feb 10 11:43:09 2012 -0800"
      },
      "message": "Move away from MediaDebug and use ADebug instead\n\nChange-Id: I963a3b6f79a7292891973cbeeaf3378b38629f08\n"
    },
    {
      "commit": "9d2f386dd2885eaffa11fd494ae258bb09fe6397",
      "tree": "382639f8cc7f1a3677589d7dfca37b667ea4261c",
      "parents": [
        "83bc7f3cf78b28a818417f40a4f0c00593993366"
      ],
      "author": {
        "name": "James Dong",
        "email": "jdong@google.com",
        "time": "Tue Jan 10 08:24:37 2012 -0800"
      },
      "committer": {
        "name": "James Dong",
        "email": "jdong@google.com",
        "time": "Thu Jan 12 16:25:12 2012 -0800"
      },
      "message": "Separate sniffing from session initialization\n\nThis avoid lengthy/duplicate sniffing for drm plugins when a decrypt session is opened\n\no The change is backward compatibile in that no update is required\n  for existing drm plug-ins if they do not plan to provide separate\n  sniffer/extractor\n\nrelated-to-bug: 5725548\n\nChange-Id: I7fc4caf82d77472da4e2bc7b5d31060fb54fd84c\n"
    },
    {
      "commit": "29357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47",
      "tree": "3bdafe4b02fe36f6ee29c3170f0b0d2799bebf86",
      "parents": [
        "d709ca9c6a0fa1c8f40cbe624a119398643c5087"
      ],
      "author": {
        "name": "Steve Block",
        "email": "steveblock@google.com",
        "time": "Fri Jan 06 19:20:56 2012 +0000"
      },
      "committer": {
        "name": "Steve Block",
        "email": "steveblock@google.com",
        "time": "Sun Jan 08 13:19:13 2012 +0000"
      },
      "message": "Rename (IF_)LOGE(_IF) to (IF_)ALOGE(_IF)  DO NOT MERGE\n\nSee https://android-git.corp.google.com/g/#/c/157220\n\nBug: 5449033\nChange-Id: Ic9c19d30693bd56755f55906127cd6bd7126096c\n"
    },
    {
      "commit": "3a13fad63af40a8364fce796b1a54a8f0a2fbf32",
      "tree": "a99d1e91d87550a46a523acfc0734a72f56db917",
      "parents": [
        "d681bbb1767bed09415e050ba78975df214bcd68"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Sep 02 09:34:51 2011 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Fri Sep 02 09:34:51 2011 -0700"
      },
      "message": "Properly serialize access to FileSource::getSize by acquiring the mutex\n\nBoth ::getSize and ::read call into lseek64, if this happens simultaneously\nfrom multiple threads the results are undefined if not properly serialized.\n\nChange-Id: I737cafebd836f3d8eb702beac557b4731f69c6f6\nrelated-to-bug: 5196490\n"
    },
    {
      "commit": "b5ce361d19e69fe156f7188c9ee0f4734b259874",
      "tree": "1536e63d3394cbbd5c2e8bc5cde6affb2b173850",
      "parents": [
        "609ce04d29780c430ff7e17511fc073a664c02d5"
      ],
      "author": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Thu Feb 24 16:40:57 2011 -0800"
      },
      "committer": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Thu Mar 10 16:20:48 2011 -0800"
      },
      "message": "Fix for bug 3477330\nThis patch fixs a crash bug caused by using a NULL DecryptHandle pointer.\nFix by using sp\u003cDecryptHandle\u003e instead.\n\nChange-Id: Icbd59858385e8256125a615a3c82656b25319d44\n"
    },
    {
      "commit": "8f64134f749e4f7861a08a3063450fc714c4651d",
      "tree": "3b095f20cf3d4da0922c6a9b2d078f4cdc65ccd3",
      "parents": [
        "b93d55d9f6e154629d47270970e0a0ace5a1b0a0"
      ],
      "author": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Tue Feb 08 13:24:08 2011 -0800"
      },
      "committer": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Tue Feb 08 13:25:27 2011 -0800"
      },
      "message": "Add more check before using the DRM manager client.\n\nChange-Id: I7369dcd6b6abd1945430373200fd5353bca70652\n"
    },
    {
      "commit": "889b340ec736a9d3e3e690256d305cc8740f0c4b",
      "tree": "fab2bdfdc9621b051923b744065f8f0331b770c1",
      "parents": [
        "802da7bc462f6f9df6e681cc75c51dc0a056a4a1"
      ],
      "author": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Mon Feb 07 11:41:11 2011 -0800"
      },
      "committer": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Mon Feb 07 15:10:33 2011 -0800"
      },
      "message": "- Do not use global DrmManagerClient\n- Release the DrmManagerClient and DecryptHandle in DataSource\nFix for bug 3429811\n\nChange-Id: I549f72b75225751877eb0e630ce8098f8ec6316f\n"
    },
    {
      "commit": "674ebd0b4e1143e38392a4e3bb38b4679a4577bc",
      "tree": "413ce9a380d7c35b935e475ea21fecf5cc5466e7",
      "parents": [
        "317ca79a49746dbd1b6bb83712e93e2dc5f6e4f0"
      ],
      "author": {
        "name": "James Dong",
        "email": "jdong@google.com",
        "time": "Thu Nov 18 20:59:13 2010 -0800"
      },
      "committer": {
        "name": "James Dong",
        "email": "jdong@google.com",
        "time": "Fri Nov 19 10:48:22 2010 -0800"
      },
      "message": "Removed uncessary FILE structure pointer for I/O\n\no also move the fd owner from caller to callee in the Writers\n\nChange-Id: I510ccfdd0fcc58f1777fea4ed1349fd251852c65\n"
    },
    {
      "commit": "c7fc37a3dab9bd1f96713649f351b5990e6316ff",
      "tree": "bd8cb4ea7521967152650311b485d2d0e6b3bcf2",
      "parents": [
        "17468ee8dbfe5eb0b9a4f72be80cbb92a5134800"
      ],
      "author": {
        "name": "James Dong",
        "email": "jdong@google.com",
        "time": "Tue Nov 16 14:04:54 2010 -0800"
      },
      "committer": {
        "name": "James Dong",
        "email": "jdong@google.com",
        "time": "Thu Nov 18 14:12:24 2010 -0800"
      },
      "message": "64-bit file size/offset support for media framework\n\nChange-Id: I3452bc2c0f1d990cc67285df2fce1f9f86ff8e10\n"
    },
    {
      "commit": "b371426ce4cf2fa6d8c3d1903b61322feb165d35",
      "tree": "ce2c36b33cf39e393b68d5feba1cb03d7ef0ed53",
      "parents": [
        "a935bc4696e4060c362b0f6913cc220331667a35"
      ],
      "author": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Mon Nov 01 15:53:16 2010 -0700"
      },
      "committer": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Fri Nov 05 10:33:58 2010 -0700"
      },
      "message": "Add support for WV DRM\n\nChange-Id: I0408c5e0a488f112a84337b21b0cd4613a4da461\n"
    },
    {
      "commit": "4e6572967da698d568a44d18797b751ec8ae5401",
      "tree": "d234ee861f583d46650e92e9718087aa08ecbb9a",
      "parents": [
        "7b54d6652692ce078df9c606d2d72ebc8ee1f4a2"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Oct 27 10:33:04 2010 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Oct 27 10:33:04 2010 -0700"
      },
      "message": "FileSource may fail to open a file in which case subsequent code dereferences a NULL pointer. This fixes this recently introduced problem.\n\nChange-Id: I60dd9532b694a1b488743b71f43e107c778d6683\n"
    },
    {
      "commit": "a9741a9232c81eaf59179acef91f5be46c42264e",
      "tree": "9a66416b42a28ec2ad4fa2ec520c42d976046aec",
      "parents": [
        "d8cba5371423841e6a85816ad4a7fd88d3a60b12",
        "dcd25efb46c41c8d24a0a9cf61fb57f84149709e"
      ],
      "author": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Mon Oct 25 15:23:04 2010 -0700"
      },
      "committer": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Mon Oct 25 16:11:18 2010 -0700"
      },
      "message": "resolved conflicts for merge of 9084631d to gingerbread-plus-aosp\n\nChange-Id: Ie2b675d50bfca3f33aee80f1a67c9f03d1f97472\n"
    },
    {
      "commit": "dcd25efb46c41c8d24a0a9cf61fb57f84149709e",
      "tree": "6b6d165ba952924f1cd1b77f3a0903e5da31445a",
      "parents": [
        "2272ee27d9022d173b6eab45c409b3c3f57f30ec"
      ],
      "author": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Tue Jun 22 13:55:38 2010 -0700"
      },
      "committer": {
        "name": "Gloria Wang",
        "email": "gwang@google.com",
        "time": "Mon Oct 25 12:16:56 2010 -0700"
      },
      "message": "DRM framework support:\n- add a sniffer for DRM files\n- add DRMSource and DRMExtractor for es_based DRM\n- add pread in FileSource.cpp for container_based DRM\n- add native DRM framework API calls in the player for\n  DRM audio/video playback\n\nChange-Id: I4b9ef19165c9b4f44ff40eeededb9a665e78a90f\n"
    },
    {
      "commit": "3d8055ac96170de7a8c49b9ffbe83ed447ccddce",
      "tree": "f12dc5696f8436c9a304beffd039d27377a56f81",
      "parents": [
        "6b19faca7040ba4ef67637801926ead2559c22e9"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon May 24 09:18:36 2010 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon May 24 09:24:02 2010 -0700"
      },
      "message": "Interestingly, a call to fseek with a NULL file handle now blocks forever...\n\nChange-Id: Ic80c579abcf2bdb73f7fd1da713649b7c7f25f56\n"
    },
    {
      "commit": "fc9ba09e3bb368f823d473f5e2bb9aa32dba6289",
      "tree": "e7a6e0357e39c58d050b23a94b61f734e5578af7",
      "parents": [
        "58e1f78683d9230932c4d5bee53b79fc685b5995"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon Jan 11 15:35:19 2010 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Tue Jan 12 09:14:15 2010 -0800"
      },
      "message": "Squashed commit of the following:\n\ncommit f81bb1dac5ef107bb0d7d5d756fb1ffa532ba2cc\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Jan 11 14:55:56 2010 -0800\n\n    Support for duration metadata, midi and ogg-vorbis files (in mediascanner)\n\ncommit 0b1385a0dc156ce27985a1ff757c4c142fd7ec39\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Mon Jan 11 14:20:45 2010 -0800\n\n    Refactor meta data logic. Container specific metadata is now also returned by the MediaExtractor.\n\ncommit f9818dfac39c96e5fefe8c8295e60580692d5990\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Fri Jan 8 14:26:09 2010 -0800\n\n    A first pass at supporting metadata through ID3 tags.\n\ncommit 476e9e253633336ab790f943e2d6c0cd8991d76a\nAuthor: Andreas Huber \u003candih@google.com\u003e\nDate:   Thu Jan 7 15:48:44 2010 -0800\n\n    Initial checkin of ID3 (V2.2 and V2.3) parser for use in stagefright.\n\nrelated-to-bug: 2295456\n"
    },
    {
      "commit": "d912f4646ece79832f9d852b39eb6b0d836ccfc4",
      "tree": "3997f451c32651068afbe82a1a6ea06884bf8cf1",
      "parents": [
        "d9618f23226f46c752e56f712bc4b505117d8b4b"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon Dec 07 16:37:37 2009 -0800"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Mon Dec 07 16:41:57 2009 -0800"
      },
      "message": "Note to self: Don\u0027t reverse the arguments to fseek(o)...\n"
    },
    {
      "commit": "03475f5af25e4aa32d46d41dd2ec756853d8dd9d",
      "tree": "aa3a35c429a4307d2383931b3dd2e72fe55277f2",
      "parents": [
        "057eacf4578ac6b90ee18c524670e01445bf2732"
      ],
      "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": "34769bc913e9f6bb138e666d94a9d685bf3da217",
      "tree": "04de6901ea0132276789b671db83c2cccbee68c0",
      "parents": [
        "66326a5ee0869f1ee4d136a477e6effba428b3cb"
      ],
      "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": "0c89199745bc1bf05b997fc7c342017807676b6f",
      "tree": "2f0e1b4ed919909207d70ce9814f5854dba551ea",
      "parents": [
        "355edcea2f15c0f619c1e1d0f4fa433b0d38098f"
      ],
      "author": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Aug 26 14:48:20 2009 -0700"
      },
      "committer": {
        "name": "Andreas Huber",
        "email": "andih@google.com",
        "time": "Wed Aug 26 14:48:20 2009 -0700"
      },
      "message": "assert \u003d\u003e CHECK in stagefright.\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"
    }
  ]
}
