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
82331045
Commit
82331045
authored
Dec 26, 2004
by
Jeff Garzik
Browse files
Options
Browse Files
Download
Plain Diff
Merge pobox.com:/garz/repo/netdev-2.6/6pack
into pobox.com:/garz/repo/net-drivers-2.6
parents
463f7d6a
43cbb0e0
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
179 additions
and
191 deletions
+179
-191
drivers/net/hamradio/6pack.c
drivers/net/hamradio/6pack.c
+179
-191
No files found.
drivers/net/hamradio/6pack.c
View file @
82331045
...
@@ -4,7 +4,7 @@
...
@@ -4,7 +4,7 @@
* kernel's AX.25 protocol layers.
* kernel's AX.25 protocol layers.
*
*
* Authors: Andreas Knsgen <ajk@iehk.rwth-aachen.de>
* Authors: Andreas Knsgen <ajk@iehk.rwth-aachen.de>
* Ralf Baechle D
O1G
RB <ralf@linux-mips.org>
* Ralf Baechle D
L5
RB <ralf@linux-mips.org>
*
*
* Quite a lot of stuff "stolen" by Joerg Reuter from slip.c, written by
* Quite a lot of stuff "stolen" by Joerg Reuter from slip.c, written by
*
*
...
@@ -119,11 +119,10 @@ struct sixpack {
...
@@ -119,11 +119,10 @@ struct sixpack {
unsigned
char
status1
;
unsigned
char
status1
;
unsigned
char
status2
;
unsigned
char
status2
;
unsigned
char
tx_enable
;
unsigned
char
tx_enable
;
unsigned
char
tnc_
ok
;
unsigned
char
tnc_
state
;
struct
timer_list
tx_t
;
struct
timer_list
tx_t
;
struct
timer_list
resync_t
;
struct
timer_list
resync_t
;
atomic_t
refcnt
;
atomic_t
refcnt
;
struct
semaphore
dead_sem
;
struct
semaphore
dead_sem
;
spinlock_t
lock
;
spinlock_t
lock
;
...
@@ -134,7 +133,6 @@ struct sixpack {
...
@@ -134,7 +133,6 @@ struct sixpack {
static
void
sp_start_tx_timer
(
struct
sixpack
*
);
static
void
sp_start_tx_timer
(
struct
sixpack
*
);
static
void
sixpack_decode
(
struct
sixpack
*
,
unsigned
char
[],
int
);
static
void
sixpack_decode
(
struct
sixpack
*
,
unsigned
char
[],
int
);
static
int
encode_sixpack
(
unsigned
char
*
,
unsigned
char
*
,
int
,
unsigned
char
);
static
int
encode_sixpack
(
unsigned
char
*
,
unsigned
char
*
,
int
,
unsigned
char
);
static
int
sixpack_init
(
struct
net_device
*
dev
);
/*
/*
* perform the persistence/slottime algorithm for CSMA access. If the
* perform the persistence/slottime algorithm for CSMA access. If the
...
@@ -187,6 +185,11 @@ static void sp_encaps(struct sixpack *sp, unsigned char *icp, int len)
...
@@ -187,6 +185,11 @@ static void sp_encaps(struct sixpack *sp, unsigned char *icp, int len)
goto
out_drop
;
goto
out_drop
;
}
}
if
(
len
>
sp
->
mtu
)
{
/* sp->mtu = AX25_MTU = max. PACLEN = 256 */
msg
=
"oversized transmit packet!"
;
goto
out_drop
;
}
if
(
p
[
0
]
>
5
)
{
if
(
p
[
0
]
>
5
)
{
msg
=
"invalid KISS command"
;
msg
=
"invalid KISS command"
;
goto
out_drop
;
goto
out_drop
;
...
@@ -249,8 +252,8 @@ static void sp_encaps(struct sixpack *sp, unsigned char *icp, int len)
...
@@ -249,8 +252,8 @@ static void sp_encaps(struct sixpack *sp, unsigned char *icp, int len)
out_drop:
out_drop:
sp
->
stats
.
tx_dropped
++
;
sp
->
stats
.
tx_dropped
++
;
netif_start_queue
(
sp
->
dev
);
netif_start_queue
(
sp
->
dev
);
if
(
net_ratelimit
())
printk
(
KERN_DEBUG
"%s: %s - dropped.
\n
"
,
sp
->
dev
->
name
,
msg
);
printk
(
KERN_DEBUG
"%s: %s - dropped.
\n
"
,
sp
->
dev
->
name
,
msg
);
return
;
}
}
/* Encapsulate an IP datagram and kick it into a TTY queue. */
/* Encapsulate an IP datagram and kick it into a TTY queue. */
...
@@ -313,10 +316,20 @@ static struct net_device_stats *sp_get_stats(struct net_device *dev)
...
@@ -313,10 +316,20 @@ static struct net_device_stats *sp_get_stats(struct net_device *dev)
return
&
sp
->
stats
;
return
&
sp
->
stats
;
}
}
static
int
sp_set_
dev_
mac_address
(
struct
net_device
*
dev
,
void
*
addr
)
static
int
sp_set_mac_address
(
struct
net_device
*
dev
,
void
*
addr
)
{
{
struct
sockaddr
*
sa
=
addr
;
struct
sockaddr_ax25
*
sa
=
addr
;
memcpy
(
dev
->
dev_addr
,
sa
->
sa_data
,
AX25_ADDR_LEN
);
if
(
sa
->
sax25_family
!=
AF_AX25
)
return
-
EINVAL
;
if
(
!
sa
->
sax25_ndigis
)
return
-
EINVAL
;
spin_lock_irq
(
&
dev
->
xmit_lock
);
memcpy
(
dev
->
dev_addr
,
&
sa
->
sax25_call
,
AX25_ADDR_LEN
);
spin_unlock_irq
(
&
dev
->
xmit_lock
);
return
0
;
return
0
;
}
}
...
@@ -337,7 +350,6 @@ static void sp_setup(struct net_device *dev)
...
@@ -337,7 +350,6 @@ static void sp_setup(struct net_device *dev)
{
'L'
<<
1
,
'I'
<<
1
,
'N'
<<
1
,
'U'
<<
1
,
'X'
<<
1
,
' '
<<
1
,
'1'
<<
1
};
{
'L'
<<
1
,
'I'
<<
1
,
'N'
<<
1
,
'U'
<<
1
,
'X'
<<
1
,
' '
<<
1
,
'1'
<<
1
};
/* Finish setting up the DEVICE info. */
/* Finish setting up the DEVICE info. */
dev
->
init
=
sixpack_init
;
dev
->
mtu
=
SIXP_MTU
;
dev
->
mtu
=
SIXP_MTU
;
dev
->
hard_start_xmit
=
sp_xmit
;
dev
->
hard_start_xmit
=
sp_xmit
;
dev
->
open
=
sp_open_dev
;
dev
->
open
=
sp_open_dev
;
...
@@ -345,7 +357,7 @@ static void sp_setup(struct net_device *dev)
...
@@ -345,7 +357,7 @@ static void sp_setup(struct net_device *dev)
dev
->
stop
=
sp_close
;
dev
->
stop
=
sp_close
;
dev
->
hard_header
=
sp_header
;
dev
->
hard_header
=
sp_header
;
dev
->
get_stats
=
sp_get_stats
;
dev
->
get_stats
=
sp_get_stats
;
dev
->
set_mac_address
=
sp_set_
dev_
mac_address
;
dev
->
set_mac_address
=
sp_set_mac_address
;
dev
->
hard_header_len
=
AX25_MAX_HEADER_LEN
;
dev
->
hard_header_len
=
AX25_MAX_HEADER_LEN
;
dev
->
addr_len
=
AX25_ADDR_LEN
;
dev
->
addr_len
=
AX25_ADDR_LEN
;
dev
->
type
=
ARPHRD_AX25
;
dev
->
type
=
ARPHRD_AX25
;
...
@@ -359,51 +371,9 @@ static void sp_setup(struct net_device *dev)
...
@@ -359,51 +371,9 @@ static void sp_setup(struct net_device *dev)
SET_MODULE_OWNER
(
dev
);
SET_MODULE_OWNER
(
dev
);
/* New-style flags. */
dev
->
flags
=
0
;
dev
->
flags
=
0
;
}
}
/* Find a free 6pack channel, and link in this `tty' line. */
static
inline
struct
sixpack
*
sp_alloc
(
void
)
{
struct
sixpack
*
sp
=
NULL
;
struct
net_device
*
dev
=
NULL
;
dev
=
alloc_netdev
(
sizeof
(
struct
sixpack
),
"sp%d"
,
sp_setup
);
if
(
!
dev
)
return
NULL
;
sp
=
netdev_priv
(
dev
);
sp
->
dev
=
dev
;
spin_lock_init
(
&
sp
->
lock
);
if
(
register_netdev
(
dev
))
goto
out_free
;
return
sp
;
out_free:
printk
(
KERN_WARNING
"sp_alloc() - register_netdev() failure.
\n
"
);
free_netdev
(
dev
);
return
NULL
;
}
/* Free a 6pack channel. */
static
inline
void
sp_free
(
struct
sixpack
*
sp
)
{
void
*
tmp
;
/* Free all 6pack frame buffers. */
if
((
tmp
=
xchg
(
&
sp
->
rbuff
,
NULL
))
!=
NULL
)
kfree
(
tmp
);
if
((
tmp
=
xchg
(
&
sp
->
xbuff
,
NULL
))
!=
NULL
)
kfree
(
tmp
);
}
/* Send one completely decapsulated IP datagram to the IP layer. */
/* Send one completely decapsulated IP datagram to the IP layer. */
/*
/*
...
@@ -482,6 +452,8 @@ static void sixpack_write_wakeup(struct tty_struct *tty)
...
@@ -482,6 +452,8 @@ static void sixpack_write_wakeup(struct tty_struct *tty)
struct
sixpack
*
sp
=
sp_get
(
tty
);
struct
sixpack
*
sp
=
sp_get
(
tty
);
int
actual
;
int
actual
;
if
(
!
sp
)
return
;
if
(
sp
->
xleft
<=
0
)
{
if
(
sp
->
xleft
<=
0
)
{
/* Now serial buffer is almost free & we can start
/* Now serial buffer is almost free & we can start
* transmission of another packet */
* transmission of another packet */
...
@@ -492,7 +464,7 @@ static void sixpack_write_wakeup(struct tty_struct *tty)
...
@@ -492,7 +464,7 @@ static void sixpack_write_wakeup(struct tty_struct *tty)
goto
out
;
goto
out
;
}
}
if
(
sp
->
tx_enable
==
1
)
{
if
(
sp
->
tx_enable
)
{
actual
=
tty
->
driver
->
write
(
tty
,
sp
->
xhead
,
sp
->
xleft
);
actual
=
tty
->
driver
->
write
(
tty
,
sp
->
xhead
,
sp
->
xleft
);
sp
->
xleft
-=
actual
;
sp
->
xleft
-=
actual
;
sp
->
xhead
+=
actual
;
sp
->
xhead
+=
actual
;
...
@@ -504,80 +476,6 @@ static void sixpack_write_wakeup(struct tty_struct *tty)
...
@@ -504,80 +476,6 @@ static void sixpack_write_wakeup(struct tty_struct *tty)
/* ----------------------------------------------------------------------- */
/* ----------------------------------------------------------------------- */
/* Open the low-level part of the 6pack channel. */
static
int
sp_open
(
struct
net_device
*
dev
)
{
struct
sixpack
*
sp
=
netdev_priv
(
dev
);
char
*
rbuff
,
*
xbuff
=
NULL
;
int
err
=
-
ENOBUFS
;
unsigned
long
len
;
/* !!! length of the buffers. MTU is IP MTU, not PACLEN! */
len
=
dev
->
mtu
*
2
;
rbuff
=
kmalloc
(
len
+
4
,
GFP_KERNEL
);
if
(
rbuff
==
NULL
)
goto
err_exit
;
xbuff
=
kmalloc
(
len
+
4
,
GFP_KERNEL
);
if
(
xbuff
==
NULL
)
goto
err_exit
;
spin_lock_bh
(
&
sp
->
lock
);
if
(
sp
->
tty
==
NULL
)
return
-
ENODEV
;
/*
* Allocate the 6pack frame buffers:
*
* rbuff Receive buffer.
* xbuff Transmit buffer.
*/
rbuff
=
xchg
(
&
sp
->
rbuff
,
rbuff
);
xbuff
=
xchg
(
&
sp
->
xbuff
,
xbuff
);
sp
->
mtu
=
AX25_MTU
+
73
;
sp
->
buffsize
=
len
;
sp
->
rcount
=
0
;
sp
->
rx_count
=
0
;
sp
->
rx_count_cooked
=
0
;
sp
->
xleft
=
0
;
sp
->
flags
=
0
;
/* Clear ESCAPE & ERROR flags */
sp
->
duplex
=
0
;
sp
->
tx_delay
=
SIXP_TXDELAY
;
sp
->
persistence
=
SIXP_PERSIST
;
sp
->
slottime
=
SIXP_SLOTTIME
;
sp
->
led_state
=
0x60
;
sp
->
status
=
1
;
sp
->
status1
=
1
;
sp
->
status2
=
0
;
sp
->
tnc_ok
=
0
;
sp
->
tx_enable
=
0
;
netif_start_queue
(
dev
);
init_timer
(
&
sp
->
tx_t
);
init_timer
(
&
sp
->
resync_t
);
spin_unlock_bh
(
&
sp
->
lock
);
err
=
0
;
err_exit:
if
(
xbuff
)
kfree
(
xbuff
);
if
(
rbuff
)
kfree
(
rbuff
);
return
err
;
}
static
int
sixpack_receive_room
(
struct
tty_struct
*
tty
)
static
int
sixpack_receive_room
(
struct
tty_struct
*
tty
)
{
{
return
65536
;
/* We can handle an infinite amount of data. :-) */
return
65536
;
/* We can handle an infinite amount of data. :-) */
...
@@ -629,14 +527,45 @@ static void sixpack_receive_buf(struct tty_struct *tty,
...
@@ -629,14 +527,45 @@ static void sixpack_receive_buf(struct tty_struct *tty,
* decode_prio_command
* decode_prio_command
*/
*/
#define TNC_UNINITIALIZED 0
#define TNC_UNSYNC_STARTUP 1
#define TNC_UNSYNCED 2
#define TNC_IN_SYNC 3
static
void
__tnc_set_sync_state
(
struct
sixpack
*
sp
,
int
new_tnc_state
)
{
char
*
msg
;
switch
(
new_tnc_state
)
{
default:
/* gcc oh piece-o-crap ... */
case
TNC_UNSYNC_STARTUP
:
msg
=
"Synchronizing with TNC"
;
break
;
case
TNC_UNSYNCED
:
msg
=
"Lost synchronization with TNC
\n
"
;
break
;
case
TNC_IN_SYNC
:
msg
=
"Found TNC"
;
break
;
}
sp
->
tnc_state
=
new_tnc_state
;
printk
(
KERN_INFO
"%s: %s
\n
"
,
sp
->
dev
->
name
,
msg
);
}
static
inline
void
tnc_set_sync_state
(
struct
sixpack
*
sp
,
int
new_tnc_state
)
{
int
old_tnc_state
=
sp
->
tnc_state
;
if
(
old_tnc_state
!=
new_tnc_state
)
__tnc_set_sync_state
(
sp
,
new_tnc_state
);
}
static
void
resync_tnc
(
unsigned
long
channel
)
static
void
resync_tnc
(
unsigned
long
channel
)
{
{
struct
sixpack
*
sp
=
(
struct
sixpack
*
)
channel
;
struct
sixpack
*
sp
=
(
struct
sixpack
*
)
channel
;
struct
net_device
*
dev
=
sp
->
dev
;
static
char
resync_cmd
=
0xe8
;
static
char
resync_cmd
=
0xe8
;
printk
(
KERN_INFO
"%s: resyncing TNC
\n
"
,
dev
->
name
);
/* clear any data that might have been received */
/* clear any data that might have been received */
sp
->
rx_count
=
0
;
sp
->
rx_count
=
0
;
...
@@ -647,7 +576,6 @@ static void resync_tnc(unsigned long channel)
...
@@ -647,7 +576,6 @@ static void resync_tnc(unsigned long channel)
sp
->
status
=
1
;
sp
->
status
=
1
;
sp
->
status1
=
1
;
sp
->
status1
=
1
;
sp
->
status2
=
0
;
sp
->
status2
=
0
;
sp
->
tnc_ok
=
0
;
/* resync the TNC */
/* resync the TNC */
...
@@ -669,6 +597,8 @@ static inline int tnc_init(struct sixpack *sp)
...
@@ -669,6 +597,8 @@ static inline int tnc_init(struct sixpack *sp)
{
{
unsigned
char
inbyte
=
0xe8
;
unsigned
char
inbyte
=
0xe8
;
tnc_set_sync_state
(
sp
,
TNC_UNSYNC_STARTUP
);
sp
->
tty
->
driver
->
write
(
sp
->
tty
,
&
inbyte
,
1
);
sp
->
tty
->
driver
->
write
(
sp
->
tty
,
&
inbyte
,
1
);
del_timer
(
&
sp
->
resync_t
);
del_timer
(
&
sp
->
resync_t
);
...
@@ -689,31 +619,91 @@ static inline int tnc_init(struct sixpack *sp)
...
@@ -689,31 +619,91 @@ static inline int tnc_init(struct sixpack *sp)
*/
*/
static
int
sixpack_open
(
struct
tty_struct
*
tty
)
static
int
sixpack_open
(
struct
tty_struct
*
tty
)
{
{
char
*
rbuff
=
NULL
,
*
xbuff
=
NULL
;
struct
net_device
*
dev
;
struct
sixpack
*
sp
;
struct
sixpack
*
sp
;
unsigned
long
len
;
int
err
=
0
;
int
err
=
0
;
if
(
!
capable
(
CAP_NET_ADMIN
))
if
(
!
capable
(
CAP_NET_ADMIN
))
return
-
EPERM
;
return
-
EPERM
;
sp
=
sp_alloc
(
);
dev
=
alloc_netdev
(
sizeof
(
struct
sixpack
),
"sp%d"
,
sp_setup
);
if
(
!
sp
)
{
if
(
!
dev
)
{
err
=
-
ENOMEM
;
err
=
-
ENOMEM
;
goto
out
;
goto
out
;
}
}
sp
->
tty
=
tty
;
sp
=
netdev_priv
(
dev
);
sp
->
dev
=
dev
;
spin_lock_init
(
&
sp
->
lock
);
atomic_set
(
&
sp
->
refcnt
,
1
);
atomic_set
(
&
sp
->
refcnt
,
1
);
init_MUTEX_LOCKED
(
&
sp
->
dead_sem
);
init_MUTEX_LOCKED
(
&
sp
->
dead_sem
);
/* Perform the low-level 6pack initialization. */
/* !!! length of the buffers. MTU is IP MTU, not PACLEN! */
if
((
err
=
sp_open
(
sp
->
dev
)))
goto
out
;
len
=
dev
->
mtu
*
2
;
rbuff
=
kmalloc
(
len
+
4
,
GFP_KERNEL
);
xbuff
=
kmalloc
(
len
+
4
,
GFP_KERNEL
);
if
(
rbuff
==
NULL
||
xbuff
==
NULL
)
{
err
=
-
ENOBUFS
;
goto
out_free
;
}
spin_lock_bh
(
&
sp
->
lock
);
sp
->
tty
=
tty
;
sp
->
rbuff
=
rbuff
;
sp
->
xbuff
=
xbuff
;
sp
->
mtu
=
AX25_MTU
+
73
;
sp
->
buffsize
=
len
;
sp
->
rcount
=
0
;
sp
->
rx_count
=
0
;
sp
->
rx_count_cooked
=
0
;
sp
->
xleft
=
0
;
sp
->
flags
=
0
;
/* Clear ESCAPE & ERROR flags */
sp
->
duplex
=
0
;
sp
->
tx_delay
=
SIXP_TXDELAY
;
sp
->
persistence
=
SIXP_PERSIST
;
sp
->
slottime
=
SIXP_SLOTTIME
;
sp
->
led_state
=
0x60
;
sp
->
status
=
1
;
sp
->
status1
=
1
;
sp
->
status2
=
0
;
sp
->
tx_enable
=
0
;
netif_start_queue
(
dev
);
init_timer
(
&
sp
->
tx_t
);
init_timer
(
&
sp
->
resync_t
);
spin_unlock_bh
(
&
sp
->
lock
);
/* Done. We have linked the TTY line to a channel. */
/* Done. We have linked the TTY line to a channel. */
tty
->
disc_data
=
sp
;
tty
->
disc_data
=
sp
;
/* Now we're ready to register. */
if
(
register_netdev
(
dev
))
goto
out_free
;
tnc_init
(
sp
);
tnc_init
(
sp
);
return
0
;
out_free:
kfree
(
xbuff
);
kfree
(
rbuff
);
if
(
dev
)
free_netdev
(
dev
);
out:
out:
return
err
;
return
err
;
}
}
...
@@ -727,7 +717,7 @@ static int sixpack_open(struct tty_struct *tty)
...
@@ -727,7 +717,7 @@ static int sixpack_open(struct tty_struct *tty)
*/
*/
static
void
sixpack_close
(
struct
tty_struct
*
tty
)
static
void
sixpack_close
(
struct
tty_struct
*
tty
)
{
{
struct
sixpack
*
sp
=
(
struct
sixpack
*
)
tty
->
disc_data
;
struct
sixpack
*
sp
;
write_lock
(
&
disc_data_lock
);
write_lock
(
&
disc_data_lock
);
sp
=
tty
->
disc_data
;
sp
=
tty
->
disc_data
;
...
@@ -743,16 +733,14 @@ static void sixpack_close(struct tty_struct *tty)
...
@@ -743,16 +733,14 @@ static void sixpack_close(struct tty_struct *tty)
if
(
!
atomic_dec_and_test
(
&
sp
->
refcnt
))
if
(
!
atomic_dec_and_test
(
&
sp
->
refcnt
))
down
(
&
sp
->
dead_sem
);
down
(
&
sp
->
dead_sem
);
unregister_netdev
(
sp
->
dev
);
del_timer
(
&
sp
->
tx_t
);
del_timer
(
&
sp
->
tx_t
);
del_timer
(
&
sp
->
resync_t
);
del_timer
(
&
sp
->
resync_t
);
sp_free
(
sp
);
/* Free all 6pack frame buffers. */
unregister_netdev
(
sp
->
dev
);
kfree
(
sp
->
rbuff
);
}
kfree
(
sp
->
xbuff
);
static
int
sp_set_mac_address
(
struct
net_device
*
dev
,
void
__user
*
addr
)
{
return
copy_from_user
(
dev
->
dev_addr
,
addr
,
AX25_ADDR_LEN
)
?
-
EFAULT
:
0
;
}
}
/* Perform I/O control on an active 6pack channel. */
/* Perform I/O control on an active 6pack channel. */
...
@@ -760,6 +748,7 @@ static int sixpack_ioctl(struct tty_struct *tty, struct file *file,
...
@@ -760,6 +748,7 @@ static int sixpack_ioctl(struct tty_struct *tty, struct file *file,
unsigned
int
cmd
,
unsigned
long
arg
)
unsigned
int
cmd
,
unsigned
long
arg
)
{
{
struct
sixpack
*
sp
=
sp_get
(
tty
);
struct
sixpack
*
sp
=
sp_get
(
tty
);
struct
net_device
*
dev
=
sp
->
dev
;
unsigned
int
tmp
,
err
;
unsigned
int
tmp
,
err
;
if
(
!
sp
)
if
(
!
sp
)
...
@@ -767,8 +756,8 @@ static int sixpack_ioctl(struct tty_struct *tty, struct file *file,
...
@@ -767,8 +756,8 @@ static int sixpack_ioctl(struct tty_struct *tty, struct file *file,
switch
(
cmd
)
{
switch
(
cmd
)
{
case
SIOCGIFNAME
:
case
SIOCGIFNAME
:
err
=
copy_to_user
((
void
__user
*
)
arg
,
sp
->
dev
->
name
,
err
=
copy_to_user
((
void
*
)
arg
,
dev
->
name
,
strlen
(
sp
->
dev
->
name
)
+
1
)
?
-
EFAULT
:
0
;
strlen
(
dev
->
name
)
+
1
)
?
-
EFAULT
:
0
;
break
;
break
;
case
SIOCGIFENCAP
:
case
SIOCGIFENCAP
:
...
@@ -782,16 +771,30 @@ static int sixpack_ioctl(struct tty_struct *tty, struct file *file,
...
@@ -782,16 +771,30 @@ static int sixpack_ioctl(struct tty_struct *tty, struct file *file,
}
}
sp
->
mode
=
tmp
;
sp
->
mode
=
tmp
;
sp
->
dev
->
addr_len
=
AX25_ADDR_LEN
;
/* sizeof an AX.25 addr */
dev
->
addr_len
=
AX25_ADDR_LEN
;
sp
->
dev
->
hard_header_len
=
AX25_KISS_HEADER_LEN
+
AX25_MAX_HEADER_LEN
+
3
;
dev
->
hard_header_len
=
AX25_KISS_HEADER_LEN
+
sp
->
dev
->
type
=
ARPHRD_AX25
;
AX25_MAX_HEADER_LEN
+
3
;
dev
->
type
=
ARPHRD_AX25
;
err
=
0
;
err
=
0
;
break
;
break
;
case
SIOCSIFHWADDR
:
case
SIOCSIFHWADDR
:
{
err
=
sp_set_mac_address
(
sp
->
dev
,
(
void
__user
*
)
arg
);
char
addr
[
AX25_ADDR_LEN
];
if
(
copy_from_user
(
&
addr
,
(
void
__user
*
)
arg
,
AX25_ADDR_LEN
))
{
err
=
-
EFAULT
;
break
;
break
;
}
spin_lock_irq
(
&
dev
->
xmit_lock
);
memcpy
(
dev
->
dev_addr
,
&
addr
,
AX25_ADDR_LEN
);
spin_unlock_irq
(
&
dev
->
xmit_lock
);
err
=
0
;
break
;
}
/* Allow stty to read, but not set, the serial port */
/* Allow stty to read, but not set, the serial port */
case
TCGETS
:
case
TCGETS
:
...
@@ -800,7 +803,7 @@ static int sixpack_ioctl(struct tty_struct *tty, struct file *file,
...
@@ -800,7 +803,7 @@ static int sixpack_ioctl(struct tty_struct *tty, struct file *file,
break
;
break
;
default:
default:
return
-
ENOIOCTLCMD
;
err
=
-
ENOIOCTLCMD
;
}
}
sp_put
(
sp
);
sp_put
(
sp
);
...
@@ -808,7 +811,6 @@ static int sixpack_ioctl(struct tty_struct *tty, struct file *file,
...
@@ -808,7 +811,6 @@ static int sixpack_ioctl(struct tty_struct *tty, struct file *file,
return
err
;
return
err
;
}
}
/* Fill in our line protocol discipline */
static
struct
tty_ldisc
sp_ldisc
=
{
static
struct
tty_ldisc
sp_ldisc
=
{
.
owner
=
THIS_MODULE
,
.
owner
=
THIS_MODULE
,
.
magic
=
TTY_LDISC_MAGIC
,
.
magic
=
TTY_LDISC_MAGIC
,
...
@@ -823,8 +825,10 @@ static struct tty_ldisc sp_ldisc = {
...
@@ -823,8 +825,10 @@ static struct tty_ldisc sp_ldisc = {
/* Initialize 6pack control device -- register 6pack line discipline */
/* Initialize 6pack control device -- register 6pack line discipline */
static
char
msg_banner
[]
__initdata
=
KERN_INFO
"AX.25: 6pack driver, "
SIXPACK_VERSION
"
\n
"
;
static
char
msg_banner
[]
__initdata
=
KERN_INFO
\
static
char
msg_regfail
[]
__initdata
=
KERN_ERR
"6pack: can't register line discipline (err = %d)
\n
"
;
"AX.25: 6pack driver, "
SIXPACK_VERSION
"
\n
"
;
static
char
msg_regfail
[]
__initdata
=
KERN_ERR
\
"6pack: can't register line discipline (err = %d)
\n
"
;
static
int
__init
sixpack_init_driver
(
void
)
static
int
__init
sixpack_init_driver
(
void
)
{
{
...
@@ -839,7 +843,8 @@ static int __init sixpack_init_driver(void)
...
@@ -839,7 +843,8 @@ static int __init sixpack_init_driver(void)
return
status
;
return
status
;
}
}
static
const
char
msg_unregfail
[]
__exitdata
=
KERN_ERR
"6pack: can't unregister line discipline (err = %d)
\n
"
;
static
const
char
msg_unregfail
[]
__exitdata
=
KERN_ERR
\
"6pack: can't unregister line discipline (err = %d)
\n
"
;
static
void
__exit
sixpack_exit_driver
(
void
)
static
void
__exit
sixpack_exit_driver
(
void
)
{
{
...
@@ -849,22 +854,6 @@ static void __exit sixpack_exit_driver(void)
...
@@ -849,22 +854,6 @@ static void __exit sixpack_exit_driver(void)
printk
(
msg_unregfail
,
ret
);
printk
(
msg_unregfail
,
ret
);
}
}
/* Initialize the 6pack driver. Called by DDI. */
static
int
sixpack_init
(
struct
net_device
*
dev
)
{
struct
sixpack
*
sp
=
netdev_priv
(
dev
);
if
(
sp
==
NULL
)
/* Allocation failed ?? */
return
-
ENODEV
;
/* Set up the "6pack Control Block". (And clear statistics) */
memset
(
sp
,
0
,
sizeof
(
struct
sixpack
));
sp
->
dev
=
dev
;
return
0
;
}
/* encode an AX.25 packet into 6pack */
/* encode an AX.25 packet into 6pack */
static
int
encode_sixpack
(
unsigned
char
*
tx_buf
,
unsigned
char
*
tx_buf_raw
,
static
int
encode_sixpack
(
unsigned
char
*
tx_buf
,
unsigned
char
*
tx_buf_raw
,
...
@@ -905,7 +894,7 @@ static int encode_sixpack(unsigned char *tx_buf, unsigned char *tx_buf_raw,
...
@@ -905,7 +894,7 @@ static int encode_sixpack(unsigned char *tx_buf, unsigned char *tx_buf_raw,
/* decode 4 sixpack-encoded bytes into 3 data bytes */
/* decode 4 sixpack-encoded bytes into 3 data bytes */
static
void
decode_data
(
unsigned
char
inbyte
,
struct
sixpack
*
sp
)
static
void
decode_data
(
struct
sixpack
*
sp
,
unsigned
char
inbyte
)
{
{
unsigned
char
*
buf
;
unsigned
char
*
buf
;
...
@@ -927,7 +916,7 @@ static void decode_data(unsigned char inbyte, struct sixpack *sp)
...
@@ -927,7 +916,7 @@ static void decode_data(unsigned char inbyte, struct sixpack *sp)
/* identify and execute a 6pack priority command byte */
/* identify and execute a 6pack priority command byte */
static
void
decode_prio_command
(
unsigned
char
cmd
,
struct
sixpack
*
sp
)
static
void
decode_prio_command
(
struct
sixpack
*
sp
,
unsigned
char
cmd
)
{
{
unsigned
char
channel
;
unsigned
char
channel
;
int
actual
;
int
actual
;
...
@@ -971,7 +960,7 @@ static void decode_prio_command(unsigned char cmd, struct sixpack *sp)
...
@@ -971,7 +960,7 @@ static void decode_prio_command(unsigned char cmd, struct sixpack *sp)
/* if the state byte has been received, the TNC is present,
/* if the state byte has been received, the TNC is present,
so the resync timer can be reset. */
so the resync timer can be reset. */
if
(
sp
->
tnc_
ok
==
1
)
{
if
(
sp
->
tnc_
state
==
TNC_IN_SYNC
)
{
del_timer
(
&
sp
->
resync_t
);
del_timer
(
&
sp
->
resync_t
);
sp
->
resync_t
.
data
=
(
unsigned
long
)
sp
;
sp
->
resync_t
.
data
=
(
unsigned
long
)
sp
;
sp
->
resync_t
.
function
=
resync_tnc
;
sp
->
resync_t
.
function
=
resync_tnc
;
...
@@ -984,7 +973,7 @@ static void decode_prio_command(unsigned char cmd, struct sixpack *sp)
...
@@ -984,7 +973,7 @@ static void decode_prio_command(unsigned char cmd, struct sixpack *sp)
/* identify and execute a standard 6pack command byte */
/* identify and execute a standard 6pack command byte */
static
void
decode_std_command
(
unsigned
char
cmd
,
struct
sixpack
*
sp
)
static
void
decode_std_command
(
struct
sixpack
*
sp
,
unsigned
char
cmd
)
{
{
unsigned
char
checksum
=
0
,
rest
=
0
,
channel
;
unsigned
char
checksum
=
0
,
rest
=
0
,
channel
;
short
i
;
short
i
;
...
@@ -1005,7 +994,7 @@ static void decode_std_command(unsigned char cmd, struct sixpack *sp)
...
@@ -1005,7 +994,7 @@ static void decode_std_command(unsigned char cmd, struct sixpack *sp)
rest
=
sp
->
rx_count
;
rest
=
sp
->
rx_count
;
if
(
rest
!=
0
)
if
(
rest
!=
0
)
for
(
i
=
rest
;
i
<=
3
;
i
++
)
for
(
i
=
rest
;
i
<=
3
;
i
++
)
decode_data
(
0
,
sp
);
decode_data
(
sp
,
0
);
if
(
rest
==
2
)
if
(
rest
==
2
)
sp
->
rx_count_cooked
-=
2
;
sp
->
rx_count_cooked
-=
2
;
else
if
(
rest
==
3
)
else
if
(
rest
==
3
)
...
@@ -1033,7 +1022,7 @@ static void decode_std_command(unsigned char cmd, struct sixpack *sp)
...
@@ -1033,7 +1022,7 @@ static void decode_std_command(unsigned char cmd, struct sixpack *sp)
/* decode a 6pack packet */
/* decode a 6pack packet */
static
void
static
void
sixpack_decode
(
struct
sixpack
*
sp
,
unsigned
char
pre_rbuff
[]
,
int
count
)
sixpack_decode
(
struct
sixpack
*
sp
,
unsigned
char
*
pre_rbuff
,
int
count
)
{
{
unsigned
char
inbyte
;
unsigned
char
inbyte
;
int
count1
;
int
count1
;
...
@@ -1041,16 +1030,15 @@ sixpack_decode(struct sixpack *sp, unsigned char pre_rbuff[], int count)
...
@@ -1041,16 +1030,15 @@ sixpack_decode(struct sixpack *sp, unsigned char pre_rbuff[], int count)
for
(
count1
=
0
;
count1
<
count
;
count1
++
)
{
for
(
count1
=
0
;
count1
<
count
;
count1
++
)
{
inbyte
=
pre_rbuff
[
count1
];
inbyte
=
pre_rbuff
[
count1
];
if
(
inbyte
==
SIXP_FOUND_TNC
)
{
if
(
inbyte
==
SIXP_FOUND_TNC
)
{
printk
(
KERN_INFO
"6pack: TNC found.
\n
"
);
tnc_set_sync_state
(
sp
,
TNC_IN_SYNC
);
sp
->
tnc_ok
=
1
;
del_timer
(
&
sp
->
resync_t
);
del_timer
(
&
sp
->
resync_t
);
}
}
if
((
inbyte
&
SIXP_PRIO_CMD_MASK
)
!=
0
)
if
((
inbyte
&
SIXP_PRIO_CMD_MASK
)
!=
0
)
decode_prio_command
(
inbyte
,
sp
);
decode_prio_command
(
sp
,
inbyte
);
else
if
((
inbyte
&
SIXP_STD_CMD_MASK
)
!=
0
)
else
if
((
inbyte
&
SIXP_STD_CMD_MASK
)
!=
0
)
decode_std_command
(
inbyte
,
sp
);
decode_std_command
(
sp
,
inbyte
);
else
if
((
sp
->
status
&
SIXP_RX_DCD_MASK
)
==
SIXP_RX_DCD_MASK
)
else
if
((
sp
->
status
&
SIXP_RX_DCD_MASK
)
==
SIXP_RX_DCD_MASK
)
decode_data
(
inbyte
,
sp
);
decode_data
(
sp
,
inbyte
);
}
}
}
}
...
...
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