[asterisk-bugs] [DAHDI-linux 0018760]: [patch] inconsistent read from /proc/dahdi if size changes

Asterisk Bug Tracker noreply at bugs.digium.com
Sun Feb 20 17:13:23 CST 2011


A NOTE has been added to this issue. 
====================================================================== 
https://issues.asterisk.org/view.php?id=18760 
====================================================================== 
Reported By:                tzafrir
Assigned To:                
====================================================================== 
Project:                    DAHDI-linux
Issue ID:                   18760
Category:                   General
Reproducibility:            always
Severity:                   minor
Priority:                   normal
Status:                     confirmed
JIRA:                        
Reviewboard Link:            
====================================================================== 
Date Submitted:             2011-02-07 09:29 CST
Last Modified:              2011-02-20 17:13 CST
====================================================================== 
Summary:                    [patch] inconsistent read from /proc/dahdi if size
changes
Description: 
Reading from a file should be done in a loop, testing for extra output.
If at the time of this read loop the "size" of /proc/dahdi/N increases,
you get extra output.

I have applied the attached patch, which simulates such a change by adding
some extra text (" CHEATING") to each line.

The effect:
# cat /proc/dahdi/1
Span 1: XBUS-00/XPD-00 "Xorcom XPD https://issues.asterisk.org/view.php?id=0/00:
BRI_NT"

           1 XPP_BRI_NT/00/00/0
           2 XPP_BRI_NT/00/00/1
           3 XPP_BRI_NT/00/00/2
P_BRI_NT/00/00/2  CHEATING

# cat /proc/dahdi/9
Span 9: XBUS-00/XPD-10 "Xorcom XPD https://issues.asterisk.org/view.php?id=0/10:
FXS" (MASTER)

          25 XPP_FXS/00/10/0
          26 XPP_FXS/00/10/1
          27 XPP_FXS/00/10/2
          28 XPP_FXS/00/10/3
          29 XPP_FXS/00/10/4
          30 XPP_FXS/00/10/5
          31 XPP_FXS/00/10/6
          32 XPP_FXS/00/10/7
HEATING
          31 XPP_FXS/00/10/6  CHEATING
          32 XPP_FXS/00/10/7  CHEATING

# strace -eread cat /proc/dahdi/1 >/dev/null
read(3,
"\177ELF\1\1\1\0\0\0\0\0\0\0\0\0\3\0\3\0\1\0\0\0\260e\1\0004\0\0\0\4"...,
512) = 512
read(3, "Span 1: XBUS-00/XPD-00 \"Xorcom XP"..., 4096) = 131
read(3, "P_BRI_NT/00/00/2  CHEATING\n"..., 4096) = 27
read(3, ""..., 4096)                    = 0

# strace -eread cat /proc/dahdi/9 >/dev/null
read(3,
"\177ELF\1\1\1\0\0\0\0\0\0\0\0\0\3\0\3\0\1\0\0\0\260e\1\0004\0\0\0\4"...,
512) = 512
read(3, "Span 9: XBUS-00/XPD-10 \"Xorcom XP"..., 4096) = 243
read(3, "HEATING\n\t  31 XPP_FXS/00/10/6  CH"..., 4096) = 72
read(3, ""..., 4096)                    = 0

We would have expected the second read to return 0. But setting 'eof=1'
does not provide this desired effect.
====================================================================== 

---------------------------------------------------------------------- 
 (0132208) svnbot (reporter) - 2011-02-20 17:13
 https://issues.asterisk.org/view.php?id=18760#c132208 
---------------------------------------------------------------------- 
Repository: dahdi
Revision: 9770

U   linux/trunk/drivers/dahdi/dahdi-base.c

------------------------------------------------------------------------
r9770 | tzafrir | 2011-02-20 17:13:21 -0600 (Sun, 20 Feb 2011) | 13 lines

replace old proc interface by modern seq_file

Switch to using the newer seq_file interface for procfs. Fixes a
race when you read the "file" while its size increases (e.g. the span
enters an alarm state).

Signed-off-by: Oron Peled <oron.peled at xorcom.com>
Acked-by: Shaun Ruffell <sruffell at digium.com>
Acked-By: Tzafrir Cohen <tzafrir.cohen at xorcom.com>

(closes issue https://issues.asterisk.org/view.php?id=18760)
Patches:
      0001-DAHDI-linux-trunk-replace-old-proc-interface-by-mode.patch
uploaded by tzafrir (license 46)
------------------------------------------------------------------------

http://svn.digium.com/view/dahdi?view=rev&revision=9770 

Issue History 
Date Modified    Username       Field                    Change               
====================================================================== 
2011-02-20 17:13 svnbot         Checkin                                      
2011-02-20 17:13 svnbot         Note Added: 0132208                          
======================================================================




More information about the asterisk-bugs mailing list