2012-10-31 1 views
4

setsockopt을 사용하여 IPTOS 값을 IPTOS_THROUGHPUT으로 설정하려고합니다. setsockopt 호출은 0을 반환했습니다. 그러나 getsockoptIP_TOS 값이 (0x8)과 다른 1으로 설정되어 있음을 보여줍니다. 누구든지 setsockoptgetsockoptIPTOS 값의 불일치를 일으킬 수있는 아이디어가 있습니까? 여기 getsockopt가 setsockopt에 설정된 것과 다른 IP_TOS 값을 반환합니다.

는 로그 출력의 :

설정 DSCP 소켓에 표시 소켓 (26)에 표시 26

소켓 (26)에 setsockopt를 8 0을 반환

DSCP 1, 서로 다른 기대에서 8

코드는 다음과 같습니다.

int iptos = IPTOS_THROUGHPUT; 

log(debug, 10, "Set DSCP Marking on socket %d\n", sockfd); 

retval = setsockopt(sockfd, IPPROTO_TCP, IP_TOS, &iptos, sizeof(iptos)); 
if (retval<0) { 
    log(error, 99, "Failed to set DSCP marking on socket %d with error %d\n", 
     sockfd, retval); 
} else { 
    log(debug, 10, "setsockopt on socket %d to %d returns %d\n", sockfd, iptos, 
     retval); 
    int tos=0; 
    socklen_t toslen=sizeof(tos); 

    retval = getsockopt(sockfd, IPPROTO_TCP, IP_TOS, &tos, &toslen); 
    if(retval<0) { 
     log(warning, 99, "Failed to get DSCP marking on socket %d with error %d\n", 
     sockfd, retval); 
    }else { 
     if(tos != iptos) { 
     log(warning, 99, "DSCP marking on socket %d is %d, different from expected %d\n", 
      sockfd, tos, iptos); 
     retval = 9999; 
     } 
     else { 
     log(debug, 10, "Success: Set DSCP Marking on socket %d to %d\n", 
      sockfd, iptos); 
     retval = 0; 
     } 
    } 
} 

답변

4

당신은 IPPROTO_TCP

+0

덕분에 많은 훌리오 대신 수준 옵션 IPPROTO_IP을 사용한다! 그게 문제 야! –

관련 문제