UDK comes with a material function that can do this job but it's rather poor: the result is pretty noisy, might suffer from small artifacts and shifts the texture by half a texel. The main reason for this is that it only offsets the height texture in one direction on both, x and y axis by a certain amount - then calculates normals from change in height.
Material
For a better result you should offset the height texture in both directions on both axes. It's also recommended to do these offsets in texel increments.
data:image/s3,"s3://crabby-images/2128c/2128c50f0c1b1ddeb8aacc6bb26561550bdeb1f1" alt=""
Of course there are more advanced algorithms available to generate normals but these are expensive and therefore not advisable for real-time usage. As an example, this is the code from ATI's NormalMapGenerator/Rendermonkey implemented in a custom node (8 samples, Sobel kernel):
data:image/s3,"s3://crabby-images/030af/030afe479d7d860362ed4a85cc396a26d5aa4a67" alt=""
Comparison
UDK Material Function (55 instructions)
Recommended Material (55 instructions)
ATI/Rendermonkey/Sobel (70 instructions)
For further comparison, here's the equivalent external normalmap
TC_Normalmap (48 instructions)
TC_NormalmapUncompressed (51 instructions)