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] [day] [month] [year] [list]
Message-Id: <F926C377-5D8A-44BF-B3A0-B9A397514200@freescale.com>
Date:	Fri, 16 May 2008 13:05:41 -0500
From:	Andy Fleming <afleming@...escale.com>
To:	"<glenn_engel@...lent.com>" <glenn_engel@...lent.com>
Cc:	<netdev@...r.kernel.org>
Subject: Re: Need ioctl for multiple register phy access


On May 16, 2008, at 11:34, <glenn_engel@...lent.com> <glenn_engel@...lent.com 
 > wrote:

> Some of the newer versions of the National Phy chip have additional  
> 'pages' of registers for things like link diagnostics or ieee1588  
> control.  Some of these require multiple writes to the phy (e.g  
> write page number to reg 19, then write to one or more registers on  
> that page).  Additionally, some phy registers have depth and may  
> need multiple reads or writes as they have more than 16 bits of  
> data.  Since these operations need to be done without interruption  
> of other phy commands, the usual write one register or read one  
> register ioctl technique does not work.  Since the phy access is an  
> intimate part of the driver it would seem the logical place would be  
> to enhance the existing driver to deal with these new phy  
> capabilities.
>
> Option 1. - Use the existing SIOCGMIIREG/SIOCSMIIREG ioctl and use a  
> magic phy_id (e.g 0xffff) in the mii_ioctl_data structure to  
> indicate a multi register access request.   The data would then be  
> encoded as a variable length sequence:
>
>    <number of bytes to follow>
>    <16 bit encoded R/W, phy id, page#, register#>
>    <16 bit write value or read result>
>    <repeat in groups of two 16 bit words>
>
> Option 2 - Add a new ioctl to allow multiple register access.  The  
> format would be something like a list of 'commands' such as read  
> register R1 on page P1,  write register R2 on page P2 etc.  I see an  
> ioctl SIOCDEVPRIVATE but I also see a comment about it being removed  
> in the future.
>
> Suggestions welcome on how to address this.


Another option would be to use the PHY Lib to deal with this.  Porting  
a driver to use the PHY Lib is fairly easy, and then you would have  
the ability to lock the bus and do your writes, or to modify the  
driver for that PHY so it configures things as needed.

Andy
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ