I don't have an older core CPU around to test this on, but this seems
correct from a code reading point of view. The rest of core_intr uses
IAP_* constants and macros, not IAF_*, and the SDM manuals document the
width for the PMCs for Architecture 1 CPUs is the IAP width. IAF doesn't
show up until Architecture 2.
Details
Diff Detail
- Repository
- rS FreeBSD src repository - subversion
- Lint
Lint Passed - Unit
No Test Coverage
Event Timeline
This is an Intel Core processor? I believe that I have access to one of these. Any idea what the symptoms would be?
I think that sampling would not work correctly. In particular, once it reloaded a counter on an interrupt it would write zero to the counter so it would have to wrap all the way around to trigger (whereas it should be writing the equivalent of -65536 by default). I think this means it would probably sample once and then fail to sample again, though it might possibly sample once per context switch. I would see if the number of samples / second for a similar workload is comparable to a later processor.
Can you do 'p core_iaf_width' in kgdb first and verify it is zero and that 'core_iap_width' is not zero after loading hwpmc?
I am having a horrific time trying to get HEAD installed on one of these systems. Unfortunately support for i386-only systems in our test lab is rotting and I haven't had time to debug the issue yet. :(
Out of curiosity are these 14Ks @rstone? In any case, I'm guessing it makes sense to just go ahead.