Well, for a computer that is a 
finite state machine there are only finitely many 
states.  So, in finite time the machine will either (a) halt or (b) return to an earlier state and, thus, be in an 
infinite loop. So, in this case can tell if the "program will stop" and, thus, 
solve "the halting problem".
Uh, we also assume that before we start, we can look at the design of "the machine" and know how many states there can be and from the speed of the machine how many new states are visited each second.  So, we will know how long we have to wait before we see either (a) or (b).