copy protection

Hi

I am developing a copy protection for my firmware, that runs on PC.
Till now, ISA cards with it’s own EEProm were used, and security was based on serial number of cards in system, and storage of security information into EEprom of those cards.

Now new PCI controller cards don’t have any serial# and no EEProm to write to.

So I have 2 problems, how to uniquely identify HW that firmware is running on (serial of HDD, CPU, MAC address ?) and how to store security information (storage in filesystem won’t be protected agains making image of disk and restoring it on expiration time)

Any tips, ideas, hints, code snippets would be appreciated

best regards

GASTAN