Replaced the MAX_PORTS constant with the gMaxPorts variable, so that it
could be changed at startup (adapted to system properties). git-svn-id: file:///srv/svn/repos/haiku/trunk/current@6955 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
b672b21619
commit
85b89008bd
@ -55,8 +55,9 @@ static int dump_port_info(int argc, char **argv);
|
|||||||
static void _dump_port_info(struct port_entry *port);
|
static void _dump_port_info(struct port_entry *port);
|
||||||
|
|
||||||
|
|
||||||
// MAX_PORTS must be power of 2
|
// gMaxPorts must be power of 2
|
||||||
#define MAX_PORTS 4096
|
int32 gMaxPorts = 4096;
|
||||||
|
|
||||||
#define MAX_QUEUE_LENGTH 4096
|
#define MAX_QUEUE_LENGTH 4096
|
||||||
#define PORT_MAX_MESSAGE_SIZE 65536
|
#define PORT_MAX_MESSAGE_SIZE 65536
|
||||||
|
|
||||||
@ -77,7 +78,7 @@ status_t
|
|||||||
port_init(kernel_args *ka)
|
port_init(kernel_args *ka)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
int size = sizeof(struct port_entry) * MAX_PORTS;
|
int size = sizeof(struct port_entry) * gMaxPorts;
|
||||||
|
|
||||||
// create and initialize ports table
|
// create and initialize ports table
|
||||||
sPortArea = create_area("port_table", (void **)&sPorts, B_ANY_KERNEL_ADDRESS,
|
sPortArea = create_area("port_table", (void **)&sPorts, B_ANY_KERNEL_ADDRESS,
|
||||||
@ -91,7 +92,7 @@ port_init(kernel_args *ka)
|
|||||||
// might do it as well, though :-)
|
// might do it as well, though :-)
|
||||||
|
|
||||||
memset(sPorts, 0, size);
|
memset(sPorts, 0, size);
|
||||||
for (i = 0; i < MAX_PORTS; i++)
|
for (i = 0; i < gMaxPorts; i++)
|
||||||
sPorts[i].id = -1;
|
sPorts[i].id = -1;
|
||||||
|
|
||||||
// add debugger commands
|
// add debugger commands
|
||||||
@ -212,7 +213,7 @@ dump_port_list(int argc, char **argv)
|
|||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < MAX_PORTS; i++) {
|
for (i = 0; i < gMaxPorts; i++) {
|
||||||
if (sPorts[i].id >= 0)
|
if (sPorts[i].id >= 0)
|
||||||
dprintf("%p\tid: 0x%lx\t\tname: '%s'\n", &sPorts[i], sPorts[i].id, sPorts[i].name);
|
dprintf("%p\tid: 0x%lx\t\tname: '%s'\n", &sPorts[i], sPorts[i].id, sPorts[i].name);
|
||||||
}
|
}
|
||||||
@ -251,11 +252,11 @@ dump_port_info(int argc, char **argv)
|
|||||||
|
|
||||||
if (num > KERNEL_BASE && num <= (KERNEL_BASE + (KERNEL_SIZE - 1))) {
|
if (num > KERNEL_BASE && num <= (KERNEL_BASE + (KERNEL_SIZE - 1))) {
|
||||||
// XXX semi-hack
|
// XXX semi-hack
|
||||||
// one can use either address or a port_id, since KERNEL_BASE > MAX_PORTS assumed
|
// one can use either address or a port_id, since KERNEL_BASE > gMaxPorts assumed
|
||||||
_dump_port_info((struct port_entry *)num);
|
_dump_port_info((struct port_entry *)num);
|
||||||
return 0;
|
return 0;
|
||||||
} else {
|
} else {
|
||||||
unsigned slot = num % MAX_PORTS;
|
unsigned slot = num % gMaxPorts;
|
||||||
if(sPorts[slot].id != (int)num) {
|
if(sPorts[slot].id != (int)num) {
|
||||||
dprintf("port 0x%lx doesn't exist!\n", num);
|
dprintf("port 0x%lx doesn't exist!\n", num);
|
||||||
return 0;
|
return 0;
|
||||||
@ -266,7 +267,7 @@ dump_port_info(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// walk through the ports list, trying to match name
|
// walk through the ports list, trying to match name
|
||||||
for (i = 0; i < MAX_PORTS; i++) {
|
for (i = 0; i < gMaxPorts; i++) {
|
||||||
if (sPorts[i].name != NULL
|
if (sPorts[i].name != NULL
|
||||||
&& strcmp(argv[1], sPorts[i].name) == 0) {
|
&& strcmp(argv[1], sPorts[i].name) == 0) {
|
||||||
_dump_port_info(&sPorts[i]);
|
_dump_port_info(&sPorts[i]);
|
||||||
@ -296,7 +297,7 @@ delete_owned_ports(team_id owner)
|
|||||||
state = disable_interrupts();
|
state = disable_interrupts();
|
||||||
GRAB_PORT_LIST_LOCK();
|
GRAB_PORT_LIST_LOCK();
|
||||||
|
|
||||||
for (i = 0; i < MAX_PORTS; i++) {
|
for (i = 0; i < gMaxPorts; i++) {
|
||||||
if (sPorts[i].id != -1 && sPorts[i].owner == owner) {
|
if (sPorts[i].id != -1 && sPorts[i].owner == owner) {
|
||||||
port_id id = sPorts[i].id;
|
port_id id = sPorts[i].id;
|
||||||
|
|
||||||
@ -407,13 +408,13 @@ create_port(int32 queueLength, const char *name)
|
|||||||
GRAB_PORT_LIST_LOCK();
|
GRAB_PORT_LIST_LOCK();
|
||||||
|
|
||||||
// find the first empty spot
|
// find the first empty spot
|
||||||
for (i = 0; i < MAX_PORTS; i++) {
|
for (i = 0; i < gMaxPorts; i++) {
|
||||||
if (sPorts[i].id == -1) {
|
if (sPorts[i].id == -1) {
|
||||||
// make the port_id be a multiple of the slot it's in
|
// make the port_id be a multiple of the slot it's in
|
||||||
if (i >= sNextPort % MAX_PORTS)
|
if (i >= sNextPort % gMaxPorts)
|
||||||
sNextPort += i - sNextPort % MAX_PORTS;
|
sNextPort += i - sNextPort % gMaxPorts;
|
||||||
else
|
else
|
||||||
sNextPort += MAX_PORTS - (sNextPort % MAX_PORTS - i);
|
sNextPort += gMaxPorts - (sNextPort % gMaxPorts - i);
|
||||||
|
|
||||||
GRAB_PORT_LOCK(sPorts[i]);
|
GRAB_PORT_LOCK(sPorts[i]);
|
||||||
sPorts[i].id = sNextPort++;
|
sPorts[i].id = sNextPort++;
|
||||||
@ -461,7 +462,7 @@ close_port(port_id id)
|
|||||||
if (!sPortsActive || id < 0)
|
if (!sPortsActive || id < 0)
|
||||||
return B_BAD_PORT_ID;
|
return B_BAD_PORT_ID;
|
||||||
|
|
||||||
slot = id % MAX_PORTS;
|
slot = id % gMaxPorts;
|
||||||
|
|
||||||
// walk through the sem list, trying to match name
|
// walk through the sem list, trying to match name
|
||||||
state = disable_interrupts();
|
state = disable_interrupts();
|
||||||
@ -497,7 +498,7 @@ delete_port(port_id id)
|
|||||||
if (!sPortsActive || id < 0)
|
if (!sPortsActive || id < 0)
|
||||||
return B_BAD_PORT_ID;
|
return B_BAD_PORT_ID;
|
||||||
|
|
||||||
slot = id % MAX_PORTS;
|
slot = id % gMaxPorts;
|
||||||
|
|
||||||
state = disable_interrupts();
|
state = disable_interrupts();
|
||||||
GRAB_PORT_LOCK(sPorts[slot]);
|
GRAB_PORT_LOCK(sPorts[slot]);
|
||||||
@ -553,7 +554,7 @@ find_port(const char *name)
|
|||||||
// the port lock in question, not the port list lock
|
// the port lock in question, not the port list lock
|
||||||
|
|
||||||
// loop over list
|
// loop over list
|
||||||
for (i = 0; i < MAX_PORTS && portFound < B_OK; i++) {
|
for (i = 0; i < gMaxPorts && portFound < B_OK; i++) {
|
||||||
// lock every individual port before comparing
|
// lock every individual port before comparing
|
||||||
state = disable_interrupts();
|
state = disable_interrupts();
|
||||||
GRAB_PORT_LOCK(sPorts[i]);
|
GRAB_PORT_LOCK(sPorts[i]);
|
||||||
@ -605,7 +606,7 @@ _get_port_info(port_id id, port_info *info, size_t size)
|
|||||||
if (!sPortsActive || id < 0)
|
if (!sPortsActive || id < 0)
|
||||||
return B_BAD_PORT_ID;
|
return B_BAD_PORT_ID;
|
||||||
|
|
||||||
slot = id % MAX_PORTS;
|
slot = id % gMaxPorts;
|
||||||
|
|
||||||
state = disable_interrupts();
|
state = disable_interrupts();
|
||||||
GRAB_PORT_LOCK(sPorts[slot]);
|
GRAB_PORT_LOCK(sPorts[slot]);
|
||||||
@ -639,7 +640,7 @@ _get_next_port_info(team_id team, int32 *_cookie, struct port_info *info, size_t
|
|||||||
return B_BAD_PORT_ID;
|
return B_BAD_PORT_ID;
|
||||||
|
|
||||||
slot = *_cookie;
|
slot = *_cookie;
|
||||||
if (slot >= MAX_PORTS)
|
if (slot >= gMaxPorts)
|
||||||
return B_BAD_PORT_ID;
|
return B_BAD_PORT_ID;
|
||||||
|
|
||||||
if (team == B_CURRENT_TEAM)
|
if (team == B_CURRENT_TEAM)
|
||||||
@ -651,7 +652,7 @@ _get_next_port_info(team_id team, int32 *_cookie, struct port_info *info, size_t
|
|||||||
state = disable_interrupts();
|
state = disable_interrupts();
|
||||||
GRAB_PORT_LIST_LOCK();
|
GRAB_PORT_LIST_LOCK();
|
||||||
|
|
||||||
while (slot < MAX_PORTS) {
|
while (slot < gMaxPorts) {
|
||||||
GRAB_PORT_LOCK(sPorts[slot]);
|
GRAB_PORT_LOCK(sPorts[slot]);
|
||||||
if (sPorts[slot].id != -1 && sPorts[slot].owner == team) {
|
if (sPorts[slot].id != -1 && sPorts[slot].owner == team) {
|
||||||
// found one!
|
// found one!
|
||||||
@ -695,7 +696,7 @@ port_buffer_size_etc(port_id id, uint32 flags, bigtime_t timeout)
|
|||||||
if (!sPortsActive || id < 0)
|
if (!sPortsActive || id < 0)
|
||||||
return B_BAD_PORT_ID;
|
return B_BAD_PORT_ID;
|
||||||
|
|
||||||
slot = id % MAX_PORTS;
|
slot = id % gMaxPorts;
|
||||||
|
|
||||||
state = disable_interrupts();
|
state = disable_interrupts();
|
||||||
GRAB_PORT_LOCK(sPorts[slot]);
|
GRAB_PORT_LOCK(sPorts[slot]);
|
||||||
@ -761,7 +762,7 @@ port_count(port_id id)
|
|||||||
if (!sPortsActive || id < 0)
|
if (!sPortsActive || id < 0)
|
||||||
return B_BAD_PORT_ID;
|
return B_BAD_PORT_ID;
|
||||||
|
|
||||||
slot = id % MAX_PORTS;
|
slot = id % gMaxPorts;
|
||||||
|
|
||||||
state = disable_interrupts();
|
state = disable_interrupts();
|
||||||
GRAB_PORT_LOCK(sPorts[slot]);
|
GRAB_PORT_LOCK(sPorts[slot]);
|
||||||
@ -814,7 +815,7 @@ read_port_etc(port_id id, int32 *_msgCode, void *msgBuffer, size_t bufferSize,
|
|||||||
return B_BAD_VALUE;
|
return B_BAD_VALUE;
|
||||||
|
|
||||||
flags = flags & (B_CAN_INTERRUPT | B_TIMEOUT);
|
flags = flags & (B_CAN_INTERRUPT | B_TIMEOUT);
|
||||||
slot = id % MAX_PORTS;
|
slot = id % gMaxPorts;
|
||||||
|
|
||||||
state = disable_interrupts();
|
state = disable_interrupts();
|
||||||
GRAB_PORT_LOCK(sPorts[slot]);
|
GRAB_PORT_LOCK(sPorts[slot]);
|
||||||
@ -922,7 +923,7 @@ write_port_etc(port_id id, int32 msgCode, const void *msgBuffer,
|
|||||||
|
|
||||||
// mask irrelevant flags (for acquire_sem() usage)
|
// mask irrelevant flags (for acquire_sem() usage)
|
||||||
flags = flags & (B_CAN_INTERRUPT | B_TIMEOUT);
|
flags = flags & (B_CAN_INTERRUPT | B_TIMEOUT);
|
||||||
slot = id % MAX_PORTS;
|
slot = id % gMaxPorts;
|
||||||
|
|
||||||
if (bufferSize > PORT_MAX_MESSAGE_SIZE)
|
if (bufferSize > PORT_MAX_MESSAGE_SIZE)
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
@ -1020,7 +1021,7 @@ set_port_owner(port_id id, team_id team)
|
|||||||
if (!sPortsActive || id < 0)
|
if (!sPortsActive || id < 0)
|
||||||
return B_BAD_PORT_ID;
|
return B_BAD_PORT_ID;
|
||||||
|
|
||||||
slot = id % MAX_PORTS;
|
slot = id % gMaxPorts;
|
||||||
|
|
||||||
state = disable_interrupts();
|
state = disable_interrupts();
|
||||||
GRAB_PORT_LOCK(sPorts[slot]);
|
GRAB_PORT_LOCK(sPorts[slot]);
|
||||||
|
Loading…
Reference in New Issue
Block a user