Read about "CPU Bound and GPU Bound Applications" to get more of an understanding what is involved with programming for hardware T&L.
Basically, you have to have a balance as to what the CPU is processing and the GPU is processing. If the CPU is doing too much work, you will see that in FPS. If the GPU is doing too much work, you will see that in rendering quality and FPS. You have to find the right balance which depends on the type of application. NVidia and ATI recommend 50/50 as a balance. They said no more than 60/40 (GPU/CPU).
An engine does a lot more than take the content and render it.
What the engine does depends on what you need to accomplish. It can be as simple as just rendering stuff, but as complex as running Artifical Intelligence. There are game engines (Unreal, Quake, NWN's Aurora, Siege Engine, Torque) and there are rendering engines (Genesis, Jet, Irrlicht, OGRE). The difference between the 2 is the amount of game specific code that is in them. For example, NWN does not have a game shell. The engine is the game shell. NWN's engine also manages all it's game content and executes all the game logic.
Quake and Unreal do the same thing. The exe initializes the engine, then runs the game loop. The engine does the rest via script commands (for UT) or hard coded game stuff (Quake).
Genesis and Jet's job is to load poly data and process it. You have to write your own gameshell (hence RF
). This makes Genesis and Jet rendering engines as all they do is load polys and render them.