26 #define RPC_PACKET_SIZE 64
29 #define PACKET_F_ALLOC 0x01
31 static inline void rpc_packet_free(
void *packet)
54 extern struct rpc_data _sif_rpc_data;
59 #ifdef F__rpc_get_packet
72 for (rid = 0; rid < len; rid++, packet = (
SifRpcPktHeader_t *)(((
unsigned char *)packet) + RPC_PACKET_SIZE)) {
91 packet->pkt_addr = packet;
100 #ifdef F__rpc_get_fpacket
106 rpc_data->rdata_table_idx = index + 1;
108 return (
void *)(
rpc_data->rdata_table + (index * RPC_PACKET_SIZE));
112 #ifdef F_sceSifBindRpc
124 cd->hdr.pkt_addr = bind;
125 cd->hdr.rpc_id = bind->rpc_id;
126 cd->hdr.sema_id = -1;
129 bind->pkt_addr = bind;
133 if (!sceSifSendCmd(SIF_CMD_RPC_BIND, bind, RPC_PACKET_SIZE, NULL, NULL, 0)) {
134 rpc_packet_free(bind);
143 cd->hdr.sema_id = CreateSema(&sema);
144 if (cd->hdr.sema_id < 0) {
145 rpc_packet_free(bind);
149 if (!sceSifSendCmd(SIF_CMD_RPC_BIND, bind, RPC_PACKET_SIZE, NULL, NULL, 0)) {
150 rpc_packet_free(bind);
151 DeleteSema(cd->hdr.sema_id);
155 WaitSema(cd->hdr.sema_id);
156 DeleteSema(cd->hdr.sema_id);
162 #ifdef F_sceSifCallRpc
164 int ssize,
void *recvbuf,
int rsize, SifRpcEndFunc_t end_function,
void *end_param)
173 cd->hdr.pkt_addr = call;
174 cd->hdr.rpc_id = call->rpc_id;
175 cd->hdr.sema_id = -1;
176 cd->end_function = end_function;
177 cd->end_param = end_param;
179 call->rpc_number = rpc_number;
180 call->send_size = ssize;
181 call->recvbuf = recvbuf;
182 call->recv_size = rsize;
184 call->pkt_addr = call;
186 call->sd = cd->server;
190 sceSifWriteBackDCache(sendbuf, ssize);
192 sceSifWriteBackDCache(recvbuf, rsize);
199 if (!sceSifSendCmd(SIF_CMD_RPC_CALL, call, RPC_PACKET_SIZE, sendbuf, cd->buf, ssize)) {
200 rpc_packet_free(call);
209 cd->hdr.sema_id = CreateSema(&sema);
210 if (cd->hdr.sema_id < 0) {
211 rpc_packet_free(call);
215 if (!sceSifSendCmd(SIF_CMD_RPC_CALL, call, RPC_PACKET_SIZE, sendbuf, cd->buf, ssize)) {
216 rpc_packet_free(call);
217 DeleteSema(cd->hdr.sema_id);
221 WaitSema(cd->hdr.sema_id);
222 DeleteSema(cd->hdr.sema_id);
228 #ifdef F_sceSifGetOtherData
238 rd->hdr.pkt_addr = other;
239 rd->hdr.rpc_id = other->rpc_id;
240 rd->hdr.sema_id = -1;
248 if (!sceSifSendCmd(SIF_CMD_RPC_RDATA, other, RPC_PACKET_SIZE, NULL, NULL, 0)) {
249 rpc_packet_free(other);
258 rd->hdr.sema_id = CreateSema(&sema);
259 if (rd->hdr.sema_id < 0) {
260 rpc_packet_free(other);
264 if (!sceSifSendCmd(SIF_CMD_RPC_RDATA, other, RPC_PACKET_SIZE, NULL, NULL, 0)) {
265 rpc_packet_free(other);
266 DeleteSema(rd->hdr.sema_id);
270 WaitSema(rd->hdr.sema_id);
271 DeleteSema(rd->hdr.sema_id);
287 pkt_table : pkt_table,
288 pkt_table_len :
sizeof(pkt_table) / RPC_PACKET_SIZE,
289 rdata_table : rdata_table,
290 rdata_table_len :
sizeof(rdata_table) / RPC_PACKET_SIZE,
291 client_table : client_table,
292 client_table_len :
sizeof(client_table) / RPC_PACKET_SIZE,
306 if (
request->cid == SIF_CMD_RPC_CALL) {
307 if (cd->end_function)
308 cd->end_function(cd->end_param);
309 }
else if (
request->cid == SIF_CMD_RPC_BIND) {
315 if (cd->hdr.sema_id >= 0)
316 iSignalSema(cd->hdr.sema_id);
318 rpc_packet_free(cd->hdr.pkt_addr);
319 cd->hdr.pkt_addr = NULL;
333 if ((u32)(sd->sid) == sid)
351 rend = _rpc_get_fpacket(data);
352 rend->pkt_addr = bind->pkt_addr;
354 rend->cid = SIF_CMD_RPC_BIND;
356 sd = search_svdata(bind->sid, data);
364 rend->cbuf = sd->cbuf;
367 isceSifSendCmd(SIF_CMD_RPC_END, rend, RPC_PACKET_SIZE, NULL, NULL, 0);
379 base->end->next = sd;
384 sd->pkt_addr =
request->pkt_addr;
386 sd->rpc_number =
request->rpc_number;
388 sd->recvbuf =
request->recvbuf;
389 sd->rsize =
request->recv_size;
393 if (base->thread_id < 0 || base->active != 0)
396 iWakeupThread(base->thread_id);
405 rend->pkt_addr = rdata->pkt_addr;
407 rend->cid = SIF_CMD_RPC_RDATA;
409 isceSifSendCmd(SIF_CMD_RPC_END, rend, RPC_PACKET_SIZE, rdata->src, rdata->dest, rdata->size);
412 void sceSifInitRpc(
int mode)
429 _sif_rpc_data.pkt_table = UNCACHED_SEG(_sif_rpc_data.pkt_table);
430 _sif_rpc_data.rdata_table = UNCACHED_SEG(_sif_rpc_data.rdata_table);
431 _sif_rpc_data.client_table = UNCACHED_SEG(_sif_rpc_data.client_table);
433 _sif_rpc_data.rdata_table_idx = 0;
441 for (rid = 0; rid < len; rid++, packet = (
SifRpcPktHeader_t *)(((
unsigned char *)packet) + RPC_PACKET_SIZE)) {
442 rpc_packet_free(packet);
446 sceSifAddCmdHandler(SIF_CMD_RPC_END, (
void *)_request_end, &_sif_rpc_data);
447 sceSifAddCmdHandler(SIF_CMD_RPC_BIND, (
void *)_request_bind, &_sif_rpc_data);
448 sceSifAddCmdHandler(SIF_CMD_RPC_CALL, (
void *)_request_call, &_sif_rpc_data);
449 sceSifAddCmdHandler(SIF_CMD_RPC_RDATA, (
void *)_request_rdata, &_sif_rpc_data);
452 if (sceSifGetReg(SIF_SYSREG_RPCINIT))
455 cmdp = (u32 *)&pkt_table[64];
457 sceSifSendCmd(SIF_CMD_INIT_CMD, cmdp, 16, NULL, NULL, 0);
461 sceSifSetReg(SIF_SYSREG_RPCINIT, 1);
464 void sceSifExitRpc(
void)
471 #ifdef F_sceSifRegisterRpc
488 if (!(server =
qd->link)) {
491 while (server->link != NULL) {
492 server = server->link;
502 #ifdef F_sceSifRemoveRpc
509 if ((server =
qd->link) == sd) {
510 qd->link = server->link;
512 while (server != NULL) {
513 if (server->link == sd) {
514 server->link = sd->link;
518 server = server->link;
528 #ifdef F_sceSifSetRpcQueue
535 qd->thread_id = thread_id;
542 if (_sif_rpc_data.active_queue == NULL) {
543 _sif_rpc_data.active_queue =
qd;
545 queue = _sif_rpc_data.active_queue;
547 while (queue->next != NULL)
557 #ifdef F_sceSifRemoveRpcQueue
564 if ((queue = _sif_rpc_data.active_queue) ==
qd) {
565 _sif_rpc_data.active_queue = queue->next;
567 while (queue != NULL) {
568 if (queue->next ==
qd) {
569 queue->next =
qd->next;
583 #ifdef F_sceSifGetNextRequest
593 qd->start = sd->next;
604 #ifdef F_sceSifExecRequest
607 if (rid < 0 || rid < rpc_data->client_table_len)
610 return rpc_data->client_table + (rid * RPC_PACKET_SIZE);
618 rec = sd->func(sd->rpc_number, sd->buf, sd->size);
621 sceSifWriteBackDCache(sd->buf, sd->size);
624 sceSifWriteBackDCache(rec, sd->rsize);
630 _rpc_get_fpacket2(&_sif_rpc_data, (sd->rid >> 16) & 0xffff);
633 _rpc_get_fpacket(&_sif_rpc_data);
637 rend->cd = sd->client;
638 rend->cid = SIF_CMD_RPC_CALL;
641 if (!sceSifSendCmd(SIF_CMD_RPC_END, rend, RPC_PACKET_SIZE, rec, sd->recvbuf,
651 dmat.dest = sd->recvbuf;
652 dmat.size = sd->rsize;
656 dmat.dest = sd->pkt_addr;
661 while (!sceSifSetDma(&dmat, 1))
666 #ifdef F_sceSifRpcLoop
672 while ((sd = sceSifGetNextRequest(
qd)))
673 sceSifExecRequest(sd);
680 #ifdef F_sceSifCheckStatRpc
688 if (cd->hdr.rpc_id != (u32)(packet->rpc_id))