Here's an argument that I believe shows that logn−omega(1) is impossible. (This argument came out of a discussion I had with Steve Fenner.)
Let Alice's input be xin0,1n and let Bob's input be yin0,1n. Assume the shared memory stores states in 0,1m, and its initial state is 0m. We are interested in lower-bounding m for any protocol that computes EQ(x,y).
A given protocol is defined by two collections of functions fx and gy, representing the functions applied to the shared memory by Alice on each input x and Bob on each input y, respectively, along with some answering criterion. To be more specific, let us assume that if the shared memory ever contains the string 1m−1b then the output of the protocol is b (for each bin0,1). For convenience, let us also assume that fx(1m−1b)=1m−1b: and gy(1m−1b)=1m−1b: for every x,yin0,1n and bin0,1. In other words, Alice and Bob don't change the shared memory once they know the answer.
Now, for each x,yin0,1n, consider what happens when Alice and Bob run the protocol on the input (x,y). Define Ax,ysubseteq0,1m to be the set of all states of the shared memory that Alice receives at any point in the protocol, and likewise define Bx,ysubseteq0,1m to be the states of the shared memory that Bob receives. Also define
[
S_{x,y} = {0w,:,win A_{x,y}} cup {1w,:,win B_{x,y}}.
]
We will assume Alice goes first, so 0minAx,y for all x,y. Let us also make the following observations:
By the definition of Ax,y and Bx,y, it holds that fx(Ax,y)subseteqBx,y and gy(Bx,y)subseteqAx,y for all x,y.
For every x,y with xnot=y it holds that 1m−10inAx,ycupBx,y, because Alice and Bob output 0 when their strings disagree.
For every x it holds that 1m−10notinAx,xcupBx,x, because Alice and Bob do not output 0 when their strings agree.
Now let us prove that Sx,xnot=Sy,y whenever xnot=y. To do this, let us assume toward contradiction that xnot=y but Sx,x=Sy,y (i.e., Ax,x=Ay,y and Bx,x=By,y), and consider the behavior of the protocol on the input (x,y).
Let wt be the contents of the shared memory after t turns have passed in the protocol, so we have w0=0m, w1=fx(w0), w2=gy(w1), and so on. It holds that
[
begin{array}{c}
w_0 = 0^m in A_{x,x}\
w_1 = f_x(w_0) in f_x(A_{x,x}) subseteq B_{x,x} = B_{y,y},\
w_2 = g_y(w_1) in g_y(B_{y,y}) subseteq A_{y,y} = A_{x,x},
end{array}
]
and in general
[
begin{array}{c}
w_{2t + 1} = f_x(w_{2t}) in f_x(A_{x,x}) subseteq B_{x,x} = B_{y,y}\
w_{2t+2} = g_y(w_{2t+1}) in g_y(B_{y,y}) subseteq A_{y,y} = A_{x,x}
end{array}
]
for each tinmathbbN. It follows that Ax,ysubseteqAx,x and Bx,ysubseteqBy,y.
But now we have our contradiction, assuming the protocol is correct: given that Ax,ysubseteqAx,x and Bx,ysubseteqBy,y, it follows that 1m−10inAx,xcupBy,y, so Alice and Bob output the incorrect answer 0 on either (x,x) or (y,y).
Each Sx,x is a subset of 0,1m+1, so there are at most 22m+1 choices for Sx,x. Given that the sets Sx,x must be distinct for distinct choices of x, it follows that 22m+1geq2n, so mgeqlogn−1.