facing problem with io_p2v() function

Misbah khan misbah_khan at engineer.com
Thu Aug 14 01:31:28 EST 2008


Hi all,

I am using io_p2v() function in my driver to get the virtual address mapping
timer control registers

i am passing address as 0x48304024 as base and after getting the virtual
address of it i am reading and writing to it but my any attempt to read the
location or write is giving segmentation fault

If i use __pa() to read the corresponding location it returning as
0x98304024 insted of 0x48304024

I dont know where the mapping is going wrong 

Even when i tried using ioremap() i got the same kernel panic 

Below is the error message 


-------------------------------------------------------------------------------------------------------

In init function
 Read reg address virt 0xd8304024 and phy 0x98304024 are
Unhandled fault: external abort on non-linefetch (0x1028) at 0xd8304024
Internal error: : 1028 [#1]
Modules linked in: omap_timer
CPU: 0    Not tainted  (2.6.22.1-omap3 #1)
PC is at omap_timer_read_register+0x30/0x3c [omap_timer]
LR is at release_console_sem+0x1c0/0x1d4
pc : [<bf000160>]    lr : [<c005f650>]    psr: 60000013
sp : c7f1bea0  ip : c7f1bdd8  fp : c7f1beb4
r10: c8858000  r9 : 00000026  r8 : 00000027
r7 : c06dfdf0  r6 : 00000000  r5 : bf001018  r4 : 00000024
r3 : d8304000  r2 : 00000000  r1 : 60000013  r0 : 0000003d
Flags: nZCv  IRQs on  FIQs on  Mode SVC_32  Segment user
Control: 00c5387f  Table: 80694018  DAC: 00000015
Process insmod (pid: 306, stack limit = 0xc7f1a2d0)
Stack: (0xc7f1bea0 to 0xc7f1c000)
bea0: 00000000 bf001018 c7f1bed4 c7f1beb8 bf0001c4 bf00013c 00000000
bf001280
bec0: bf001100 c06dfdf0 c7f1bef4 c7f1bed8 bf0030c4 bf0001b0 00000000
c006b5c4
bee0: c06dfdc4 c06dfc00 c7f1bfa4 c7f1bef8 c007f514 bf00300c 00000000
c0024380
bf00: 000ce008 00000000 00000000 00000000 00000000 00000000 00000000
00000000
bf20: 00000000 00000000 00000000 00000000 00000000 00000000 c886ca30
c07fc200
bf40: 00000000 c8867c88 c88678f0 00000000 00000054 00000054 0000000a
c886758f
bf60: c8867cd8 bf00110c c8867cb0 00000024 00000000 c035da98 c0030184
000a81fc
bf80: bebf5d74 00014cdd 00000080 c0029f68 c7f1a000 00000000 00000000
c7f1bfa8
bfa0: c0029dc0 c007e1d8 000a81fc bebf5d74 000ce018 00014cdd 000ce008
00000001
bfc0: 000a81fc bebf5d74 00014cdd 00000080 00000000 bebf5d74 bebf5e54
00000061
bfe0: bebf5a20 bebf5a10 0001e1c0 401d2ec0 60000010 000ce018 00000017
0011b8d8
Backtrace:
[<bf000130>] (omap_timer_read_register+0x0/0x3c [omap_timer]) from
[<bf0001c4>] (omap_dm_timer_set_l
oad+0x20/0x5c [omap_timer])
 r5:bf001018 r4:00000000
[<bf0001a4>] (omap_dm_timer_set_load+0x0/0x5c [omap_timer]) from
[<bf0030c4>] (omap_gp_timer_init_mo
de+0xc4/0xf0 [omap_timer])
 r7:c06dfdf0 r6:bf001100 r5:bf001280 r4:00000000
[<bf003000>] (omap_gp_timer_init_mode+0x0/0xf0 [omap_timer]) from
[<c007f514>] (sys_init_module+0x13
48/0x1400)
 r5:c06dfc00 r4:c06dfdc4
[<c007e1cc>] (sys_init_module+0x0/0x1400) from [<c0029dc0>]
(ret_fast_syscall+0x0/0x2c)
Code: e1a01003 e59f000c eb417e8b e5953010 (e7930004)
Segmentation fault

-----------------------------------------------------------------------------------------------------------

Looking forward for the suggestion for the above problem


----- Misbah <><
-- 
View this message in context: http://www.nabble.com/facing-problem-with-io_p2v%28%29-function-tp18965524p18965524.html
Sent from the linuxppc-embedded mailing list archive at Nabble.com.



More information about the Linuxppc-embedded mailing list