On 16 Jun 2014, at 19:36, Mark R V Murray <ma...@freebsd.org> wrote:
> 
> On 16 Jun 2014, at 08:28, Michael Tuexen <tue...@freebsd.org> wrote:
>> your patch for accessing the value is correct. However, the initialisation 
>> code also
>> needs to be adopted to the platform. So in addition to your patch, you also 
>> need:
> 
> Thanks!
> 
>> Is there an easy test to see if the code actually works as expected and not 
>> that it just
>> allows the system to boot?
> 
> Yes. :-)
> 
> #include <sys/types.h>
> 
> #include <stdio.h>
> 
> static __inline uint64_t
> get_cyclecount(void)
> {
>       uint32_t ccnt;
>       uint64_t tsc;
> 
>       /* Read CCNT.  */
>       __asm __volatile("mrc p15, 0, %0, c15, c12, 1": "=r" (ccnt));
> 
>       tsc = (uint64_t)ccnt;
> 
>       return (tsc);
> }
> 
> #define N 100000
> 
> int
> main(int argc, char *argv[])
> {
>       int i;
>       uint64_t ccnt[N];
> 
>       for (i = 0; i < N; i++)
>               ccnt[i] = get_cyclecount();
> 
>       for (i = 1; i < N; i++)
>               printf("%6d %016llX %16llu\n", i, ccnt[i], ccnt[i] - ccnt[i - 
> 1]);
> 
> 
>       return (0);
> }
> 
> Should print a whole lotta numbers, incrementing, unless you hit the 
> wraparound.
Don't I need to compile a kernel with _PMC_USER_READ_WRITE_ being defined, since
without it a user process can't access the register. When running it on a kernel
not defining _PMC_USER_READ_WRITE_, I get a core with Illegal instruction.

Let me build a kernel with the above define and retest.
> 
>> Regarding the 32-bit limitation: Do we want to increment the register only 
>> every
>> 64 clock cycle?
> 
> Definitely not! The value is in the low bits; wrap is of little consequence.
OK.

Best regards
Michael
> 
> M
> -- 
> Mark R V Murray
> 
> 

_______________________________________________
svn-src-head@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to