lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <00ef01cbab0a$66bfce60$343f6b20$@mprc.pku.edu.cn>
Date:	Mon, 3 Jan 2011 13:52:26 +0800
From:	"Guan Xuetao" <guanxuetao@...c.pku.edu.cn>
To:	"'john stultz'" <johnstul@...ibm.com>
Cc:	<linux-arch@...r.kernel.org>, <linux-kernel@...r.kernel.org>
Subject: RE: [PATCHv1 09/12] unicore32 core architecture: timer and time



> -----Original Message-----
> From: linux-arch-owner@...r.kernel.org [mailto:linux-arch-owner@...r.kernel.org] On Behalf Of Guan Xuetao
> Sent: Sunday, January 02, 2011 5:48 PM
> To: 'john stultz'
> Cc: linux-arch@...r.kernel.org; linux-kernel@...r.kernel.org
> Subject: RE: [PATCHv1 09/12] unicore32 core architecture: timer and time
> 
> 
> 
> > -----Original Message-----
> > From: johnstul.lkml@...il.com [mailto:johnstul.lkml@...il.com] On Behalf Of john stultz
> > Sent: Tuesday, December 28, 2010 5:27 AM
> > To: Guan Xuetao
> > Cc: linux-arch@...r.kernel.org; linux-kernel@...r.kernel.org
> > Subject: Re: [PATCHv1 09/12] unicore32 core architecture: timer and time
> >
> > 2010/12/25 Guan Xuetao <guanxuetao@...c.pku.edu.cn>:
> > > From: Guan Xuetao <guanxuetao@...c.pku.edu.cn>
> > >
> > > Patch 9 implements timer and time. RTC and PWM device drivers are also here.
> > >
> > > Signed-off-by: Guan Xuetao <guanxuetao@...c.pku.edu.cn>
> >
> > Just a small request:
> >
> > > +static struct clocksource cksrc_puv3_oscr = {
> > > +       .name           = "oscr",
> > > +       .rating         = 200,
> > > +       .read           = puv3_read_oscr,
> > > +       .mask           = CLOCKSOURCE_MASK(32),
> > > +       .shift          = 18,
> >
> > Drop the shift assignment here.
> >
> > > +       cksrc_puv3_oscr.mult =
> > > +               clocksource_hz2mult(CLOCK_TICK_RATE, cksrc_puv3_oscr.shift);
> > > +
> > Drop the mult assignment here.
> >
> >
> > > +       clocksource_register(&cksrc_puv3_oscr);
> >
> > Use "clocksource_register_hz(&cksrc_puv3_oscr, CLOCK_TICK_RATE );" and
> > the kernel will fill in mult/shift appropriately.
> >
> > If you have any troubles after doing so, let me know.
> 
> When using clocksource_register_hz(&cksrc_puv3_oscr, CLOCK_TICK_RATE ),
>  the shift value become 0, and mult value become 0x838a91a7, and the system will be broken
> after printing "Switching to clocksource oscr".
> 
> When using clocksource_register_khz(&cksrc_puv3_oscr, CLOCK_TICK_RATE ),
> the shift value become 0, and mult value become  0x4359611, and the system will run smoothly,
> but timer interrupt seems too frequently. Perhaps it is 4 times faster.
> 
> For comparison, originally, when shift value is set to 0x12, the mult value become 1175e5e.
> 

The error is the implementation of do_div() function.
When replacing the arch-specific div64.h with asm-generic/div64.h, clocksource_rigister_hz() works.
Thanks.

> Which one is better?
> 
> >
> > thanks
> > -john
> 
> Thanks john.
> 
> Guan Xuetao
> 

Guan Xuetao

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ