)]}'
{
  "log": [
    {
      "commit": "74e9f5fa1570f956c96dd5d3f1053daedbbf01a0",
      "tree": "095bfed9efced3538507d16eb93010d91c074f5f",
      "parents": [
        "c6a46696f97ff260a4ecce5e287f8de4b9d7fe14"
      ],
      "author": {
        "name": "Greg Kroah-Hartman",
        "email": "gregkh@suse.de",
        "time": "Tue Apr 09 12:14:34 2002 -0700"
      },
      "committer": {
        "name": "Greg Kroah-Hartman",
        "email": "gregkh@suse.de",
        "time": "Fri Apr 27 10:57:29 2007 -0700"
      },
      "message": "Driver core: remove unneeded completion from driver release path\n\nThe completion in the driver release path is due to ancient history in\nthe _very_ early 2.5 days when we were not tracking the module reference\ncount of attributes.  It is not needed at all and can be removed.\n\nNote, we now have an empty release function for the driver structure.\nThis is due to the fact that drivers are statically allocated in the\nsystem at this point in time, something which I want to change in the\nfuture.  But remember, drivers are really code, which is reference\ncounted by the module, unlike devices, which are data and _must_ be\nreference counted properly in order to work correctly.\n\n\nCc: Kay Sievers \u003ckay.sievers@vrfy.org\u003e\nSigned-off-by: Greg Kroah-Hartman \u003cgregkh@suse.de\u003e\n\n\n"
    },
    {
      "commit": "21c7f30b1d3f8a3de3128478daca3ce203fc8733",
      "tree": "ff84247ba68f82906182a214273dd330c6d1970f",
      "parents": [
        "460f7e9a1bde2c74f060f7ce0a308dab4be6a56b"
      ],
      "author": {
        "name": "Cornelia Huck",
        "email": "cornelia.huck@de.ibm.com",
        "time": "Mon Feb 05 16:15:25 2007 -0800"
      },
      "committer": {
        "name": "Greg Kroah-Hartman",
        "email": "gregkh@suse.de",
        "time": "Fri Apr 27 10:57:28 2007 -0700"
      },
      "message": "driver core: per-subsystem multithreaded probing\n\nMake multithreaded probing work per subsystem instead of per driver.\n\nIt doesn\u0027t make much sense to probe the same device for multiple drivers in\nparallel (after all, only one driver can bind to the device).  Instead, create\na probing thread for each device that probes the drivers one after another. \nAlso make the decision to use multi-threaded probe per bus instead of per\ndevice and adapt the pci code.\n\nSigned-off-by: Cornelia Huck \u003ccornelia.huck@de.ibm.com\u003e\nCc: Benjamin Herrenschmidt \u003cbenh@kernel.crashing.org\u003e\nSigned-off-by: Andrew Morton \u003cakpm@linux-foundation.org\u003e\nSigned-off-by: Greg Kroah-Hartman \u003cgregkh@suse.de\u003e\n\n"
    },
    {
      "commit": "414264f959cf46f49f974b3510400e12ac3624a6",
      "tree": "ead43994761620cbf7cb22525610627786562098",
      "parents": [
        "621a1672f7377e08a942f205d6742d8af1292aab"
      ],
      "author": {
        "name": "Kay Sievers",
        "email": "kay.sievers@vrfy.org",
        "time": "Mon Mar 12 21:08:57 2007 +0100"
      },
      "committer": {
        "name": "Greg Kroah-Hartman",
        "email": "gregkh@suse.de",
        "time": "Fri Apr 27 10:57:28 2007 -0700"
      },
      "message": "Driver core: add name to device_type\n\nIf \"name\" of a device_type is specified, the uevent will\ncontain the device_type name in the DEVTYPE variable.\nThis helps userspace to distingiush between different types\nof devices, belonging to the same subsystem.\n\nSigned-off-by: Kay Sievers \u003ckay.sievers@vrfy.org\u003e\nSigned-off-by: Greg Kroah-Hartman \u003cgregkh@suse.de\u003e\n\n"
    },
    {
      "commit": "621a1672f7377e08a942f205d6742d8af1292aab",
      "tree": "9249308b3df0675f713058e3f5ac0442ce2a5e1e",
      "parents": [
        "b8c5cec23d5c33b767a1cddebd4f8813a9563e3c"
      ],
      "author": {
        "name": "Dmitry Torokhov",
        "email": "dtor@insightbb.com",
        "time": "Sat Mar 10 01:37:34 2007 -0500"
      },
      "committer": {
        "name": "Greg Kroah-Hartman",
        "email": "gregkh@suse.de",
        "time": "Fri Apr 27 10:57:28 2007 -0700"
      },
      "message": "driver core: Use attribute groups in struct device_type\n\nDriver core: use attribute groups in struct device_type\n\nAttribute groups are more flexible than attribute lists\n(an attribute list can be represented by anonymous group)\nso switch struct device_type to use them.\n\nAlso rework attribute creation for devices so that they all\ncleaned up properly in case of errors.\n\nSigned-off-by: Dmitry Torokhov \u003cdtor@mail.ru\u003e\nCc: Kay Sievers \u003ckay.sievers@novell.com\u003e\nSigned-off-by: Greg Kroah-Hartman \u003cgregkh@suse.de\u003e\n\n"
    },
    {
      "commit": "b8c5cec23d5c33b767a1cddebd4f8813a9563e3c",
      "tree": "cffec2c5df58866aa6e7ed5540c2718a166c3246",
      "parents": [
        "a456b7023e0abf80bb03b0bdf5471b48878e5c49"
      ],
      "author": {
        "name": "Kay Sievers",
        "email": "kay.sievers@vrfy.org",
        "time": "Fri Feb 16 17:33:36 2007 +0100"
      },
      "committer": {
        "name": "Greg Kroah-Hartman",
        "email": "gregkh@suse.de",
        "time": "Fri Apr 27 10:57:28 2007 -0700"
      },
      "message": "Driver core: udev triggered device-\u003c\u003edriver binding\n\nWe get two per-bus sysfs files:\n  ls-l /sys/subsystem/usb\n  drwxr-xr-x 2 root root    0 2007-02-16 16:42 devices\n  drwxr-xr-x 7 root root    0 2007-02-16 14:55 drivers\n  -rw-r--r-- 1 root root 4096 2007-02-16 16:42 drivers_autoprobe\n  --w------- 1 root root 4096 2007-02-16 16:42 drivers_probe\n\nThe flag \"drivers_autoprobe\" controls the behavior of the bus to bind\ndevices by default, or just initialize the device and leave it alone.\n\nThe command \"drivers_probe\" accepts a bus_id and the bus tries to bind a\ndriver to this device.\n\nSystems who want to control the driver binding with udev, switch off the\nbus initiated probing:\n  echo 0 \u003e /sys/subsystem/usb/drivers_autoprobe\n  echo 0 \u003e /sys/subsystem/pcmcia/drivers_autoprobe\n  ...\n\nand initiate the probing with udev rules like:\n  ACTION\u003d\u003d\"add\", SUBSYSTEM\u003d\u003d\"usb\", ATTR{subsystem/drivers_probe}\u003d\"$kernel\"\n  ACTION\u003d\u003d\"add\", SUBSYSTEM\u003d\u003d\"pcmcia\", ATTR{subsystem/drivers_probe}\u003d\"$kernel\"\n  ...\n\nCustom driver binding can happen in earlier rules by something like:\n  ACTION\u003d\u003d\"add\", SUBSYSTEM\u003d\u003d\"usb\", \\\n  ATTRS{idVendor}\u003d\u003d\"1234\", ATTRS{idProduct}\u003d\u003d\"5678\" \\\n  ATTR{subsystem/drivers/\u003ccustom-driver\u003e/bind}\u003d\"$kernel\"\n\nThis is intended to solve the modprobe.conf mess with \"install-rules\", custom\nbind/unbind-scripts and all the weird things people invented over the years.\nIt should also provide the functionality \"libusual\" was supposed to do.\n\nWith udev, one can just write a udev rule to drive all USB-disks at the\nthird port of USB-hub by the \"ub\" driver, and everything else by\nusb-storage. One can also instruct udev to bind different wireless\ndrivers to identical cards - just selected by the pcmcia slot-number, and\nwhatever ...\n\nTo use the mentioned rules, it needs udev version 106, to be able to\nwrite ATTR{}\u003d\"$kernel\" to sysfs files.\n\nSigned-off-by: Greg Kroah-Hartman \u003cgregkh@suse.de\u003e\n"
    },
    {
      "commit": "864062457a2e444227bd368ca5f2a2b740de604f",
      "tree": "38e516852ee9825b5ffe0b1f2e8abea0a88b1674",
      "parents": [
        "00ed8e3dda47f8421b11da17e353d7db8c878121"
      ],
      "author": {
        "name": "Kay Sievers",
        "email": "kay.sievers@vrfy.org",
        "time": "Wed Mar 14 03:25:56 2007 +0100"
      },
      "committer": {
        "name": "Greg Kroah-Hartman",
        "email": "gregkh@suse.de",
        "time": "Fri Apr 27 10:57:28 2007 -0700"
      },
      "message": "driver core: fix namespace issue with devices assigned to classes\n\n  - uses a kset in \"struct class\" to keep track of all directories\n    belonging to this class\n  - merges with the /sys/devices/virtual logic.\n  - removes the namespace-dir if the last member of that class\n    leaves the directory.\n\nThere may be locking or refcounting fixes left, I stopped when it seemed\nto work with network and sound modules. :)\n\nFrom: Kay Sievers \u003ckay.sievers@vrfy.org\u003e\nSigned-off-by: Greg Kroah-Hartman \u003cgregkh@suse.de\u003e\n\n"
    },
    {
      "commit": "0278ef8b484a71917bd4f03a763285cdaac10954",
      "tree": "8f6f7bf2e2a85b4643dfe3d0475811ce858fb4fc",
      "parents": [
        "15c54033964a943de7b0763efd3bd0ede7326395",
        "cd9ad58d4061494e7fdd70ded7bcf2418daf356a"
      ],
      "author": {
        "name": "Linus Torvalds",
        "email": "torvalds@woody.linux-foundation.org",
        "time": "Fri Apr 27 09:29:04 2007 -0700"
      },
      "committer": {
        "name": "Linus Torvalds",
        "email": "torvalds@woody.linux-foundation.org",
        "time": "Fri Apr 27 09:29:04 2007 -0700"
      },
      "message": "Merge master.kernel.org:/pub/scm/linux/kernel/git/davem/sparc-2.6\n\n* master.kernel.org:/pub/scm/linux/kernel/git/davem/sparc-2.6: (67 commits)\n  [SCSI] SUNESP: Complete driver rewrite to version 2.0\n  [SPARC64]: Convert PCI over to generic struct iommu/strbuf.\n  [SPARC]: device_node name constification fallout\n  [SPARC64]: Convert SBUS over to generic iommu/strbuf structs.\n  [SPARC64]: Add generic iommu and strbuf structs to iommu.h\n  [SPARC64]: Consolidate {sbus,pci}_iommu_arena.\n  [SPARC]: Make device_node name and type const\n  [SPARC64]: constify some paramaters of OF routines\n  [TIGON3]: of_get_property() returns const.\n  [SPARC64]: Fix PCI rework to adhere to of_get_property() const return.\n  [SPARC64]: Document and fix calculation of pages_avail.\n  [SPARC64]: Make sure pbm-\u003eprom_node is setup easly enough in psycho.c\n  [SPARC64]: Use bootmem_bootmap_pages() in choose_bootmap_pfn().\n  [SPARC64]: Add proper header file extern for cmdline_memory_size.\n  [SPARC64]: Kill sparc_ultra_dump_{i,d}tlb()\n  [SPARC64]: Use DECLARE_BITMAP and BITS_TO_LONGS in mm/init.c\n  [SPARC64]: Give move verbose show_mem() output just like i386.\n  [SPARC64]: Mark show_mem() printk\u0027s with KERN_INFO.\n  [SPARC64]: Kill kvaddr_to_phys() and friends.\n  [SPARC64]: Privatize sun4u_get_pte() and fix name.\n  ...\n"
    },
    {
      "commit": "15c54033964a943de7b0763efd3bd0ede7326395",
      "tree": "840b292612d1b5396d5bab5bde537a9013db3ceb",
      "parents": [
        "ad5da3cf39a5b11a198929be1f2644e17ecd767e",
        "912a41a4ab935ce8c4308428ec13fc7f8b1f18f4"
      ],
      "author": {
        "name": "Linus Torvalds",
        "email": "torvalds@woody.linux-foundation.org",
        "time": "Fri Apr 27 09:26:46 2007 -0700"
      },
      "committer": {
        "name": "Linus Torvalds",
        "email": "torvalds@woody.linux-foundation.org",
        "time": "Fri Apr 27 09:26:46 2007 -0700"
      },
      "message": "Merge master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6\n\n* master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6: (448 commits)\n  [IPV4] nl_fib_lookup: Initialise res.r before fib_res_put(\u0026res)\n  [IPV6]: Fix thinko in ipv6_rthdr_rcv() changes.\n  [IPV4]: Add multipath cached to feature-removal-schedule.txt\n  [WIRELESS] cfg80211: Clarify locking comment.\n  [WIRELESS] cfg80211: Fix locking in wiphy_new.\n  [WEXT] net_device: Don\u0027t include wext bits if not required.\n  [WEXT]: Misc code cleanups.\n  [WEXT]: Reduce inline abuse.\n  [WEXT]: Move EXPORT_SYMBOL statements where they belong.\n  [WEXT]: Cleanup early ioctl call path.\n  [WEXT]: Remove options.\n  [WEXT]: Remove dead debug code.\n  [WEXT]: Clean up how wext is called.\n  [WEXT]: Move to net/wireless\n  [AFS]: Eliminate cmpxchg() usage in vlocation code.\n  [RXRPC]: Fix pointers passed to bitops.\n  [RXRPC]: Remove bogus atomic_* overrides.\n  [AFS]: Fix u64 printing in debug logging.\n  [AFS]: Add \"directory write\" support.\n  [AFS]: Implement the CB.InitCallBackState3 operation.\n  ...\n"
    },
    {
      "commit": "ad5da3cf39a5b11a198929be1f2644e17ecd767e",
      "tree": "22d98f2a14db70e7229ec3b9c944488f2d50d4a1",
      "parents": [
        "da8ac5e0fab11d0e84be4e49aaaa828c52d17097",
        "14cf232ab161ce87ca538af3daad5f717c20d487"
      ],
      "author": {
        "name": "Linus Torvalds",
        "email": "torvalds@woody.linux-foundation.org",
        "time": "Fri Apr 27 09:20:51 2007 -0700"
      },
      "committer": {
        "name": "Linus Torvalds",
        "email": "torvalds@woody.linux-foundation.org",
        "time": "Fri Apr 27 09:20:51 2007 -0700"
      },
      "message": "Merge branch \u0027upstream\u0027 of git://ftp.linux-mips.org/pub/scm/upstream-linus\n\n* \u0027upstream\u0027 of git://ftp.linux-mips.org/pub/scm/upstream-linus: (22 commits)\n  [MIPS] Don\u0027t force frame pointers for lockdep on MIPS\n  [MIPS] update vr41xx Kconfig\n  [MIPS] remove 2 select entries for VR41xx\n  [MIPS] rename VR41XX to VR4100 series\n  [MIPS] Use DEFINE_SPINLOCK instead of SPIN_LOCK_UNLOCKED.\n  [MIPS] Replace old fashioned \"__typeof\" with \"__typeof__\".\n  [MIPS] Remove unused _THREAD_SIZE_ORDER from asm-offset.c.\n  [MIPS] Change PCI host bridge setup/resources\n  [MIPS] Register PCI host bridge resource earlier\n  [MIPS] Remove pnx8550-v2pci_defconfig\n  [MIPS] Add bcm1480 ZBus trace support, fix wait related bugs\n  [MIPS] Updated Sibyte headers\n  [MIPS] Remove unused argument from kunmap_coherent().\n  [MIPS] Malta: Delete unused prototype of mips_timer_interrupt.\n  [MIPS] Select ZONE_DMA only if GENERIC_ISA_DMA selected\n  [MIPS] MIPS Tech: Get rid of volatile in core code.\n  [MIPS] IP22: Get rid of volatile in IP22 core code.\n  [MIPS] JMR3927 cleanup\n  [MIPS] merge GT64111 PCI routines and GT64120 PCI_0 routines\n  [MIPS] Cobalt: Split PCI codes from setup.c\n  ...\n"
    },
    {
      "commit": "da8ac5e0fab11d0e84be4e49aaaa828c52d17097",
      "tree": "eade52afcbb5eb31d2d8869fc66e8223a7681a6f",
      "parents": [
        "32f15dc5e6252f03aa2e04a2b140827a8297f21f",
        "cb629a01bb5bca951287e761c590a5686c6ca416"
      ],
      "author": {
        "name": "Linus Torvalds",
        "email": "torvalds@woody.linux-foundation.org",
        "time": "Fri Apr 27 09:15:31 2007 -0700"
      },
      "committer": {
        "name": "Linus Torvalds",
        "email": "torvalds@woody.linux-foundation.org",
        "time": "Fri Apr 27 09:15:31 2007 -0700"
      },
      "message": "Merge branch \u0027for-linus\u0027 of git://git390.osdl.marist.edu/pub/scm/linux-2.6\n\n* \u0027for-linus\u0027 of git://git390.osdl.marist.edu/pub/scm/linux-2.6: (38 commits)\n  [S390] SPIN_LOCK_UNLOCKED cleanup in drivers/s390\n  [S390] Clean up smp code in preparation for some larger changes.\n  [S390] Remove debugging junk.\n  [S390] Switch etr from tasklet to workqueue.\n  [S390] split page_test_and_clear_dirty.\n  [S390] Processor degradation notification.\n  [S390] vtime: cleanup per_cpu usage.\n  [S390] crypto: cleanup.\n  [S390] sclp: fix coding style.\n  [S390] vmlogrdr: stop IUCV connection in vmlogrdr_release.\n  [S390] sclp: initialize early.\n  [S390] ctc: kmalloc-\u003ekzalloc/casting cleanups.\n  [S390] zfcpdump support.\n  [S390] dasd: Add ipldev parameter.\n  [S390] dasd: Add sysfs attribute status and generate uevents.\n  [S390] Improved kernel stack overflow checking.\n  [S390] Get rid of console setup functions.\n  [S390] No execute support cleanup.\n  [S390] Minor fault path optimization.\n  [S390] Use generic bug.\n  ...\n"
    },
    {
      "commit": "a4c9bb7d22aa61ec585984f46df185669e557e3d",
      "tree": "e657c363b6cdd95ae210ab40e53707657f91745a",
      "parents": [
        "05bc284a719b778243f51e23c88fe6cefe6b219b"
      ],
      "author": {
        "name": "Robert P. J. Day",
        "email": "rpjday@mindspring.com",
        "time": "Tue Apr 10 06:23:27 2007 -0400"
      },
      "committer": {
        "name": "Ralf Baechle",
        "email": "ralf@linux-mips.org",
        "time": "Fri Apr 27 16:20:25 2007 +0100"
      },
      "message": "[MIPS] Replace old fashioned \"__typeof\" with \"__typeof__\".\n\n[Robert\u0027s original log message said this was a bug but it isn\u0027t, it\u0027s\njust very old fashioned syntax that is not (no longer?) documented in the\ngcc documentation.  So for the sake of uniformity I\u0027m applying his\npatch but with a modified log message. -- Ralf]\n\nSigned-off-by: Robert P. J. Day \u003crpjday@mindspring.com\u003e\nSigned-off-by: Ralf Baechle \u003cralf@linux-mips.org\u003e\n"
    },
    {
      "commit": "8deab1144b553548fb2f1b51affdd36dcd652aaa",
      "tree": "ca5c971933b74f73532381db5bb76dc2dbe34dec",
      "parents": [
        "eacb9d61919db56482dcea7ec943c9508175dc16"
      ],
      "author": {
        "name": "Mark Mason",
        "email": "mmason@upwardaccess.com",
        "time": "Wed Mar 28 14:40:25 2007 -0700"
      },
      "committer": {
        "name": "Ralf Baechle",
        "email": "ralf@linux-mips.org",
        "time": "Fri Apr 27 16:20:24 2007 +0100"
      },
      "message": "[MIPS] Updated Sibyte headers\n\nThis is an update to the earlier patch for the sibyte headers, and superceeds\nthe previous patch.  Changes were necessary to get the tbprof driver working\non the bcm1480.\n\nPatch to update Sibyte header files to match master versions maintained\nat Broadcom.  This patch also corrects some whitespace problems, and\n(hopefully) shouldn\u0027t introduce any new ones.\n\nSigned-off-by: Mark Mason \u003cmason@broadcom.com\u003e\nSigned-off-by: Ralf Baechle \u003cralf@linux-mips.org\u003e\n"
    },
    {
      "commit": "eacb9d61919db56482dcea7ec943c9508175dc16",
      "tree": "37bb55ace9b1f9e62db9cce6853cf0e58d1b5376",
      "parents": [
        "e3cf10e93f42171224e88b06c226d450f3b3a55f"
      ],
      "author": {
        "name": "Ralf Baechle",
        "email": "ralf@linux-mips.org",
        "time": "Thu Apr 26 15:46:25 2007 +0100"
      },
      "committer": {
        "name": "Ralf Baechle",
        "email": "ralf@linux-mips.org",
        "time": "Fri Apr 27 16:20:24 2007 +0100"
      },
      "message": "[MIPS] Remove unused argument from kunmap_coherent().\n\nSigned-off-by: Ralf Baechle \u003cralf@linux-mips.org\u003e\n"
    },
    {
      "commit": "78709b9df35346965b214e0e548412748d147776",
      "tree": "b2121c099b1a99901aed86921cce59e1f40d3bea",
      "parents": [
        "2127435e57a15f1fea8d6969e264eeb05b28ba4b"
      ],
      "author": {
        "name": "Ralf Baechle",
        "email": "ralf@linux-mips.org",
        "time": "Thu Apr 26 15:46:24 2007 +0100"
      },
      "committer": {
        "name": "Ralf Baechle",
        "email": "ralf@linux-mips.org",
        "time": "Fri Apr 27 16:20:23 2007 +0100"
      },
      "message": "[MIPS] IP22: Get rid of volatile in IP22 core code.\n\nSigned-off-by: Ralf Baechle \u003cralf@linux-mips.org\u003e\n"
    },
    {
      "commit": "2127435e57a15f1fea8d6969e264eeb05b28ba4b",
      "tree": "c8ae7407efcfe42309fbab978c931e17042780b8",
      "parents": [
        "252161eccd1a44f32a506d0fedb424d4ff84e4dc"
      ],
      "author": {
        "name": "Atsushi Nemoto",
        "email": "anemo@mba.ocn.ne.jp",
        "time": "Thu Mar 15 00:58:28 2007 +0900"
      },
      "committer": {
        "name": "Ralf Baechle",
        "email": "ralf@linux-mips.org",
        "time": "Fri Apr 27 16:20:23 2007 +0100"
      },
      "message": "[MIPS] JMR3927 cleanup\n\n* Kill dead codes\n* Rearrange irq chip handlers\n* Minimize defconfig\n\nSigned-off-by: Atsushi Nemoto \u003canemo@mba.ocn.ne.jp\u003e\nSigned-off-by: Ralf Baechle \u003cralf@linux-mips.org\u003e\n"
    },
    {
      "commit": "39ce010d38bf6703b49f59eb73bef030b1d659f2",
      "tree": "76a0ca6ba8289644def45c30d214dd7d8b2921a4",
      "parents": [
        "9ff6f4577e69801a43c0d58606a80040aecbc4bc"
      ],
      "author": {
        "name": "Heiko Carstens",
        "email": "heiko.carstens@de.ibm.com",
        "time": "Fri Apr 27 16:02:00 2007 +0200"
      },
      "committer": {
        "name": "Martin Schwidefsky",
        "email": "schwidefsky@de.ibm.com",
        "time": "Fri Apr 27 16:01:47 2007 +0200"
      },
      "message": "[S390] Clean up smp code in preparation for some larger changes.\n\nSigned-off-by: Martin Schwidefsky \u003cschwidefsky@de.ibm.com\u003e\nSigned-off-by: Heiko Carstens \u003cheiko.carstens@de.ibm.com\u003e\n"
    },
    {
      "commit": "6c210482ae4a9a5bb9377ad250feaacec3faa3cd",
      "tree": "2eb89d89a22380298d64edad59010c1d0a59e5a4",
      "parents": [
        "2fc2d1e9ffcde78af7ab63ed640d9a4901797de2"
      ],
      "author": {
        "name": "Martin Schwidefsky",
        "email": "schwidefsky@de.ibm.com",
        "time": "Fri Apr 27 16:01:57 2007 +0200"
      },
      "committer": {
        "name": "Martin Schwidefsky",
        "email": "schwidefsky@de.ibm.com",
        "time": "Fri Apr 27 16:01:46 2007 +0200"
      },
      "message": "[S390] split page_test_and_clear_dirty.\n\nThe page_test_and_clear_dirty primitive really consists of two\noperations, page_test_dirty and the page_clear_dirty. The combination\nof the two is not an atomic operation, so it makes more sense to have\ntwo separate operations instead of one.\nIn addition to the improved readability of the s390 version of\nSetPageUptodate, it now avoids the page_test_dirty operation which is\nan insert-storage-key-extended (iske) instruction which is an expensive\noperation.\n\nSigned-off-by: Martin Schwidefsky \u003cschwidefsky@de.ibm.com\u003e\n"
    },
    {
      "commit": "2fc2d1e9ffcde78af7ab63ed640d9a4901797de2",
      "tree": "9fd8fcbf4b6882200480da1f04e30b406d1f8a57",
      "parents": [
        "db77aa5f3d01fe6a6cc629dbd37936b1fdd129ba"
      ],
      "author": {
        "name": "Heiko Carstens",
        "email": "heiko.carstens@de.ibm.com",
        "time": "Fri Apr 27 16:01:56 2007 +0200"
      },
      "committer": {
        "name": "Martin Schwidefsky",
        "email": "schwidefsky@de.ibm.com",
        "time": "Fri Apr 27 16:01:46 2007 +0200"
      },
      "message": "[S390] Processor degradation notification.\n\nGenerate uevents for all cpus if cpu capability changes. This can\nhappen e.g. because the cpus are overheating. The cpu capability can\nbe read via /sys/devices/system/cpu/cpuN/capability.\n\nSigned-off-by: Martin Schwidefsky \u003cschwidefsky@de.ibm.com\u003e\nSigned-off-by: Heiko Carstens \u003cheiko.carstens@de.ibm.com\u003e\n"
    },
    {
      "commit": "411ed3225733dbd83b4cbaaa992ef80d6ec1534e",
      "tree": "388aeac39e9fad5f7cadcc8fcbf0838811f5829d",
      "parents": [
        "7039d3a11c4b4b59f9ef933b4b0a28304bdd07d1"
      ],
      "author": {
        "name": "Michael Holzheu",
        "email": "holzheu@de.ibm.com",
        "time": "Fri Apr 27 16:01:49 2007 +0200"
      },
      "committer": {
        "name": "Martin Schwidefsky",
        "email": "schwidefsky@de.ibm.com",
        "time": "Fri Apr 27 16:01:44 2007 +0200"
      },
      "message": "[S390] zfcpdump support.\n\ns390 machines provide hardware support for creating Linux dumps on SCSI\ndisks. For creating a dump a special purpose dump Linux is used. The first\n32 MB of memory are saved by the hardware before the dump Linux is\nbooted. Via an SCLP interface, the saved memory can be accessed from\nLinux. This patch exports memory and registers of the crashed Linux to\nuserspace via a debugfs file. For more information refer to\nDocumentation/s390/zfcpdump.txt, which is included in this patch.\n\nSigned-off-by: Michael Holzheu \u003cholzheu@de.ibm.com\u003e\nSigned-off-by: Martin Schwidefsky \u003cschwidefsky@de.ibm.com\u003e\nSigned-off-by: Heiko Carstens \u003cheiko.carstens@de.ibm.com\u003e\n"
    },
    {
      "commit": "c0007f1a65762eaf55633d403b380130ec60adad",
      "tree": "877ad01344b48a11b293c879b2161a4865b897e5",
      "parents": [
        "bb11e3bdbac08f773a89f3ca287024a956ee8a12"
      ],
      "author": {
        "name": "Heiko Carstens",
        "email": "heiko.carstens@de.ibm.com",
        "time": "Fri Apr 27 16:01:42 2007 +0200"
      },
      "committer": {
        "name": "Martin Schwidefsky",
        "email": "schwidefsky@de.ibm.com",
        "time": "Fri Apr 27 16:01:42 2007 +0200"
      },
      "message": "[S390] Use generic bug.\n\nGeneric bug implementation for s390. Will increase the value of the\nconsole output on BUG() statements since registers r0-r5,r14 will\nnot be clobbered by a printk() call that was previously done before\nthe illegal instruction of BUG() was hit.\nAlso implements an architecture specific WARN_ON(). Output of that\ncould be increased but requires common code change.\n\nSigned-off-by: Martin Schwidefsky \u003cschwidefsky@de.ibm.com\u003e\nSigned-off-by: Heiko Carstens \u003cheiko.carstens@de.ibm.com\u003e\n"
    },
    {
      "commit": "bb11e3bdbac08f773a89f3ca287024a956ee8a12",
      "tree": "f0d1f39efbe08c8217d1d18ff7bcb1fdc36ee6d2",
      "parents": [
        "03ff9a235a0602724fc54916469b6e0939c62c9b"
      ],
      "author": {
        "name": "Martin Schwidefsky",
        "email": "schwidefsky@de.ibm.com",
        "time": "Fri Apr 27 16:01:41 2007 +0200"
      },
      "committer": {
        "name": "Martin Schwidefsky",
        "email": "schwidefsky@de.ibm.com",
        "time": "Fri Apr 27 16:01:42 2007 +0200"
      },
      "message": "[S390] Improved oops output.\n\nThis patch adds two improvements to the oops output. First it adds an\nadditional line after the PSW which decodes the different fields of it.\nSecond a disassembler is added that decodes the instructions surrounding\nthe faulting PSW. The output of a test oops now looks like this:\n\nkernel BUG at init/main.c:419\nillegal operation: 0001 [#1]\nCPU:    0    Not tainted\nProcess swapper (pid: 0, task: 0000000000464968, ksp: 00000000004be000)\nKrnl PSW : 0700000180000000 00000000000120b6 (rest_init+0x36/0x38)\n           R:0 T:1 IO:1 EX:1 Key:0 M:0 W:0 P:0 AS:0 CC:0 PM:0 EA:3\nKrnl GPRS: 0000000000000003 00000000004ba017 0000000000000022 0000000000000001\n           000000000003a5f6 0000000000000000 00000000004be6a8 0000000000000000\n           0000000000000000 00000000004b8200 0000000000003a50 0000000000008000\n           0000000000516368 000000000033d008 00000000000120b2 00000000004bdee0\nKrnl Code: 00000000000120a6: e3e0f0980024       stg     %r14,152(%r15)\n           00000000000120ac: c0e500014296       brasl   %r14,3a5d8\n           00000000000120b2: a7f40001           brc     15,120b4\n          \u003e00000000000120b6: 0707               bcr     0,%r7\n           00000000000120b8: eb7ff0500024       stmg    %r7,%r15,80(%r15)\n           00000000000120be: c0d000195825       larl    %r13,33d108\n           00000000000120c4: a7f13f00           tmll    %r15,16128\n           00000000000120c8: a7840001           brc     8,120ca\nCall Trace:\n([\u003c00000000000120b2\u003e] rest_init+0x32/0x38)\n [\u003c00000000004be614\u003e] start_kernel+0x37c/0x410\n [\u003c0000000000012020\u003e] _ehead+0x20/0x80\n\nSigned-off-by: Martin Schwidefsky \u003cschwidefsky@de.ibm.com\u003e\nSigned-off-by: Heiko Carstens \u003cheiko.carstens@de.ibm.com\u003e\n"
    },
    {
      "commit": "d76123eb357a4baa653714183df286c1bb99f707",
      "tree": "b7244cc14038bc337d89d7a00acd847626438ffe",
      "parents": [
        "82b7ac058f60e0c92f9237fbaf440671f437ecdf"
      ],
      "author": {
        "name": "Cornelia Huck",
        "email": "cornelia.huck@de.ibm.com",
        "time": "Fri Apr 27 16:01:37 2007 +0200"
      },
      "committer": {
        "name": "Martin Schwidefsky",
        "email": "schwidefsky@de.ibm.com",
        "time": "Fri Apr 27 16:01:41 2007 +0200"
      },
      "message": "[S390] cio: ccwgroup register vs. unregister.\n\nIntroduce a mutex for struct ccwgroup to prevent simuntaneous\nregister/unregister on the same ccwgroup device.\n\nSigned-off-by: Cornelia Huck \u003ccornelia.huck@de.ibm.com\u003e\nSigned-off-by: Martin Schwidefsky \u003cschwidefsky@de.ibm.com\u003e\n"
    },
    {
      "commit": "e5854a5839fa426a7873f038080f63587de5f1f1",
      "tree": "c0a3705df925e652ff0694a47e7acb98e5f7d7bd",
      "parents": [
        "f5ba6c863617c15d22cce5f8666ff4c832773025"
      ],
      "author": {
        "name": "Peter Oberparleiter",
        "email": "peter.oberparleiter@de.ibm.com",
        "time": "Fri Apr 27 16:01:31 2007 +0200"
      },
      "committer": {
        "name": "Martin Schwidefsky",
        "email": "schwidefsky@de.ibm.com",
        "time": "Fri Apr 27 16:01:39 2007 +0200"
      },
      "message": "[S390] cio: Channel-path configure function.\n\nAdd a new attribute to the channel-path sysfs directory through which\nchannel-path configure operations can be triggered. Also listen for\nhardware events requesting channel-path configure operations and\nprocess them accordingly.\n\nSigned-off-by: Peter Oberparleiter \u003cpeter.oberparleiter@de.ibm.com\u003e\nSigned-off-by: Martin Schwidefsky \u003cschwidefsky@de.ibm.com\u003e\nSigned-off-by: Heiko Carstens \u003cheiko.carstens@de.ibm.com\u003e\n"
    },
    {
      "commit": "6fc321fd7dd91f0592f37503219196835314fbb7",
      "tree": "d512811f8f6761608829c8df44a55a2ada074cdc",
      "parents": [
        "29c380f5f06d0c5a320b9bb6f8987065e7b81c91"
      ],
      "author": {
        "name": "Heiko Carstens",
        "email": "heiko.carstens@de.ibm.com",
        "time": "Fri Apr 27 16:01:25 2007 +0200"
      },
      "committer": {
        "name": "Martin Schwidefsky",
        "email": "schwidefsky@de.ibm.com",
        "time": "Fri Apr 27 16:01:38 2007 +0200"
      },
      "message": "[S390] cio/ipl: Clean interface between cio and ipl code.\n\nClean interface between cio and ipl code, so Peter stops complaining.\n\nSigned-off-by: Martin Schwidefsky \u003cschwidefsky@de.ibm.com\u003e\nSigned-off-by: Heiko Carstens \u003cheiko.carstens@de.ibm.com\u003e\n"
    },
    {
      "commit": "8224ca195874525533665bbcd23b6da1e575aa4d",
      "tree": "2d3e170f3fd58c2ec39d33136059eaf12a94e53f",
      "parents": [
        "a4022b0d6005b117a985cec64559e048981a4244"
      ],
      "author": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Fri Apr 27 14:21:47 2007 +0200"
      },
      "committer": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Fri Apr 27 14:21:47 2007 +0200"
      },
      "message": "[AVR32] Fix compile error with gcc 4.1\n\ngcc 4.1 doesn\u0027t seem to like const variables as inline assembly\noutputs. Drop support for reading 64-bit values using get_user() so\nthat we can use an unsigned long to hold the result regardless of the\nactual size. This should be safe since many architectures, including\ni386, doesn\u0027t support reading 64-bit values with get_user().\n\nSigned-off-by: Haavard Skinnemoen \u003chskinnemoen@atmel.com\u003e\n"
    },
    {
      "commit": "a4022b0d6005b117a985cec64559e048981a4244",
      "tree": "49714219f452a86b421b76631945fba029e0fb04",
      "parents": [
        "0277b378c3779e3c8a413afb7d4ee00fa24a5a26"
      ],
      "author": {
        "name": "Mathieu Desnoyers",
        "email": "mathieu.desnoyers@polymtl.ca",
        "time": "Tue Apr 10 18:23:09 2007 -0400"
      },
      "committer": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Fri Apr 27 13:54:02 2007 +0200"
      },
      "message": "avr32: remove unneeded cast in atomic.h\n\nThis int cast is superfluous since system.h cmpxchg already casts it in\n(typeof(*(ptr))).\n\nSigned-off-by: Mathieu Desnoyers \u003cmathieu.desnoyers@polymtl.ca\u003e\nSigned-off-by: Andrew Morton \u003cakpm@linux-foundation.org\u003e\nSigned-off-by: Haavard Skinnemoen \u003chskinnemoen@atmel.com\u003e\n"
    },
    {
      "commit": "2c1a2a3441a754a9b5a8e7184071154f8a9bd61b",
      "tree": "a11527d9a32495d800c949e9616b82c5c25aba5f",
      "parents": [
        "d80e2bb12606906fd0b5b5592f519852de8b0113"
      ],
      "author": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Wed Mar 07 10:40:44 2007 +0100"
      },
      "committer": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Fri Apr 27 13:44:15 2007 +0200"
      },
      "message": "[AVR32] Use memcpy/memset in memcpy_{from,to}_io and memset_io\n\nUsing readb/writeb to implement these breaks NOR flash support. I\ncan\u0027t see any reason why regular memcpy and memset shouldn\u0027t work.\n\nSigned-off-by: Haavard Skinnemoen \u003chskinnemoen@atmel.com\u003e\n"
    },
    {
      "commit": "d80e2bb12606906fd0b5b5592f519852de8b0113",
      "tree": "37f751e0c020d50abf92eae9dca8ae01c2eba492",
      "parents": [
        "f9692b9501c339ec90647d8cd6ee5c106f072f9f"
      ],
      "author": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Wed Mar 21 16:23:41 2007 +0100"
      },
      "committer": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Fri Apr 27 13:44:15 2007 +0200"
      },
      "message": "[AVR32] Get rid of board_setup_fbmem()\n\nSince the core setup code takes care of both allocation and\nreservation of framebuffer memory, there\u0027s no need for this board-\nspecific hook anymore. Replace it with two global variables,\nfbmem_start and fbmem_size, which can be used directly.\n\nSigned-off-by: Haavard Skinnemoen \u003chskinnemoen@atmel.com\u003e\n"
    },
    {
      "commit": "d8011768e6bdd0d9de5cc7bdbd3077b4b4fab8c7",
      "tree": "0d03566388d439edf87432424d4377dbfcbe053f",
      "parents": [
        "5539f59ac40473730806580f212c4eac6e769f01"
      ],
      "author": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Wed Mar 21 16:02:57 2007 +0100"
      },
      "committer": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Fri Apr 27 13:44:14 2007 +0200"
      },
      "message": "[AVR32] Simplify early handling of memory regions\n\nUse struct resource to specify both physical memory regions and\nreserved regions and push everything into the same framework,\nincluding kernel code/data and initrd memory. This allows us to get\nrid of many special cases in the bootmem initialization and will also\nmake it easier to implement more robust handling of framebuffer\nmemory later.\n\nSigned-off-by: Haavard Skinnemoen \u003chskinnemoen@atmel.com\u003e\n"
    },
    {
      "commit": "5539f59ac40473730806580f212c4eac6e769f01",
      "tree": "330d159dfcc9e329f5e8b7f5cf18dbf3eb39ee0b",
      "parents": [
        "e3e7d8d4ea37b8372ee417452d03171c5dc55125"
      ],
      "author": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Wed Mar 21 15:39:18 2007 +0100"
      },
      "committer": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Fri Apr 27 13:44:14 2007 +0200"
      },
      "message": "[AVR32] Move setup_bootmem() from mm/init.c to kernel/setup.c\n\nSigned-off-by: Haavard Skinnemoen \u003chskinnemoen@atmel.com\u003e\n"
    },
    {
      "commit": "e3e7d8d4ea37b8372ee417452d03171c5dc55125",
      "tree": "247a899f472e5cf1a3f7467dda88a017bee134a6",
      "parents": [
        "92b728c147adb8c690b520304f4c9ee3eee43c21"
      ],
      "author": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Mon Feb 12 16:28:56 2007 +0100"
      },
      "committer": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Fri Apr 27 13:44:14 2007 +0200"
      },
      "message": "[AVR32] Make I/O access macros work with external devices\n\nFix the I/O access macros so that they work with externally connected\ndevices accessed in little-endian mode over any bus width:\n\n* Use a set of macros to define I/O port- and memory operations\n  borrowed from MIPS.\n* Allow subarchitecture to specify address- and data-mangling\n* Implement at32ap-specific port mangling (with build-time\n  configurable bus width. Only one bus width at a time supported\n  for now.)\n* Rewrite iowriteN and friends to use write[bwl] and friends\n  (not the __raw counterparts.)\n\nThis has been tested using pata_pcmcia to access a CompactFlash card\nconnected to the EBI (16-bit bus width.)\n\nSigned-off-by: Haavard Skinnemoen \u003chskinnemoen@atmel.com\u003e\n"
    },
    {
      "commit": "623b0355d5b1f9c6d05005b649a2f3a7b9fd7816",
      "tree": "43ef35d4f6e83a49c1fb72df4b538271b650c054",
      "parents": [
        "3b328c98093702c584692bffabd440800b383d73"
      ],
      "author": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Tue Mar 13 17:59:11 2007 +0100"
      },
      "committer": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Fri Apr 27 13:44:13 2007 +0200"
      },
      "message": "[AVR32] Clean up exception handling code\n\n  * Use generic BUG() handling\n  * Remove some useless debug statements\n  * Use a common function _exception() to send signals or oops when\n    an exception can\u0027t be handled. This makes sure init doesn\u0027t\n    enter an infinite exception loop as well. Borrowed from powerpc.\n  * Add some basic exception tracing support to the page fault code.\n  * Rework dump_stack(), show_regs() and friends and move everything\n    into process.c\n  * Print information about configuration options and chip type when\n    oopsing\n\nSigned-off-by: Haavard Skinnemoen \u003chskinnemoen@atmel.com\u003e\n"
    },
    {
      "commit": "3b328c98093702c584692bffabd440800b383d73",
      "tree": "2590a7013631f5915d2c80d0b749e54e26ff8520",
      "parents": [
        "535c806c26ef602d578792083df52b31803b961e"
      ],
      "author": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Tue Mar 13 15:30:38 2007 +0100"
      },
      "committer": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Fri Apr 27 13:44:13 2007 +0200"
      },
      "message": "[AVR32] Clean up cpu identification and add features bitmap\n\nClean up the cpu identification code, using definitions from\n\u003casm/sysreg.h\u003e instead of hardcoded constants. Also, add a features\nbitmap to struct avr32_cpuinfo to allow other code to make decisions\nbased upon what the running cpu is actually capable of.\n\nSigned-off-by: Haavard Skinnemoen \u003chskinnemoen@atmel.com\u003e\n"
    },
    {
      "commit": "535c806c26ef602d578792083df52b31803b961e",
      "tree": "5ade704a620d218c5264b9e665d758b32463a689",
      "parents": [
        "188ff65d49dadf7b0e9b6718abc3fe98a5098711"
      ],
      "author": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Tue Mar 13 14:17:14 2007 +0100"
      },
      "committer": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Fri Apr 27 13:44:13 2007 +0200"
      },
      "message": "[AVR32] Clean up asm/sysreg.h\n\nFix indentation and remove spurious comments in asm-avr32/sysreg.h\n\nSigned-off-by: Haavard Skinnemoen \u003chskinnemoen@atmel.com\u003e\n"
    },
    {
      "commit": "19b7ce8bad718a2850ea19aeb7383f1728596c24",
      "tree": "1fef17c37eaf90231a497b92dd49565e56986b6c",
      "parents": [
        "7760989e5e2900e484e9115e6e690c6ce0b0221c"
      ],
      "author": {
        "name": "Hans-Christian Egtvedt",
        "email": "hcegtvedt@atmel.com",
        "time": "Mon Feb 26 13:50:43 2007 +0100"
      },
      "committer": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Fri Apr 27 13:44:12 2007 +0200"
      },
      "message": "[AVR32] Put cpu in sleep 0 when idle.\n\nThis patch puts the CPU in sleep 0 when doing nothing, idle. This will\nturn of the CPU clock and thus save power. The CPU is waken again when\nan interrupt occurs.\n\nSigned-off-by: Hans-Christian Egtvedt \u003chcegtvedt@atmel.com\u003e\nSigned-off-by: Haavard Skinnemoen \u003chskinnemoen@atmel.com\u003e\n"
    },
    {
      "commit": "7760989e5e2900e484e9115e6e690c6ce0b0221c",
      "tree": "465791d8a5d0360a6d41fc592c09abd4932aafe1",
      "parents": [
        "228e845fd243bf42033998afab792357444e9e4a"
      ],
      "author": {
        "name": "Hans-Christian Egtvedt",
        "email": "hcegtvedt@atmel.com",
        "time": "Mon Mar 12 18:15:16 2007 +0100"
      },
      "committer": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Fri Apr 27 13:44:12 2007 +0200"
      },
      "message": "[AVR32] Change system timer from count-compare to Timer/Counter 0\n\nDue to limitation of the count-compare system timer (not able to\ncount when CPU is in sleep), the system timer had to be changed to\nuse a peripheral timer/counter.\n\nThe old COUNT-COMPARE code is still present in time.c as weak\nfunctions. The new timer is added to the architecture directory.\n\nThis patch sets up TC0 as system timer The new timer has been tested\non AT32AP7000/ATSTK1000 at 100 Hz, 250 Hz, 300 Hz and 1000 Hz.\n\nFor more details about the timer/counter see the datasheet for\nAT32AP700x available at\n\nhttp://www.atmel.com/dyn/products/product_card.asp?part_id\u003d3903\n\nSigned-off-by: Hans-Christian Egtvedt \u003chcegtvedt@atmel.com\u003e\nSigned-off-by: Haavard Skinnemoen \u003chskinnemoen@atmel.com\u003e\n"
    },
    {
      "commit": "068d9f6eb9369a00eb45be91c07653cfef65f4a0",
      "tree": "845e2162383a78c29fb05c4e8113730270b46583",
      "parents": [
        "9c8f8e752431f3f7ed6ea6ea6e491ce12057f572"
      ],
      "author": {
        "name": "Hans-Christian Egtvedt",
        "email": "hcegtvedt@atmel.com",
        "time": "Wed Jan 31 18:01:45 2007 +0100"
      },
      "committer": {
        "name": "Haavard Skinnemoen",
        "email": "hskinnemoen@atmel.com",
        "time": "Fri Apr 27 13:43:27 2007 +0200"
      },
      "message": "[AVR32] Add nwait and tdf parameters to SMC configuration\n\nComplete the SMC configuration code by adding nwait and tdf\nparameter. After this change, we support the same parameters as the\nhardware.\n\nSigned-off-by: Haavard Skinnemoen \u003chskinnemoen@atmel.com\u003e\n"
    },
    {
      "commit": "16ce82d846f2e6b652a064f91c5019cfe8682be4",
      "tree": "9100d2baface8ec8d5b7911e00e093fd177cb9e4",
      "parents": [
        "ee5ac9ddf2ea13be2418ac7d0ce5a930e78af013"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 21:08:21 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 21:08:21 2007 -0700"
      },
      "message": "[SPARC64]: Convert PCI over to generic struct iommu/strbuf.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "b86e0280bb5585a610783ff5392d9d439dee7ddd",
      "tree": "150f65cdf5fd17a41c7c2042c0f90ebc6e9f0268",
      "parents": [
        "4d44e0dfe961e02489d40d32334454ebe0e784e8"
      ],
      "author": {
        "name": "Johannes Berg",
        "email": "johannes@sipsolutions.net",
        "time": "Thu Apr 26 20:48:23 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@davemloft.net",
        "time": "Thu Apr 26 20:48:23 2007 -0700"
      },
      "message": "[WEXT] net_device: Don\u0027t include wext bits if not required.\n\nThis patch makes the wext bits in struct net_device depend on\nCONFIG_WIRELESS_EXT.\n\nSigned-off-by: Johannes Berg \u003cjohannes@sipsolutions.net\u003e\nSigned-off-by: John W. Linville \u003clinville@tuxdriver.com\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "295f4a1fa3ecdf816b18393ef7bcd37c032df2fa",
      "tree": "231c71578608e46b45dd36006dd1112a6bc6c39a",
      "parents": [
        "11433ee450eb4a320f46ce5ed51410b52803ffcc"
      ],
      "author": {
        "name": "Johannes Berg",
        "email": "johannes@sipsolutions.net",
        "time": "Thu Apr 26 20:43:56 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@davemloft.net",
        "time": "Thu Apr 26 20:43:56 2007 -0700"
      },
      "message": "[WEXT]: Clean up how wext is called.\n\nThis patch cleans up the call paths from the core code into wext.\n\nSigned-off-by: Johannes Berg \u003cjohannes@sipsolutions.net\u003e\nSigned-off-by: John W. Linville \u003clinville@tuxdriver.com\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "63b6be55e8b51cb718468794d343058e96c7462c",
      "tree": "83c06275ba6b7ca1ffbf8c2e52497d7bceed567c",
      "parents": [
        "08e0e7c82eeadec6f4871a386b86bf0f0fbcb4eb"
      ],
      "author": {
        "name": "David Howells",
        "email": "dhowells@redhat.com",
        "time": "Thu Apr 26 15:55:48 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@davemloft.net",
        "time": "Thu Apr 26 15:55:48 2007 -0700"
      },
      "message": "[AF_RXRPC]: Delete the old RxRPC code.\n\nDelete the old RxRPC code as it\u0027s now no longer used.\n\nSigned-off-by: David Howells \u003cdhowells@redhat.com\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "651350d10f93bed7003c9a66e24cf25e0f8eed3d",
      "tree": "4748c1dd0b1a905b0e34b100c3c6ced6565a06de",
      "parents": [
        "ec26815ad847dbf74a1e27aa5515fb7d5dc6ee6f"
      ],
      "author": {
        "name": "David Howells",
        "email": "dhowells@redhat.com",
        "time": "Thu Apr 26 15:50:17 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@davemloft.net",
        "time": "Thu Apr 26 15:50:17 2007 -0700"
      },
      "message": "[AF_RXRPC]: Add an interface to the AF_RXRPC module for the AFS filesystem to use\n\nAdd an interface to the AF_RXRPC module so that the AFS filesystem module can\nmore easily make use of the services available.  AFS still opens a socket but\nthen uses the action functions in lieu of sendmsg() and registers an intercept\nfunctions to grab messages before they\u0027re queued on the socket Rx queue.\n\nThis permits AFS (or whatever) to:\n\n (1) Avoid the overhead of using the recvmsg() call.\n\n (2) Use different keys directly on individual client calls on one socket\n     rather than having to open a whole slew of sockets, one for each key it\n     might want to use.\n\n (3) Avoid calling request_key() at the point of issue of a call or opening of\n     a socket.  This is done instead by AFS at the point of open(), unlink() or\n     other VFS operation and the key handed through.\n\n (4) Request the use of something other than GFP_KERNEL to allocate memory.\n\nFurthermore:\n\n (*) The socket buffer markings used by RxRPC are made available for AFS so\n     that it can interpret the cooked RxRPC messages itself.\n\n (*) rxgen (un)marshalling abort codes are made available.\n\n\nThe following documentation for the kernel interface is added to\nDocumentation/networking/rxrpc.txt:\n\n\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\nAF_RXRPC KERNEL INTERFACE\n\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\n\nThe AF_RXRPC module also provides an interface for use by in-kernel utilities\nsuch as the AFS filesystem.  This permits such a utility to:\n\n (1) Use different keys directly on individual client calls on one socket\n     rather than having to open a whole slew of sockets, one for each key it\n     might want to use.\n\n (2) Avoid having RxRPC call request_key() at the point of issue of a call or\n     opening of a socket.  Instead the utility is responsible for requesting a\n     key at the appropriate point.  AFS, for instance, would do this during VFS\n     operations such as open() or unlink().  The key is then handed through\n     when the call is initiated.\n\n (3) Request the use of something other than GFP_KERNEL to allocate memory.\n\n (4) Avoid the overhead of using the recvmsg() call.  RxRPC messages can be\n     intercepted before they get put into the socket Rx queue and the socket\n     buffers manipulated directly.\n\nTo use the RxRPC facility, a kernel utility must still open an AF_RXRPC socket,\nbind an addess as appropriate and listen if it\u0027s to be a server socket, but\nthen it passes this to the kernel interface functions.\n\nThe kernel interface functions are as follows:\n\n (*) Begin a new client call.\n\n\tstruct rxrpc_call *\n\trxrpc_kernel_begin_call(struct socket *sock,\n\t\t\t\tstruct sockaddr_rxrpc *srx,\n\t\t\t\tstruct key *key,\n\t\t\t\tunsigned long user_call_ID,\n\t\t\t\tgfp_t gfp);\n\n     This allocates the infrastructure to make a new RxRPC call and assigns\n     call and connection numbers.  The call will be made on the UDP port that\n     the socket is bound to.  The call will go to the destination address of a\n     connected client socket unless an alternative is supplied (srx is\n     non-NULL).\n\n     If a key is supplied then this will be used to secure the call instead of\n     the key bound to the socket with the RXRPC_SECURITY_KEY sockopt.  Calls\n     secured in this way will still share connections if at all possible.\n\n     The user_call_ID is equivalent to that supplied to sendmsg() in the\n     control data buffer.  It is entirely feasible to use this to point to a\n     kernel data structure.\n\n     If this function is successful, an opaque reference to the RxRPC call is\n     returned.  The caller now holds a reference on this and it must be\n     properly ended.\n\n (*) End a client call.\n\n\tvoid rxrpc_kernel_end_call(struct rxrpc_call *call);\n\n     This is used to end a previously begun call.  The user_call_ID is expunged\n     from AF_RXRPC\u0027s knowledge and will not be seen again in association with\n     the specified call.\n\n (*) Send data through a call.\n\n\tint rxrpc_kernel_send_data(struct rxrpc_call *call, struct msghdr *msg,\n\t\t\t\t   size_t len);\n\n     This is used to supply either the request part of a client call or the\n     reply part of a server call.  msg.msg_iovlen and msg.msg_iov specify the\n     data buffers to be used.  msg_iov may not be NULL and must point\n     exclusively to in-kernel virtual addresses.  msg.msg_flags may be given\n     MSG_MORE if there will be subsequent data sends for this call.\n\n     The msg must not specify a destination address, control data or any flags\n     other than MSG_MORE.  len is the total amount of data to transmit.\n\n (*) Abort a call.\n\n\tvoid rxrpc_kernel_abort_call(struct rxrpc_call *call, u32 abort_code);\n\n     This is used to abort a call if it\u0027s still in an abortable state.  The\n     abort code specified will be placed in the ABORT message sent.\n\n (*) Intercept received RxRPC messages.\n\n\ttypedef void (*rxrpc_interceptor_t)(struct sock *sk,\n\t\t\t\t\t    unsigned long user_call_ID,\n\t\t\t\t\t    struct sk_buff *skb);\n\n\tvoid\n\trxrpc_kernel_intercept_rx_messages(struct socket *sock,\n\t\t\t\t\t   rxrpc_interceptor_t interceptor);\n\n     This installs an interceptor function on the specified AF_RXRPC socket.\n     All messages that would otherwise wind up in the socket\u0027s Rx queue are\n     then diverted to this function.  Note that care must be taken to process\n     the messages in the right order to maintain DATA message sequentiality.\n\n     The interceptor function itself is provided with the address of the socket\n     and handling the incoming message, the ID assigned by the kernel utility\n     to the call and the socket buffer containing the message.\n\n     The skb-\u003emark field indicates the type of message:\n\n\tMARK\t\t\t\tMEANING\n\t\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\t\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\u003d\n\tRXRPC_SKB_MARK_DATA\t\tData message\n\tRXRPC_SKB_MARK_FINAL_ACK\tFinal ACK received for an incoming call\n\tRXRPC_SKB_MARK_BUSY\t\tClient call rejected as server busy\n\tRXRPC_SKB_MARK_REMOTE_ABORT\tCall aborted by peer\n\tRXRPC_SKB_MARK_NET_ERROR\tNetwork error detected\n\tRXRPC_SKB_MARK_LOCAL_ERROR\tLocal error encountered\n\tRXRPC_SKB_MARK_NEW_CALL\t\tNew incoming call awaiting acceptance\n\n     The remote abort message can be probed with rxrpc_kernel_get_abort_code().\n     The two error messages can be probed with rxrpc_kernel_get_error_number().\n     A new call can be accepted with rxrpc_kernel_accept_call().\n\n     Data messages can have their contents extracted with the usual bunch of\n     socket buffer manipulation functions.  A data message can be determined to\n     be the last one in a sequence with rxrpc_kernel_is_data_last().  When a\n     data message has been used up, rxrpc_kernel_data_delivered() should be\n     called on it..\n\n     Non-data messages should be handled to rxrpc_kernel_free_skb() to dispose\n     of.  It is possible to get extra refs on all types of message for later\n     freeing, but this may pin the state of a call until the message is finally\n     freed.\n\n (*) Accept an incoming call.\n\n\tstruct rxrpc_call *\n\trxrpc_kernel_accept_call(struct socket *sock,\n\t\t\t\t unsigned long user_call_ID);\n\n     This is used to accept an incoming call and to assign it a call ID.  This\n     function is similar to rxrpc_kernel_begin_call() and calls accepted must\n     be ended in the same way.\n\n     If this function is successful, an opaque reference to the RxRPC call is\n     returned.  The caller now holds a reference on this and it must be\n     properly ended.\n\n (*) Reject an incoming call.\n\n\tint rxrpc_kernel_reject_call(struct socket *sock);\n\n     This is used to reject the first incoming call on the socket\u0027s queue with\n     a BUSY message.  -ENODATA is returned if there were no incoming calls.\n     Other errors may be returned if the call had been aborted (-ECONNABORTED)\n     or had timed out (-ETIME).\n\n (*) Record the delivery of a data message and free it.\n\n\tvoid rxrpc_kernel_data_delivered(struct sk_buff *skb);\n\n     This is used to record a data message as having been delivered and to\n     update the ACK state for the call.  The socket buffer will be freed.\n\n (*) Free a message.\n\n\tvoid rxrpc_kernel_free_skb(struct sk_buff *skb);\n\n     This is used to free a non-DATA socket buffer intercepted from an AF_RXRPC\n     socket.\n\n (*) Determine if a data message is the last one on a call.\n\n\tbool rxrpc_kernel_is_data_last(struct sk_buff *skb);\n\n     This is used to determine if a socket buffer holds the last data message\n     to be received for a call (true will be returned if it does, false\n     if not).\n\n     The data message will be part of the reply on a client call and the\n     request on an incoming call.  In the latter case there will be more\n     messages, but in the former case there will not.\n\n (*) Get the abort code from an abort message.\n\n\tu32 rxrpc_kernel_get_abort_code(struct sk_buff *skb);\n\n     This is used to extract the abort code from a remote abort message.\n\n (*) Get the error number from a local or network error message.\n\n\tint rxrpc_kernel_get_error_number(struct sk_buff *skb);\n\n     This is used to extract the error number from a message indicating either\n     a local error occurred or a network error occurred.\n\nSigned-off-by: David Howells \u003cdhowells@redhat.com\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "17926a79320afa9b95df6b977b40cca6d8713cea",
      "tree": "5cedff43b69520ad17b86783d3752053686ec99c",
      "parents": [
        "e19dff1fdd99a25819af74cf0710e147fff4fd3a"
      ],
      "author": {
        "name": "David Howells",
        "email": "dhowells@redhat.com",
        "time": "Thu Apr 26 15:48:28 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@davemloft.net",
        "time": "Thu Apr 26 15:48:28 2007 -0700"
      },
      "message": "[AF_RXRPC]: Provide secure RxRPC sockets for use by userspace and kernel both\n\nProvide AF_RXRPC sockets that can be used to talk to AFS servers, or serve\nanswers to AFS clients.  KerberosIV security is fully supported.  The patches\nand some example test programs can be found in:\n\n\thttp://people.redhat.com/~dhowells/rxrpc/\n\nThis will eventually replace the old implementation of kernel-only RxRPC\ncurrently resident in net/rxrpc/.\n\nSigned-off-by: David Howells \u003cdhowells@redhat.com\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "7318226ea2931a627f3572e5f4804c91ca19ecbc",
      "tree": "d2492bb7e87a9c1740432c4dcde13e75ee46ad8d",
      "parents": [
        "071b638689464c6b39407025eedd810d5b5e6f5d"
      ],
      "author": {
        "name": "David Howells",
        "email": "dhowells@redhat.com",
        "time": "Thu Apr 26 15:46:23 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@davemloft.net",
        "time": "Thu Apr 26 15:46:23 2007 -0700"
      },
      "message": "[AF_RXRPC]: Key facility changes for AF_RXRPC\n\nExport the keyring key type definition and document its availability.\n\nAdd alternative types into the key\u0027s type_data union to make it more useful.\nNot all users necessarily want to use it as a list_head (AF_RXRPC doesn\u0027t, for\nexample), so make it clear that it can be used in other ways.\n\nSigned-off-by: David Howells \u003cdhowells@redhat.com\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "071b638689464c6b39407025eedd810d5b5e6f5d",
      "tree": "702b28d1a7acdd7ea904cd442c4491a24b93c059",
      "parents": [
        "566ec03448052c096dc3982fbe573522dc0ba479"
      ],
      "author": {
        "name": "Oleg Nesterov",
        "email": "oleg@tv-sign.ru",
        "time": "Thu Apr 26 15:45:32 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@davemloft.net",
        "time": "Thu Apr 26 15:45:32 2007 -0700"
      },
      "message": "[WORKQUEUE]: cancel_delayed_work: use del_timer() instead of del_timer_sync()\n\ndel_timer_sync() buys nothing for cancel_delayed_work(), but it is less\nefficient since it locks the timer unconditionally, and may wait for the\ncompletion of the delayed_work_timer_fn().\n\ncancel_delayed_work() \u003d\u003d 0 means:\n\n\tbefore this patch:\n\t\twork-\u003efunc may still be running or queued\n\n\tafter this patch:\n\t\twork-\u003efunc may still be running or queued, or\n\t\tdelayed_work_timer_fn-\u003e__queue_work() in progress.\n\n\t\tThe latter doesn\u0027t differ from the caller\u0027s POV,\n\t\tdelayed_work_timer_fn() is called with _PENDING\n\t\tbit set.\n\ncancel_delayed_work() \u003d\u003d 1 with this patch adds a new possibility:\n\n\tdelayed_work-\u003ework was cancelled, but delayed_work_timer_fn\n\tis still running (this is only possible for the re-arming\n\tworks on single-threaded workqueue).\n\n\tIn this case the timer was re-started by work-\u003efunc(), nobody\n\telse can do this. This in turn means that delayed_work_timer_fn\n\thas already passed __queue_work() (and wont\u0027t touch delayed_work)\n\tbecause nobody else can queue delayed_work-\u003ework.\n\nSigned-off-by: Oleg Nesterov \u003coleg@tv-sign.ru\u003e\nSigned-Off-By: David Howells \u003cdhowells@redhat.com\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "66875088098f314af1a4d9e0cc47e617d643bffd",
      "tree": "52db91a75778d9a5b155a88f860c9656a7de1c15",
      "parents": [
        "9b3627f389c07c5be9c86ac4d472a0d4fd47feac"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 00:12:09 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:43 2007 -0700"
      },
      "message": "[SPARC64]: Add generic iommu and strbuf structs to iommu.h\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "9b3627f389c07c5be9c86ac4d472a0d4fd47feac",
      "tree": "4e00925c81102399ec57e4eefe647dc23710a66d",
      "parents": [
        "711b360d64418e88ed45f812e0ebd202073d888d"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Tue Apr 24 23:51:18 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:42 2007 -0700"
      },
      "message": "[SPARC64]: Consolidate {sbus,pci}_iommu_arena.\n\nMove to asm-sparc64/iommu.h and rename to plain \"iommu_arena\".\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "711b360d64418e88ed45f812e0ebd202073d888d",
      "tree": "355c2e050aa4229b912800bb62b612051f6228c6",
      "parents": [
        "3dfe10ee7caae9802d84a06fe7724274dea24020"
      ],
      "author": {
        "name": "Stephen Rothwell",
        "email": "sfr@canb.auug.org.au",
        "time": "Thu Apr 12 14:38:34 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:41 2007 -0700"
      },
      "message": "[SPARC]: Make device_node name and type const\n\nSigned-off-by: Stephen Rothwell \u003csfr@canb.auug.org.au\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "3dfe10ee7caae9802d84a06fe7724274dea24020",
      "tree": "9d8c39445c1a66135ae23e8444d51a66613e5798",
      "parents": [
        "374d4cac6283469f101282ca83ee008368bd8350"
      ],
      "author": {
        "name": "Stephen Rothwell",
        "email": "sfr@canb.auug.org.au",
        "time": "Thu Mar 29 11:22:57 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:40 2007 -0700"
      },
      "message": "[SPARC64]: constify some paramaters of OF routines\n\nThis starts bringing the PowerPC and Sparc64 implemetations back closer\ntogether.\n\nSigned-off-by: Stephen Rothwell \u003csfr@canb.auug.org.au\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "b93f2620231d4641bdbaaa952d3e8890687124bb",
      "tree": "14b6eb3db5831cb74fb385ce7101682a2513e58a",
      "parents": [
        "9753f0d6502acd65761ff15244d26d0e88f0820a"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Mar 15 18:29:13 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:33 2007 -0700"
      },
      "message": "[SPARC64]: Add proper header file extern for cmdline_memory_size.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "4be5c34dc47b5a9e6f91c8f5937a93c464870b8e",
      "tree": "0b62b34193547010e8446a4ecba7ab06d691f64c",
      "parents": [
        "a0963bdfb91ca97c2b0b6d4ca81ff557fac66901"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Mar 15 15:44:05 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:26 2007 -0700"
      },
      "message": "[SPARC64]: Privatize sun4u_get_pte() and fix name.\n\n__get_phys is only called from init.c as is prom_virt_to_phys(),\n__get_iospace() is not called at all, and sun4u_get_pte() is largely\nmisnamed.\n\nPrivatize the implementation and helper functions of\nsun4u_get_phys() to mm/init.c, and rename to\nkvaddr_to_paddr().\n\nThe only used of this thing is flush_icache_range(), and thus\nthings can be considerably further simplified.  For example,\nwe should only see module or PAGE_OFFSET kernel addresses here,\nso we don\u0027t need the OBP firmware range handling at all.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "4e286d5be63c93b17f8a82d6f3618faa9c1b025c",
      "tree": "763061532d360fcab38b9723c52f17ffa250bc90",
      "parents": [
        "0015d3d68c84eb33e6b380802ad61b23f7eb6523"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Mar 15 00:21:45 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:24 2007 -0700"
      },
      "message": "[SPARC64]: MAX_PHYSADDR_BITS et al. really need to be 42 bits not 41.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "d78d0891d3dd976a2fb707c6c691d9cd5ed60727",
      "tree": "75a1f09a7f316c5cfd6ab3d1dc0e48e89320a200",
      "parents": [
        "43bed127376ff2ef9c268cf6688a43d0fbed2ff4"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Mar 14 22:47:01 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:22 2007 -0700"
      },
      "message": "[SPARC64]: Use SPARSEMEM_STATIC\n\nDecrease the SECTION_SIZE_BITS --\u003e MAX_PHYSADDR_BITS\nrange a little bit.\n\nThe cost of going to SPARSEMEM_STATIC becomes 8K of BSS space, and in\nreturn we save a pointer dereferences on every page struct lookup.\nEven better we hit the main kernel image for the base address which is\nin a hugepage locked TLB entry.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "43bed127376ff2ef9c268cf6688a43d0fbed2ff4",
      "tree": "1241d2ae9d1d092688df43ffa5e67ec5fd5a83ca",
      "parents": [
        "28f57e774d91ce01e03ff65caa2313bc8786b66f"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Mar 14 18:33:49 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:21 2007 -0700"
      },
      "message": "[SPARC64]: Use DECLARE_BITMAP in struct pci_iommu.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "c6e87566ea080bbbe926c0e429fed48e6f680d93",
      "tree": "36d13a5bdef56329cd5be6eef1ada88fb7d8a802",
      "parents": [
        "0bba2dd823fd995ed805ae5cbd5a1c1381257a12"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Fri Mar 09 16:58:43 2007 -0800"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:18 2007 -0700"
      },
      "message": "[SPARC64]: Const\u0027ify pci_iommu_ops.\n\nBased upon a similar patch for x86_64 written by\nStephen Hemminger.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "0bba2dd823fd995ed805ae5cbd5a1c1381257a12",
      "tree": "ab88f46bcec15478b1effd3afbefcd133f26a8c7",
      "parents": [
        "3875c5c02d7112aa85f815d65d8add2e39ae9e34"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Mar 08 23:06:39 2007 -0800"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:17 2007 -0700"
      },
      "message": "[SPARC64]: Kill pbm-\u003epci_first_slot.\n\nSet but never used.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "3875c5c02d7112aa85f815d65d8add2e39ae9e34",
      "tree": "c2fe7a4800fc5f1e70d84a4c0da942de2aa9b30b",
      "parents": [
        "8d3aee937596d2ca6676c2c27789751445bf0bc9"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Mar 08 22:52:11 2007 -0800"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:16 2007 -0700"
      },
      "message": "[SPARC64]: Kill pci_controller-\u003epbms_same_domain\n\nWe don\u0027t do the \"Simba APB is a PBM\" bogosity for Sabre\ncontrollers any longer, so this pbms_same_domain thing\nis no longer necessary.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "8d3aee937596d2ca6676c2c27789751445bf0bc9",
      "tree": "b22a333a9947ab94d8c35c13b4989cde53630ac9",
      "parents": [
        "0bae5f81b6f8130f5197e59b0e2ad6820c766b2b"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Mar 08 22:46:02 2007 -0800"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:15 2007 -0700"
      },
      "message": "[SPARC64]: Kill pci_controller-\u003ebase_address_update().\n\nImplemented but never actually used.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "0bae5f81b6f8130f5197e59b0e2ad6820c766b2b",
      "tree": "e0a7f1e0018941ed6f76ea7ff97ec2506c14b899",
      "parents": [
        "3487a1f9e719d36c9b2d4d492994b2dd815a58b7"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Mar 08 22:42:19 2007 -0800"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:14 2007 -0700"
      },
      "message": "[SPARC64]: Kill pci_controller-\u003eresource_adjust()\n\nAll the implementations can be identical and generic, so\nno need for controller specific methods.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "3487a1f9e719d36c9b2d4d492994b2dd815a58b7",
      "tree": "34d5ef82a837ff61413a40fa9ce6d06a9bfbc65a",
      "parents": [
        "229177c7f38d6a2b1285b42da4b19d76346b4bac"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Mar 08 22:28:17 2007 -0800"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:13 2007 -0700"
      },
      "message": "[SPARC64]: Kill PBM ranges software state.\n\nIt is only used in one spot and we can just fetch the\nOF property right there.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "229177c7f38d6a2b1285b42da4b19d76346b4bac",
      "tree": "516b4586e3cf03722f35adc212c38f57dd94f212",
      "parents": [
        "9fd8b64761d3fe7e4ef567161be57e4234af5c1c"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Mar 08 22:11:00 2007 -0800"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:12 2007 -0700"
      },
      "message": "[SPARC64]: Kill PBM intmap software state.\n\nSet but never used.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "1e8a8cc52daa95e702303ca3ce67955a4c051d7d",
      "tree": "8008f55f6d3c3f83b8512e9f02aa864482271f37",
      "parents": [
        "a2fb23af1c31ad6e0c281e56d385f803229d57fa"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Feb 28 23:38:38 2007 -0800"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:07 2007 -0700"
      },
      "message": "[SPARC64]: Internalize pci_memspace_mask.\n\nThe only user was bus_dvma_to_mem() which is no longer used\nby any driver, so kill that, and the export of pci_memspace_mask.\n\nThe only user now is the PCI mmap support code.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "a2fb23af1c31ad6e0c281e56d385f803229d57fa",
      "tree": "9c093cd9cc639cfaac4e2b1057f5d45eb6ab69e3",
      "parents": [
        "deb66c4521e119442aa266553e8cbfc86eb71232"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Feb 28 23:35:04 2007 -0800"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:06 2007 -0700"
      },
      "message": "[SPARC64]: Probe PCI bus using OF device tree.\n\nAlmost entirely taken from the 64-bit PowerPC PCI code.\n\nThis allowed to eliminate a ton of cruft from the sparc64\nPCI layer.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "deb66c4521e119442aa266553e8cbfc86eb71232",
      "tree": "c98485097187792065b9f2968d9b6fc0e6ca3fae",
      "parents": [
        "1327e9b62fc88e64ffbbd42d61fccd34e521bb86"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Feb 28 18:01:38 2007 -0800"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:05 2007 -0700"
      },
      "message": "[SPARC64] isa: Convert to use pci_device_to_OF_node().\n\nAlso, do not try to compute resources by hand, instead use\nthe pre-computed ones in the of_device.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "1327e9b62fc88e64ffbbd42d61fccd34e521bb86",
      "tree": "23d7c52e9cdc86b519b7d2289fd18855493d2d7d",
      "parents": [
        "9b1caafe09ccec8e0103e9375b711e3a0c838260"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Feb 28 17:55:46 2007 -0800"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:55:04 2007 -0700"
      },
      "message": "[SPARC64] ebus: Convert to use pci_device_to_OF_node().\n\nAlso, we don\u0027t need to store or use the PBM so kill that\nfrom the linux_ebus.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "ded220bd8f0823771fc0a9bdf7f5bcbe543197b6",
      "tree": "530854859821c51cb3bcd9092140c535153627e5",
      "parents": [
        "357418e7cac16fed4ca558c6037d189d2109c9c2"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Mar 29 01:18:42 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:54:39 2007 -0700"
      },
      "message": "[STRING]: Move strcasecmp/strncasecmp to lib/string.c\n\nWe have several platforms using local copies of identical\ncode.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "357418e7cac16fed4ca558c6037d189d2109c9c2",
      "tree": "dcf8c149254c3fab546b866ded5cc547e33b855c",
      "parents": [
        "64b94701c0714f814e640ff351d5f784fdc0381e"
      ],
      "author": {
        "name": "Stephen Rothwell",
        "email": "sfr@canb.auug.org.au",
        "time": "Thu Mar 29 00:54:04 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:54:37 2007 -0700"
      },
      "message": "[SPARC]: constify some paramaters of OF routines\n\nThis starts bringing the PowerPC and Sparc implemetations back closer\ntogether.\n\nSigned-off-by: Stephen Rothwell \u003csfr@canb.auug.org.au\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "64b94701c0714f814e640ff351d5f784fdc0381e",
      "tree": "2bb66f86ccec74533e40042f60aafe8551cae991",
      "parents": [
        "3198514d2d10fb3ce5e49ba0c611764ad8a214d0"
      ],
      "author": {
        "name": "Stephen Rothwell",
        "email": "sfr@canb.auug.org.au",
        "time": "Thu Mar 29 00:53:28 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:54:35 2007 -0700"
      },
      "message": "[SPARC/64]: constify of_get_property return\n\nFinally, we actually change the functions themselves.\n\nSigned-off-by: Stephen Rothwell \u003csfr@canb.auug.org.au\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "66f3cb7ccfe6d735bd1fa435aebc9b985ac74e07",
      "tree": "ea615feb8a7a882e496d1b5c04f6c96244dd0ad2",
      "parents": [
        "ccf0dec6fcadb4e1c877b9bafb031a6bdb7112b9"
      ],
      "author": {
        "name": "Stephen Rothwell",
        "email": "sfr@canb.auug.org.au",
        "time": "Thu Mar 29 00:50:29 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:54:30 2007 -0700"
      },
      "message": "[SPARC64] constify of_get_property return: include\n\nSigned-off-by: Stephen Rothwell \u003csfr@canb.auug.org.au\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "112f48716d9f292c92a033cff9e3ce7405ed4280",
      "tree": "5be2952ca83adb519df5995c10e0686447fea88f",
      "parents": [
        "038cb01ea69cb24ecf30e3ec882e429c84badbeb"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Mon Mar 05 15:28:37 2007 -0800"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:54:15 2007 -0700"
      },
      "message": "[SPARC64]: Add clocksource/clockevents support.\n\nI\u0027d like to thank John Stul and others for helping\nme along the way.\n\nA lot of cleanups fell out of this.  For example, the get_compare()\ntick_op was totally unused, so was deleted.  And the most often used\ntick_op members were grouped together for cache-friendlyness.\n\nThe sparc64 TSC is given to the kernel as a one-shot timer.\n\ntick_ops-\u003einit_timer() simply turns off the privileged bit in\nthe tick register (when possible), and disables the interrupt\nby setting bit 63 in the compare register.  The -\u003edisable_irq()\nop also sets this bit.\n\ntick_ops-\u003eadd_compare() is changed to:\n\n1) Add the given delta to \"tick\" not to \"compare\"\n2) Return a boolean which, if true, means that the tick\n   value read after writing the compare value was found\n   to have incremented past the initial tick value.  This\n   mirrors logic used in the HPET driver\u0027s -\u003enext_event()\n   method.\n\nEach tick_ops implementation also now provides a name string.\nAnd we feed this into the clocksource and clockevents layers.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "777a447529ad138f5fceb9c9ad28bab19848f277",
      "tree": "d6fa75027b26d0b2d436cb0f8dc97c72f411b970",
      "parents": [
        "a58c9f3c1e929c3c323c26dbdafef46373a719d4"
      ],
      "author": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Feb 22 06:24:10 2007 -0800"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Thu Apr 26 01:54:11 2007 -0700"
      },
      "message": "[SPARC64]: Unify timer interrupt handler.\n\nThings were scattered all over the place, split between\nSMP and non-SMP.\n\nUnify it all so that dyntick support is easier to add.\n\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "48491e6bdb8fa73751cc95f740175ec799db5d55",
      "tree": "918ae1267a349136d44670bad9aa7326cb7ec715",
      "parents": [
        "c1a068f6b0c38665c079e8d4ca241e24020eff36"
      ],
      "author": {
        "name": "Robert P. J. Day",
        "email": "rpjday@mindspring.com",
        "time": "Thu Apr 26 00:59:27 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@davemloft.net",
        "time": "Thu Apr 26 00:59:27 2007 -0700"
      },
      "message": "[NET]: Delete unused header file linux/if_wanpipe_common.h\n\nDelete the unreferenced header file include/linux/if_wanpipe_common.h,\nas well as the reference to it in the Doc file.\n\nSigned-off-by: Robert P. J. Day \u003crpjday@mindspring.com\u003e\nSigned-off-by: Andrew Morton \u003cakpm@linux-foundation.org\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "c1a068f6b0c38665c079e8d4ca241e24020eff36",
      "tree": "7bd5490d3b391bed017d4f5643383f06e79550bd",
      "parents": [
        "42bad1da506cafa7041a02ab84033a724afe88ac"
      ],
      "author": {
        "name": "Robert P. J. Day",
        "email": "rpjday@mindspring.com",
        "time": "Thu Apr 26 00:58:39 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@davemloft.net",
        "time": "Thu Apr 26 00:58:39 2007 -0700"
      },
      "message": "[NET]: Delete unused header file linux/sdla_fr.h.\n\nDelete the unreferenced header file include/linux/sdla_fr.h.\n\nSigned-off-by: Robert P. J. Day \u003crpjday@mindspring.com\u003e\nSigned-off-by: Andrew Morton \u003cakpm@linux-foundation.org\u003e\n"
    },
    {
      "commit": "42bad1da506cafa7041a02ab84033a724afe88ac",
      "tree": "2850b3483c2fd05341c32663f4adb8f2ce7506da",
      "parents": [
        "55404bca6c45595fee1a546f1a0cc616aeef0b00"
      ],
      "author": {
        "name": "Adrian Bunk",
        "email": "bunk@stusta.de",
        "time": "Thu Apr 26 00:57:41 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@davemloft.net",
        "time": "Thu Apr 26 00:57:41 2007 -0700"
      },
      "message": "[NETLINK]: Possible cleanups.\n\n- make the following needlessly global variables static:\n  - core/rtnetlink.c: struct rtnl_msg_handlers[]\n  - netfilter/nf_conntrack_proto.c: struct nf_ct_protos[]\n- make the following needlessly global functions static:\n  - core/rtnetlink.c: rtnl_dump_all()\n  - netlink/af_netlink.c: netlink_queue_skip()\n\nSigned-off-by: Adrian Bunk \u003cbunk@stusta.de\u003e\nSigned-off-by: Andrew Morton \u003cakpm@linux-foundation.org\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "28d8909bc790d936ce33f4402adf7577533bbd4b",
      "tree": "8de479d6660aba23bc99fa555c150852548df58d",
      "parents": [
        "98486fa2f4894e2b01e325c659635596bdec1614"
      ],
      "author": {
        "name": "Jamal Hadi Salim",
        "email": "hadi@cyberus.ca",
        "time": "Thu Apr 26 00:10:29 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@davemloft.net",
        "time": "Thu Apr 26 00:10:29 2007 -0700"
      },
      "message": "[XFRM]: Export SAD info.\n\nOn a system with a lot of SAs, counting SAD entries chews useful\nCPU time since you need to dump the whole SAD to user space;\ni.e something like ip xfrm state ls | grep -i src | wc -l\nI have seen taking literally minutes on a 40K SAs when the system\nis swapping.\nWith this patch, some of the SAD info (that was already being tracked)\nis exposed to user space. i.e you do:\nip xfrm state count\nAnd you get the count; you can also pass -s to the command line and\nget the hash info.\n\nSigned-off-by: Jamal Hadi Salim \u003chadi@cyberus.ca\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "2111f8b9e58fd04b87b8b07d66485f255a57b0bb",
      "tree": "aaeb558abcc903e8d4960368e7a4650c4ef6f4e9",
      "parents": [
        "83aa0938ff59e8ef6d0b99260063ebe84fc84a16"
      ],
      "author": {
        "name": "Stephen Hemminger",
        "email": "shemminger@linux-foundation.org",
        "time": "Wed Apr 25 22:05:55 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:30:01 2007 -0700"
      },
      "message": "[BRIDGE]: drop PAUSE frames\n\nPause frames should never make it out of the network device into\nthe stack. But if a device was misconfigured, it might happen.\nSo drop pause frames in bridge.\n\nSigned-off-by: Stephen Hemminger \u003cshemminger@linux-foundation.org\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "df8981dc1928f3a231d91f27c2b3dc373fb4d410",
      "tree": "b55c3e7af5a5808fbbe5b6abf990315c04ff6030",
      "parents": [
        "5056a1ef9e2597cff7b15904fbc74193f316fc40"
      ],
      "author": {
        "name": "YOSHIFUJI Hideaki",
        "email": "yoshfuji@linux-ipv6.org",
        "time": "Tue Apr 24 20:44:49 2007 +0900"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:57 2007 -0700"
      },
      "message": "[IPV6]: Export in6addr_any for future use.\n\nSigned-off-by: YOSHIFUJI Hideaki \u003cyoshfuji@linux-ipv6.org\u003e\n"
    },
    {
      "commit": "7f7d9a6b96c5708c5184cbed61bbc15b163a0f08",
      "tree": "f6841ff1239e80c3083b1e41eb343b811dc92afc",
      "parents": [
        "5e0f04351d11e07a23b5ab4914282cbb78027e50"
      ],
      "author": {
        "name": "Herbert Xu",
        "email": "herbert@gondor.apana.org.au",
        "time": "Tue Apr 24 21:54:09 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:52 2007 -0700"
      },
      "message": "[IPV6]: Consolidate common SNMP code\n\nThis patch moves the non-proc SNMP code into addrconf.c and reuses\nIPv4 SNMP code where applicable.\n\nAs a result we can skip proc.o if /proc is disabled.\n\nNote that I\u0027ve made a number of functions static since they\u0027re only\nused by addrconf.c for now.  If they ever get used elsewhere we can\nalways remove the static.\n\nSigned-off-by: Herbert Xu \u003cherbert@gondor.apana.org.au\u003e\nAcked-by: YOSHIFUJI Hideaki \u003cyoshfuji@linux-ipv6.org\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "5e0f04351d11e07a23b5ab4914282cbb78027e50",
      "tree": "271fbed72ec607ecb8f7574a3b450aee1b0c8186",
      "parents": [
        "bb7ec6dfb5aa32b5b4d7d6388b4098b33cd01e8c"
      ],
      "author": {
        "name": "Herbert Xu",
        "email": "herbert@gondor.apana.org.au",
        "time": "Tue Apr 24 21:53:35 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:51 2007 -0700"
      },
      "message": "[IPV4]: Consolidate common SNMP code\n\nThis patch moves the SNMP code shared between IPv4/IPv6 from proc.c\ninto net/ipv4/af_inet.c.  This makes sense because these functions\naren\u0027t specific to /proc.\n\nAs a result we can again skip proc.o if /proc is disabled.\n\nSigned-off-by: Herbert Xu \u003cherbert@gondor.apana.org.au\u003e\nAcked-by: YOSHIFUJI Hideaki \u003cyoshfuji@linux-ipv6.org\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "84299b3bc4eaedc0734fcc9052b01291e44445fc",
      "tree": "a66254a9d648ec93334abbb058a376e7482e80d5",
      "parents": [
        "1f9eda7e2b67898fb8e79b3aa3880211b51235e6"
      ],
      "author": {
        "name": "YOSHIFUJI Hideaki",
        "email": "yoshfuji@linux-ipv6.org",
        "time": "Tue Apr 24 16:21:38 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:49 2007 -0700"
      },
      "message": "[TCP]: Fix linkage errors on i386.\n\nTo avoid raw division, use ktime_to_timeval() to get usec.\n\nSigned-off-by: YOSHIFUJI Hideaki \u003cyoshfuji@linux-ipv6.org\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "43fb45cb79e9441a79ece206cf741774500dd627",
      "tree": "203a30ae74da7408967e16d2329ebdfea5782e86",
      "parents": [
        "f9d106a6d53b57b78eae5544f9582c643343a764"
      ],
      "author": {
        "name": "Johannes Berg",
        "email": "johannes@sipsolutions.net",
        "time": "Tue Apr 24 14:07:27 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:48 2007 -0700"
      },
      "message": "[WIRELESS] cfg80211: Update comment for locking.\n\nThis patch adds a comment that was part of my rtnl locking patch for\ncfg80211 but which I forgot for the merge.\n\nSigned-off-by: Johannes Berg \u003cjohannes@sipsolutions.net\u003e\nSigned-off-by: John W. Linville \u003clinville@tuxdriver.com\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "164891aadf1721fca4dce473bb0e0998181537c6",
      "tree": "991393ec7306da475cb306fcc7cb084f737ebadc",
      "parents": [
        "65d1b4a7e73fe0e1f5275ad7d2d3547981480886"
      ],
      "author": {
        "name": "Stephen Hemminger",
        "email": "shemminger@linux-foundation.org",
        "time": "Mon Apr 23 22:26:16 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:45 2007 -0700"
      },
      "message": "[TCP]: Congestion control API update.\n\nDo some simple changes to make congestion control API faster/cleaner.\n* use ktime_t rather than timeval\n* merge rtt sampling into existing ack callback\n  this means one indirect call versus two per ack.\n* use flags bits to store options/settings\n\nSigned-off-by: Stephen Hemminger \u003cshemminger@linux-foundation.org\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "9e101eab153073d8a1fc7ea22b20af65de8ab44b",
      "tree": "fb438ff40a479b289ea8b92707f9a629fb6abbd0",
      "parents": [
        "704232c2718c9d4b3375ec15a14fc0397970c449"
      ],
      "author": {
        "name": "Johannes Berg",
        "email": "johannes@sipsolutions.net",
        "time": "Mon Apr 23 12:20:55 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:42 2007 -0700"
      },
      "message": "[WIRELESS]: Remove wext over netlink.\n\nAs scheduled, this patch removes the pointless wext over netlink code.\n\nSigned-off-by: Johannes Berg \u003cjohannes@sipsolutions.net\u003e\nSigned-off-by: John W. Linville \u003clinville@tuxdriver.com\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "704232c2718c9d4b3375ec15a14fc0397970c449",
      "tree": "6ffaa759ebaee36c4242bff6b7630f148efcaea3",
      "parents": [
        "2a5e1c0eb9efe26eed1dd072fe08de5797a7efd5"
      ],
      "author": {
        "name": "Johannes Berg",
        "email": "johannes@sipsolutions.net",
        "time": "Mon Apr 23 12:20:05 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:41 2007 -0700"
      },
      "message": "[WIRELESS] cfg80211: New wireless config infrastructure.\n\nThis patch creates the core cfg80211 code along with some sysfs bits.\nThis is a stripped down version to allow mac80211 to function, but\ndoesn\u0027t include any configuration yet except for creating and removing\nvirtual interfaces.\n\nThis patch includes the nl80211 header file but it only contains the\ninterface types which the cfg80211 interface for creating virtual\ninterfaces relies on.\n\nSigned-off-by: Johannes Berg \u003cjohannes@sipsolutions.net\u003e\nSigned-off-by: John W. Linville \u003clinville@tuxdriver.com\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "97fc8d0bc58cd09e62dc06ea5a64b58841738934",
      "tree": "d8e5c32caefe07161dbcb00bebba4c72089364e3",
      "parents": [
        "952a10be3272c4b5b7839b09cb0483dc72137101"
      ],
      "author": {
        "name": "YOSHIFUJI Hideaki",
        "email": "yoshfuji@linux-ipv6.org",
        "time": "Sat Apr 21 19:52:04 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:37 2007 -0700"
      },
      "message": "[IPV6] SNMP: Use put_unaligned() instead of memcpy().\n\nHint from David Miller \u003cdavem@davemloft.net\u003e.\n\nSigned-off-by: YOSHIFUJI Hideaki \u003cyoshfuji@linux-ipv6.org\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "2334e973559e119fa4161047035f03ad97a8676a",
      "tree": "0c01f78dac17f031ed39e262eea042c4381f9dd7",
      "parents": [
        "9e412ba7632f71259a53085665d4983b78257b7c"
      ],
      "author": {
        "name": "YOSHIFUJI Hideaki",
        "email": "yoshfuji@linux-ipv6.org",
        "time": "Sat Apr 21 20:12:43 2007 +0900"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:35 2007 -0700"
      },
      "message": "[IPV6] SNMP: Avoid unaligned accesses.\n\nBecause stats pointer may not be aligned for u64, use memcpy\nto fill u64 values.\nIssue reported by David Miller \u003cdavem@davemloft.net\u003e.\n\nSigned-off-by: YOSHIFUJI Hideaki \u003cyoshfuji@linux-ipv6.org\u003e\n"
    },
    {
      "commit": "9e412ba7632f71259a53085665d4983b78257b7c",
      "tree": "b02d6df7e5357a741bf6d52a93e04a52b84f1f90",
      "parents": [
        "38b4da383705394788aa09208917ba200792de4b"
      ],
      "author": {
        "name": "Ilpo Järvinen",
        "email": "ilpo.jarvinen@helsinki.fi",
        "time": "Fri Apr 20 22:18:02 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:34 2007 -0700"
      },
      "message": "[TCP]: Sed magic converts func(sk, tp, ...) -\u003e func(sk, ...)\n\nThis is (mostly) automated change using magic:\n\nsed -e \u0027/struct sock \\*sk/ N\u0027 -e \u0027/struct sock \\*sk/ N\u0027\n    -e \u0027/struct sock \\*sk/ N\u0027 -e \u0027/struct sock \\*sk/ N\u0027\n    -e \u0027s|struct sock \\*sk,[\\n\\t ]*struct tcp_sock \\*tp\\([^{]*\\n{\\n\\)|\n\t  struct sock \\*sk\\1\\tstruct tcp_sock *tp \u003d tcp_sk(sk);\\n|g\u0027\n    -e \u0027s|struct sock \\*sk, struct tcp_sock \\*tp|\n\t  struct sock \\*sk|g\u0027 -e \u0027s|sk, tp\\([^-]\\)|sk\\1|g\u0027\n\nFixed four unused variable (tp) warnings that were introduced.\n\nIn addition, manually added newlines after local variables and\ntweaked function arguments positioning.\n\n$ gcc --version\ngcc (GCC) 4.1.1 20060525 (Red Hat 4.1.1-1)\n...\n$ codiff -fV built-in.o.old built-in.o.new\nnet/ipv4/route.c:\n  rt_cache_flush |  +14\n 1 function changed, 14 bytes added\n\nnet/ipv4/tcp.c:\n  tcp_setsockopt |   -5\n  tcp_sendpage   |  -25\n  tcp_sendmsg    |  -16\n 3 functions changed, 46 bytes removed\n\nnet/ipv4/tcp_input.c:\n  tcp_try_undo_recovery |   +3\n  tcp_try_undo_dsack    |   +2\n  tcp_mark_head_lost    |  -12\n  tcp_ack               |  -15\n  tcp_event_data_recv   |  -32\n  tcp_rcv_state_process |  -10\n  tcp_rcv_established   |   +1\n 7 functions changed, 6 bytes added, 69 bytes removed, diff: -63\n\nnet/ipv4/tcp_output.c:\n  update_send_head          |   -9\n  tcp_transmit_skb          |  +19\n  tcp_cwnd_validate         |   +1\n  tcp_write_wakeup          |  -17\n  __tcp_push_pending_frames |  -25\n  tcp_push_one              |   -8\n  tcp_send_fin              |   -4\n 7 functions changed, 20 bytes added, 63 bytes removed, diff: -43\n\nbuilt-in.o.new:\n 18 functions changed, 40 bytes added, 178 bytes removed, diff: -138\n\nSigned-off-by: Ilpo Järvinen \u003cilpo.jarvinen@helsinki.fi\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "9958089a43ae8a9af07402461c0b2b7548c7341e",
      "tree": "6d07cf01f9f6cc647dd6b01d0a16757f025845f8",
      "parents": [
        "4ac02bab77438b484a5cf855a002fb6a1d592894"
      ],
      "author": {
        "name": "Andi Kleen",
        "email": "ak@suse.de",
        "time": "Fri Apr 20 17:12:43 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:26 2007 -0700"
      },
      "message": "[NET]: Move sk_setup_caps() out of line.\n\nIt is far too large to be an inline and not in any hot paths.\n\nSigned-off-by: Andi Kleen \u003cak@suse.de\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "4ac02bab77438b484a5cf855a002fb6a1d592894",
      "tree": "8a7442a9c9fa39e147eca0f0728a0691712b191a",
      "parents": [
        "3ff50b7997fe06cd5d276b229967bb52d6b3b6c1"
      ],
      "author": {
        "name": "Andi Kleen",
        "email": "ak@suse.de",
        "time": "Fri Apr 20 17:11:46 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:25 2007 -0700"
      },
      "message": "[TCP]: Uninline tcp_done().\n\nThe function is quite big and has several call sites and nothing\nto collapse by compiler optimization on inlining.\n\nBesides it\u0027s nicer to read in a in .c file.\n\nSigned-off-by: Andi Kleen \u003cak@suse.de\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "0c6fcc8a8cfcc737d05b6be8b2c3e931ef99cfc2",
      "tree": "53da0c434b22dba352d34c01b50154a4ce23e564",
      "parents": [
        "3e6cf558b0098a15d8c360c4eaad3e4d719a555a"
      ],
      "author": {
        "name": "Stephen Hemminger",
        "email": "shemminger@linux-foundation.org",
        "time": "Fri Apr 20 16:40:01 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:17 2007 -0700"
      },
      "message": "[NET] skbuff: skb_store_bits const is backwards\n\nGetting warnings becuase skb_store_bits has skb as constant,\nbut the function overwrites it. Looks like const was on the\nwrong side.\n\nSigned-off-by: Stephen Hemminger \u003cshemminger@linux-foundation.org\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "80feaacb8a6400a9540a961b6743c69a5896b937",
      "tree": "a4f07e635de521f5e283e0f4081923a98c0256d5",
      "parents": [
        "1370b5a59b941ac3873b5e8614d496e9f481d670"
      ],
      "author": {
        "name": "Peter P. Waskiewicz Jr",
        "email": "peter.p.waskiewicz.jr@intel.com",
        "time": "Fri Apr 20 16:05:39 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:14 2007 -0700"
      },
      "message": "[AF_PACKET]: Add option to return orig_dev to userspace.\n\nAdd a packet socket option to allow the orig_dev index to be returned\nto userspace when passing traffic through a decapsulated device, such\nas the bonding driver.\n\nThis is very useful for layer 2 traffic being able to report which\nphysical device actually received the traffic, instead of having the\nencapsulating device hide that information.\n\nThe new option is called PACKET_ORIGDEV.\n\nSigned-off-by: Peter P. Waskiewicz Jr. \u003cpeter.p.waskiewicz.jr@intel.com\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "334901700f9f58993ebd7f6136d3f9062460d34d",
      "tree": "af1887c408d6757debd73d2e56d45039943e413b",
      "parents": [
        "49ed67a9eee3c756263feed4474e4fcf5c8eaed2"
      ],
      "author": {
        "name": "YOSHIFUJI Hideaki",
        "email": "yoshfuji@linux-ipv6.org",
        "time": "Fri Apr 20 15:57:15 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:12 2007 -0700"
      },
      "message": "[IPV4] SNMP: Move some statistic bits to net/ipv4/proc.c.\n\nThis also fixes memory leak in error path.\n\nSigned-off-by: YOSHIFUJI Hideaki \u003cyoshfuji@linux-ipv6.org\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "bf99f1bde3b3009af74874f3465f6861431fbb66",
      "tree": "ec3ee5ca8e95e090d65671d74994b7729058c845",
      "parents": [
        "628a5c561890a9a9a74dea017873530584aab06e"
      ],
      "author": {
        "name": "YOSHIFUJI Hideaki",
        "email": "yoshfuji@linux-ipv6.org",
        "time": "Fri Apr 20 15:56:20 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:10 2007 -0700"
      },
      "message": "[IPV6] SNMP: Netlink interface.\n\nSigned-off-by: YOSHIFUJI Hideaki \u003cyoshfuji@linux-ipv6.org\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "628a5c561890a9a9a74dea017873530584aab06e",
      "tree": "f10edc4078c3f19487bbe3a902ecadda89273361",
      "parents": [
        "b881ef7603230550aa0150b22af94089f07ab00d"
      ],
      "author": {
        "name": "John Heffner",
        "email": "jheffner@psc.edu",
        "time": "Fri Apr 20 15:53:27 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:10 2007 -0700"
      },
      "message": "[INET]: Add IP(V6)_PMTUDISC_RPOBE\n\nAdd IP(V6)_PMTUDISC_PROBE value for IP(V6)_MTU_DISCOVER.  This option forces\nus not to fragment, but does not make use of the kernel path MTU discovery.\nThat is, it allows for user-mode MTU probing (or, packetization-layer path\nMTU discovery).  This is particularly useful for diagnostic utilities, like\ntraceroute/tracepath.\n\nSigned-off-by: John Heffner \u003cjheffner@psc.edu\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "0463d4ae25771aaf3379bb6b2392f6edf23c2828",
      "tree": "5c820b718abfe086a7b1d91814cb99d721439a46",
      "parents": [
        "ffa4d7216e848fbfdcb8e6f0bb66abeaa1888964"
      ],
      "author": {
        "name": "Patrick McHardy",
        "email": "kaber@trash.net",
        "time": "Mon Apr 16 17:02:10 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:07 2007 -0700"
      },
      "message": "[NET_SCHED]: Eliminate qdisc_tree_lock\n\nSince we\u0027re now holding the rtnl during the entire dump operation, we\ncan remove qdisc_tree_lock, whose only purpose is to protect dump\ncallbacks from concurrent changes to the qdisc tree.\n\nSigned-off-by: Patrick McHardy \u003ckaber@trash.net\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "af65bdfce98d7965fbe93a48b8128444a2eea024",
      "tree": "e6ac5ff82a0d5067213135cdf049b912b02e824d",
      "parents": [
        "b076deb8498e26c9aa2f44046fe5e9936ae2fb5a"
      ],
      "author": {
        "name": "Patrick McHardy",
        "email": "kaber@trash.net",
        "time": "Fri Apr 20 14:14:21 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:29:03 2007 -0700"
      },
      "message": "[NETLINK]: Switch cb_lock spinlock to mutex and allow to override it\n\nSwitch cb_lock to mutex and allow netlink kernel users to override it\nwith a subsystem specific mutex for consistent locking in dump callbacks.\nAll netlink_dump_start users have been audited not to rely on any\nside-effects of the previously used spinlock.\n\nSigned-off-by: Patrick McHardy \u003ckaber@trash.net\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "c15bf6e699f4c366f2d1e19ac5d7add21c6b5a19",
      "tree": "2bcd680115a8b07cd6d7493b134ae2d36fe637be",
      "parents": [
        "516299d2f5b6f9703b9b388faf91898dc636a678"
      ],
      "author": {
        "name": "Bart De Schuymer",
        "email": "bdschuym@pandora.be",
        "time": "Thu Apr 12 22:15:06 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:28:58 2007 -0700"
      },
      "message": "[NETFILTER]: ebt_arp: add gratuitous arp filtering\n\nThe attached patch adds gratuitous arp filtering, more precisely: it\nallows checking that the IPv4 source address matches the IPv4\ndestination address inside the ARP header. It also adds a check for the\nhardware address type when matching MAC addresses (nothing critical,\njust for better consistency).\n\nSigned-off-by: Bart De Schuymer \u003cbdschuym@pandora.be\u003e\nAcked-by: Carl-Daniel Hailfinger \u003cc-d.hailfinger.devel.2006@gmx.net\u003e\nSigned-off-by: Patrick McHardy \u003ckaber@trash.net\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "516299d2f5b6f9703b9b388faf91898dc636a678",
      "tree": "909b7003188f0f100e0782c9620515e39cba1603",
      "parents": [
        "91d73c15cb165195bc8c3d6a35e30df454b1485b"
      ],
      "author": {
        "name": "Michael Milner",
        "email": "milner@blissisland.ca",
        "time": "Thu Apr 12 22:14:23 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:28:57 2007 -0700"
      },
      "message": "[NETFILTER]: bridge-nf: filter bridged IPv4/IPv6 encapsulated in pppoe traffic\n\nThe attached patch by Michael Milner adds support for using iptables and\nip6tables on bridged traffic encapsulated in ppoe frames, similar to\nwhat\u0027s already supported for vlan.\n\nSigned-off-by: Michael Milner \u003cmilner@blissisland.ca\u003e\nSigned-off-by: Bart De Schuymer \u003cbdschuym@pandora.be\u003e\nSigned-off-by: Patrick McHardy \u003ckaber@trash.net\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "91d73c15cb165195bc8c3d6a35e30df454b1485b",
      "tree": "3e32716861f8784f635d482a187d4a5fda25658f",
      "parents": [
        "f73f7097c986aab159491dcded7fc918e76e9ec3"
      ],
      "author": {
        "name": "Gerrit Renker",
        "email": "gerrit@erg.abdn.ac.uk",
        "time": "Fri Apr 20 13:57:21 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:28:56 2007 -0700"
      },
      "message": "[DCCP]: Complete documentation of dccp_sock\n\nThis fills in missing documentation for dccp_sock fields.\n\nSigned-off-by: Gerrit Renker \u003cgerrit@erg.abdn.ac.uk\u003e\nSigned-off-by: Ian McDonald \u003cian.mcdonald@jandi.co.nz\u003e\nSigned-off-by: Arnaldo Carvalho de Melo \u003cacme@ghostprotocols.net\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n"
    },
    {
      "commit": "6229e362dd49b9e8387126bd4483ab0574d23e9c",
      "tree": "425c24858a6d21e58e49c05655875237d9b37a7c",
      "parents": [
        "604763722c655c7e3f31ecf6f7b4dafcd26a7a15"
      ],
      "author": {
        "name": "Stephen Hemminger",
        "email": "shemminger@osdl.org",
        "time": "Wed Mar 21 13:38:47 2007 -0700"
      },
      "committer": {
        "name": "David S. Miller",
        "email": "davem@sunset.davemloft.net",
        "time": "Wed Apr 25 22:28:44 2007 -0700"
      },
      "message": "bridge: eliminate call by reference\n\nChange the bridging hook to be simple function with return value\nrather than modifying the skb argument. This could generate better\ncode and is cleaner.\n\nSigned-off-by: Stephen Hemminger \u003cshemminger@linux-foundation.org\u003e\n"
    }
  ],
  "next": "604763722c655c7e3f31ecf6f7b4dafcd26a7a15"
}
