-fixed ftp server file transfers

-fixed a wrong button position (thx mamule)
This commit is contained in:
fix94.1 2013-11-19 22:05:53 +00:00
parent 959d71c186
commit 27948551b5
3 changed files with 23 additions and 4 deletions

View File

@ -300,7 +300,7 @@ void CMenu::_initLangSettingsMenu()
m_LangSettingsBtnGetLanguages = _addButton("LANGUAGE/GET_LANG_BTN", theme.btnFont, L"", 420, 190, 200, 48, theme.btnFontColor);
m_LangSettingsLblDlLang = _addLabel("LANGUAGE/DL_LANG", theme.lblFont, L"", 20, 245, 385, 56, theme.lblFontColor, FTGX_JUSTIFY_LEFT | FTGX_ALIGN_MIDDLE);
m_LangSettingsLblCurDLLang = _addLabel("LANGUAGE/DL_LANG_BTN", theme.btnFont, L"", 386, 250, 104, 48, theme.btnFontColor, FTGX_JUSTIFY_CENTER | FTGX_ALIGN_MIDDLE, theme.btnTexC);
m_LangSettingsLblCurDLLang = _addLabel("LANGUAGE/DL_LANG_BTN", theme.btnFont, L"", 468, 250, 104, 48, theme.btnFontColor, FTGX_JUSTIFY_CENTER | FTGX_ALIGN_MIDDLE, theme.btnTexC);
m_LangSettingsBtnCurDlLangM = _addPicButton("LANGUAGE/DL_LANG_MINUS", theme.btnTexMinus, theme.btnTexMinusS, 420, 250, 48, 48);
m_LangSettingsBtnCurDlLangP = _addPicButton("LANGUAGE/DL_LANG_PLUS", theme.btnTexPlus, theme.btnTexPlusS, 572, 250, 48, 48);

View File

@ -24,6 +24,7 @@
#include "fileOps/fileOps.h"
#include "gui/fmt.h"
#include "loader/wbfs.h"
#include "memory/mem2.hpp"
#ifdef __cplusplus
extern "C" {
@ -277,6 +278,8 @@ int ftp_delete(char *path)
}
lwp_t ftpThrdPtr = LWP_THREAD_NULL;
u8 *ftpThrdStack = NULL;
static const u32 ftpThrdStackSize = 65536; //we need a big stack for all the transfers
volatile bool ftpThrd_running = false;
bool end_ftp = false;
s32 cur_server_num = -1;
@ -303,9 +306,16 @@ bool ftp_startThread(void)
end_ftp = false;
ftpThrd_running = true;
LWP_CreateThread(&ftpThrdPtr, ftp_loopThrd, NULL, NULL, 0, 64);
ftpThrdStack = (u8*)MEM2_memalign(32, ftpThrdStackSize);
if(ftpThrdStack != NULL)
{
memset(ftpThrdStack, 0, ftpThrdStackSize);
DCFlushRange(ftpThrdStack, ftpThrdStackSize);
LWP_CreateThread(&ftpThrdPtr, ftp_loopThrd, NULL, ftpThrdStack, ftpThrdStackSize, 64);
return true;
}
return false;
}
void ftp_endTread(void)
{
@ -320,6 +330,10 @@ void ftp_endTread(void)
LWP_JoinThread(ftpThrdPtr, NULL);
ftpThrdPtr = LWP_THREAD_NULL;
if(ftpThrdStack != NULL)
MEM2_free(ftpThrdStack);
ftpThrdStack = NULL;
end_server();
cur_server_num = -1;
}

View File

@ -114,8 +114,11 @@ s32 send_from_file(s32 s, FILE *f) {
s32 bytes_read;
s32 result = 0;
DCFlushRange(buf, FREAD_BUFFER_SIZE);
ICInvalidateRange(buf, FREAD_BUFFER_SIZE);
bytes_read = fread(buf, 1, FREAD_BUFFER_SIZE, f);
if (bytes_read > 0) {
DCFlushRange(buf, bytes_read);
result = send_exact(s, buf, bytes_read);
if (result < 0) goto end;
}
@ -133,6 +136,8 @@ s32 recv_to_file(s32 s, FILE *f) {
s32 bytes_read;
while (1) {
try_again_with_smaller_buffer:
DCFlushRange(buf, NET_BUFFER_SIZE);
ICInvalidateRange(buf, NET_BUFFER_SIZE);
bytes_read = net_read(s, buf, NET_BUFFER_SIZE);
if (bytes_read < 0) {
if (bytes_read == -EINVAL && NET_BUFFER_SIZE == MAX_NET_BUFFER_SIZE) {
@ -143,7 +148,7 @@ s32 recv_to_file(s32 s, FILE *f) {
} else if (bytes_read == 0) {
return 0;
}
DCFlushRange(buf, bytes_read);
s32 bytes_written = fwrite(buf, 1, bytes_read, f);
if (bytes_written < bytes_read) return -1;
}