Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
bf01bbad
Commit
bf01bbad
authored
Nov 08, 2004
by
Greg Kroah-Hartman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
I2C: fix i2c_detect to allow NULL fields in adapter address structure.
Signed-off-by:
Greg Kroah-Hartman
<
greg@kroah.com
>
parent
331dc808
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
36 additions
and
16 deletions
+36
-16
drivers/i2c/i2c-sensor-detect.c
drivers/i2c/i2c-sensor-detect.c
+36
-16
No files found.
drivers/i2c/i2c-sensor-detect.c
View file @
bf01bbad
...
@@ -31,6 +31,8 @@
...
@@ -31,6 +31,8 @@
#include <linux/i2c-sensor.h>
#include <linux/i2c-sensor.h>
#include <asm/uaccess.h>
#include <asm/uaccess.h>
static
unsigned
short
empty
[]
=
{
I2C_CLIENT_END
};
static
unsigned
int
empty_isa
[]
=
{
I2C_CLIENT_ISA_END
};
/* Very inefficient for ISA detects, and won't work for 10-bit addresses! */
/* Very inefficient for ISA detects, and won't work for 10-bit addresses! */
int
i2c_detect
(
struct
i2c_adapter
*
adapter
,
int
i2c_detect
(
struct
i2c_adapter
*
adapter
,
...
@@ -42,11 +44,30 @@ int i2c_detect(struct i2c_adapter *adapter,
...
@@ -42,11 +44,30 @@ int i2c_detect(struct i2c_adapter *adapter,
int
is_isa
=
i2c_is_isa_adapter
(
adapter
);
int
is_isa
=
i2c_is_isa_adapter
(
adapter
);
int
adapter_id
=
int
adapter_id
=
is_isa
?
ANY_I2C_ISA_BUS
:
i2c_adapter_id
(
adapter
);
is_isa
?
ANY_I2C_ISA_BUS
:
i2c_adapter_id
(
adapter
);
unsigned
short
*
normal_i2c
;
unsigned
short
*
normal_i2c_range
;
unsigned
int
*
normal_isa
;
unsigned
short
*
probe
;
unsigned
short
*
ignore
;
/* Forget it if we can't probe using SMBUS_QUICK */
/* Forget it if we can't probe using SMBUS_QUICK */
if
((
!
is_isa
)
&&
if
((
!
is_isa
)
&&
!
i2c_check_functionality
(
adapter
,
I2C_FUNC_SMBUS_QUICK
))
!
i2c_check_functionality
(
adapter
,
I2C_FUNC_SMBUS_QUICK
))
return
-
1
;
return
-
1
;
/* Use default "empty" list if the adapter doesn't specify any */
normal_i2c
=
normal_i2c_range
=
probe
=
ignore
=
empty
;
normal_isa
=
empty_isa
;
if
(
address_data
->
normal_i2c
)
normal_i2c
=
address_data
->
normal_i2c
;
if
(
address_data
->
normal_i2c_range
)
normal_i2c_range
=
address_data
->
normal_i2c_range
;
if
(
address_data
->
normal_isa
)
normal_isa
=
address_data
->
normal_isa
;
if
(
address_data
->
probe
)
probe
=
address_data
->
probe
;
if
(
address_data
->
ignore
)
ignore
=
address_data
->
ignore
;
for
(
addr
=
0x00
;
addr
<=
(
is_isa
?
0xffff
:
0x7f
);
addr
++
)
{
for
(
addr
=
0x00
;
addr
<=
(
is_isa
?
0xffff
:
0x7f
);
addr
++
)
{
if
(
!
is_isa
&&
i2c_check_addr
(
adapter
,
addr
))
if
(
!
is_isa
&&
i2c_check_addr
(
adapter
,
addr
))
...
@@ -72,11 +93,11 @@ int i2c_detect(struct i2c_adapter *adapter,
...
@@ -72,11 +93,11 @@ int i2c_detect(struct i2c_adapter *adapter,
/* If this address is in one of the ignores, we can forget about it
/* If this address is in one of the ignores, we can forget about it
right now */
right now */
for
(
i
=
0
;
!
found
&&
(
address_data
->
ignore
[
i
]
!=
I2C_CLIENT_END
);
i
+=
2
)
{
for
(
i
=
0
;
!
found
&&
(
ignore
[
i
]
!=
I2C_CLIENT_END
);
i
+=
2
)
{
if
(
((
adapter_id
==
address_data
->
ignore
[
i
])
||
if
(
((
adapter_id
==
ignore
[
i
])
||
((
address_data
->
ignore
[
i
]
==
ANY_I2C_BUS
)
&&
((
ignore
[
i
]
==
ANY_I2C_BUS
)
&&
!
is_isa
))
&&
!
is_isa
))
&&
(
addr
==
address_data
->
ignore
[
i
+
1
]))
{
(
addr
==
ignore
[
i
+
1
]))
{
dev_dbg
(
&
adapter
->
dev
,
"found ignore parameter for adapter %d, addr %04x
\n
"
,
adapter_id
,
addr
);
dev_dbg
(
&
adapter
->
dev
,
"found ignore parameter for adapter %d, addr %04x
\n
"
,
adapter_id
,
addr
);
found
=
1
;
found
=
1
;
}
}
...
@@ -87,22 +108,22 @@ int i2c_detect(struct i2c_adapter *adapter,
...
@@ -87,22 +108,22 @@ int i2c_detect(struct i2c_adapter *adapter,
/* Now, we will do a detection, but only if it is in the normal or
/* Now, we will do a detection, but only if it is in the normal or
probe entries */
probe entries */
if
(
is_isa
)
{
if
(
is_isa
)
{
for
(
i
=
0
;
!
found
&&
(
address_data
->
normal_isa
[
i
]
!=
I2C_CLIENT_ISA_END
);
i
+=
1
)
{
for
(
i
=
0
;
!
found
&&
(
normal_isa
[
i
]
!=
I2C_CLIENT_ISA_END
);
i
+=
1
)
{
if
(
addr
==
address_data
->
normal_isa
[
i
])
{
if
(
addr
==
normal_isa
[
i
])
{
dev_dbg
(
&
adapter
->
dev
,
"found normal isa entry for adapter %d, addr %04x
\n
"
,
adapter_id
,
addr
);
dev_dbg
(
&
adapter
->
dev
,
"found normal isa entry for adapter %d, addr %04x
\n
"
,
adapter_id
,
addr
);
found
=
1
;
found
=
1
;
}
}
}
}
}
else
{
}
else
{
for
(
i
=
0
;
!
found
&&
(
address_data
->
normal_i2c
[
i
]
!=
I2C_CLIENT_END
);
i
+=
1
)
{
for
(
i
=
0
;
!
found
&&
(
normal_i2c
[
i
]
!=
I2C_CLIENT_END
);
i
+=
1
)
{
if
(
addr
==
address_data
->
normal_i2c
[
i
])
{
if
(
addr
==
normal_i2c
[
i
])
{
found
=
1
;
found
=
1
;
dev_dbg
(
&
adapter
->
dev
,
"found normal i2c entry for adapter %d, addr %02x"
,
adapter_id
,
addr
);
dev_dbg
(
&
adapter
->
dev
,
"found normal i2c entry for adapter %d, addr %02x"
,
adapter_id
,
addr
);
}
}
}
}
for
(
i
=
0
;
!
found
&&
(
address_data
->
normal_i2c_range
[
i
]
!=
I2C_CLIENT_END
);
i
+=
2
)
{
for
(
i
=
0
;
!
found
&&
(
normal_i2c_range
[
i
]
!=
I2C_CLIENT_END
);
i
+=
2
)
{
if
((
addr
>=
address_data
->
normal_i2c_range
[
i
])
&&
if
((
addr
>=
normal_i2c_range
[
i
])
&&
(
addr
<=
address_data
->
normal_i2c_range
[
i
+
1
]))
{
(
addr
<=
normal_i2c_range
[
i
+
1
]))
{
dev_dbg
(
&
adapter
->
dev
,
"found normal i2c_range entry for adapter %d, addr %04x
\n
"
,
adapter_id
,
addr
);
dev_dbg
(
&
adapter
->
dev
,
"found normal i2c_range entry for adapter %d, addr %04x
\n
"
,
adapter_id
,
addr
);
found
=
1
;
found
=
1
;
}
}
...
@@ -110,12 +131,11 @@ int i2c_detect(struct i2c_adapter *adapter,
...
@@ -110,12 +131,11 @@ int i2c_detect(struct i2c_adapter *adapter,
}
}
for
(
i
=
0
;
for
(
i
=
0
;
!
found
&&
(
address_data
->
probe
[
i
]
!=
I2C_CLIENT_END
);
!
found
&&
(
probe
[
i
]
!=
I2C_CLIENT_END
);
i
+=
2
)
{
i
+=
2
)
{
if
(((
adapter_id
==
address_data
->
probe
[
i
])
||
if
(((
adapter_id
==
probe
[
i
])
||
((
address_data
->
((
probe
[
i
]
==
ANY_I2C_BUS
)
&&
!
is_isa
))
probe
[
i
]
==
ANY_I2C_BUS
)
&&
!
is_isa
))
&&
(
addr
==
probe
[
i
+
1
]))
{
&&
(
addr
==
address_data
->
probe
[
i
+
1
]))
{
dev_dbg
(
&
adapter
->
dev
,
"found probe parameter for adapter %d, addr %04x
\n
"
,
adapter_id
,
addr
);
dev_dbg
(
&
adapter
->
dev
,
"found probe parameter for adapter %d, addr %04x
\n
"
,
adapter_id
,
addr
);
found
=
1
;
found
=
1
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment