Commit 0d5e18d6 authored by claes's avatar claes

*** empty log message ***

parent 2f3de648
/* /*
* Proview $Id: rt_io_m_ssab_remoterack.c,v 1.3 2006-04-12 12:14:38 claes Exp $ * Proview $Id: rt_io_m_ssab_remoterack.c,v 1.4 2006-06-02 07:14:29 claes Exp $
* Copyright (C) 2005 SSAB Oxelsund AB. * Copyright (C) 2005 SSAB Oxelsund AB.
* *
* This program is free software; you can redistribute it and/or * This program is free software; you can redistribute it and/or
...@@ -65,21 +65,23 @@ static pwr_tStatus IoRackInit ( ...@@ -65,21 +65,23 @@ static pwr_tStatus IoRackInit (
return IO__ERRINIDEVICE; return IO__ERRINIDEVICE;
} }
/* Set local port same as remote port and bind the created socket */ /* Bind local port if explicitly numbered ( != 0 ) */
local->my_addr.sin_family = AF_INET; if (op->LocalPort != 0) {
local->my_addr.sin_port = htons(op->Port); local->my_addr.sin_family = AF_INET;
sts = bind(local->s, (struct sockaddr *) &local->my_addr, sizeof(local->my_addr)); local->my_addr.sin_port = htons(op->LocalPort);
if (sts != 0) { sts = bind(local->s, (struct sockaddr *) &local->my_addr, sizeof(local->my_addr));
errh_Error( "Error binding local socket for IO remote rack %s, %d", rp->Name, sts); if (sts != 0) {
op->Status = IO__INITFAIL; errh_Error( "Error binding local socket for IO remote rack %s, %d", rp->Name, sts);
return IO__ERRINIDEVICE; op->Status = IO__INITFAIL;
return IO__ERRINIDEVICE;
}
} }
/* Initialize remote address structure */ /* Initialize remote address structure */
local->rem_addr.sin_family = AF_INET; local->rem_addr.sin_family = AF_INET;
local->rem_addr.sin_port = htons(op->Port); local->rem_addr.sin_port = htons(op->RemotePort);
local->rem_addr.sin_addr.s_addr = inet_addr((char *) &(op->Address)); local->rem_addr.sin_addr.s_addr = inet_addr((char *) &(op->Address));
/* Connect to remote address */ /* Connect to remote address */
...@@ -91,17 +93,16 @@ static pwr_tStatus IoRackInit ( ...@@ -91,17 +93,16 @@ static pwr_tStatus IoRackInit (
return IO__ERRINIDEVICE; return IO__ERRINIDEVICE;
} }
local->in_items = 0; local->next_read_req_item = 0;
local->out_items = 0; local->next_write_req_item = 0;
op->RX_packets = 0; op->RX_packets = 0;
op->TX_packets = 0; op->TX_packets = 0;
/* Log initialization */ /* Log initialization */
errh_Info( "Init of IO remote rack %s, %d/%s:%d", errh_Info( "Init of IO remote rack %s/%s:%d",
rp->Name, ntohs(local->my_addr.sin_port), rp->Name, inet_ntoa(local->rem_addr.sin_addr), ntohs(local->rem_addr.sin_port));
inet_ntoa(local->rem_addr.sin_addr), ntohs(local->rem_addr.sin_port));
op->Status = IO__NORMAL; op->Status = IO__NORMAL;
return IO__SUCCESS; return IO__SUCCESS;
} }
...@@ -127,6 +128,11 @@ static pwr_tStatus IoRackRead ( ...@@ -127,6 +128,11 @@ static pwr_tStatus IoRackRead (
struct timeval tv; struct timeval tv;
io_sRackLocal *local = (io_sRackLocal *) rp->Local; io_sRackLocal *local = (io_sRackLocal *) rp->Local;
pwr_sClass_Ssab_RemoteRack *op = (pwr_sClass_Ssab_RemoteRack *) rp->op; pwr_sClass_Ssab_RemoteRack *op = (pwr_sClass_Ssab_RemoteRack *) rp->op;
struct bfb_buf rbuf;
int size;
bzero(&local->read_area, sizeof(local->read_area));
bzero(&local->write_area, sizeof(local->write_area));
sts = 1; sts = 1;
while (sts > 0) { while (sts > 0) {
...@@ -136,7 +142,15 @@ static pwr_tStatus IoRackRead ( ...@@ -136,7 +142,15 @@ static pwr_tStatus IoRackRead (
tv.tv_usec = 0; tv.tv_usec = 0;
sts = select(32, &fds, NULL, NULL, &tv); sts = select(32, &fds, NULL, NULL, &tv);
if (sts > 0) { if (sts > 0) {
recv(local->s, &local->in, sizeof(local->in), 0); size = recv(local->s, &rbuf, sizeof(rbuf), 0);
if (rbuf.service == BFB_SERVICE_READ) {
bzero(&local->read_area, sizeof(local->read_area));
memcpy(&local->read_area, &rbuf, size);
}
else if (rbuf.service == BFB_SERVICE_WRITE) {
bzero(&local->write_area, sizeof(local->write_area));
memcpy(&local->write_area, &rbuf, size);
}
op->RX_packets++; op->RX_packets++;
} }
} }
...@@ -154,17 +168,20 @@ static pwr_tStatus IoRackWrite ( ...@@ -154,17 +168,20 @@ static pwr_tStatus IoRackWrite (
io_sRackLocal *local = (io_sRackLocal *) rp->Local; io_sRackLocal *local = (io_sRackLocal *) rp->Local;
pwr_sClass_Ssab_RemoteRack *op = (pwr_sClass_Ssab_RemoteRack *) rp->op; pwr_sClass_Ssab_RemoteRack *op = (pwr_sClass_Ssab_RemoteRack *) rp->op;
// Send write request // Calc length and send write request
local->out.service = BFB_SERVICE_WRITE; local->write_req.service = BFB_SERVICE_WRITE;
local->out.length = local->out_items*4 + 4; local->write_req.length = local->next_write_req_item*4 + 4;
sts = send(local->s, &local->out, local->out.length, 0); sts = send(local->s, &local->write_req, local->write_req.length, 0);
op->TX_packets++; op->TX_packets++;
// Send read request // Calc length and send read request
local->in.service = BFB_SERVICE_READ; local->read_req.service = BFB_SERVICE_READ;
local->in.length = local->in_items*4 + 4; local->read_req.length = local->next_read_req_item*4 + 4;
sts = send(local->s, &local->in, local->in.length, 0); sts = send(local->s, &local->read_req, local->read_req.length, 0);
op->TX_packets++; op->TX_packets++;
local->next_read_req_item = 0;
local->next_write_req_item = 0;
return IO__SUCCESS; return IO__SUCCESS;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment