You don't need the "eop_201007 as eop" in your FROM.  The following will work:
UPDATE eop_201007
set coord_x = gi.x_etrs89, coord_y = gi.x_etrs89,gr_type = 4
from geoindex201001 as gi
where eop_201007.cp7=gi.cp7 AND eop_201007.gr_type=0;
I think the extra eop is causing a cross-join (basically the cross product of the two tables which is HUGE) because it isn't constrained against the original eop table which is "automatically" in the FROM list already
If that doesn't fix things, here's some other thoughts:
You probably want to do a vacuum analyze on it first if you haven't.  Make sure you have all your memory settings tunes in postgresql.conf.  Working memory, shared buffers, etc can make a huge difference.
If this is a one-time thing, and not a nightly job, you should turn fsync off.  Also, make sure (if you turn fsync off) you don't have too many checkpoint segments configured (24 or so will do) otherwise you'll pollute your disk cache.
As @Frank Heikens said, you should look at explain.  Also check EXPLAIN ANALYZE (if you query does ever finish).