-/* ------------------------------------------------
- Copyright 2014 AT&T Intellectual Property
- Licensed under the Apache License, Version 2.0 (the "License");
- you may not use this file except in compliance with the License.
- You may obtain a copy of the License at
-
- http://www.apache.org/licenses/LICENSE-2.0
-
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
- ------------------------------------------- */
-
-#include <lappregistries.h>
-#include <stdio.h>
-#include <stdlib.h>
-
-/* datastructure to keep track of streamids used by the lapp */
-struct streamregistry {
- gs_int32_t used;
- FTAID ftaid;
- struct ringbuf * r;
-};
-
-struct streamregistry * sreg =0;
-gs_int32_t lsreg=0;
-
-struct ringbuf ** rbr=0;
-gs_int32_t lrbr=0;
-
-FTAID ** rms=0;
-gs_int32_t lrms=0;
-
-/* adds the remote streamid with its associated msgid and ringbuf
- */
-gs_retval_t streamregistry_add(FTAID ftaid,struct ringbuf * r)
-{
- gs_int32_t x;
- if (lsreg == 0) {
- if ((sreg = malloc(sizeof(struct streamregistry)*STARTSZ))==0) {
- gslog(LOG_EMERG,"ERROR:Out of memory streanregistry\n");
- return -1;
- }
- memset(sreg,0,sizeof(struct streamregistry)*STARTSZ);
- lsreg = STARTSZ;
- }
- for(x=0;(x<lsreg)&&(sreg[x].used!=0);x++);
- if (x == lsreg) {
- gs_int32_t y;
- lsreg = 2*lsreg;
- if ((sreg = realloc(sreg,lsreg*sizeof(struct streamregistry)))==0) {
- gslog(LOG_EMERG,"ERROR:Out of memory streamregistry\n");
- return -1;
- }
- for (y=x;y<lsreg;y++)
- sreg[y].used=0;
- }
- sreg[x].ftaid=ftaid;
- sreg[x].r=r;
- sreg[x].used=1;
- return 0;
-}
-
-/* removes streamid from registry for specific msgid and ringbuf */
-void streamregistry_remove(FTAID ftaid)
-{
- gs_int32_t x;
- for(x=0;x<lsreg;x++) {
- if ((sreg[x].ftaid.ip==ftaid.ip)
- && (sreg[x].ftaid.port==ftaid.port)
- && (sreg[x].ftaid.index==ftaid.index)
- && (sreg[x].ftaid.streamid==ftaid.streamid)) {
- sreg[x].used=0;
- }
- }
- return;
-}
-
-
-
-/* the following two functions are used to cycle
- through all ringbuffers
- */
-gs_retval_t streamregistry_getactiveringbuf_reset()
-{
- gs_int32_t x,y;
- /* XXXOS this is not the most effective way of doing
- this needs improvment. */
- /* Build a list of all ringbufs make sure they
- are unique since multiple entrys could share
- a ringbuf
- */
- if (rbr!=0) (free(rbr));
- if ((rbr=malloc(sizeof(struct ringbuf *)*lsreg))==0) {
- gslog(LOG_EMERG,"Can't allocate memory in ftaregistry\n");
- return -1;
- }
- memset(rbr,0,sizeof(struct ringbuf *)*lsreg);
- lrbr=0;
- for(x=0;x<lsreg;x++) {
- if (sreg[x].used) {
- for(y=0;(y<lrbr)&&(rbr[y]!=sreg[x].r);y++);
- if (y>=lrbr) {
- rbr[y]=sreg[x].r;
- lrbr++;
- }
- }
- }
- return 0;
-}
-
-struct ringbuf * streamregistry_getactiveringbuf()
-{
- if (lrbr>0) {
- lrbr --;
- return rbr[lrbr];
- }
- return 0;
-}
-
-
-gs_retval_t streamregistry_getactiveftaid_reset()
-{
- gs_int32_t x,y;
- /* XXXOS this is not the most effective way of doing
- this needs improvment. */
- /* Build a list of at least one ftaid per process
- */
- if (rms!=0) (free(rms));
- if ((rms=malloc(sizeof(FTAID *)*lsreg))==0) {
- gslog(LOG_EMERG,"Can't allocate memory in ftaregistry\n");
- return -1;
- }
- memset(rms,0,sizeof(gs_int32_t *)*lsreg);
- lrms=0;
- for(x=0;x<lsreg;x++) {
- if (sreg[x].used) {
- for(y=0;(y<lrms)
- &&(rms[y]->ip!=sreg[x].ftaid.ip)
- &&(rms[y]->port!=sreg[x].ftaid.port);y++);
- if (y>=lrms) {
- rms[y]=&(sreg[x].ftaid);
- lrms++;
- }
- }
- }
- return 0;
-}
-
-FTAID * streamregistry_getactiveftaid()
-{
- if (lrms>0) {
- lrms --;
- return rms[lrms];
- }
- return 0;
-}
+/* ------------------------------------------------\r
+ Copyright 2014 AT&T Intellectual Property\r
+ Licensed under the Apache License, Version 2.0 (the "License");\r
+ you may not use this file except in compliance with the License.\r
+ You may obtain a copy of the License at\r
+ \r
+ http://www.apache.org/licenses/LICENSE-2.0\r
+ \r
+ Unless required by applicable law or agreed to in writing, software\r
+ distributed under the License is distributed on an "AS IS" BASIS,\r
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
+ See the License for the specific language governing permissions and\r
+ limitations under the License.\r
+ ------------------------------------------- */\r
+\r
+#include <lappregistries.h>\r
+#include <stdio.h>\r
+#include <stdlib.h>\r
+\r
+/* datastructure to keep track of streamids used by the lapp */\r
+struct streamregistry {\r
+ gs_int32_t used;\r
+ FTAID ftaid;\r
+ struct ringbuf * r;\r
+};\r
+\r
+struct streamregistry * sreg =0;\r
+gs_int32_t lsreg=0;\r
+\r
+struct ringbuf ** rbr=0;\r
+gs_int32_t lrbr=0;\r
+\r
+FTAID ** rms=0;\r
+gs_int32_t lrms=0;\r
+\r
+/* adds the remote streamid with its associated msgid and ringbuf\r
+ */\r
+gs_retval_t streamregistry_add(FTAID ftaid,struct ringbuf * r)\r
+{\r
+ gs_int32_t x;\r
+ if (lsreg == 0) {\r
+ if ((sreg = malloc(sizeof(struct streamregistry)*STARTSZ))==0) {\r
+ gslog(LOG_EMERG,"ERROR:Out of memory streanregistry\n");\r
+ return -1;\r
+ }\r
+ memset(sreg,0,sizeof(struct streamregistry)*STARTSZ);\r
+ lsreg = STARTSZ;\r
+ }\r
+ for(x=0;(x<lsreg)&&(sreg[x].used!=0);x++);\r
+ if (x == lsreg) {\r
+ gs_int32_t y;\r
+ lsreg = 2*lsreg;\r
+ if ((sreg = realloc(sreg,lsreg*sizeof(struct streamregistry)))==0) {\r
+ gslog(LOG_EMERG,"ERROR:Out of memory streamregistry\n");\r
+ return -1;\r
+ }\r
+ for (y=x;y<lsreg;y++)\r
+ sreg[y].used=0;\r
+ }\r
+ sreg[x].ftaid=ftaid;\r
+ sreg[x].r=r;\r
+ sreg[x].used=1;\r
+ return 0;\r
+}\r
+\r
+/* removes streamid from registry for specific msgid and ringbuf */\r
+void streamregistry_remove(FTAID ftaid)\r
+{\r
+ gs_int32_t x;\r
+ for(x=0;x<lsreg;x++) {\r
+ if ((sreg[x].ftaid.ip==ftaid.ip)\r
+ && (sreg[x].ftaid.port==ftaid.port)\r
+ && (sreg[x].ftaid.index==ftaid.index)\r
+ && (sreg[x].ftaid.streamid==ftaid.streamid)) {\r
+ sreg[x].used=0;\r
+ }\r
+ }\r
+ return;\r
+}\r
+\r
+\r
+\r
+/* the following two functions are used to cycle\r
+ through all ringbuffers\r
+ */\r
+gs_retval_t streamregistry_getactiveringbuf_reset()\r
+{\r
+ gs_int32_t x,y;\r
+ /* XXXOS this is not the most effective way of doing\r
+ this needs improvment. */\r
+ /* Build a list of all ringbufs make sure they\r
+ are unique since multiple entrys could share\r
+ a ringbuf\r
+ */\r
+ if (rbr!=0) (free(rbr));\r
+ if ((rbr=malloc(sizeof(struct ringbuf *)*lsreg))==0) {\r
+ gslog(LOG_EMERG,"Can't allocate memory in ftaregistry\n");\r
+ return -1;\r
+ }\r
+ memset(rbr,0,sizeof(struct ringbuf *)*lsreg);\r
+ lrbr=0;\r
+ for(x=0;x<lsreg;x++) {\r
+ if (sreg[x].used) {\r
+ for(y=0;(y<lrbr)&&(rbr[y]!=sreg[x].r);y++);\r
+ if (y>=lrbr) {\r
+ rbr[y]=sreg[x].r;\r
+ lrbr++;\r
+ }\r
+ }\r
+ }\r
+ return 0;\r
+}\r
+\r
+struct ringbuf * streamregistry_getactiveringbuf()\r
+{\r
+ if (lrbr>0) {\r
+ lrbr --;\r
+ return rbr[lrbr];\r
+ }\r
+ return 0;\r
+}\r
+\r
+\r
+gs_retval_t streamregistry_getactiveftaid_reset()\r
+{\r
+ gs_int32_t x,y;\r
+ /* XXXOS this is not the most effective way of doing\r
+ this needs improvment. */\r
+ /* Build a list of at least one ftaid per process\r
+ */\r
+ if (rms!=0) (free(rms));\r
+ if ((rms=malloc(sizeof(FTAID *)*lsreg))==0) {\r
+ gslog(LOG_EMERG,"Can't allocate memory in ftaregistry\n");\r
+ return -1;\r
+ }\r
+ memset(rms,0,sizeof(gs_int32_t *)*lsreg);\r
+ lrms=0;\r
+ for(x=0;x<lsreg;x++) {\r
+ if (sreg[x].used) {\r
+ for(y=0;(y<lrms)\r
+ &&(rms[y]->ip!=sreg[x].ftaid.ip)\r
+ &&(rms[y]->port!=sreg[x].ftaid.port);y++);\r
+ if (y>=lrms) {\r
+ rms[y]=&(sreg[x].ftaid);\r
+ lrms++;\r
+ }\r
+ }\r
+ }\r
+ return 0;\r
+}\r
+\r
+FTAID * streamregistry_getactiveftaid()\r
+{\r
+ if (lrms>0) {\r
+ lrms --;\r
+ return rms[lrms];\r
+ }\r
+ return 0; \r
+}\r