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
a2ad031d
Commit
a2ad031d
authored
May 06, 2003
by
James Bottomley
Browse files
Options
Browse Files
Download
Plain Diff
Merge hch/andmike changes
parents
f6842023
154173a0
Changes
13
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
230 additions
and
174 deletions
+230
-174
drivers/acorn/scsi/acornscsi.c
drivers/acorn/scsi/acornscsi.c
+0
-1
drivers/acorn/scsi/arxescsi.c
drivers/acorn/scsi/arxescsi.c
+0
-1
drivers/acorn/scsi/cumana_1.c
drivers/acorn/scsi/cumana_1.c
+0
-1
drivers/acorn/scsi/cumana_2.c
drivers/acorn/scsi/cumana_2.c
+0
-1
drivers/acorn/scsi/eesox.c
drivers/acorn/scsi/eesox.c
+0
-1
drivers/acorn/scsi/oak.c
drivers/acorn/scsi/oak.c
+0
-1
drivers/acorn/scsi/powertec.c
drivers/acorn/scsi/powertec.c
+0
-1
drivers/scsi/hosts.c
drivers/scsi/hosts.c
+5
-18
drivers/scsi/hosts.h
drivers/scsi/hosts.h
+14
-6
drivers/scsi/scsi_debug.c
drivers/scsi/scsi_debug.c
+113
-102
drivers/scsi/scsi_debug.h
drivers/scsi/scsi_debug.h
+1
-0
drivers/scsi/scsi_scan.c
drivers/scsi/scsi_scan.c
+1
-3
drivers/scsi/scsi_sysfs.c
drivers/scsi/scsi_sysfs.c
+96
-38
No files found.
drivers/acorn/scsi/acornscsi.c
View file @
a2ad031d
...
@@ -3079,7 +3079,6 @@ static struct ecard_driver acornscsi_driver = {
...
@@ -3079,7 +3079,6 @@ static struct ecard_driver acornscsi_driver = {
.
remove
=
__devexit_p
(
acornscsi_remove
),
.
remove
=
__devexit_p
(
acornscsi_remove
),
.
id_table
=
acornscsi_cids
,
.
id_table
=
acornscsi_cids
,
.
drv
=
{
.
drv
=
{
.
devclass
=
&
shost_devclass
,
.
name
=
"acornscsi"
,
.
name
=
"acornscsi"
,
},
},
};
};
...
...
drivers/acorn/scsi/arxescsi.c
View file @
a2ad031d
...
@@ -397,7 +397,6 @@ static struct ecard_driver arxescsi_driver = {
...
@@ -397,7 +397,6 @@ static struct ecard_driver arxescsi_driver = {
.
remove
=
__devexit_p
(
arxescsi_remove
),
.
remove
=
__devexit_p
(
arxescsi_remove
),
.
id_table
=
arxescsi_cids
,
.
id_table
=
arxescsi_cids
,
.
drv
=
{
.
drv
=
{
.
devclass
=
&
shost_devclass
,
.
name
=
"arxescsi"
,
.
name
=
"arxescsi"
,
},
},
};
};
...
...
drivers/acorn/scsi/cumana_1.c
View file @
a2ad031d
...
@@ -334,7 +334,6 @@ static struct ecard_driver cumanascsi1_driver = {
...
@@ -334,7 +334,6 @@ static struct ecard_driver cumanascsi1_driver = {
.
remove
=
__devexit_p
(
cumanascsi1_remove
),
.
remove
=
__devexit_p
(
cumanascsi1_remove
),
.
id_table
=
cumanascsi1_cids
,
.
id_table
=
cumanascsi1_cids
,
.
drv
=
{
.
drv
=
{
.
devclass
=
&
shost_devclass
,
.
name
=
"cumanascsi1"
,
.
name
=
"cumanascsi1"
,
},
},
};
};
...
...
drivers/acorn/scsi/cumana_2.c
View file @
a2ad031d
...
@@ -552,7 +552,6 @@ static struct ecard_driver cumanascsi2_driver = {
...
@@ -552,7 +552,6 @@ static struct ecard_driver cumanascsi2_driver = {
.
remove
=
__devexit_p
(
cumanascsi2_remove
),
.
remove
=
__devexit_p
(
cumanascsi2_remove
),
.
id_table
=
cumanascsi2_cids
,
.
id_table
=
cumanascsi2_cids
,
.
drv
=
{
.
drv
=
{
.
devclass
=
&
shost_devclass
,
.
name
=
"cumanascsi2"
,
.
name
=
"cumanascsi2"
,
},
},
};
};
...
...
drivers/acorn/scsi/eesox.c
View file @
a2ad031d
...
@@ -660,7 +660,6 @@ static struct ecard_driver eesoxscsi_driver = {
...
@@ -660,7 +660,6 @@ static struct ecard_driver eesoxscsi_driver = {
.
remove
=
__devexit_p
(
eesoxscsi_remove
),
.
remove
=
__devexit_p
(
eesoxscsi_remove
),
.
id_table
=
eesoxscsi_cids
,
.
id_table
=
eesoxscsi_cids
,
.
drv
=
{
.
drv
=
{
.
devclass
=
&
shost_devclass
,
.
name
=
"eesoxscsi"
,
.
name
=
"eesoxscsi"
,
},
},
};
};
...
...
drivers/acorn/scsi/oak.c
View file @
a2ad031d
...
@@ -192,7 +192,6 @@ static struct ecard_driver oakscsi_driver = {
...
@@ -192,7 +192,6 @@ static struct ecard_driver oakscsi_driver = {
.
remove
=
__devexit_p
(
oakscsi_remove
),
.
remove
=
__devexit_p
(
oakscsi_remove
),
.
id_table
=
oakscsi_cids
,
.
id_table
=
oakscsi_cids
,
.
drv
=
{
.
drv
=
{
.
devclass
=
&
shost_devclass
,
.
name
=
"oakscsi"
,
.
name
=
"oakscsi"
,
},
},
};
};
...
...
drivers/acorn/scsi/powertec.c
View file @
a2ad031d
...
@@ -475,7 +475,6 @@ static struct ecard_driver powertecscsi_driver = {
...
@@ -475,7 +475,6 @@ static struct ecard_driver powertecscsi_driver = {
.
remove
=
__devexit_p
(
powertecscsi_remove
),
.
remove
=
__devexit_p
(
powertecscsi_remove
),
.
id_table
=
powertecscsi_cids
,
.
id_table
=
powertecscsi_cids
,
.
drv
=
{
.
drv
=
{
.
devclass
=
&
shost_devclass
,
.
name
=
"powertecscsi"
,
.
name
=
"powertecscsi"
,
},
},
};
};
...
...
drivers/scsi/hosts.c
View file @
a2ad031d
...
@@ -193,16 +193,6 @@ static int scsi_host_legacy_release(struct Scsi_Host *shost)
...
@@ -193,16 +193,6 @@ static int scsi_host_legacy_release(struct Scsi_Host *shost)
return
0
;
return
0
;
}
}
static
int
scsi_remove_legacy_host
(
struct
Scsi_Host
*
shost
)
{
int
error
;
error
=
scsi_remove_host
(
shost
);
if
(
!
error
)
(
*
shost
->
hostt
->
release
)(
shost
);
return
0
;
}
static
int
scsi_check_device_busy
(
struct
scsi_device
*
sdev
)
static
int
scsi_check_device_busy
(
struct
scsi_device
*
sdev
)
{
{
struct
Scsi_Host
*
shost
=
sdev
->
host
;
struct
Scsi_Host
*
shost
=
sdev
->
host
;
...
@@ -268,11 +258,8 @@ int scsi_remove_host(struct Scsi_Host *shost)
...
@@ -268,11 +258,8 @@ int scsi_remove_host(struct Scsi_Host *shost)
list_for_each_entry
(
sdev
,
&
shost
->
my_devices
,
siblings
)
list_for_each_entry
(
sdev
,
&
shost
->
my_devices
,
siblings
)
sdev
->
online
=
FALSE
;
sdev
->
online
=
FALSE
;
list_for_each_entry
(
sdev
,
&
shost
->
my_devices
,
siblings
)
if
(
scsi_check_device_busy
(
sdev
))
return
1
;
scsi_forget_host
(
shost
);
scsi_forget_host
(
shost
);
scsi_sysfs_remove_host
(
shost
);
return
0
;
return
0
;
}
}
...
@@ -293,9 +280,9 @@ int scsi_add_host(struct Scsi_Host *shost, struct device *dev)
...
@@ -293,9 +280,9 @@ int scsi_add_host(struct Scsi_Host *shost, struct device *dev)
printk
(
KERN_INFO
"scsi%d : %s
\n
"
,
shost
->
host_no
,
printk
(
KERN_INFO
"scsi%d : %s
\n
"
,
shost
->
host_no
,
sht
->
info
?
sht
->
info
(
shost
)
:
sht
->
name
);
sht
->
info
?
sht
->
info
(
shost
)
:
sht
->
name
);
if
(
dev
)
{
error
=
scsi_sysfs_add_host
(
shost
,
dev
);
shost
->
host_gendev
=
dev
;
if
(
error
)
}
return
error
;
scsi_scan_host
(
shost
);
scsi_scan_host
(
shost
);
...
@@ -531,7 +518,7 @@ int scsi_register_host(Scsi_Host_Template *shost_tp)
...
@@ -531,7 +518,7 @@ int scsi_register_host(Scsi_Host_Template *shost_tp)
**/
**/
int
scsi_unregister_host
(
Scsi_Host_Template
*
shost_tp
)
int
scsi_unregister_host
(
Scsi_Host_Template
*
shost_tp
)
{
{
scsi_tp_for_each_host
(
shost_tp
,
scsi_remove_
legacy_
host
);
scsi_tp_for_each_host
(
shost_tp
,
scsi_remove_host
);
return
0
;
return
0
;
}
}
...
...
drivers/scsi/hosts.h
View file @
a2ad031d
...
@@ -482,9 +482,10 @@ struct Scsi_Host
...
@@ -482,9 +482,10 @@ struct Scsi_Host
unsigned
int
max_host_blocked
;
unsigned
int
max_host_blocked
;
/*
/*
* Support for
driverfs filesystem
* Support for
sysfs
*/
*/
struct
device
*
host_gendev
;
struct
device
host_gendev
;
struct
class_device
class_dev
;
/*
/*
* We should ensure that this is aligned, both for better performance
* We should ensure that this is aligned, both for better performance
...
@@ -495,7 +496,10 @@ struct Scsi_Host
...
@@ -495,7 +496,10 @@ struct Scsi_Host
__attribute__
((
aligned
(
sizeof
(
unsigned
long
))));
__attribute__
((
aligned
(
sizeof
(
unsigned
long
))));
};
};
#define to_scsi_host(d) d->driver_data
/* Major logical breakage, but we compile again... */
#define dev_to_shost(d) \
container_of(d, struct Scsi_Host, host_gendev)
#define class_to_shost(d) \
container_of(d, struct Scsi_Host, class_dev)
/*
/*
* These two functions are used to allocate and free a pseudo device
* These two functions are used to allocate and free a pseudo device
...
@@ -519,12 +523,12 @@ static inline void scsi_assign_lock(struct Scsi_Host *shost, spinlock_t *lock)
...
@@ -519,12 +523,12 @@ static inline void scsi_assign_lock(struct Scsi_Host *shost, spinlock_t *lock)
static
inline
void
scsi_set_device
(
struct
Scsi_Host
*
shost
,
static
inline
void
scsi_set_device
(
struct
Scsi_Host
*
shost
,
struct
device
*
dev
)
struct
device
*
dev
)
{
{
shost
->
host_gendev
=
dev
;
shost
->
host_gendev
.
parent
=
dev
;
}
}
static
inline
struct
device
*
scsi_get_device
(
struct
Scsi_Host
*
shost
)
static
inline
struct
device
*
scsi_get_device
(
struct
Scsi_Host
*
shost
)
{
{
return
shost
->
host_gendev
;
return
shost
->
host_gendev
.
parent
;
}
}
struct
Scsi_Device_Template
struct
Scsi_Device_Template
...
@@ -591,6 +595,10 @@ static inline Scsi_Device *scsi_find_device(struct Scsi_Host *shost,
...
@@ -591,6 +595,10 @@ static inline Scsi_Device *scsi_find_device(struct Scsi_Host *shost,
*/
*/
extern
int
scsi_upper_driver_register
(
struct
Scsi_Device_Template
*
);
extern
int
scsi_upper_driver_register
(
struct
Scsi_Device_Template
*
);
extern
void
scsi_upper_driver_unregister
(
struct
Scsi_Device_Template
*
);
extern
void
scsi_upper_driver_unregister
(
struct
Scsi_Device_Template
*
);
extern
int
scsi_sysfs_add_host
(
struct
Scsi_Host
*
,
struct
device
*
);
extern
void
scsi_sysfs_remove_host
(
struct
Scsi_Host
*
);
extern
void
scsi_free_sdev
(
struct
scsi_device
*
);
extern
struct
class
shost_class
;
extern
struct
class
shost_class
;
...
...
drivers/scsi/scsi_debug.c
View file @
a2ad031d
This diff is collapsed.
Click to expand it.
drivers/scsi/scsi_debug.h
View file @
a2ad031d
...
@@ -16,6 +16,7 @@ static int scsi_debug_device_reset(struct scsi_cmnd *);
...
@@ -16,6 +16,7 @@ static int scsi_debug_device_reset(struct scsi_cmnd *);
static
int
scsi_debug_host_reset
(
struct
scsi_cmnd
*
);
static
int
scsi_debug_host_reset
(
struct
scsi_cmnd
*
);
static
int
scsi_debug_proc_info
(
char
*
,
char
**
,
off_t
,
int
,
int
,
int
);
static
int
scsi_debug_proc_info
(
char
*
,
char
**
,
off_t
,
int
,
int
,
int
);
static
const
char
*
scsi_debug_info
(
struct
Scsi_Host
*
);
static
const
char
*
scsi_debug_info
(
struct
Scsi_Host
*
);
static
int
scsi_debug_release
(
struct
Scsi_Host
*
);
/*
/*
* This driver is written for the lk 2.5 series
* This driver is written for the lk 2.5 series
...
...
drivers/scsi/scsi_scan.c
View file @
a2ad031d
...
@@ -480,7 +480,7 @@ static struct scsi_device *scsi_alloc_sdev(struct Scsi_Host *shost,
...
@@ -480,7 +480,7 @@ static struct scsi_device *scsi_alloc_sdev(struct Scsi_Host *shost,
* Undo the actions in scsi_alloc_sdev, including removing @sdev from
* Undo the actions in scsi_alloc_sdev, including removing @sdev from
* the list, and freeing @sdev.
* the list, and freeing @sdev.
**/
**/
static
void
scsi_free_sdev
(
struct
scsi_device
*
sdev
)
void
scsi_free_sdev
(
struct
scsi_device
*
sdev
)
{
{
unsigned
long
flags
;
unsigned
long
flags
;
...
@@ -1273,8 +1273,6 @@ int scsi_remove_device(struct scsi_device *sdev)
...
@@ -1273,8 +1273,6 @@ int scsi_remove_device(struct scsi_device *sdev)
return
-
EINVAL
;
return
-
EINVAL
;
scsi_device_unregister
(
sdev
);
scsi_device_unregister
(
sdev
);
scsi_free_sdev
(
sdev
);
return
0
;
return
0
;
}
}
...
...
drivers/scsi/scsi_sysfs.c
View file @
a2ad031d
...
@@ -22,9 +22,9 @@
...
@@ -22,9 +22,9 @@
*/
*/
#define shost_show_function(field, format_string) \
#define shost_show_function(field, format_string) \
static ssize_t \
static ssize_t \
show_##field (struct
device *dev, char *buf)
\
show_##field (struct
class_device *class_dev, char *buf)
\
{ \
{ \
struct Scsi_Host *shost =
to_scsi_host(dev);
\
struct Scsi_Host *shost =
class_to_shost(class_dev);
\
return snprintf (buf, 20, format_string, shost->field); \
return snprintf (buf, 20, format_string, shost->field); \
}
}
...
@@ -34,7 +34,7 @@ show_##field (struct device *dev, char *buf) \
...
@@ -34,7 +34,7 @@ show_##field (struct device *dev, char *buf) \
*/
*/
#define shost_rd_attr(field, format_string) \
#define shost_rd_attr(field, format_string) \
shost_show_function(field, format_string) \
shost_show_function(field, format_string) \
static DEVICE_ATTR(field, S_IRUGO, show_##field, NULL)
static
CLASS_
DEVICE_ATTR(field, S_IRUGO, show_##field, NULL)
/*
/*
* Create the actual show/store functions and data structures.
* Create the actual show/store functions and data structures.
...
@@ -45,39 +45,16 @@ shost_rd_attr(cmd_per_lun, "%hd\n");
...
@@ -45,39 +45,16 @@ shost_rd_attr(cmd_per_lun, "%hd\n");
shost_rd_attr
(
sg_tablesize
,
"%hu
\n
"
);
shost_rd_attr
(
sg_tablesize
,
"%hu
\n
"
);
shost_rd_attr
(
unchecked_isa_dma
,
"%d
\n
"
);
shost_rd_attr
(
unchecked_isa_dma
,
"%d
\n
"
);
static
struct
device_attribute
*
const
shost_attrs
[]
=
{
static
struct
class_
device_attribute
*
const
shost_attrs
[]
=
{
&
dev
_attr_unique_id
,
&
class_device
_attr_unique_id
,
&
dev
_attr_host_busy
,
&
class_device
_attr_host_busy
,
&
dev
_attr_cmd_per_lun
,
&
class_device
_attr_cmd_per_lun
,
&
dev
_attr_sg_tablesize
,
&
class_device
_attr_sg_tablesize
,
&
dev
_attr_unchecked_isa_dma
,
&
class_device
_attr_unchecked_isa_dma
,
};
};
/**
* scsi_host_class_name_show - copy out the SCSI host name
* @dev: device to check
* @page: copy data into this area
* @count: number of bytes to copy
* @off: start at this offset in page
* Return:
* number of bytes written into page.
**/
static
ssize_t
scsi_host_class_name_show
(
struct
device
*
dev
,
char
*
page
)
{
struct
Scsi_Host
*
shost
;
shost
=
to_scsi_host
(
dev
);
if
(
!
shost
)
return
0
;
return
snprintf
(
page
,
20
,
"scsi%d
\n
"
,
shost
->
host_no
);
}
DEVICE_ATTR
(
class_name
,
S_IRUGO
,
scsi_host_class_name_show
,
NULL
);
struct
class
shost_class
=
{
struct
class
shost_class
=
{
.
name
=
"scsi
-
host"
,
.
name
=
"scsi
_
host"
,
};
};
/**
/**
...
@@ -114,10 +91,16 @@ static struct bus_type scsi_bus_type = {
...
@@ -114,10 +91,16 @@ static struct bus_type scsi_bus_type = {
int
scsi_sysfs_register
(
void
)
int
scsi_sysfs_register
(
void
)
{
{
bus_register
(
&
scsi_bus_type
);
int
error
;
class_register
(
&
shost_class
);
return
0
;
error
=
bus_register
(
&
scsi_bus_type
);
if
(
error
)
return
error
;
error
=
class_register
(
&
shost_class
);
if
(
error
)
return
error
;
return
error
;
}
}
void
scsi_sysfs_unregister
(
void
)
void
scsi_sysfs_unregister
(
void
)
...
@@ -273,6 +256,16 @@ static struct device_attribute * const sdev_attrs[] = {
...
@@ -273,6 +256,16 @@ static struct device_attribute * const sdev_attrs[] = {
&
dev_attr_rescan
,
&
dev_attr_rescan
,
};
};
static
void
scsi_device_release
(
struct
device
*
dev
)
{
struct
scsi_device
*
sdev
;
sdev
=
to_scsi_device
(
dev
);
if
(
!
sdev
)
return
;
scsi_free_sdev
(
sdev
);
}
/**
/**
* scsi_device_register - register a scsi device with the scsi bus
* scsi_device_register - register a scsi device with the scsi bus
* @sdev: scsi_device to register
* @sdev: scsi_device to register
...
@@ -286,8 +279,9 @@ int scsi_device_register(struct scsi_device *sdev)
...
@@ -286,8 +279,9 @@ int scsi_device_register(struct scsi_device *sdev)
sprintf
(
sdev
->
sdev_driverfs_dev
.
bus_id
,
"%d:%d:%d:%d"
,
sprintf
(
sdev
->
sdev_driverfs_dev
.
bus_id
,
"%d:%d:%d:%d"
,
sdev
->
host
->
host_no
,
sdev
->
channel
,
sdev
->
id
,
sdev
->
lun
);
sdev
->
host
->
host_no
,
sdev
->
channel
,
sdev
->
id
,
sdev
->
lun
);
sdev
->
sdev_driverfs_dev
.
parent
=
sdev
->
host
->
host_gendev
;
sdev
->
sdev_driverfs_dev
.
parent
=
&
sdev
->
host
->
host_gendev
;
sdev
->
sdev_driverfs_dev
.
bus
=
&
scsi_bus_type
;
sdev
->
sdev_driverfs_dev
.
bus
=
&
scsi_bus_type
;
sdev
->
sdev_driverfs_dev
.
release
=
scsi_device_release
;
error
=
device_register
(
&
sdev
->
sdev_driverfs_dev
);
error
=
device_register
(
&
sdev
->
sdev_driverfs_dev
);
if
(
error
)
if
(
error
)
...
@@ -315,3 +309,67 @@ void scsi_device_unregister(struct scsi_device *sdev)
...
@@ -315,3 +309,67 @@ void scsi_device_unregister(struct scsi_device *sdev)
device_remove_file
(
&
sdev
->
sdev_driverfs_dev
,
sdev_attrs
[
i
]);
device_remove_file
(
&
sdev
->
sdev_driverfs_dev
,
sdev_attrs
[
i
]);
device_unregister
(
&
sdev
->
sdev_driverfs_dev
);
device_unregister
(
&
sdev
->
sdev_driverfs_dev
);
}
}
static
void
scsi_host_release
(
struct
device
*
dev
)
{
struct
Scsi_Host
*
shost
;
shost
=
dev_to_shost
(
dev
);
if
(
!
shost
)
return
;
shost
->
hostt
->
release
(
shost
);
}
/**
* scsi_sysfs_add_host - add scsi host to subsystem
* @shost: scsi host struct to add to subsystem
* @dev: parent struct device pointer
**/
int
scsi_sysfs_add_host
(
struct
Scsi_Host
*
shost
,
struct
device
*
dev
)
{
int
i
,
error
;
sprintf
(
shost
->
host_gendev
.
bus_id
,
"host%d"
,
shost
->
host_no
);
if
(
!
shost
->
host_gendev
.
parent
)
shost
->
host_gendev
.
parent
=
(
dev
)
?
dev
:
&
legacy_bus
;
shost
->
host_gendev
.
release
=
scsi_host_release
;
error
=
device_register
(
&
shost
->
host_gendev
);
if
(
error
)
return
error
;
shost
->
class_dev
.
dev
=
&
shost
->
host_gendev
;
shost
->
class_dev
.
class
=
&
shost_class
;
snprintf
(
shost
->
class_dev
.
class_id
,
BUS_ID_SIZE
,
"host%d"
,
shost
->
host_no
);
error
=
class_device_register
(
&
shost
->
class_dev
);
if
(
error
)
goto
clean_device
;
for
(
i
=
0
;
!
error
&&
i
<
ARRAY_SIZE
(
shost_attrs
);
i
++
)
error
=
class_device_create_file
(
&
shost
->
class_dev
,
shost_attrs
[
i
]);
if
(
error
)
goto
clean_class
;
return
error
;
clean_class:
class_device_unregister
(
&
shost
->
class_dev
);
clean_device:
device_unregister
(
&
shost
->
host_gendev
);
return
error
;
}
/**
* scsi_sysfs_remove_host - remove scsi host from subsystem
* @shost: scsi host to remove from subsystem
**/
void
scsi_sysfs_remove_host
(
struct
Scsi_Host
*
shost
)
{
class_device_unregister
(
&
shost
->
class_dev
);
device_unregister
(
&
shost
->
host_gendev
);
}
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