#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
using namespace std;
using namespace __gnu_pbds;
typedef long long ll;
typedef unsigned long long ull;
#define output(v) for(auto&it:v){cout<<it<<" ";}cout<<"\n"
#define input(v) for(auto&it:v){cin>>it;}
#define ordered_set tree<int, null_type,less<int>, rb_tree_tag,tree_order_statistics_node_update>
const int N = 1e6+5;
const int MOD = 1e9+7;
const double pi= 3.1415926535897932;
//======================================================
void FastCode()
{
std::ios_base::sync_with_stdio(0);
cin.tie(NULL);
cout.tie(NULL);
}
//======================================================
struct DSU{
vector<int> parent;
vector<int> sizeOfGroup;
DSU(int N){
parent.resize(N+5);
sizeOfGroup.resize(N+5);
for(int i = 0 ; i < N ; i++){
parent[i] = i;
sizeOfGroup[i] = 1;
}
}
ll getLeader(int i){
if(i == parent[i]) return i;
else return parent[i] = getLeader(parent[i]);
}
bool sameGroup(int x , int y){
return getLeader(x) == getLeader(y);
}
void mergeGroup(int x , int y){
int leader1 = getLeader(x);
int leader2 = getLeader(y);
if(leader1 == leader2) return;
else if(sizeOfGroup[leader1]>sizeOfGroup[leader2]){
parent[leader2] = leader1;
sizeOfGroup[leader1]+=sizeOfGroup[leader2];
}else{
parent[leader1] = leader2;
sizeOfGroup[leader2]+=sizeOfGroup[leader1];
}
}
int getSize(int x){
return sizeOfGroup[getLeader(x)];
}
};
//======================================================
struct FenwickTree{
vector<ll> arr;
int n;
FenwickTree(int N){
n=N;
arr.resize(N+5);
}
void update(ll idx , ll val){
while(idx < n+5){
arr[idx]+=val;
idx += idx&-idx;
}
}
ll sum(ll idx){
ll s=0;
while(idx){
s+=arr[idx];
idx -= idx&-idx;
}
return s;
}
ll sum(ll l , ll r){
return sum(r)-sum(l-1);
}
ll get(int idx){
return sum(idx)-sum(idx-1);
}
};
//======================================================
struct SegmentTreeRangeSum{
int size;
vector<ll> arr;
SegmentTreeRangeSum(vector<ll> &a){
size = 1;
int n = a.size();
while(size < n) size *= 2;
arr.assign(size*2 , 0ll);
build( a,0,0,size);
}
void build(vector<ll> &a , int x , int lx , int rx){
if(rx-lx == 1){
if(lx < a.size()) arr[x] = a[lx];
return;
}
int md = (lx+rx)>>1;
build(a , 2*x+1 , lx , md);
build(a , 2*x+2 , md , rx);
arr[x] = arr[2*x+1] + arr[2*x+2];
}
void set(int idx , int val , int x , int lx , int rx){
if(rx-lx == 1){
arr[x] = val;
return;
}
int md = (lx+rx)>>1;
if(idx < md){
set(idx , val , 2*x+1 , lx ,md);
}else{
set(idx , val , 2*x+2 , md ,rx);
}
arr[x] = arr[2*x+1] + arr[2*x+2];
}
void set(int idx , ll val){
set(idx , val , 0 , 0 , size);
}
ll sum(int l , int r, int cur , int lx , int rx){
if(lx >= r || l >= rx) return 0;
else if(lx >= l && r >= rx) return arr[cur];
int md = (lx+rx)>>1;
return sum(l , r , 2*cur+1 , lx , md) + sum(l , r , 2*cur+2 , md , rx);
}
ll sum(int l , int r){
return sum(l , r , 0 , 0 , size);
}
};
//======================================================
struct SegmentTreeMinVal{
int size;
vector<pair<ll , int>> tree;
SegmentTreeMinVal(int n){
size = 1;
while(size < n) size *= 2;
tree.assign(2*size-1 , {LLONG_MAX , 1});
}
void insert(int idx , ll val , int x , int lx , int rx){
if(rx - lx == 1){
tree[x] = {val , 1};
return;
}
int md = (rx+lx)>>1;
if(idx < md){
insert(idx ,val , 2*x+1 , lx , md);
}else{
insert(idx ,val , 2*x+2 , md , rx);
}
pair<ll , int> p1 = tree[2*x+1];
pair<ll , int> p2 = tree[2*x+2];
if(p1.first == p2.first)
tree[x] = {p1.first , p1.second + p2.second};
else if(p1.first > p2.first)
tree[x] = p2;
else tree[x] = p1;
}
void insert(int idx , ll val){
insert(idx , val , 0 , 0 , size);
}
pair<ll , int> getMinVal(int l , int r , int x , int lx , int rx){
if(lx >= r || l >= rx) return {LLONG_MAX , 1};
else if(lx >= l && rx <= r) return tree[x];
else{
int md = (lx+rx)>>1;
pair<ll , int> p1 = getMinVal(l , r , 2*x+1 , lx , md);
pair<ll , int> p2 = getMinVal(l , r , 2*x+2 , md , rx);
if(p1.first == p2.first) return {p1.first , p1.second+p2.second};
else if(p1.first > p2.first) return p2;
else return p1;
}
}
pair<ll , int> getMinVal(int l , int r){
return getMinVal(l , r , 0 , 0 , size);
}
};
//======================================================
ll gcd(ll a , ll b){
if(min(a,b) == 0) return max(a,b);
else return gcd(b , a%b);
}
//======================================================
ll lcm(ll a , ll b){
return a / gcd(a,b) * b;
}
//======================================================
ll KadaneMaxSum(vector<ll> &arr){
ll globalSum = arr[0];
ll curSum = arr[0];
int n = arr.size();
for(int i = 1 ; i < n ; i++){
curSum = max(arr[i] ,curSum+arr[i]);
globalSum = max(globalSum , curSum);
}
return globalSum;
}
//======================================================
ll KadaneMinSum(vector<ll> &arr){
ll globalSum = arr[0];
ll curSum = arr[0];
int n = arr.size();
for(int i = 1 ; i < n ; i++){
curSum = min(arr[i] ,curSum+arr[i]);
globalSum = min(globalSum , curSum);
}
return globalSum;
}
//======================================================
struct Sieve{
int N;
vector<int> primes;
vector<int> isPrime;
Sieve(int n){
N = n;
isPrime.resize(N+5);
for(int i = 0 ; i < N+5 ; i++)
isPrime[i] = true;
sieve();
}
bool check(int x){
return isPrime[x];
}
void sieve(){
isPrime[0] = isPrime[1] = false;
for(int i = 2 ; i*i < N ; i++){
if(isPrime[i])
for(int j = i*i ; j< N ; j+=i){
isPrime[j] = false;
}
}
for(int i = 2 ; i < N ; i++)
if(isPrime[i])
primes.push_back(i);
}
};
//======================================================
ll stringMod(string num , ll mod){
ll ans = 0;
int n = num.size();
for(int i = 0 ; i < n ; i++){
int d = num[i]-'0';
ans = (ans*10+d)%mod;
}
return ans;
}
//======================================================
ll fp(ll base , ll pow , int cMod = MOD){
ll ans = 1;
while(pow){
if(pow&1) ans = (ans%cMod * base%cMod)%cMod;
base = (base*base)%cMod;
pow >>=1;
}
return ans;
}
//======================================================
bool isPrime(ll n){ //not optimise
for(int i = 2 ; i*i<=n ; i++)
if(n%i == 0) return false;
return true;
}
//======================================================
ll findXOR(ll n){
ll mod = n % 4;
if (mod == 0)
return n;
else if (mod == 1)
return 1;
else if (mod == 2)
return n + 1;
else if (mod == 3)
return 0;
}
//======================================================
ll findXOR(ll l, ll r){
return (findXOR(l - 1) ^ findXOR(r));
}
//======================================================
struct combinatorics{
vector<ll> fac;
vector<ll> invers;
combinatorics(){
fac.push_back(1);
invers.push_back(1);
for(int i = 1 ; i < 1e6 ; i++){
fac.push_back( (fac.back()*i)%MOD );
invers.push_back(fp(fac.back() , MOD-2)%MOD);
}
}
ll nCr(int n , int r){
return (fac[n]%MOD * invers[r]%MOD * invers[n-r]%MOD)%MOD;
}ll nPr(int n , int r){
return (fac[n]%MOD * invers[n-r]%MOD)%MOD;
}
};
//======================================================
vector<int> childCnt(N);
int countChild(int root , int cnt ,vector<vector<int>> &adj, vector<bool> &vis){
vis[root] = true;
for(int num : adj[root])
if(!vis[num])
cnt += countChild(num,1 , adj , vis);
childCnt[root] = cnt-1;
return cnt;
}
//======================================================
class comp{
public:
bool operator()(pair<int , int> a , pair<int , int> b){
if(a.first != b.first) return a.first<b.first;
else return a.second>b.second;
}
};
//=====================================================
int dijkstra(vector<vector<pair<int , int>>> &adj , ll u , ll v){
int oo = 1e7;
ll dic[adj.size()+5];
ll par[adj.size()+5];
for(ll i = 0 ; i < adj.size()+5 ; i++)
dic[i] = oo , par[i] = 0;;
priority_queue<pair<ll , ll> , vector<pair<ll , ll>> , greater<>> pq;
pq.push({0 , u});
dic[u] = 0;
while(!pq.empty()){
ll cost = pq.top().first;
ll node = pq.top().second;
pq.pop();
if(cost > dic[node]) continue;
for(auto child : adj[node]){
int nxtCost = child.second;
if(nxtCost + cost < dic[child.first]){
dic[child.first] = nxtCost + cost;
par[child.first] = node;
pq.push({nxtCost + cost , child.first});
}
}
}
return dic[v];
}
//=====================================================
bool bellman_ford(ll src ,ll n , vector<pair<pair<ll , ll> , ll>> &list){
ll dist[n+1];
ll oo = 1e9;
for(ll i = 1 ; i <= n ; i++ )
dist[i] = oo;
dist[src] = 0;
for(ll i = 1 ; i <= n ;i++){
for(ll j = 0 ; j < list.size() ; j++){
if(dist[list[j].first.first] + list[j].second < dist[list[j].first.second]){
dist[list[j].first.second] = dist[list[j].first.first] + list[j].second;
if(i == n) return true;
}
}
}
return false;
}
//=====================================================
vector<vector<int>> floydList;
void floyd_warshall(int n , vector<pair<pair<int , int> , int>> &list){
int oo = 1e8;
floydList.assign(n+1 , vector<int>(n+1 , oo));
for(int i = 1 ; i <= n ;i++)
floydList[i][i] = 0;
for(pair<pair<int , int> , int> p : list){
floydList[p.first.first][p.first.second] = p.second;
floydList[p.first.second][p.first.first] = p.second;
}
for(int k = 1 ; k <= n ; k++)
for(int i = 1 ; i <= n ; i++)
for(int j = 1 ; j <= n ; j++)
floydList[i][j] = min(floydList[i][j] , floydList[i][k] + floydList[k][j]);
}
//=====================================================
void File(){
// freopen("doroob.in", "r", stdin);
// freopen("output.txt", "w", stdout);
}
//=====================================================
void testCase(ll ct){
ll n , m;
cin >> n >> m;
ll rx , ry , mx , my;
cin >> rx >> ry >> mx >> my;
if(rx > mx){
cout<<"-1\n";
return;
}
if(ry > my){
my = ry + (ry-my);
}
ll ans = 1e17;
ll st = 0 , en = 2e10;
while(st<=en){
ll md = st+en>>1;
ll tempx =rx+md, tempy=ry+md;
if(tempx > mx){
en = md-1;
continue;
}
if(tempy > m){
en = md-1;
continue;
}
if(tempy < my){
st = md+1;
continue;
}
ll dis = mx-tempx;
if(tempy-dis == my){
ans = min(ans,md+dis);
break;
}
else if(tempy-dis > my){
en = md-1;
}else{
st = md+1;
}
}
st = 0 , en = 2e10;
while(st<=en){
ll md = st+en>>1;
ll tempx =rx+md, tempy=ry-md;
if(tempx > mx){
en = md-1;
continue;
}
if(tempy <=0){
en = md-1;
continue;
}
if(tempy > my){
st = md+1;
continue;
}
ll dis = mx-tempx;
if(tempy+dis == my){
ans = min(ans,md+dis);
break;
}
else if(tempy+dis > my){
st = md+1;
}else{
en = md-1;
}
}
if(ans == 1e17) ans = -1;
cout<<ans<<"\n";
}
int main(){
File();
FastCode();
int t = 1;
cin >> t;
for(int i = 1 ; i <= t ; i++)
testCase(i);
return 0;
}
#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>

using namespace std;
using namespace __gnu_pbds;

typedef long long ll;
typedef unsigned long long ull;
#define output(v) for(auto&it:v){cout<<it<<" ";}cout<<"\n"
#define input(v) for(auto&it:v){cin>>it;}
#define ordered_set tree<int, null_type,less<int>, rb_tree_tag,tree_order_statistics_node_update>
const int N = 1e6+5;
const int MOD = 1e9+7;
const double pi= 3.1415926535897932;
//======================================================
void FastCode()
{
    std::ios_base::sync_with_stdio(0);
    cin.tie(NULL);
    cout.tie(NULL);
}
//======================================================
struct DSU{
    vector<int> parent;
    vector<int> sizeOfGroup;
    DSU(int N){
        parent.resize(N+5);
        sizeOfGroup.resize(N+5);
        for(int i = 0 ; i < N ; i++){
            parent[i] = i;
            sizeOfGroup[i] = 1;
        }
    }
    ll getLeader(int i){
        if(i == parent[i]) return i;
        else return parent[i] = getLeader(parent[i]);
    }
    bool sameGroup(int x , int y){
        return getLeader(x) == getLeader(y);
    }
    void mergeGroup(int x , int y){
        int leader1 = getLeader(x);
        int leader2 = getLeader(y);
        if(leader1 == leader2) return;
        else if(sizeOfGroup[leader1]>sizeOfGroup[leader2]){
            parent[leader2] = leader1;
            sizeOfGroup[leader1]+=sizeOfGroup[leader2];
        }else{
            parent[leader1] = leader2;
            sizeOfGroup[leader2]+=sizeOfGroup[leader1];
        }
    }
    int getSize(int x){
        return sizeOfGroup[getLeader(x)];
    }

};
//======================================================
struct FenwickTree{
    vector<ll> arr;
    int n;
    FenwickTree(int N){
        n=N;
        arr.resize(N+5);
    }

    void update(ll idx , ll val){
        while(idx < n+5){
            arr[idx]+=val;
            idx += idx&-idx;
        }
    }
    ll sum(ll idx){
        ll s=0;
        while(idx){
            s+=arr[idx];
            idx -= idx&-idx;
        }
        return s;
    }
    ll sum(ll l , ll r){
        return sum(r)-sum(l-1);
    }
    ll get(int idx){
        return sum(idx)-sum(idx-1);
    }
};
//======================================================
struct SegmentTreeRangeSum{
    int size;
    vector<ll> arr;
    SegmentTreeRangeSum(vector<ll> &a){
        size = 1;
        int n = a.size();
        while(size < n) size *= 2;
        arr.assign(size*2 , 0ll);
        build( a,0,0,size);
    }
    void build(vector<ll> &a , int x , int lx , int rx){
        if(rx-lx == 1){
            if(lx < a.size()) arr[x] = a[lx];
            return;
        }
        int md = (lx+rx)>>1;
        build(a , 2*x+1 , lx , md);
        build(a , 2*x+2 , md , rx);
        arr[x] = arr[2*x+1] + arr[2*x+2];
    }
    void set(int idx , int val , int x , int lx , int rx){
        if(rx-lx == 1){
            arr[x] = val;
            return;
        }
        int md = (lx+rx)>>1;
        if(idx < md){
            set(idx , val , 2*x+1 , lx ,md);
        }else{
            set(idx , val , 2*x+2 , md ,rx);
        }
        arr[x] = arr[2*x+1] + arr[2*x+2];
    }
    void set(int idx , ll val){
        set(idx , val , 0 , 0 , size);
    }
    ll sum(int l , int r, int cur , int lx , int rx){
        if(lx >= r || l >= rx) return 0;
        else if(lx >= l && r >= rx) return  arr[cur];
        int md = (lx+rx)>>1;
        return sum(l , r , 2*cur+1 , lx , md) + sum(l , r , 2*cur+2 , md , rx);
    }
    ll sum(int l , int r){
        return sum(l , r , 0 , 0 , size);
    }
};
//======================================================
struct SegmentTreeMinVal{
    int size;
    vector<pair<ll , int>> tree;
    SegmentTreeMinVal(int n){
        size = 1;
        while(size < n) size *= 2;
        tree.assign(2*size-1 , {LLONG_MAX , 1});
    }
    void insert(int idx , ll val , int x , int lx , int rx){
        if(rx - lx == 1){
            tree[x] = {val , 1};
            return;
        }
        int md = (rx+lx)>>1;
        if(idx < md){
            insert(idx ,val , 2*x+1 , lx , md);
        }else{
            insert(idx ,val , 2*x+2 , md , rx);
        }
        pair<ll , int> p1 = tree[2*x+1];
        pair<ll , int> p2 = tree[2*x+2];
        if(p1.first == p2.first)
            tree[x] = {p1.first , p1.second + p2.second};
        else if(p1.first > p2.first)
            tree[x] = p2;
        else tree[x] = p1;
    }
    void insert(int idx , ll val){
        insert(idx , val , 0 , 0 , size);
    }
    pair<ll , int> getMinVal(int l , int r , int x , int lx , int rx){
        if(lx >= r || l >= rx) return {LLONG_MAX , 1};
        else if(lx >= l && rx <= r) return tree[x];
        else{
            int md = (lx+rx)>>1;
            pair<ll , int> p1 = getMinVal(l , r , 2*x+1 , lx , md);
            pair<ll , int> p2 = getMinVal(l , r , 2*x+2 , md , rx);
            if(p1.first == p2.first) return {p1.first , p1.second+p2.second};
            else if(p1.first > p2.first) return p2;
            else return p1;
        }
    }
    pair<ll , int> getMinVal(int l , int r){
        return getMinVal(l , r , 0 , 0 , size);
    }
};
//======================================================
ll gcd(ll a , ll b){
    if(min(a,b) == 0) return max(a,b);
    else return gcd(b , a%b);
}
//======================================================
ll lcm(ll a , ll b){
    return a / gcd(a,b) * b;
}
//======================================================
ll KadaneMaxSum(vector<ll> &arr){
    ll globalSum = arr[0];
    ll curSum = arr[0];
    int n = arr.size();
    for(int i = 1 ; i < n ; i++){
        curSum = max(arr[i] ,curSum+arr[i]);
        globalSum = max(globalSum , curSum);
    }
    return globalSum;
}
//======================================================
ll KadaneMinSum(vector<ll> &arr){
    ll globalSum = arr[0];
    ll curSum = arr[0];
    int n = arr.size();
    for(int i = 1 ; i < n ; i++){
        curSum = min(arr[i] ,curSum+arr[i]);
        globalSum = min(globalSum , curSum);
    }
    return globalSum;
}
//======================================================
struct Sieve{
    int N;
    vector<int> primes;
    vector<int> isPrime;
    Sieve(int n){
        N = n;
        isPrime.resize(N+5);
        for(int i = 0 ; i < N+5 ; i++)
            isPrime[i] = true;
        sieve();
    }
    bool check(int x){
        return isPrime[x];
    }
    void sieve(){
        isPrime[0] = isPrime[1] = false;
        for(int i = 2 ; i*i < N ; i++){
            if(isPrime[i])
                for(int j = i*i ; j< N ; j+=i){
                    isPrime[j] = false;
                }

        }
        for(int i = 2 ; i < N ; i++)
            if(isPrime[i])
                primes.push_back(i);
    }
};
//======================================================
ll stringMod(string num , ll mod){
    ll ans = 0;
    int n = num.size();
    for(int i = 0 ; i < n ; i++){
        int d = num[i]-'0';
        ans = (ans*10+d)%mod;
    }
    return ans;
}
//======================================================
ll fp(ll base , ll pow , int cMod = MOD){
    ll ans = 1;
    while(pow){
        if(pow&1) ans = (ans%cMod * base%cMod)%cMod;
        base = (base*base)%cMod;
        pow >>=1;
    }
    return ans;
}
//======================================================
bool isPrime(ll n){ //not optimise
    for(int i = 2 ; i*i<=n ; i++)
        if(n%i == 0) return  false;
    return  true;
}
//======================================================
ll findXOR(ll n){
    ll mod = n % 4;
    if (mod == 0)
        return n;
    else if (mod == 1)
        return 1;
    else if (mod == 2)
        return n + 1;
    else if (mod == 3)
        return 0;
}
//======================================================
ll findXOR(ll l, ll r){
    return (findXOR(l - 1) ^ findXOR(r));
}
//======================================================
struct combinatorics{
    vector<ll> fac;
    vector<ll> invers;
    combinatorics(){
        fac.push_back(1);
        invers.push_back(1);
        for(int i = 1 ; i < 1e6 ; i++){
            fac.push_back( (fac.back()*i)%MOD );
            invers.push_back(fp(fac.back() , MOD-2)%MOD);
        }
    }
    ll nCr(int n , int r){
        return (fac[n]%MOD * invers[r]%MOD * invers[n-r]%MOD)%MOD;
    }ll nPr(int n , int r){
        return (fac[n]%MOD *  invers[n-r]%MOD)%MOD;
    }
};
//======================================================
vector<int> childCnt(N);
int countChild(int root , int cnt ,vector<vector<int>> &adj, vector<bool> &vis){
    vis[root] = true;
    for(int num : adj[root])
        if(!vis[num])
            cnt += countChild(num,1 , adj , vis);
    childCnt[root] = cnt-1;
    return cnt;
}
//======================================================
class comp{
public:
    bool operator()(pair<int , int> a , pair<int , int> b){
        if(a.first != b.first) return a.first<b.first;
        else return a.second>b.second;
    }
};
//=====================================================
int dijkstra(vector<vector<pair<int , int>>> &adj ,  ll u , ll v){
    int oo = 1e7;
    ll dic[adj.size()+5];
    ll par[adj.size()+5];
    for(ll i = 0 ; i < adj.size()+5 ; i++)
        dic[i] = oo , par[i] = 0;;
    priority_queue<pair<ll , ll> , vector<pair<ll , ll>> , greater<>> pq;
    pq.push({0 , u});
    dic[u] = 0;
    while(!pq.empty()){
        ll cost = pq.top().first;
        ll node = pq.top().second;
        pq.pop();
        if(cost > dic[node]) continue;
        for(auto child : adj[node]){
            int nxtCost = child.second;
            if(nxtCost + cost < dic[child.first]){
                dic[child.first] = nxtCost + cost;
                par[child.first] = node;
                pq.push({nxtCost + cost , child.first});
            }
        }
    }
    return dic[v];
}
//=====================================================
bool bellman_ford(ll src ,ll n ,  vector<pair<pair<ll , ll> , ll>> &list){
    ll dist[n+1];
    ll oo = 1e9;
    for(ll i = 1 ; i <= n ; i++ )
        dist[i] = oo;
    dist[src] = 0;
    for(ll i = 1 ; i <= n ;i++){
        for(ll j = 0 ; j < list.size() ; j++){
            if(dist[list[j].first.first] + list[j].second < dist[list[j].first.second]){
                dist[list[j].first.second] = dist[list[j].first.first] + list[j].second;
                if(i == n) return true;
            }
        }
    }
    return false;
}
//=====================================================
vector<vector<int>> floydList;
void floyd_warshall(int n , vector<pair<pair<int , int> , int>> &list){
    int oo = 1e8;
    floydList.assign(n+1 , vector<int>(n+1 , oo));
    for(int i = 1 ; i <= n ;i++)
        floydList[i][i] = 0;
    for(pair<pair<int , int> , int> p : list){
        floydList[p.first.first][p.first.second] = p.second;
        floydList[p.first.second][p.first.first] = p.second;
    }
    for(int k = 1 ; k <= n ; k++)
        for(int i = 1 ; i <= n ; i++)
            for(int j = 1 ; j <= n ; j++)
                floydList[i][j] = min(floydList[i][j] , floydList[i][k] + floydList[k][j]);
}
//=====================================================
void File(){
//    freopen("doroob.in", "r", stdin);
//        freopen("output.txt", "w", stdout);
}
//=====================================================
void testCase(ll ct){
    ll n , m;
    cin >> n >> m;
    ll rx , ry , mx , my;
    cin >> rx >> ry >> mx >> my;
    if(rx > mx){
        cout<<"-1\n";
        return;
    }
    if(ry > my){
        my = ry + (ry-my);
    }
    ll ans = 1e17;
    ll st = 0 , en = 2e10;
    while(st<=en){
        ll md = st+en>>1;
        ll tempx =rx+md, tempy=ry+md;
        if(tempx > mx){
            en = md-1;
            continue;
        }
        if(tempy > m){
            en = md-1;
            continue;
        }
        if(tempy < my){
            st = md+1;
            continue;
        }
        ll dis = mx-tempx;
        if(tempy-dis == my){
            ans = min(ans,md+dis);
            break;
        }
        else if(tempy-dis > my){
            en = md-1;
        }else{
            st = md+1;
        }
    }
    st = 0 , en = 2e10;
    while(st<=en){
        ll md = st+en>>1;
        ll tempx =rx+md, tempy=ry-md;
        if(tempx > mx){
            en = md-1;
            continue;
        }
        if(tempy <=0){
            en = md-1;
            continue;
        }
        if(tempy > my){
            st = md+1;
            continue;
        }
        ll dis = mx-tempx;
        if(tempy+dis == my){
            ans = min(ans,md+dis);
            break;
        }
        else if(tempy+dis > my){
            st = md+1;
        }else{
            en = md-1;
        }
    }

    if(ans == 1e17) ans = -1;
    cout<<ans<<"\n";
}
int main(){
    File();
    FastCode();
    int t = 1;
    cin >> t;
    for(int i = 1 ; i <= t ; i++)
        testCase(i);
    return 0;
}