)]}'
{
  "log": [
    {
      "commit": "697fa9721cbc54ce1604dae09d1be6bb918567f6",
      "tree": "86359dcb48ae4e08a259c46a675269ba84b90ba3",
      "parents": [
        "8a0f572397ca0673c65c1662946014bb73b5cdc6"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Apr 23 13:43:21 2008 +0300"
      },
      "committer": {
        "name": "David Woodhouse",
        "email": "dwmw2@infradead.org",
        "time": "Wed Apr 23 11:32:10 2008 +0100"
      },
      "message": "UBI: add a message\n\nUBI scan takes quite a time on some systems, so it is nice\nto print a message that we started attaching an MTD device.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\nSigned-off-by: David Woodhouse \u003cdwmw2@infradead.org\u003e\n"
    },
    {
      "commit": "e43fe686e48835ca027559a068bbe0b6d264a254",
      "tree": "def98b52b111ba384a2fd01955465f813ca299e4",
      "parents": [
        "986ee0139a91ab8b6b07d29d7a112c8033b5f8e0",
        "434b825e1fc9ef7971fc962734278ffbab36a1ab"
      ],
      "author": {
        "name": "David Woodhouse",
        "email": "dwmw2@infradead.org",
        "time": "Wed Apr 23 09:57:25 2008 +0100"
      },
      "committer": {
        "name": "David Woodhouse",
        "email": "dwmw2@infradead.org",
        "time": "Wed Apr 23 09:57:25 2008 +0100"
      },
      "message": "Merge git://git.infradead.org/~dedekind/ubi-2.6\n"
    },
    {
      "commit": "cb53b3b99992b6c548d56cdf47bc710640ee2ee1",
      "tree": "b47772c81b5a2adfbd2ca96bbc4f4b29d8a2e3c3",
      "parents": [
        "35d086b143e52f43a70c85ab86c054cbf1c4ff26"
      ],
      "author": {
        "name": "Harvey Harrison",
        "email": "harvey.harrison@gmail.com",
        "time": "Fri Apr 18 13:44:19 2008 -0700"
      },
      "committer": {
        "name": "David Woodhouse",
        "email": "dwmw2@infradead.org",
        "time": "Tue Apr 22 12:36:04 2008 +0100"
      },
      "message": "[MTD] replace remaining __FUNCTION__ occurrences\n\n__FUNCTION__ is gcc-specific, use __func__\n\nSigned-off-by: Harvey Harrison \u003charvey.harrison@gmail.com\u003e\nSigned-off-by: Andrew Morton \u003cakpm@linux-foundation.org\u003e\nSigned-off-by: David Woodhouse \u003cdwmw2@infradead.org\u003e\n"
    },
    {
      "commit": "434b825e1fc9ef7971fc962734278ffbab36a1ab",
      "tree": "361f3f17722a53a3eaf6d3b94623c2ab4517cfc7",
      "parents": [
        "4bc1dca4b0eb4dfbf100895bfc1256f21e3c901a"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Apr 20 18:00:33 2008 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Apr 20 18:02:42 2008 +0300"
      },
      "message": "UBI: print media information earlier\n\nPrint information about logicale eraseblock size, sub-page\nsize and so on at early stage, befor an attempt to attach\nthe MTD device was made. This is more convenient to do so\nbecause the attempt to attach may fail, and the information\nis never printed then.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "4bc1dca4b0eb4dfbf100895bfc1256f21e3c901a",
      "tree": "4ccfc207a0b55cfad4247f49bd1bce03d5034560",
      "parents": [
        "cbd8a9d2cd6f576ca41022599341bbd8be1b0b27"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sat Apr 19 20:44:31 2008 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sat Apr 19 20:49:41 2008 +0300"
      },
      "message": "UBI: fix mean EC calculation\n\n(a + b) / (c + d) !\u003d a / c + b / d. The old code errornously\nassumed this incorrect formuld. Instead, just sum all erase\ncounters in a 64-bit variable and divide to the number of EBs\nat the end.\n\nThanks to Adrian Hunter for pointing this out.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "cbd8a9d2cd6f576ca41022599341bbd8be1b0b27",
      "tree": "4b85d8497972adb46b574fc37bb73761c76d04ab",
      "parents": [
        "6e0c84e37e809e79313043385148020ceb760496"
      ],
      "author": {
        "name": "Jan Altenberg",
        "email": "jan.altenberg@linutronix.de",
        "time": "Fri Mar 28 16:13:53 2008 +0100"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Apr 17 11:32:02 2008 +0300"
      },
      "message": "UBI: initialize static volumes with vol-\u003eused_bytes\n\nI came across a problem which seems to be present since:\n\ncommit 941dfb07ed91451b1c58626a0d258dfdf468b593\nUBI: set correct gluebi device size\n\nubi_create_gluebi() leaves mtd-\u003esize \u003d 0 for static volumes. So even\nexisting static volumes are initialized with a size of 0.\n\nSigned-off-by: Jan Altenberg \u003cjan.altenberg@linutronix.de\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "6e0c84e37e809e79313043385148020ceb760496",
      "tree": "50759478329fb8cd2083db986bc2b60395820024",
      "parents": [
        "c4506092c1773211b71a75bd557c02b090c82b66"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Mar 27 17:18:45 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Apr 17 11:32:00 2008 +0300"
      },
      "message": "UBI: improve Kconfig documentation\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "c4506092c1773211b71a75bd557c02b090c82b66",
      "tree": "79e5aca3f160ca0a6237aa92a41340017a764317",
      "parents": [
        "92a74f1c1c9ca4d8009bfdea1c5febb7c0674f15"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Feb 12 16:36:41 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Apr 17 11:31:59 2008 +0300"
      },
      "message": "UBI: fix error printing\n\nUse existing ubi_err() as the rest of the code does.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "92a74f1c1c9ca4d8009bfdea1c5febb7c0674f15",
      "tree": "513e647abdbad5137146ab7c765a3345ca18765c",
      "parents": [
        "a4f0fcdfb2397e81d22446bb364dc190bf16b25a"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sat Feb 16 15:42:52 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Apr 17 11:31:58 2008 +0300"
      },
      "message": "UBI: make ubi-header.h local\n\nThe new trend in linux is not to store headers which define\non-media format in the include/ directory, but instead, store\nthem locally. This is because these headers \"do not define any\nkernel\u003c-\u003euserspace interface\".\n\nDo so for UBI as well.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "a4f0fcdfb2397e81d22446bb364dc190bf16b25a",
      "tree": "1261dcd0a2a4bf52065b0c9dedd4b730b6eed6cd",
      "parents": [
        "f4988927a257791d372dddeda8eda8521bf6cb00"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Feb 12 13:26:31 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Apr 17 11:31:58 2008 +0300"
      },
      "message": "UBI: be verbose when debuggin is enabled\n\nMake I/O function to be always verbose when about CRC errors\nand magic number errors when I/O debugging is enabled.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "f7f0283776b6fe33f87f6a2ef15b1feb49ef6dac",
      "tree": "e2328ff5d42741519a03290e5c8f74c966c991b9",
      "parents": [
        "8eee9f100b1cc3d1b0a701a8626c54422af3c987"
      ],
      "author": {
        "name": "Adrian Bunk",
        "email": "bunk@kernel.org",
        "time": "Mon Mar 03 20:07:52 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Mar 04 11:03:09 2008 +0200"
      },
      "message": "UBI: mtd/ubi/vtbl.c: fix memory leak\n\nThis patch fixes a memory leak introduced by commit\n4ccf8cffa963c7b5bdc6d455ea9417084ee49aa8 and spotted by the Coverity\nchecker.\n\nSigned-off-by: Adrian Bunk \u003cbunk@kernel.org\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "8eee9f100b1cc3d1b0a701a8626c54422af3c987",
      "tree": "957d7cf0d12aa63a20f67725081f385d76b7cfa4",
      "parents": [
        "19cd7b7de1804a50264dfd5c6ba3c6d332362a77"
      ],
      "author": {
        "name": "Harvey Harrison",
        "email": "harvey.harrison@gmail.com",
        "time": "Fri Feb 15 10:47:51 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Mar 04 11:02:50 2008 +0200"
      },
      "message": "UBI: fix sparse errors in ubi.h\n\nIn C, signed 1-bit bitfields can only take the values 0 and -1, only 0 and 1\nare ever assigned in current code.  Make them unsigned bitfields.\n\nFixes the (repeated) sparse errors:\ndrivers/mtd/ubi/ubi.h:220:15: error: dubious one-bit signed bitfield\ndrivers/mtd/ubi/ubi.h:221:17: error: dubious one-bit signed bitfield\ndrivers/mtd/ubi/ubi.h:222:18: error: dubious one-bit signed bitfield\ndrivers/mtd/ubi/ubi.h:223:16: error: dubious one-bit signed bitfield\ndrivers/mtd/ubi/ubi.h:224:20: error: dubious one-bit signed bitfield\n\nSigned-off-by: Harvey Harrison \u003charvey.harrison@gmail.com\u003e\nCc: Artem Bityutskiy \u003cdedekind@infradead.org\u003e\nSigned-off-by: Andrew Morton \u003cakpm@linux-foundation.org\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "19cd7b7de1804a50264dfd5c6ba3c6d332362a77",
      "tree": "2f0933a3d1259345856098cb6358d8b9cacccbcf",
      "parents": [
        "fc398769ac5cbfdf4dc16a7ba657b284abcc92f5"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Feb 12 16:32:35 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Mar 04 11:02:26 2008 +0200"
      },
      "message": "UBI: fix error message\n\nMake it print \"UBI error: cannot attach mtd4\"\ninstead of \"UBI error: cannot attach 4\"\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "fc398769ac5cbfdf4dc16a7ba657b284abcc92f5",
      "tree": "f78291a5da7f15239ce1b29da1144a0ee5c79801",
      "parents": [
        "bfa274e2436fc7ef72ef51c878083647f1cfd429"
      ],
      "author": {
        "name": "S.Çağlar Onur",
        "email": "caglar@pardus.org.tr",
        "time": "Tue Feb 12 13:25:06 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Mar 04 11:02:04 2008 +0200"
      },
      "message": "UBI: silence warning\n\ndrivers/mtd/ubi/vmt.c: In function `ubi_create_volume\u0027:\ndrivers/mtd/ubi/vmt.c:379: warning: statement with no effect\n\nSigned-off-by: S.Çağlar Onur \u003ccaglar@pardus.org.tr\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "6dc4a8717fadd47103b5015cc678c75afda43ae0",
      "tree": "3fd91ac0761a815bdfc813deb50aaf7605db9cb6",
      "parents": [
        "e653879c269735c9ff6684e03edf1d4e041ff3d3"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Feb 01 13:48:49 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Feb 01 13:48:49 2008 +0200"
      },
      "message": "UBI: do not flush queue on each vtbl change\n\nThis is just not necessary. We re-write whole layout copy, so\nthe old contents cannot show up again sice scan process will\ndrop it.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "e653879c269735c9ff6684e03edf1d4e041ff3d3",
      "tree": "2019a018e3fd809798dabfa92e356acc8030cdd4",
      "parents": [
        "866136827b9a71c39dcb06d23ce523f719eab74b"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Jan 24 18:48:21 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jan 25 16:41:26 2008 +0200"
      },
      "message": "UBI: implement atomic LEB change ioctl\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "60c031531a85b3580f66c2530f9b2802adcad4df",
      "tree": "f3d9211a948233f23f8e193af951776024d6aa29",
      "parents": [
        "1b68d0eea5daddc762c54bf02154f4ad607d9ce8"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Jan 24 17:56:14 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jan 25 16:41:25 2008 +0200"
      },
      "message": "UBI: handle zero-length case\n\nubi_eba_atomic_leb_change() has to just map the LEB to a free PEB\nif data length is zero.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "1b68d0eea5daddc762c54bf02154f4ad607d9ce8",
      "tree": "e918b5d434da7213a7af8cff2b6bd692035f72cf",
      "parents": [
        "0411e7353192d7deebd4f50b9ee41974ec3a634c"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Jan 24 17:04:01 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jan 25 16:41:25 2008 +0200"
      },
      "message": "UBI: simplify internal interfaces\n\nInstead of passing vol_id to all functions and then find\nstruct ubi_volume, pass struct ubi_volume pointer.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "0411e7353192d7deebd4f50b9ee41974ec3a634c",
      "tree": "059c8f96ee9692818f16f0761b41a63e72cb9ced",
      "parents": [
        "91f2d53cd75a8fa3557246af965155208c4c69a7"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Jan 24 16:45:57 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jan 25 16:41:25 2008 +0200"
      },
      "message": "UBI: do not change file pointer while updating\n\nSince we do not change semantics of seek(), changing the file\npointer while updating does not make much sense.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "91f2d53cd75a8fa3557246af965155208c4c69a7",
      "tree": "a428ac05cb6998e97df0e7894a51ec6a0db45920",
      "parents": [
        "c18a84186cc05bee19d55823f1a35f4ea91a92d6"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Jan 24 11:23:23 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jan 25 16:41:25 2008 +0200"
      },
      "message": "UBI: add layout volume information\n\nAdd more information about layout volume to make userspace tools\nuse the macros instead of constants. Also rename UBI_LAYOUT_VOL_ID\nto make it consistent with other macros.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "c18a84186cc05bee19d55823f1a35f4ea91a92d6",
      "tree": "f0707d090a079afbb6a971fdad6670ce9f31e062",
      "parents": [
        "64203195edf44601d9825284101dcaf7ad54ece8"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Jan 24 11:19:14 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jan 25 16:41:25 2008 +0200"
      },
      "message": "UBI: fix warnings\n\nOld gcc complains:\n\nCC      drivers/mtd/ubi/wl.o\ndrivers/mtd/ubi/wl.c: In function \u0027wear_leveling_worker\u0027:\ndrivers/mtd/ubi/wl.c:746: warning: \u0027pe\u0027 may be used uninitialized in this function\nCC      drivers/mtd/ubi/scan.o\ndrivers/mtd/ubi/scan.c: In function \u0027ubi_scan\u0027:\ndrivers/mtd/ubi/scan.c:772: warning: \u0027ec\u0027 may be used uninitialized in this function\ndrivers/mtd/ubi/scan.c:772: note: \u0027ec\u0027 was declared here\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "64203195edf44601d9825284101dcaf7ad54ece8",
      "tree": "9db30aa5b9dca3e04a8c593005d1aee0d001a5cb",
      "parents": [
        "2f9270e7fe86591d6ba01c0df6ad3f6c035687ea"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Jan 22 12:38:15 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jan 25 16:41:25 2008 +0200"
      },
      "message": "UBI: add sanity check\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "2f9270e7fe86591d6ba01c0df6ad3f6c035687ea",
      "tree": "67f7caaaa18be97255600decf2e8d2ae9d3898c0",
      "parents": [
        "d536058752274b2fe60135142da550b5355ffa94"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Jan 22 12:31:30 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jan 25 16:41:25 2008 +0200"
      },
      "message": "UBI: remove bogus assertion\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "d536058752274b2fe60135142da550b5355ffa94",
      "tree": "c3b2bb4a3097a06c1ed085e202cdff87f8a2d564",
      "parents": [
        "ddc4939161c502452392b353f9e0dd088239e4c1"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Jan 17 15:41:14 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jan 25 16:41:24 2008 +0200"
      },
      "message": "UBI: bugfix: calculate data offset properly\n\nData offset is VID header offset + VID header size aligned to\nthe min. I/O unit size up.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "ddc4939161c502452392b353f9e0dd088239e4c1",
      "tree": "764fcb506468a032aea6fb65802c0ee9413a9644",
      "parents": [
        "4ccf8cffa963c7b5bdc6d455ea9417084ee49aa8"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Jan 17 15:35:57 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jan 25 16:41:24 2008 +0200"
      },
      "message": "UBI: amend array size\n\nSince the data offset parameter was removed, the size of\nthe parameters array is now 2, not 3.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "4ccf8cffa963c7b5bdc6d455ea9417084ee49aa8",
      "tree": "a7281874dc9298b3d7eca2d1e4cb22c326625382",
      "parents": [
        "896c0c06aa30147630e9a75949b6ae2014c841fc"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jan 16 15:44:24 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jan 25 16:41:24 2008 +0200"
      },
      "message": "UBI: add auto-resize feature\n\nThe problem: NAND flashes have different amount of initial bad physical\neraseblocks (marked as bad by the manufacturer). For example, for 256MiB\nSamsung OneNAND flash there might be from 0 to 40 bad initial eraseblocks,\nwhich is about 2%. When UBI is used as the base system, one needs to know\nthe exact amount of good physical eraseblocks, because this number is\nneeded to create the UBI image which is put to the devices during\nproduction. But this number is not know, which forces us to use the\nminimum number of good physical eraseblocks. And UBI additionally\nreserves some percentage of physical eraseblocks for bad block handling\n(default is 1%), so we have 1-3% of PEBs reserved at the end, depending\non the amount of initial bad PEBs. But it is desired to always have\n1% (or more, depending on the configuration).\n\nSolution: this patch adds an \"auto-resize\" flag to the volume table.\nThe volume which has the \"auto-resize\" flag will automatically be re-sized\n(enlarged) on the first UBI initialization. UBI clears the flag when\nthe volume is re-sized. Only one volume may have the \"auto-resize\" flag.\n\nSo, the production UBI image may have one volume with \"auto-resize\"\nflag set, and its size is automatically adjusted on the first boot\nof the device.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "896c0c06aa30147630e9a75949b6ae2014c841fc",
      "tree": "d34cbb7ed0995b92883311134e624b0d82686e4f",
      "parents": [
        "ae616e1be13599c3b64e544ebe99e69ea851e99c"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jan 16 14:24:14 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jan 25 16:41:24 2008 +0200"
      },
      "message": "UBI: use bit-fields\n\nSave 12 bytes of RAM per volume by using bit-fields instead of integers.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "ae616e1be13599c3b64e544ebe99e69ea851e99c",
      "tree": "02edc84279e332991f75e998255ee563d6579027",
      "parents": [
        "b9a06623d9d0c6dff758d525ceb0d9e2bba8f7d6"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jan 16 12:15:47 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jan 25 16:41:24 2008 +0200"
      },
      "message": "UBI: fix warnings\n\ndrivers/mtd/ubi/cdev.c: In function ‘vol_cdev_read’:\ndrivers/mtd/ubi/cdev.c:187: warning: unused variable ‘vol_id’\nCC [M]  drivers/mtd/ubi/kapi.o\ndrivers/mtd/ubi/kapi.c: In function ‘ubi_leb_erase’:\ndrivers/mtd/ubi/kapi.c:483: warning: unused variable ‘vol_id’\ndrivers/mtd/ubi/kapi.c: In function ‘ubi_leb_unmap’:\ndrivers/mtd/ubi/kapi.c:544: warning: unused variable ‘vol_id’\ndrivers/mtd/ubi/kapi.c: In function ‘ubi_leb_map’:\ndrivers/mtd/ubi/kapi.c:582: warning: unused variable ‘vol_id’\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "b9a06623d9d0c6dff758d525ceb0d9e2bba8f7d6",
      "tree": "9107daa5cf1aa527603c7d33d55ca45dbe760d5a",
      "parents": [
        "4fac9f698404a5cd50b978fbdb7e54235353c215"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jan 16 12:11:54 2008 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jan 25 16:41:24 2008 +0200"
      },
      "message": "UBI: get rid of ubi_ltree_slab\n\nThis slab cache is not really needed since the number of objects\nis low and the constructor does not make much sense because we\nallocate oblects when doint I/O, which is way slower then allocation.\n\nSuggested-by: Arnd Bergmann \u003carnd@arndb.de\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "4b3cc340614e552c476bec29d984c5a363b26494",
      "tree": "5fd0df68217f18dcfb80761c932a5dcba5de947d",
      "parents": [
        "aeddb87718823fb81b896155b34d1bb4c8cae874"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 15:59:39 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:18 2007 +0200"
      },
      "message": "UBI: bugfix: do not forget to increment vol_count\n\nWhen creating a new volume, do not forget to increment the\nvol_count variable.\n\nAlso, users are not interested in internal volumes, so do not show\nthem in the volumes_count sysfs file.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "aeddb87718823fb81b896155b34d1bb4c8cae874",
      "tree": "b96e3d90dbbbcebb77476a73dcfb958ab0b4d374",
      "parents": [
        "b6b76ba466bbd47397efad0fdaeaa5ebf7d462c7"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 14:25:58 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:18 2007 +0200"
      },
      "message": "UBI: do not support kiB\n\nBe strict and accept only KiB, MiB and GiB, not Kib, not kib, etc.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "b6b76ba466bbd47397efad0fdaeaa5ebf7d462c7",
      "tree": "06af1b32c201abdc87bb852c5ba10c8acccaf9bc",
      "parents": [
        "d1f3dd6cc00f5bf744118fb2820ecdf09a1f4b73"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 13:46:46 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:17 2007 +0200"
      },
      "message": "UBI: add mtd_num sysfs attribute\n\nExpose number or the underlying MTD device in sysfs.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "d1f3dd6cc00f5bf744118fb2820ecdf09a1f4b73",
      "tree": "48663606422eda9245c3a53f1437f9c4458b8aa7",
      "parents": [
        "783b273afab43437dca731a229d53d72faf77fd3"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Dec 25 19:17:00 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:17 2007 +0200"
      },
      "message": "UBI: fix mtd device string parsing\n\nUBI allows to specify MTD device name or number when the module is being\nloaded. When parsing MTD device identity string, it first tries to treat\nit as device NAME, and if that fails, it treats it as device number.\n\nMake it vice-versa as this is more logical and makes less troubles when\nyou have an MTD device named \"1\" and try to load mtd1 which has different\nname. This is especially easy to hit when gluebi is enabled.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "783b273afab43437dca731a229d53d72faf77fd3",
      "tree": "daadf822539189bcc81d64a609f2b084849114e5",
      "parents": [
        "897a316c9e6f7fea6f1d3759797b75c0ebaec479"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Dec 25 18:13:33 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:17 2007 +0200"
      },
      "message": "UBI: use separate mutex for volumes checking\n\nIntroduce a separate mutex which serializes volumes checking,\nbecause we cammot really use volumes_mutex - it cases reverse\nlocking problems with mtd_tbl_mutex when gluebi is used -\nthanks to lockdep.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "897a316c9e6f7fea6f1d3759797b75c0ebaec479",
      "tree": "487f211f3a862d8948ba19ca3f645c7a37f4d547",
      "parents": [
        "9b79cc0f84edecceb04b806b9014fcec1306c34d"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Dec 18 18:23:39 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:17 2007 +0200"
      },
      "message": "UBI: handle attach ioctl\n\nActually implement the MTD device attach/detach handlers.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "dd38fccfbc77e12417512c38508a5283ea79a375",
      "tree": "591cae6d1ebdbdc52fc9d38bcb3454c3487bd9a0",
      "parents": [
        "cdfa788acd134a35d3e5b73d1a76fca4033d8aa9"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 19 21:43:32 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:17 2007 +0200"
      },
      "message": "UBI: remove data_offset\n\n\u0027data_offset\u0027 parameter does not really make sense and it is not\nneeded. Get rid of it.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "cdfa788acd134a35d3e5b73d1a76fca4033d8aa9",
      "tree": "ccc8cbf0bad80f569d9e3bbdc7cbf9c97556f155",
      "parents": [
        "e73f4459d969bb266f03dd4cbe21bdba8cb2732c"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Mon Dec 17 20:33:20 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:17 2007 +0200"
      },
      "message": "UBI: prepare attach and detach functions\n\nPrepare the attach and detach functions to by used outside of\nmodule initialization:\n\n* detach function checks reference count before detaching\n* it kills the background thread as well\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "e73f4459d969bb266f03dd4cbe21bdba8cb2732c",
      "tree": "5af7655da65f2c33f6ea4efdfaa8b0e0670d6aea",
      "parents": [
        "9f961b57568960a150cc9781c52824c9093a0514"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Mon Dec 17 17:37:26 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:17 2007 +0200"
      },
      "message": "UBI: add UBI devices reference counting\n\nThis is one more step on the way to \"removable\" UBI devices. It\nadds reference counting for UBI devices. Every time a volume on\nthis device is opened - the device\u0027s refcount is increased. It\nis also increased if someone is reading any sysfs file of this\nUBI device or of one of its volumes.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "9f961b57568960a150cc9781c52824c9093a0514",
      "tree": "345d60347d63bdc9973a2447d84024776b73dd2f",
      "parents": [
        "16f557ecbf96dd13d13788a6f62d4d97ae73b1f9"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Dec 16 16:59:31 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:17 2007 +0200"
      },
      "message": "UBI: add UBI control device\n\nThis patch is a preparation to make UBI devices dynamic. It\nadds an UBI control device which has dynamically allocated\nmajor number and registers itself as \"ubi_ctrl\". It does not\ndo anything so far. The idea is that this device will allow\nto attach/detach MTD devices from userspace.\n\nThis is symilar to what the Linux device mapper has.\n\nThe next things to do are:\n* Fix UBI, because it now assumes UBI devices cannot go away\n* Implement control device ioctls which will attach/detach MTD\n  devices\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "16f557ecbf96dd13d13788a6f62d4d97ae73b1f9",
      "tree": "c4bf8b052b7d8e0fb968cf7a274da1db7dd7bf97",
      "parents": [
        "593dd33c92c6529443d5df1350dc5cc76511232d"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 19 16:03:17 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:16 2007 +0200"
      },
      "message": "UBI: fix comment\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "593dd33c92c6529443d5df1350dc5cc76511232d",
      "tree": "dda360da5a5f66eb36b55a4c2e8eb985e997ffd6",
      "parents": [
        "458dbb3d07574e8fcdcb921ac155ccd81b16b05f"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Dec 18 15:54:35 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:16 2007 +0200"
      },
      "message": "UBI: fix ubi_wl_flush\n\nThe flush function should finish all the pending jobs. But if\nsomebody else is doing a work, this function should wait and let\nit finish.\n\nThis patche uses rw semaphore for synchronization purpose - it\njust looks quite convinient.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "458dbb3d07574e8fcdcb921ac155ccd81b16b05f",
      "tree": "38d2857bd29347a052c15fb909e10c1b39f6294a",
      "parents": [
        "43f9b25a9cdd7b177f77f026b1461abd1abbd174"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 19 17:03:42 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:16 2007 +0200"
      },
      "message": "UBI: fix printk\n\nAdd proper log level to printk\u0027s.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "43f9b25a9cdd7b177f77f026b1461abd1abbd174",
      "tree": "0c58fa96a8b6050fd2166d67552809cebd435549",
      "parents": [
        "d2c468550915ab2f16149e274a6f0da0b925a748"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Dec 18 15:06:55 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:16 2007 +0200"
      },
      "message": "UBI: bugfix: protect from volume removal\n\nWhen the WL worker is moving an LEB, the volume might go away\noccasionally. UBI does not handle these situations correctly.\n\nThis patch introduces a new mutex which serializes wear-levelling\nworker and the the \u0027ubi_wl_put_peb()\u0027 function. Now, if one puts\nan LEB, and its PEB is being moved, it will wait on the mutex.\nAnd because we unmap all LEBs when removing volumes, this will make\nthe volume remove function to wait while the LEB movement\nfinishes.\n\nBelow is an example of an oops which should be fixed by this patch:\n\nPid: 9167, comm: io_paral Not tainted (2.6.24-rc5-ubi-2.6.git #2)\nEIP: 0060:[\u003cf884a379\u003e] EFLAGS: 00010246 CPU: 0\nEIP is at prot_tree_del+0x2a/0x63 [ubi]\nEAX: f39a90e0 EBX: 00000000 ECX: 00000000 EDX: 00000134\nESI: f39a90e0 EDI: f39a90e0 EBP: f2d55ddc ESP: f2d55dd4\n DS: 007b ES: 007b FS: 00d8 GS: 0033 SS: 0068\nProcess io_paral (pid: 9167, ti\u003df2d54000 task\u003df72a8030 task.ti\u003df2d54000)\nStack: f39a95f8 ef6aae50 f2d55e08 f884a511 f88538e1 f884ecea 00000134 00000000\n       f39a9604 f39a95f0 efea8280 00000000 f39a90e0 f2d55e40 f8847261 f8850c3c\n       f884eaad 00000001 000000b9 00000134 00000172 000000b9 00000134 00000001\nCall Trace:\n [\u003cc0105227\u003e] show_trace_log_lvl+0x1a/0x30\n [\u003cc01052e2\u003e] show_stack_log_lvl+0xa5/0xca\n [\u003cc01053d6\u003e] show_registers+0xcf/0x21b\n [\u003cc0105648\u003e] die+0x126/0x224\n [\u003cc0119a62\u003e] do_page_fault+0x27f/0x60d\n [\u003cc037dd62\u003e] error_code+0x72/0x78\n [\u003cf884a511\u003e] ubi_wl_put_peb+0xf0/0x191 [ubi]\n [\u003cf8847261\u003e] ubi_eba_unmap_leb+0xaf/0xcc [ubi]\n [\u003cf8843c21\u003e] ubi_remove_volume+0x102/0x1e8 [ubi]\n [\u003cf8846077\u003e] ubi_cdev_ioctl+0x22a/0x383 [ubi]\n [\u003cc017d768\u003e] do_ioctl+0x68/0x71\n [\u003cc017d7c6\u003e] vfs_ioctl+0x55/0x271\n [\u003cc017da15\u003e] sys_ioctl+0x33/0x52\n [\u003cc0104152\u003e] sysenter_past_esp+0x5f/0xa5\n \u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "d2c468550915ab2f16149e274a6f0da0b925a748",
      "tree": "dfed962522327032ec98b5b92b526b59ea9b132e",
      "parents": [
        "d19bafd99d334cdc2530a7466235756bbc87c5d5"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Dec 18 13:17:24 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:16 2007 +0200"
      },
      "message": "UBI: improve comment\n\nExplain better the purpose of thie \u0027move_to_put\u0027 stuff.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "d19bafd99d334cdc2530a7466235756bbc87c5d5",
      "tree": "e30b3568c55c31659f92f7f30153ed32f91a16d8",
      "parents": [
        "40e4d0c1660f8ee01ea4ed570297b32c35c70aa3"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Dec 18 12:57:52 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:16 2007 +0200"
      },
      "message": "UBI: add PID to debugging prints\n\nAlso, use single dbg_msg() macro for all prints.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "40e4d0c1660f8ee01ea4ed570297b32c35c70aa3",
      "tree": "d1fbdf8b790ebc002302259e9f0d507d5a508855",
      "parents": [
        "d05c77a816974c09f8c7e8f48e5b9f7b59dafdf3"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Mon Dec 17 17:08:55 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:16 2007 +0200"
      },
      "message": "UBI: tweak volumes locking some more\n\nMake the code more consistent by requiring the caller to lock the\nubi-\u003evolume_mutex, because this is what we do for updates.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "d05c77a816974c09f8c7e8f48e5b9f7b59dafdf3",
      "tree": "6263ef3ad76c654e9d2635e5145f15c2b517edeb",
      "parents": [
        "db6e5770ef0ab351a403ac26e1ab1309e58f15d7"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Mon Dec 17 15:42:57 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:16 2007 +0200"
      },
      "message": "UBI: introduce volume refcounting\n\nAdd ref_count field to UBI volumes and remove weired \"vol-\u003eremoved\"\nfield. This way things are better understandable and we do not have\nto do whold show_attr operation under spinlock.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "db6e5770ef0ab351a403ac26e1ab1309e58f15d7",
      "tree": "29048da47919be2b8f54bf408fe900c042c9868a",
      "parents": [
        "35ad5fb76cc0a08e14068408b064103439feee36"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Mon Dec 17 15:48:49 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:15 2007 +0200"
      },
      "message": "UBI: simplify error handling\n\nIf we fail halfway through sysfs file creation, we may just call\nsysfs remove function and it will delete all the files we created.\nFor non-existing files it will also be OK - the remove functions\njust return -ENOENT.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "35ad5fb76cc0a08e14068408b064103439feee36",
      "tree": "21f90c6206a0d49ded3b35defb705c4fb131eebb",
      "parents": [
        "fc75a1e166268e0c3366c3b30888a024125f6665"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Mon Dec 17 14:22:55 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:15 2007 +0200"
      },
      "message": "UBI: fix and cleanup volume opening functions\n\nThis patch fixes error codes of the functions - if the device number\nis out of range, -EINVAL should be returned. It also removes unneeded\ntry_module_get call from the open by name function.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "fc75a1e166268e0c3366c3b30888a024125f6665",
      "tree": "82dc34795ee9299d6184a31fb87b4e9b8925f6a2",
      "parents": [
        "450f872a8e1763c883c9f723e6937b7ed223e6d3"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Mon Dec 17 14:02:09 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:15 2007 +0200"
      },
      "message": "UBI: fix error path\n\nError path in volume creation is bogus. First of, it ovverrides the\n\u0027err\u0027 variable and returns zero to the caller. Second, ubi_assert()\nin the release function is wrong.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "450f872a8e1763c883c9f723e6937b7ed223e6d3",
      "tree": "256c2d6a485a4d5b4d38d2e591eb8c9105b38f90",
      "parents": [
        "c63a491d3737aec3c47c5e785d87021752ad9fa6"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Mon Dec 17 13:09:09 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:15 2007 +0200"
      },
      "message": "UBI: get device when opening volume\n\nWhen a volume is opened, get its kref via get_device() call.\nAnd put the reference when closing the volume. With this, we\nmay have a bit saner volume delete.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "c63a491d3737aec3c47c5e785d87021752ad9fa6",
      "tree": "0fc3a0dee3493d52997426a745c52ff8d2287225",
      "parents": [
        "cae0a77125467c42f0918e78457913ee4a2f925b"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Mon Dec 17 13:21:07 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:15 2007 +0200"
      },
      "message": "UBI: add some more comments\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "cae0a77125467c42f0918e78457913ee4a2f925b",
      "tree": "92ce552bb67d6e0d44e1144e08260ea0bbcee80a",
      "parents": [
        "89b96b69290668351a33b09372ec1c94cb5748e5"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Mon Dec 17 12:46:48 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:15 2007 +0200"
      },
      "message": "UBI: tweak volumes locking\n\nTransform vtbl_mutex to volumes_mutex - this just makes code\neasier to understand.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "89b96b69290668351a33b09372ec1c94cb5748e5",
      "tree": "cdbb79da1c821f2155815119ded20d181c23c7c2",
      "parents": [
        "77c722dde9975361051c5530475f8f92ed67a506"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Dec 16 20:00:38 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:15 2007 +0200"
      },
      "message": "UBI: improve internal interfaces\n\nPass volume description object to the EBA function which makes\nmore sense, and EBA function do not have to find the volume\ndescription object by volume ID.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "77c722dde9975361051c5530475f8f92ed67a506",
      "tree": "a2d4acd9f868a5d9fb5fcf96d7a7af488246e98c",
      "parents": [
        "b96bf4c33d4860bf1584ad2f9ed3b783d79aada8"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Dec 16 16:46:57 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:15 2007 +0200"
      },
      "message": "UBI: bugfix: dont oops with NULL module parameter\n\nE.g., it oopsed in case of: modprobe ubi mtd \u003d 0\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "b96bf4c33d4860bf1584ad2f9ed3b783d79aada8",
      "tree": "30eb7bd3d0de569dd5087b62aa11520d1490c7a6",
      "parents": [
        "06b68ba15671f32a3aa3bbddf04b0d2dd7fbf902"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Dec 16 13:01:03 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:15 2007 +0200"
      },
      "message": "UBI: remove ubi_devices_cnt\n\nThis global variablea is not really needed, remove it\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "06b68ba15671f32a3aa3bbddf04b0d2dd7fbf902",
      "tree": "67024857173069023835148077775e8c9e381d8a",
      "parents": [
        "3a8d4642861fb69b62401949e490c0bcb19ceb40"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Dec 16 12:49:01 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:14 2007 +0200"
      },
      "message": "UBI: create ubi_wl_entry slab on initialization\n\nSimilarly to ltree_entry_slab, it makes more sense to create\nand destroy ubi_wl_entry slab on module initialization/exit.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "3a8d4642861fb69b62401949e490c0bcb19ceb40",
      "tree": "cb1d196fc42fa590f755abd336e4be777e60ff62",
      "parents": [
        "01f7b309e453dc8499c318f6810f76b606b66134"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Dec 16 12:32:51 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:14 2007 +0200"
      },
      "message": "UBI: create ltree_entry slab on initialization\n\nSince the ltree_entry slab cache is a global entity, which is\nused by all UBI devices, it is more logical to create it on\nmodule initialization time and destro on module exit time.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "01f7b309e453dc8499c318f6810f76b606b66134",
      "tree": "7d5d09cbd3e95f9b644859daedecbe2f4cbe797a",
      "parents": [
        "49dfc299288fe183b62a3f679a40c91b482d6d73"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sat Dec 15 19:56:51 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:14 2007 +0200"
      },
      "message": "UBI: improve error messages\n\nAlways print error code with error messages, sometimes it is\nextremely helpful info.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "49dfc299288fe183b62a3f679a40c91b482d6d73",
      "tree": "a4860162ae77f9c118619ec5562626c25a2f7800",
      "parents": [
        "732aeacff6b2fcf3750cad9018bdd663a21a6a12"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sat Dec 15 18:13:56 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:14 2007 +0200"
      },
      "message": "UBI: remove redundant field\n\nRemove redundant ubi-\u003emajor field - we have it in ubi-\u003ecdev.dev\nalready.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "732aeacff6b2fcf3750cad9018bdd663a21a6a12",
      "tree": "ba1014f5878f124842a6f9931e7bfce2198e4cfb",
      "parents": [
        "54b2c8f93d7c3ddc04b55666b878fec437d32983"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sat Dec 15 15:09:07 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:14 2007 +0200"
      },
      "message": "UBI: minor tidy-ups\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "54b2c8f93d7c3ddc04b55666b878fec437d32983",
      "tree": "fc7d622fcd920e98178bdf8099b4f8728b827259",
      "parents": [
        "393852ecfeec575ac78216b0eb58e4fd92f0816c"
      ],
      "author": {
        "name": "Jesper Juhl",
        "email": "jesper.juhl@gmail.com",
        "time": "Thu Dec 13 23:53:08 2007 +0100"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:14 2007 +0200"
      },
      "message": "UBI: silence a warning\n\nThis patch silences the following warning :\n\n  drivers/mtd/ubi/vmt.c:73: warning: \u0027ret\u0027 may be used uninitialized in this function\n\ngcc can\u0027t see that we always initialize ret in all situations where it is\nactually used. The one case where it\u0027s not initialized is when we BUG(),\nbut gcc doesn\u0027t know that we won\u0027t then continue and use an uninitialized\n\u0027ret\u0027.\n\nThis patch results in code that does exactely the same as before, but it\nalso makes gcc shut up, so we generate one less line of warning noise.\n\nSigned-off-by: Jesper Juhl \u003cjesper.juhl@gmail.com\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "393852ecfeec575ac78216b0eb58e4fd92f0816c",
      "tree": "99edbcd7fee9cdaa69f51187834f93ada73feada",
      "parents": [
        "94780d4de2e9339ab93df63420db70f11882634d"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Dec 06 18:47:30 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:14 2007 +0200"
      },
      "message": "UBI: add ubi_leb_map interface\n\nThe idea of this interface belongs to Adrian Hunter. The\ninterface is extremely useful when one has to have a guarantee\nthat an LEB will contain all 0xFFs even in case of an unclean\nreboot. UBI does have an \u0027ubi_leb_erase()\u0027 call which may do\nthis, but it is stupid and ineffecient, because it flushes whole\nqueue. I should be re-worked to just be a pair of unmap,\nmap calls.\n\nThe user of the interfaci is UBIFS at the moment.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "94780d4de2e9339ab93df63420db70f11882634d",
      "tree": "39c83f8c66ca2529d5e30560818ef85e97992c76",
      "parents": [
        "2362a53ec59f286495307e0e0d8ef2401e8c5c49"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Dec 04 21:36:12 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:14 2007 +0200"
      },
      "message": "UBI: bugfix: allocate mandatory EBs first\n\nFirst allocate the necessary eraseblocks, then the optional ones.\nOtherwise it allocates all PEBs for bad EB handling, and fails\non then following EBA LEB allocation.\n\nReported-by: Adrian Hunter \u003cext-adrian.hunter@nokia.com\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "2362a53ec59f286495307e0e0d8ef2401e8c5c49",
      "tree": "a7913ce0ed7c28c7f4543c875ded5716147a4b6d",
      "parents": [
        "235d6200ea63372935e097cb82e6a8c133d51cad"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Oct 18 20:09:41 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Dec 26 19:15:13 2007 +0200"
      },
      "message": "UBI: fix error code in ubi_io_read()\n\nWhen NAND detects an ECC error, it returns -EBADMSG. It does not\nstop reading requested data if one page has an ECC error, it keeps\ngoing and reads all the requested data. If it fails to read all\nthe data, it does not return -EBADMSG, but returns the error code\nwhich reflects the reason of the failure.\n\nBut some drivers may have bugs (e.g., OneNAND had) and stop reading\nafter the first ECC error, so it returns -EBADMSG. In turn, UBI\npropagates this up to the caller. The caller will treat this as\n\"all the requested data was read, but there was an ECC error\".\n\nSo we change the error code to -EIO if it is -EBADMSG and the read\nlength is less then the requested length. We also add an assertion,\nso if UBI debugging is enabled, UBI will bug.\n\nPointed-to-by: Adrian Hunter \u003cext-adrian.hunter@nokia.com\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "ba25f9dcc4ea6e30839fcab5a5516f2176d5bfed",
      "tree": "3123c03b25dd5c0cd24b6ab4fc16731217838157",
      "parents": [
        "9a2e70572e94e21e7ec4186702d045415422bda0"
      ],
      "author": {
        "name": "Pavel Emelyanov",
        "email": "xemul@openvz.org",
        "time": "Thu Oct 18 23:40:40 2007 -0700"
      },
      "committer": {
        "name": "Linus Torvalds",
        "email": "torvalds@woody.linux-foundation.org",
        "time": "Fri Oct 19 11:53:43 2007 -0700"
      },
      "message": "Use helpers to obtain task pid in printks\n\nThe task_struct-\u003epid member is going to be deprecated, so start\nusing the helpers (task_pid_nr/task_pid_vnr/task_pid_nr_ns) in\nthe kernel.\n\nThe first thing to start with is the pid, printed to dmesg - in\nthis case we may safely use task_pid_nr(). Besides, printks produce\nmore (much more) than a half of all the explicit pid usage.\n\n[akpm@linux-foundation.org: git-drm went and changed lots of stuff]\nSigned-off-by: Pavel Emelyanov \u003cxemul@openvz.org\u003e\nCc: Dave Airlie \u003cairlied@linux.ie\u003e\nSigned-off-by: Andrew Morton \u003cakpm@linux-foundation.org\u003e\nSigned-off-by: Linus Torvalds \u003ctorvalds@linux-foundation.org\u003e\n"
    },
    {
      "commit": "4ba9b9d0ba0a49d91fa6417c7510ee36f48cf957",
      "tree": "191b4f45f926e44b882b1e87a9a85dc12230b892",
      "parents": [
        "b811c202a0edadaac7242ab834fe7ba409978ae7"
      ],
      "author": {
        "name": "Christoph Lameter",
        "email": "clameter@sgi.com",
        "time": "Tue Oct 16 23:25:51 2007 -0700"
      },
      "committer": {
        "name": "Linus Torvalds",
        "email": "torvalds@woody.linux-foundation.org",
        "time": "Wed Oct 17 08:42:45 2007 -0700"
      },
      "message": "Slab API: remove useless ctor parameter and reorder parameters\n\nSlab constructors currently have a flags parameter that is never used.  And\nthe order of the arguments is opposite to other slab functions.  The object\npointer is placed before the kmem_cache pointer.\n\nConvert\n\n        ctor(void *object, struct kmem_cache *s, unsigned long flags)\n\nto\n\n        ctor(struct kmem_cache *s, void *object)\n\nthroughout the kernel\n\n[akpm@linux-foundation.org: coupla fixes]\nSigned-off-by: Christoph Lameter \u003cclameter@sgi.com\u003e\nSigned-off-by: Andrew Morton \u003cakpm@linux-foundation.org\u003e\nSigned-off-by: Linus Torvalds \u003ctorvalds@linux-foundation.org\u003e\n"
    },
    {
      "commit": "e3d18658d4f28e4783e1bb1c41e9134c9e5db0a9",
      "tree": "d4fe529460e98522775bc0ecca557dcc76866999",
      "parents": [
        "a2e1b833d9e0231d67e722b7e2f4d79daf919baf",
        "cc5f4f28755b3b152297fd7bc3e03781dd8008e2"
      ],
      "author": {
        "name": "David Woodhouse",
        "email": "dwmw2@infradead.org",
        "time": "Sun Oct 14 14:29:00 2007 +0100"
      },
      "committer": {
        "name": "David Woodhouse",
        "email": "dwmw2@infradead.org",
        "time": "Sun Oct 14 14:29:00 2007 +0100"
      },
      "message": "Merge branch \u0027master\u0027 of git://git.infradead.org/~dedekind/ubi-2.6\n"
    },
    {
      "commit": "cc5f4f28755b3b152297fd7bc3e03781dd8008e2",
      "tree": "8b09a2c0bec66a588f0cc5a5dfda5fe40801c07d",
      "parents": [
        "5abde384e350e44e9d0584238b9ee327f2062f93"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Oct 14 13:01:58 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Oct 14 13:10:21 2007 +0300"
      },
      "message": "UBI: return correct error code\n\nFix the following warning:\n\ndrivers/mtd/ubi/eba.c: In function \u0027ubi_eba_init_scan\u0027:\ndrivers/mtd/ubi/eba.c:1116: warning: \u0027err\u0027 may be used uninitialized in this function\n\nPointed-to-by: Andrew Morton \u003cakpm@linux-foundation.org\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "5abde384e350e44e9d0584238b9ee327f2062f93",
      "tree": "78c80bba9b0f77c3f1d391d9f58ac473bab444e2",
      "parents": [
        "e8823bd63d50bb1f9bd73f1197230e1f7217456a"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Sep 13 14:48:20 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Oct 14 13:10:21 2007 +0300"
      },
      "message": "UBI: remove useless inlines\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "e8823bd63d50bb1f9bd73f1197230e1f7217456a",
      "tree": "3b8b849512686aebda99f83d290c9e09ed983967",
      "parents": [
        "6986646ba752fef150286926aa922ef04e9d19dd"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Thu Sep 13 14:28:14 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Oct 14 13:10:21 2007 +0300"
      },
      "message": "UBI: fix atomic LEB change problems\n\nWhen the UBI device is nearly full, i.e. all LEBs are mapped, we have\nonly one spare LEB left - the one we reserved for WL purposes. Well,\nI do not count the LEBs which were reserved for bad PEB handling -\nsuppose NOR flash for simplicity. If an \"atomic LEB change operation\"\nis run, and the WL unit is moving a LEB, we have no spare LEBs to\nfinish the operation and fail, which is not good. Moreover, if there\nare 2 or more simultanious \"atomic LEB change\" requests, only one of\nthem has chances to succeed, the other will fail with -ENOSPC. Not\ngood either.\n\nThis patch does 2 things:\n1. Reserves one PEB for the \"atomic LEB change\" operation.\n2. Serealize the operations so that only on of them may run\n   at a time (by means of a mutex).\n\nPointed-to-by: Brijesh Singh \u003cbrijesh.s.singh@gmail.com\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "6986646ba752fef150286926aa922ef04e9d19dd",
      "tree": "7635c603881998c94af316e487978e8bc8dbffc8",
      "parents": [
        "e88d6e10e5c848fd5be8f89e09e3bce2570886b7"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Aug 29 14:56:20 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Oct 14 13:10:21 2007 +0300"
      },
      "message": "UBI: use byte hexdump\n\nMore handy since word hexdump prints in host endian.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "e88d6e10e5c848fd5be8f89e09e3bce2570886b7",
      "tree": "27b5547a0e24add89deafedaed784328bc3c173e",
      "parents": [
        "33818bbb84cd371b63ed8849cc5264d24c8b3aa2"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Aug 29 14:51:52 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Oct 14 13:10:21 2007 +0300"
      },
      "message": "UBI: do not use vmalloc on I/O path\n\nSimilar reason as in case of the previous patch: it causes\ndeadlocks if a filesystem with writeback support works on top\nof UBI. So pre-allocate needed buffers when attaching MTD device.\nWe also need mutexes to protect the buffers, but they do not\ncause much contantion because they are used in recovery, torture,\nand WL copy routines, which are called seldom.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "33818bbb84cd371b63ed8849cc5264d24c8b3aa2",
      "tree": "ecee6a8f02d2d103c6eb33cc6173e74343b1861b",
      "parents": [
        "ef6075fbfca9139f428d52d60e671da38aa2e212"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Aug 28 21:29:32 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Oct 14 13:10:20 2007 +0300"
      },
      "message": "UBI: allocate memory with GFP_NOFS\n\nUse GFP_NOFS flag when allocating memory on I/O path, because otherwise\nwe may deadlock the filesystem which works on top of us. We observed\nthe deadlocks with UBIFS. Example:\n\nVFS-\u003eFS lock a lock-\u003eUBI-\u003ekmalloc()-\u003eVFS writeback-\u003eFS locks the same\nlock again.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "ef6075fbfca9139f428d52d60e671da38aa2e212",
      "tree": "077b0265e67e46e09f6d3dcf35a45fbbe6e20748",
      "parents": [
        "0169b49d52400a6035cd0f2ccd08bcba061a1a9b"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Aug 07 23:34:20 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Oct 14 13:10:20 2007 +0300"
      },
      "message": "UBI: use linux print_hex_dump(), not home-grown one\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "0169b49d52400a6035cd0f2ccd08bcba061a1a9b",
      "tree": "534643ffe146db43ece0ce2476c2da919408bce5",
      "parents": [
        "8d2d4011f1398d984819c65043abb559c451a3c8"
      ],
      "author": {
        "name": "Jesper Juhl",
        "email": "jesper.juhl@gmail.com",
        "time": "Sat Aug 04 01:25:26 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Oct 14 13:10:20 2007 +0300"
      },
      "message": "UBI: don\u0027t use array index before testing if it is negative\n\nI can\u0027t find anything guaranteeing that \u0027ubi_num\u0027 cannot be \u003c0 in\ndrivers/mtd/ubi/kapi.c::ubi_open_volume(), and in fact the code\neven tests for that and errors out if so. Unfortunately the test\nfor \"ubi_num \u003c 0\" happens after we\u0027ve already used \u0027ubi_num\u0027 as\nan array index - bad thing to do if it is negative.\nThis patch moves the test earlier in the function and then moves\nthe indexing using that variable after the check. A bit safer :-)\n\nSigned-off-by: Jesper Juhl \u003cjesper.juhl@gmail.com\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "8d2d4011f1398d984819c65043abb559c451a3c8",
      "tree": "a563add73b96dd245acffbe8b3e3288441fce7f8",
      "parents": [
        "8bc22961966b845aa5f965be30771902146c2fcc"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Jul 22 22:32:51 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Oct 14 13:10:20 2007 +0300"
      },
      "message": "UBI: add more prints\n\nI hit those situations and found out lack of print messages. Add more prints\nwhen erase problems occur.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "8bc22961966b845aa5f965be30771902146c2fcc",
      "tree": "bfa7236da8184560f85fdeb2ad4d565995e237ac",
      "parents": [
        "dcec4c3bdc4d5f4bd2d858ee1ce11e3424cbaed7"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Jul 22 15:25:02 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Oct 14 13:10:20 2007 +0300"
      },
      "message": "UBI: fix sparse warnings\n\nFix \"symbol shadows an earlier one\" warnings. Although they are harmless\nbut it does not hurt to fix them and make sparse happy.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "dcec4c3bdc4d5f4bd2d858ee1ce11e3424cbaed7",
      "tree": "350dc84ecd5069e2cc69595482c0fb1ce72ab1e8",
      "parents": [
        "bbf25010f1a6b761914430f5fca081ec8c7accd1"
      ],
      "author": {
        "name": "Florin Malita",
        "email": "fmalita@gmail.com",
        "time": "Thu Jul 19 15:22:41 2007 -0400"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Sun Oct 14 13:10:20 2007 +0300"
      },
      "message": "UBI: fix leak in ubi_scan_erase_peb\n\nCoverity (1769) found the following problem: if the erase counter\noverflow check triggers, ec_hdr is leaked.\n\nMoving the allocation after the overflow check should take care of it.\n\nSigned-off-by: Florin Malita \u003cfmalita@gmail.com\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "d9b0744d6c75f7b268b728cdd1843f31bdeba311",
      "tree": "ab97d3ff2eb925e13c25e25db8236e12962a1272",
      "parents": [
        "4fb4caa639a27a3cb0b3bfbf2041524af43efff9"
      ],
      "author": {
        "name": "Mariusz Kozlowski",
        "email": "m.kozlowski@tuxland.pl",
        "time": "Wed Aug 01 00:02:10 2007 +0200"
      },
      "committer": {
        "name": "David Woodhouse",
        "email": "dwmw2@infradead.org",
        "time": "Wed Aug 01 11:04:05 2007 +0100"
      },
      "message": "[UBI] drivers/mtd/ubi/scan.c: kmalloc + memset conversion to kzalloc\n\nTo be able to convert kmalloc + memset(..., 1, ...) to kzalloc this patch\nreverses the logic around \u0027buf\u0027.\n\nSigned-off-by: Mariusz Kozlowski \u003cm.kozlowski@tuxland.pl\u003e\nSigned-off-by: David Woodhouse \u003cdwmw2@infradead.org\u003e\n"
    },
    {
      "commit": "20c2df83d25c6a95affe6157a4c9cac4cf5ffaac",
      "tree": "415c4453d2b17a50abe7a3e515177e1fa337bd67",
      "parents": [
        "64fb98fc40738ae1a98bcea9ca3145b89fb71524"
      ],
      "author": {
        "name": "Paul Mundt",
        "email": "lethal@linux-sh.org",
        "time": "Fri Jul 20 10:11:58 2007 +0900"
      },
      "committer": {
        "name": "Paul Mundt",
        "email": "lethal@linux-sh.org",
        "time": "Fri Jul 20 10:11:58 2007 +0900"
      },
      "message": "mm: Remove slab destructors from kmem_cache_create().\n\nSlab destructors were no longer supported after Christoph\u0027s\nc59def9f222d44bb7e2f0a559f2906191a0862d7 change. They\u0027ve been\nBUGs for both slab and slub, and slob never supported them\neither.\n\nThis rips out support for the dtor pointer from kmem_cache_create()\ncompletely and fixes up every single callsite in the kernel (there were\nabout 224, not including the slab allocator definitions themselves,\nor the documentation references).\n\nSigned-off-by: Paul Mundt \u003clethal@linux-sh.org\u003e\n"
    },
    {
      "commit": "add0b43ca67bf281ef7ac8ab47e9ee7b2d97a69f",
      "tree": "7a7aaab48f6ac1cff65ad920e306ffe79620fb47",
      "parents": [
        "784c145444e7dd58ae740d406155b72ac658f151"
      ],
      "author": {
        "name": "Paul Mundt",
        "email": "lethal@linux-sh.org",
        "time": "Wed Jul 18 18:39:45 2007 +0900"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:59:17 2007 +0300"
      },
      "message": "UBI: fix compile warning\n\ncdev.c whines in current git:\n\ndrivers/mtd/ubi/cdev.c: In function `major_to_device\u0027:\ndrivers/mtd/ubi/cdev.c:67: warning: control reaches end of non-void function\n\nShut it up.\n\nSigned-off-by: Paul Mundt \u003clethal@linux-sh.org\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "784c145444e7dd58ae740d406155b72ac658f151",
      "tree": "31c304913db2011a3a9f09da9dbaf2f74004d887",
      "parents": [
        "63b6c1ed56f69fdd35122dc591164587e3407ba0"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 13:42:10 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:59:09 2007 +0300"
      },
      "message": "UBI: fix error handling in erase worker\n\nDo not switch to read-only mode in case of -EINTR and some\nother obvious cases. Switch to RO mode only when we do not\nknow what is the error.\n\nReported-by: Vinit Agnihotri \u003cvinit.agnihotri@gmail.com\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "63b6c1ed56f69fdd35122dc591164587e3407ba0",
      "tree": "db3f7a3ba16f5c76f7c0b65f3f57de4cc989136c",
      "parents": [
        "503990ebb21e5aabe497a3eb1d39bef0bbc1be6f"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Tue Jul 17 15:04:20 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:59:01 2007 +0300"
      },
      "message": "UBI: fix comments\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "503990ebb21e5aabe497a3eb1d39bef0bbc1be6f",
      "tree": "9236566c401828cedc2785cabbf4d85d5f26d215",
      "parents": [
        "2db61c95c03d08bb885c87a816540e75190c924a"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 11 16:03:29 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:58:53 2007 +0300"
      },
      "message": "UBI: remove unneeded error checks\n\nPointed to by viro.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "2db61c95c03d08bb885c87a816540e75190c924a",
      "tree": "1376072b9ed06ff51e35c50be6fec569ee7a3e61",
      "parents": [
        "d08c3b78b8c46a01b8fa59037a0d9fbb777fb465"
      ],
      "author": {
        "name": "Fernando Luis Vázquez Cao",
        "email": "fernando@oss.ntt.co.jp",
        "time": "Wed Jul 11 17:11:45 2007 +0900"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:58:45 2007 +0300"
      },
      "message": "UBI: cleanup usage of try_module_get\n\nThe use of try_module_get(THIS_MODULE) in ubi_get_device_info does not\noffer real protection against unexpected driver unloads, since we could\nbe preempted before try_modules_get gets executed. It is the caller who\nshould manipulate the refcounts. Besides, ubi_get_device_info is an\nexported symbol which guarantees protection when accessed through\nsymbol_get.\n\nSigned-off-by: Fernando Luis Vazquez Cao \u003cfernando@oss.ntt.co.jp\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "d08c3b78b8c46a01b8fa59037a0d9fbb777fb465",
      "tree": "c27d7d436864175107fe8e2b1de3a11b928c975a",
      "parents": [
        "2f3cdb55eef4fa1398965e893f731fb6e6312d34"
      ],
      "author": {
        "name": "Vinit Agnihotri",
        "email": "vinit.agnihotri@gmail.com",
        "time": "Tue Jul 10 13:04:59 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:58:12 2007 +0300"
      },
      "message": "UBI: fix overflow bug\n\nI was experiencing overflows in multiplications for\nvolume-\u003eused_bytes in vmt.c \u0026 vtbl.c, while creating \u0026 resizing large volumes.\n\nvol-\u003eused_bytes is long long however its 2 operands vol-\u003eused_ebs \u0026\nvol-\u003eusable_leb_size\nare int. So their multiplication for larger values causes integer overflows.\nTypecasting them solves the problem.\n\nMy machine \u0026 flash details:\n\n64Bit dual-core AMD opteron, 1 GB RAM, linux 2.6.18.3.\nmtd size \u003d 6GB, volume size\u003d 5GB, peb_size \u003d 4MB.\n\nheres patch which does the fix.\n\nSigned-off-by: Vinit Agnihotri \u003cvinit.agnihotri@gmail.com\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "2f3cdb55eef4fa1398965e893f731fb6e6312d34",
      "tree": "9c5fd92c4a09fc3a93044ca35108ccecae9be571",
      "parents": [
        "76eafe479ec30dd72b8cf209c4f576eac3c93112"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Fri Jul 06 14:38:46 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:58:02 2007 +0300"
      },
      "message": "UBI: bugfix in max_sqnum calculation\n\nDo not zero max_sqnum after a new volume has been found.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "76eafe479ec30dd72b8cf209c4f576eac3c93112",
      "tree": "68fa0b8943e8629a9208951a2d8dede4b8de17e6",
      "parents": [
        "2f176f79877937082ce052977e552a75e23a73d1"
      ],
      "author": {
        "name": "Brijesh Singh",
        "email": "brijesh.s.singh@gmail.com",
        "time": "Fri Jul 06 14:35:43 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:57:52 2007 +0300"
      },
      "message": "UBI: bugfix in sqnum calculation\n\nHi,I came across problem of having two leb with same sequence no.This\nhappens when we continuously write one block again and again and reboot\nmachine before background thread erases those blocks.\nThe problem here was,when we find two blocks with same sequence no,we take\nthe higher one,but we were not updating max seq no,so next block may have\nthe same seqnum.\nThis patch solves this problem.\n\nSigned-off-by: Brijesh Singh \u003cbrijesh.s.singh@gmail.com\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "2f176f79877937082ce052977e552a75e23a73d1",
      "tree": "c7f8eb96bac676fe06d77338e44a0da17810fce3",
      "parents": [
        "84a925806210e002fab29966c09b9c92f382a79d"
      ],
      "author": {
        "name": "Brijesh Singh",
        "email": "brijesh.s.singh@gmail.com",
        "time": "Thu Jul 05 15:07:35 2007 +0530"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:57:34 2007 +0300"
      },
      "message": "UBI: fix signed-unsigned multiplication\n\nThere is signed multiplication assigned to unsigned ei.addr in io.c.\nThis causes wrong addresses for big multiplication.This patch solves the\nproblem.\n\nSigned-off-by: Brijesh Singh \u003cbrijesh.s.singh@gmail.com\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "84a925806210e002fab29966c09b9c92f382a79d",
      "tree": "a1914318f425b387190030f0765c57a6d1b5627a",
      "parents": [
        "a6ded48e34f803fcbb42719cee452d1f18938ec7"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 04 16:16:51 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:56:24 2007 +0300"
      },
      "message": "UBI: fix bug in atomic_leb_change()\n\natomic_leb_change() is only allowed for dynamic volumes, so set\nthe volume type correctly.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "a6ded48e34f803fcbb42719cee452d1f18938ec7",
      "tree": "6787132e92040a2921f8e8b7d1a66567f1369640",
      "parents": [
        "b89044bfa06e8a9a82094fda031cc6d4e8d4a0b0"
      ],
      "author": {
        "name": "Vinit Agnihotri",
        "email": "vinit.agnihotri@gmail.com",
        "time": "Wed Jul 04 16:35:56 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:56:13 2007 +0300"
      },
      "message": "UBI: fix message\n\nIncrease UBI devices couter after the message, not before.\n\nSigned-off-by: Vinit Agnihotri \u003cvinit.agnihotri@gmail.com\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "b89044bfa06e8a9a82094fda031cc6d4e8d4a0b0",
      "tree": "596493157a385142b71c9da111d841b8a14150bc",
      "parents": [
        "94784d916458d51043ba76849b9beaf330baef2f"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Mon Jun 18 16:29:30 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:56:05 2007 +0300"
      },
      "message": "UBI: fix debugging stuff\n\nDo not check volumes which are currently in use because thay may be\nin inconsistent state.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "94784d916458d51043ba76849b9beaf330baef2f",
      "tree": "a7b71f0aa61ce5524dc602716c6ae722ff78d461",
      "parents": [
        "7753f1692f53d82b4cc08084462b0fd2803c1f04"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Mon Jun 18 12:06:30 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:55:55 2007 +0300"
      },
      "message": "UBI: bugfix in error path\n\nWhen volume creation fails, we have to set ubi-\u003evolumes[vol_id]\nback to NULL.\n\nThis patch also tweaks some debugging stuff.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "7753f1692f53d82b4cc08084462b0fd2803c1f04",
      "tree": "1af69abb56aaa61f4b149ce044c3b214d581db6d",
      "parents": [
        "d7f0c4dc31f1297a613f1e61a7d682dc9a5e859a"
      ],
      "author": {
        "name": "Vignesh Babu",
        "email": "vignesh.babu@wipro.com",
        "time": "Tue Jun 12 10:31:05 2007 +0530"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:55:26 2007 +0300"
      },
      "message": "UBI: use is_power_of_2()\n\nReplacing (n \u0026 (n-1)) in the context of power of 2 checks\nwith is_power_of_2\n\nSigned-off-by: Vignesh Babu \u003cvignesh.babu@wipro.com\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "d7f0c4dc31f1297a613f1e61a7d682dc9a5e859a",
      "tree": "cdc9e28d8708774e174ad7baf78c67b71a34d57e",
      "parents": [
        "21600546ab84e451adb88771b52b64b97866a444"
      ],
      "author": {
        "name": "Vinit Agnihotri",
        "email": "vinit.agnihotri@gmail.com",
        "time": "Fri Jun 15 15:31:22 2007 +0530"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:54:15 2007 +0300"
      },
      "message": "UBI: fix freeing ubi-\u003evtbl while unloading\n\nubi-\u003evtbl is allocated using vmalloc() in vtbl.c empty_create_lvol(),\nbut it is freed in build.c with kfree()\n\nSigned-off-by: Vinit Agnihotri \u003cvinit.agnihotri@gmail.com\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "a443db48e05a8d2d8db0a17409655c58da65a35e",
      "tree": "becf7ff602745c657d2d07a7354ba7cca0fe20c7",
      "parents": [
        "3261ebd7d4194ff30d0eae7ba8d937dcccf7235d"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Mon May 21 20:26:05 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:53:57 2007 +0300"
      },
      "message": "UBI: bugfix in ubi_leb_change()\n\nDo not call \u0027ubi_wl_put_peb()\u0027 if the LEB was unmapped.\n\nReported-by: Gabor Loki \u003cloki@inf.u-szeged.hu\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "3261ebd7d4194ff30d0eae7ba8d937dcccf7235d",
      "tree": "75381f6dd24263cdf484ebc9a5c8a93db6d83cb4",
      "parents": [
        "bf07803a6827ef8d4c9d840a1de800ba36db0213"
      ],
      "author": {
        "name": "Christoph Hellwig",
        "email": "hch@lst.de",
        "time": "Mon May 21 17:41:46 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:53:49 2007 +0300"
      },
      "message": "UBI: kill homegrown endian macros\n\nKill UBI\u0027s homegrown endianess handling and replace it with\nthe standard kernel endianess handling.\n\nSigned-off-by: Christoph Hellwig \u003chch@lst.de\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "bf07803a6827ef8d4c9d840a1de800ba36db0213",
      "tree": "35634c88d81dbacc2b12db25755845370d6f7e59",
      "parents": [
        "16d8cd7ce408a20db1ab192e0fb565573e446b28"
      ],
      "author": {
        "name": "Christoph Hellwig",
        "email": "hch@lst.de",
        "time": "Thu May 17 16:32:10 2007 +0200"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:53:36 2007 +0300"
      },
      "message": "UBI: cleanup ioctl handling\n\n- don\u0027t do access_ok + get/put user but use the proper macro\n- remove useless checks\n\nSigned-off-by: Christoph Hellwig \u003chch@lst.de\u003e\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    },
    {
      "commit": "16d8cd7ce408a20db1ab192e0fb565573e446b28",
      "tree": "136c377df9bba42dd76d1e07e8838bbf539cf5f0",
      "parents": [
        "f800f09bf44871f6c6e4d3e42a60946e1ea51b17"
      ],
      "author": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed May 16 15:49:16 2007 +0300"
      },
      "committer": {
        "name": "Artem Bityutskiy",
        "email": "Artem.Bityutskiy@nokia.com",
        "time": "Wed Jul 18 16:53:27 2007 +0300"
      },
      "message": "UBI: error path bugfix\n\nNo need to unlock the lock, this will be done at out_unlock.\n\nSigned-off-by: Artem Bityutskiy \u003cArtem.Bityutskiy@nokia.com\u003e\n"
    }
  ],
  "next": "f800f09bf44871f6c6e4d3e42a60946e1ea51b17"
}
