[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Xen-devel] [linux-3.10 bisection] complete test-amd64-amd64-pv



branch xen-unstable
xen branch xen-unstable
job test-amd64-amd64-pv
test leak-check/check

Tree: linux git://xenbits.xen.org/linux-pvops.git
Tree: linuxfirmware git://xenbits.xen.org/osstest/linux-firmware.git
Tree: qemu git://xenbits.xen.org/staging/qemu-xen-unstable.git
Tree: qemuu git://xenbits.xen.org/staging/qemu-upstream-unstable.git
Tree: xen git://xenbits.xen.org/xen.git

*** Found and reproduced problem changeset ***

  Bug is in tree:  linux git://xenbits.xen.org/linux-pvops.git
  Bug introduced:  f495ddc46f97dd0054ff2d5d3c7493d59f7511fb
  Bug not present: b9396c4c9e7f499b1dd8080e901c88705f2efa99


  commit f495ddc46f97dd0054ff2d5d3c7493d59f7511fb
  Author: Paul Durrant <paul.durrant@xxxxxxxxxx>
  Date:   Tue Oct 8 14:22:56 2013 +0100
  
      xen-netback: Don't destroy the netdev until the vif is shut down
      
      [ upstream commit id: 279f438e36c0a70b23b86d2090aeec50155034a9 ]
      
      Without this patch, if a frontend cycles through states Closing
      and Closed (which Windows frontends need to do) then the netdev
      will be destroyed and requires re-invocation of hotplug scripts
      to restore state before the frontend can move to Connected. Thus
      when udev is not in use the backend gets stuck in InitWait.
      
      With this patch, the netdev is left alone whilst the backend is
      still online and is only de-registered and freed just prior to
      destroying the vif (which is also nicely symmetrical with the
      netdev allocation and registration being done during probe) so
      no re-invocation of hotplug scripts is required.
      
      Signed-off-by: Paul Durrant <paul.durrant@xxxxxxxxxx>
      Cc: David Vrabel <david.vrabel@xxxxxxxxxx>
      Cc: Wei Liu <wei.liu2@xxxxxxxxxx>
      Cc: Ian Campbell <ian.campbell@xxxxxxxxxx>
      Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>


For bisection revision-tuple graph see:
   
http://www.chiark.greenend.org.uk/~xensrcts/results/bisect.linux-3.10.test-amd64-amd64-pv.leak-check--check.html
Revision IDs in each graph node refer, respectively, to the Trees above.

----------------------------------------
Searching for failure / basis pass:
 21573 fail [host=lace-bug] / 21026 [host=lake-frog] 21016 [host=potato-beetle] 
21013 [host=woodlouse] 20866 [host=lake-frog] 20857 [host=gall-mite] 20093 
[host=gall-mite] 20090 [host=earwig] 20064 [host=leaf-beetle] 20056 
[host=woodlouse] 19839 [host=fire-frog] 19696 [host=itch-mite] 19691 
[host=fire-frog] 19677 [host=grain-weevil] 19579 [host=rice-weevil] 19499 
[host=woodlouse] 19303 [host=earwig] 19157 [host=earwig] 19152 [host=woodlouse] 
18962 [host=fire-frog] 18944 [host=leaf-beetle] 18933 [host=gall-mite] 18886 
[host=bush-cricket] 18860 [host=potato-beetle] 18855 [host=earwig] 18850 ok.
Failure / basis pass flights: 21573 / 18850
Tree: linux git://xenbits.xen.org/linux-pvops.git
Tree: linuxfirmware git://xenbits.xen.org/osstest/linux-firmware.git
Tree: qemu git://xenbits.xen.org/staging/qemu-xen-unstable.git
Tree: qemuu git://xenbits.xen.org/staging/qemu-upstream-unstable.git
Tree: xen git://xenbits.xen.org/xen.git
Latest 4e77f7f1261f65cff06918bc5e66d02a418fc842 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
ac6e1ae87b229f452fa5859bf95dc51459eaeb68
Basis pass 0a4b6d4ff200a553951f77f765971cb3e4c91ec0 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
7483e7f15139603380c45ebcd8cc2a57dda5583c 
8a7769b4453168e23e8935a85e9a875ef5117253
Generating revisions with ./adhoc-revtuple-generator  
git://xenbits.xen.org/linux-pvops.git#0a4b6d4ff200a553951f77f765971cb3e4c91ec0-4e77f7f1261f65cff06918bc5e66d02a418fc842
 
git://xenbits.xen.org/osstest/linux-firmware.git#c530a75c1e6a472b0eb9558310b518f0dfcd8860-c530a75c1e6a472b0eb9558310b518f0dfcd8860
 
git://xenbits.xen.org/staging/qemu-xen-unstable.git#84411871262363200e70fa087d7b21647091a450-84411871262363200e70fa087d7b21647091a450
 
git://xenbits.xen.org/staging/qemu-upstream-unstable.git#7483e7f15139603380c45ebcd8cc2a57dda5583c-8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3
 
git://xenbits.xen.org/xen.git#8a7769b4453168e23e8935a85e9a875ef5117253-ac6e1ae87b229f452fa5859bf95dc51459eaeb68
using cache /export/home/osstest/repos/git-cache...
using cache /export/home/osstest/repos/git-cache...
locked cache /export/home/osstest/repos/git-cache...
processing ./cacheing-git clone --bare git://xenbits.xen.org/linux-pvops.git 
/export/home/osstest/repos/linux-pvops...
Initialized empty Git repository in /export/home/osstest/repos/linux-pvops/
updating cache /export/home/osstest/repos/git-cache linux-pvops...
using cache /export/home/osstest/repos/git-cache...
using cache /export/home/osstest/repos/git-cache...
locked cache /export/home/osstest/repos/git-cache...
processing ./cacheing-git clone --bare 
git://xenbits.xen.org/staging/qemu-upstream-unstable.git 
/export/home/osstest/repos/qemu-upstream-unstable...
Initialized empty Git repository in 
/export/home/osstest/repos/qemu-upstream-unstable/
updating cache /export/home/osstest/repos/git-cache qemu-upstream-unstable...
using cache /export/home/osstest/repos/git-cache...
using cache /export/home/osstest/repos/git-cache...
locked cache /export/home/osstest/repos/git-cache...
processing ./cacheing-git clone --bare git://xenbits.xen.org/xen.git 
/export/home/osstest/repos/xen...
Initialized empty Git repository in /export/home/osstest/repos/xen/
updating cache /export/home/osstest/repos/git-cache xen...
using cache /export/home/osstest/repos/git-cache...
using cache /export/home/osstest/repos/git-cache...
locked cache /export/home/osstest/repos/git-cache...
processing ./cacheing-git clone --bare git://xenbits.xen.org/linux-pvops.git 
/export/home/osstest/repos/linux-pvops...
Initialized empty Git repository in /export/home/osstest/repos/linux-pvops/
updating cache /export/home/osstest/repos/git-cache linux-pvops...
using cache /export/home/osstest/repos/git-cache...
using cache /export/home/osstest/repos/git-cache...
locked cache /export/home/osstest/repos/git-cache...
processing ./cacheing-git clone --bare 
git://xenbits.xen.org/staging/qemu-upstream-unstable.git 
/export/home/osstest/repos/qemu-upstream-unstable...
Initialized empty Git repository in 
/export/home/osstest/repos/qemu-upstream-unstable/
updating cache /export/home/osstest/repos/git-cache qemu-upstream-unstable...
using cache /export/home/osstest/repos/git-cache...
using cache /export/home/osstest/repos/git-cache...
locked cache /export/home/osstest/repos/git-cache...
processing ./cacheing-git clone --bare git://xenbits.xen.org/xen.git 
/export/home/osstest/repos/xen...
Initialized empty Git repository in /export/home/osstest/repos/xen/
updating cache /export/home/osstest/repos/git-cache xen...
Loaded 4398 nodes in revision graph
Searching for test results:
 18860 [host=potato-beetle]
 18850 pass 0a4b6d4ff200a553951f77f765971cb3e4c91ec0 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
7483e7f15139603380c45ebcd8cc2a57dda5583c 
8a7769b4453168e23e8935a85e9a875ef5117253
 18855 [host=earwig]
 18933 [host=gall-mite]
 18886 [host=bush-cricket]
 18962 [host=fire-frog]
 18944 [host=leaf-beetle]
 19152 [host=woodlouse]
 19157 [host=earwig]
 19303 [host=earwig]
 19499 [host=woodlouse]
 19579 [host=rice-weevil]
 19691 [host=fire-frog]
 19677 [host=grain-weevil]
 19696 [host=itch-mite]
 19839 [host=fire-frog]
 19895 []
 19907 []
 19961 []
 20056 [host=woodlouse]
 20064 [host=leaf-beetle]
 20090 [host=earwig]
 20093 [host=gall-mite]
 20857 [host=gall-mite]
 20866 [host=lake-frog]
 21013 [host=woodlouse]
 21026 [host=lake-frog]
 21016 [host=potato-beetle]
 21423 fail irrelevant
 21415 fail irrelevant
 21443 fail 4e77f7f1261f65cff06918bc5e66d02a418fc842 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
68bd172e6fa565899c846eb72755c8ffd8562c8a
 21490 fail 4e77f7f1261f65cff06918bc5e66d02a418fc842 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
68bd172e6fa565899c846eb72755c8ffd8562c8a
 21516 fail 4e77f7f1261f65cff06918bc5e66d02a418fc842 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
6f366e276264f61b752d9eea63c42021b8fffec6
 21480 fail 4e77f7f1261f65cff06918bc5e66d02a418fc842 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
68bd172e6fa565899c846eb72755c8ffd8562c8a
 21498 fail 4e77f7f1261f65cff06918bc5e66d02a418fc842 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
6f366e276264f61b752d9eea63c42021b8fffec6
 21526 fail 4e77f7f1261f65cff06918bc5e66d02a418fc842 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
11662fa1a92f2d9d9cfaff7b041e0f4180d86566
 21538 fail 4e77f7f1261f65cff06918bc5e66d02a418fc842 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
11662fa1a92f2d9d9cfaff7b041e0f4180d86566
 21574 pass b9396c4c9e7f499b1dd8080e901c88705f2efa99 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
2c24cdcce3269f3286790c63821951a1de93c66a
 21576 fail f495ddc46f97dd0054ff2d5d3c7493d59f7511fb 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
2c24cdcce3269f3286790c63821951a1de93c66a
 21549 pass 0a4b6d4ff200a553951f77f765971cb3e4c91ec0 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
7483e7f15139603380c45ebcd8cc2a57dda5583c 
8a7769b4453168e23e8935a85e9a875ef5117253
 21577 pass b9396c4c9e7f499b1dd8080e901c88705f2efa99 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
2c24cdcce3269f3286790c63821951a1de93c66a
 21551 fail 4e77f7f1261f65cff06918bc5e66d02a418fc842 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
11662fa1a92f2d9d9cfaff7b041e0f4180d86566
 21578 fail f495ddc46f97dd0054ff2d5d3c7493d59f7511fb 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
2c24cdcce3269f3286790c63821951a1de93c66a
 21552 pass cac65253a9c5a30d4c8d7bc4c60197935f9e2e70 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
1dc5178097e62fc7137cf17cd16628675f0b5ee1
 21554 pass d6e770beb3489067fc68e0d468c99f0e44a42052 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
7483e7f15139603380c45ebcd8cc2a57dda5583c 
1aac966e24e92d664089cfa075f21bbb570a7d58
 21579 pass b9396c4c9e7f499b1dd8080e901c88705f2efa99 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
2c24cdcce3269f3286790c63821951a1de93c66a
 21555 pass c9b391f6d166118c5543e9d1708e67977dbdbe1f 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
1a510f3c447452006fa2a661b387fdc5410c41d5
 21573 fail 4e77f7f1261f65cff06918bc5e66d02a418fc842 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
ac6e1ae87b229f452fa5859bf95dc51459eaeb68
 21550 fail 4e77f7f1261f65cff06918bc5e66d02a418fc842 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
11662fa1a92f2d9d9cfaff7b041e0f4180d86566
 21556 pass b56e88e25e1d576619343e97fdb6cbe11035cf6d 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
06afffeffd7a7da83b17ff7f49979d56bbdf6710
 21580 fail f495ddc46f97dd0054ff2d5d3c7493d59f7511fb 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
2c24cdcce3269f3286790c63821951a1de93c66a
 21559 pass 14e9c7db465387ede7f019c42f28c90f99fc2793 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
f2f06a2f1b42d27dccf08d8ff887c96608b8c6b7
 21561 fail 30983d3c66572348f078fe2e2d55638d73c3e486 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
2c24cdcce3269f3286790c63821951a1de93c66a
 21562 pass bd83cd77073e5c54a88f976d6d6c785a1a80b0c0 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
2c24cdcce3269f3286790c63821951a1de93c66a
 21563 fail f495ddc46f97dd0054ff2d5d3c7493d59f7511fb 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
2c24cdcce3269f3286790c63821951a1de93c66a
 21558 fail 4e77f7f1261f65cff06918bc5e66d02a418fc842 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
ac6e1ae87b229f452fa5859bf95dc51459eaeb68
 21564 pass 2e8d97ab1f1236d08a8576d5c4b25d3180ff01f6 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
2c24cdcce3269f3286790c63821951a1de93c66a
 21566 pass 0a4b6d4ff200a553951f77f765971cb3e4c91ec0 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
7483e7f15139603380c45ebcd8cc2a57dda5583c 
8a7769b4453168e23e8935a85e9a875ef5117253
 21569 fail 4e77f7f1261f65cff06918bc5e66d02a418fc842 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
ac6e1ae87b229f452fa5859bf95dc51459eaeb68
 21571 pass b15e22da6eb11f54ef53bec9b9e9adbc4fba1609 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
2c24cdcce3269f3286790c63821951a1de93c66a
 21565 fail 4e77f7f1261f65cff06918bc5e66d02a418fc842 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
ac6e1ae87b229f452fa5859bf95dc51459eaeb68
 21572 pass 42fc155b9fe58a8885b76136ebdb7b5e376740b6 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
2c24cdcce3269f3286790c63821951a1de93c66a
Searching for interesting versions
 Result found: flight 18850 (pass), for basis pass
 Result found: flight 21558 (fail), for basis failure
 Repro found: flight 21566 (pass), for basis pass
 Repro found: flight 21569 (fail), for basis failure
 0 revisions at b9396c4c9e7f499b1dd8080e901c88705f2efa99 
c530a75c1e6a472b0eb9558310b518f0dfcd8860 
84411871262363200e70fa087d7b21647091a450 
8a4bd762aa01b21c43aa24c5b743f4bd7c9db3e3 
2c24cdcce3269f3286790c63821951a1de93c66a
No revisions left to test, checking graph state.
 Result found: flight 21574 (pass), for last pass
 Result found: flight 21576 (fail), for first failure
 Repro found: flight 21577 (pass), for last pass
 Repro found: flight 21578 (fail), for first failure
 Repro found: flight 21579 (pass), for last pass
 Repro found: flight 21580 (fail), for first failure

*** Found and reproduced problem changeset ***

  Bug is in tree:  linux git://xenbits.xen.org/linux-pvops.git
  Bug introduced:  f495ddc46f97dd0054ff2d5d3c7493d59f7511fb
  Bug not present: b9396c4c9e7f499b1dd8080e901c88705f2efa99

using cache /export/home/osstest/repos/git-cache...
using cache /export/home/osstest/repos/git-cache...
locked cache /export/home/osstest/repos/git-cache...
processing ./cacheing-git clone --bare git://xenbits.xen.org/linux-pvops.git 
/export/home/osstest/repos/linux-pvops...
Initialized empty Git repository in /export/home/osstest/repos/linux-pvops/
updating cache /export/home/osstest/repos/git-cache linux-pvops...

  commit f495ddc46f97dd0054ff2d5d3c7493d59f7511fb
  Author: Paul Durrant <paul.durrant@xxxxxxxxxx>
  Date:   Tue Oct 8 14:22:56 2013 +0100
  
      xen-netback: Don't destroy the netdev until the vif is shut down
      
      [ upstream commit id: 279f438e36c0a70b23b86d2090aeec50155034a9 ]
      
      Without this patch, if a frontend cycles through states Closing
      and Closed (which Windows frontends need to do) then the netdev
      will be destroyed and requires re-invocation of hotplug scripts
      to restore state before the frontend can move to Connected. Thus
      when udev is not in use the backend gets stuck in InitWait.
      
      With this patch, the netdev is left alone whilst the backend is
      still online and is only de-registered and freed just prior to
      destroying the vif (which is also nicely symmetrical with the
      netdev allocation and registration being done during probe) so
      no re-invocation of hotplug scripts is required.
      
      Signed-off-by: Paul Durrant <paul.durrant@xxxxxxxxxx>
      Cc: David Vrabel <david.vrabel@xxxxxxxxxx>
      Cc: Wei Liu <wei.liu2@xxxxxxxxxx>
      Cc: Ian Campbell <ian.campbell@xxxxxxxxxx>
      Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>

dot: height (61099 >= 32768) is too large.
----------------------------------------
21580: tolerable ALL FAIL

flight 21580 linux-3.10 real-bisect [real]
http://www.chiark.greenend.org.uk/~xensrcts/logs/21580/

Failures :-/ but no regressions.

Tests which did not succeed,
including tests which could not be run:
 test-amd64-amd64-pv          18 leak-check/check        fail baseline untested


jobs:
 test-amd64-amd64-pv                                          fail    


------------------------------------------------------------
sg-report-flight on woking.cam.xci-test.com
logs: /home/xc_osstest/logs
images: /home/xc_osstest/images

Logs, config files, etc. are available at
    http://www.chiark.greenend.org.uk/~xensrcts/logs

Test harness code can be found at
    http://xenbits.xensource.com/gitweb?p=osstest.git;a=summary


_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.