Member
Статус: Не в сети Регистрация: 20.09.2005 Откуда: Москва
Я разобрался. Программу написал, все работает. Наверное вопрос задал не в тот раздел, программа на которую я дал ссылку писалась на С++/CLI, знак % это отслеживающая ссылка. Помог учебник Хортон Visual c++ 2005 Базовый курс.
Microsoft VisualStudio медленно умирает как платформа для разработчиков.
ну почему умирает, да может не такой популярностью C, C++ пользуется как другие языки, но все же спрос есть, даже если посмотреть на фрилансе, много заказов. Я даже планирую к репетитору обратиться, чтоб натаскал по некоторым сложным для меня моментам в C++. Правда не знаю еще как найти такого репетитора. На курсы идти не хочу, т.к. пустая трата времени. Нужен именно частный репетитор в Москве. Смотрел тут, удобно что отзывы, оценки можно посмотреть. Но как выбирать в итоге, по опыту программирования? Где найти, кто подскажет?
Подскажите, как перегрузить присваивание, чтобы структуры типа A могли присваиваться структурам типа B и наоборот? Обе структуры никак не связаны/не наследники.
Member
Статус: Не в сети Регистрация: 05.12.2005 Откуда: портовый город
Hive писал(а):
как перегрузить присваивание
А зачем вам это, если не секрет? Операторы не рулят. Как вы будете искать нужную операцию присваивания по коду, по '=' что ли? Насколько проще будет сопровождать код в котором будет элегантный код "a.super_import(b);" вместо безликого "a = b;".
troll ЗАЧЕМ мне ее искать "по коду"??? что за бред. мне просто нужна компактная форма записи, перекидывающая нужные поля из одной структуры в другую, без пол-страницы кода каждый раз. а сейчас именно костыль в виде перегруженной функции вроде "super_import" и используется.
Добавлено спустя 1 минуту 17 секунд: Lord_of_Darkness thx, попробую привинтить
Мне нужно понять алгоритм изменения скорости кулера процессора. Есть рабочий код управления регистрами контроллера (я проверял установкой программы, его содержащей, скорость кулера корректно регулируется) Я понимаю этот код так:
1) Послать в порт номер 0x66 команду 0x99 2) Для случая CPU FAN послать в порт 0x62 команду 0x1 3) Потом послать hex данные в порт 0x62
Где-то я ошибся, т.к. при ручном изменении регистров в соответствии с понятым мной алгоритмом, скорость кулера не меняется. Пожалуйста, помогите мне найти ошибку в моем анализе кода.
/** * Set IO port input/output permissions * On success, zero is returned. On error, -1 is returned, and errno is * set appropriately. * * @return Status of Operation */ static int EcInit() { if (ioperm(EC_DATA_PORT, 1, 1) != 0) { return EXIT_FAILURE; }
if (ioperm(EC_COMMAND_PORT, 1, 1) != 0) { return EXIT_FAILURE; }
return EXIT_SUCCESS; }
/** * Wait on EC * * @param port The port for waiting * @param flag * @param value * * @return Status of Operation */ static int EcIoWait(const uint32_t port, const uint32_t flag, const char value) { uint8_t data = inb(port); int i = 0;
while ((((data >> flag) & 0x1) != value) && (i++ < 100)) { data = inb(port); }
if (i >= 100) { return EXIT_FAILURE; }
return EXIT_SUCCESS; }
/** * Read the Port informations * * @param port The port for waiting * * @return the Data */ static uint8_t EcIoRead(const uint32_t port) { EcIoWait(EC_COMMAND_PORT, IBF, 0); outb(EC_SC_READ_CMD, EC_COMMAND_PORT);
EcIoWait(EC_COMMAND_PORT, OBF, 1); uint8_t value = inb(EC_DATA_PORT);
return value; }
/** * Flush the EC */ static void EcFlush() { while ((inb(EC_COMMAND_PORT) & 0x1) == 0x1) { inb(EC_DATA_PORT); } }
/** * Read a byte from EC * * @return Returns the current byte */ static int ReadByte() { int i = 1000000; while ((inb(EC_COMMAND_PORT) & 1) == 0 && i > 0) { i -= 1; }
if (i == 0) { return 0; } else { return inb(EC_DATA_PORT); } }
/** * Send a command to the ec * * @param command the comamnd to send */ static void SendCommand(int command) { int tt = 0; while((inb(EC_COMMAND_PORT) & 2)) { tt++; if(tt>30000) { break; } }
outb(command, EC_COMMAND_PORT); }
/** * Write data to ec * * @param data the data to write */ static void WriteData(int data) { while((inb(EC_COMMAND_PORT) & 2));
outb(data, EC_DATA_PORT); }
/** * Read the Callbackinforamtions Envoiroment and returns the Index of the fan parameter * * @param info the nodejs CallbackInfo * * @return The index of the fan */ static int GetFanDutyIndexParameter(const Napi::CallbackInfo& info) { Napi::Env env = info.Env();
if (info.Length() != 1) { Napi::TypeError::New(env, "Wrong number of arguments").ThrowAsJavaScriptException(); return -1; }
if (!info[0].IsNumber()) { Napi::TypeError::New(env, "Wrong argument").ThrowAsJavaScriptException(); return -1; }
uint32_t index = info[0].As<Napi::Number>(); if(index < 1 || index > 3) { Napi::TypeError::New(env, "Wrong Index").ThrowAsJavaScriptException(); return -1; }
return index; }
/** * Read and return the Raw Fan duty of fan * * @param index the fan index * * @return the fan duty value */ static int RawFanDuty(int index) { EcInit(); EcFlush();
SendCommand(TEMP); WriteData(index);
ReadByte(); ReadByte(); int value = ReadByte();
return value; }
/** * Get the clean Fan Duty in percent * * @param info the nodejs CallbackInfo * * @return The current fan duty of fan in percent */ Napi::Number GetFanDuty(const Napi::CallbackInfo& info) { Napi::Env env = info.Env(); float fan_duty_perc = 0; int index = GetFanDutyIndexParameter(info);
/** * Return the raw fan duty (value 0 - 255) * * @param info the nodejs CallbackInfo * * @return The current raw fan duty of fan (value 0 - 255) */ Napi::Number GetRawFanDuty(const Napi::CallbackInfo& info) { Napi::Env env = info.Env(); int index = GetFanDutyIndexParameter(info);
int fanDutyValue = RawFanDuty(index);
return Napi::Number::New(env, fanDutyValue); }
/** * Read and returns the remote temp of the fan * * @param info the nodejs CallbackInfo * * @return the remote temp */ Napi::Number GetRemoteTemp(const Napi::CallbackInfo& info) { Napi::Env env = info.Env(); int index = GetFanDutyIndexParameter(info);
EcInit(); EcFlush();
SendCommand(TEMP); WriteData(index);
int value = ReadByte();
return Napi::Number::New(env, value); }
/** * Read and returns the local temp of the fan * * @param info the nodejs CallbackInfo * * @return the local temp */ Napi::Number GetLocalTemp(const Napi::CallbackInfo& info) { Napi::Env env = info.Env(); int index = GetFanDutyIndexParameter(info);
EcInit(); EcFlush();
SendCommand(TEMP); WriteData(index); ReadByte();
int value = ReadByte();
return Napi::Number::New(env, value); }
/** * Calculate the fan rpms * * @param raw_rpm_high The raw high rpm value of the fan * @param raw_rpm_low The raw low rpm value of the fan */ static int calculate_fan_rpms(int raw_rpm_high, int raw_rpm_low) { int raw_rpm = (raw_rpm_high << 8) + raw_rpm_low; return raw_rpm > 0 ? (2156220 / raw_rpm) : 0; }
/** * Read and returns the rpm of the fan * * @param info the nodejs CallbackInfo * * @return Returns the fan rpm */ Napi::Number GetFanRpm(const Napi::CallbackInfo& info) { Napi::Env env = info.Env(); int index = GetFanDutyIndexParameter(info); int value = 0;
if(index == 1) { EcInit(); EcFlush();
int raw_rpm_hi = EcIoRead(EC_REG_CPU_FAN_RPMS_HI); int raw_rpm_lo = EcIoRead(EC_REG_CPU_FAN_RPMS_LO);
value = calculate_fan_rpms(raw_rpm_hi, raw_rpm_lo); } else if(index == 2) { EcInit(); EcFlush(); int raw_rpm_hi = EcIoRead(EC_REG_GPU_FAN_RPMS_HI); int raw_rpm_lo = EcIoRead(EC_REG_GPU_FAN_RPMS_LO);
value = calculate_fan_rpms(raw_rpm_hi, raw_rpm_lo); } else if(index == 3) { EcInit(); EcFlush(); int raw_rpm_hi = EcIoRead(0xD4); int raw_rpm_lo = EcIoRead(0xD5);
value = calculate_fan_rpms(raw_rpm_hi, raw_rpm_lo); }
return Napi::Number::New(env, value); }
/** * Set the fan duty * * @param info the nodejs CallbackInfo * * @return Returns a bool to indicate was the operation sucessfully or not */ Napi::Boolean SetFanDuty(const Napi::CallbackInfo& info) { Napi::Env env = info.Env();
if (info.Length() != 2) { Napi::TypeError::New(env, "Wrong number of arguments").ThrowAsJavaScriptException(); return Napi::Boolean::New(env, false); }
if (!info[0].IsNumber()) { Napi::TypeError::New(env, "Wrong argument for index").ThrowAsJavaScriptException(); return Napi::Boolean::New(env, false); }
if (!info[1].IsNumber()) { Napi::TypeError::New(env, "Wrong argument for duty").ThrowAsJavaScriptException(); return Napi::Boolean::New(env, false); }
uint32_t index = info[0].As<Napi::Number>(); uint32_t fanDuty = info[1].As<Napi::Number>();
if (fanDuty < 1 || fanDuty > 255) { std::string message = "Wrong fan duty to write: " + std::to_string(fanDuty) + "\n"; Napi::Error::New(env, message).ThrowAsJavaScriptException();
return Napi::Boolean::New(env, false); }
EcInit(); SendCommand(0x99);
switch(index) { case 1: WriteData(0x01); break; case 2: WriteData(0x02); break; case 3: WriteData(0x03); break; default: return Napi::Boolean::New(env, false); }
WriteData(fanDuty);
return Napi::Boolean::New(env, true); }
/** * Set the fan duty on auto modus * * @param info the nodejs CallbackInfo */ void SetAutoFanDuty(const Napi::CallbackInfo& info) { Napi::Env env = info.Env(); if (info.Length() != 1) { Napi::TypeError::New(env, "Wrong number of arguments").ThrowAsJavaScriptException(); }
if (!info[0].IsNumber()) { Napi::TypeError::New(env, "Wrong argument").ThrowAsJavaScriptException(); }
uint32_t index = info[0].As<Napi::Number>(); if(index < 1 || index > 5) { Napi::TypeError::New(env, "Wrong Index").ThrowAsJavaScriptException(); }
EcInit();
SendCommand(0x99); WriteData(0xff);
switch (index) { case 1: WriteData(0x01); break; case 2: WriteData(0x02); break; case 3: WriteData(0x03); break; case 5: WriteData(0xff); WriteData(0xff); break; default: break; } }
Мне нужно понять алгоритм изменения скорости кулера процессора. Есть рабочий код управления регистрами контроллера (я проверял установкой программы, его содержащей, скорость кулера корректно регулируется) Я понимаю этот код так:
1) Послать в порт номер 0x66 команду 0x99 2) Для случая CPU FAN послать в порт 0x62 команду 0x1 3) Потом послать hex данные в порт 0x62
Где-то я ошибся, т.к. при ручном изменении регистров в соответствии с понятым мной алгоритмом, скорость кулера не меняется. Пожалуйста, помогите мне найти ошибку в моем анализе кода.
/** * Set IO port input/output permissions * On success, zero is returned. On error, -1 is returned, and errno is * set appropriately. * * @return Status of Operation */ static int EcInit() { if (ioperm(EC_DATA_PORT, 1, 1) != 0) { return EXIT_FAILURE; }
if (ioperm(EC_COMMAND_PORT, 1, 1) != 0) { return EXIT_FAILURE; }
return EXIT_SUCCESS; }
/** * Wait on EC * * @param port The port for waiting * @param flag * @param value * * @return Status of Operation */ static int EcIoWait(const uint32_t port, const uint32_t flag, const char value) { uint8_t data = inb(port); int i = 0;
while ((((data >> flag) & 0x1) != value) && (i++ < 100)) { data = inb(port); }
if (i >= 100) { return EXIT_FAILURE; }
return EXIT_SUCCESS; }
/** * Read the Port informations * * @param port The port for waiting * * @return the Data */ static uint8_t EcIoRead(const uint32_t port) { EcIoWait(EC_COMMAND_PORT, IBF, 0); outb(EC_SC_READ_CMD, EC_COMMAND_PORT);
EcIoWait(EC_COMMAND_PORT, OBF, 1); uint8_t value = inb(EC_DATA_PORT);
return value; }
/** * Flush the EC */ static void EcFlush() { while ((inb(EC_COMMAND_PORT) & 0x1) == 0x1) { inb(EC_DATA_PORT); } }
/** * Read a byte from EC * * @return Returns the current byte */ static int ReadByte() { int i = 1000000; while ((inb(EC_COMMAND_PORT) & 1) == 0 && i > 0) { i -= 1; }
if (i == 0) { return 0; } else { return inb(EC_DATA_PORT); } }
/** * Send a command to the ec * * @param command the comamnd to send */ static void SendCommand(int command) { int tt = 0; while((inb(EC_COMMAND_PORT) & 2)) { tt++; if(tt>30000) { break; } }
outb(command, EC_COMMAND_PORT); }
/** * Write data to ec * * @param data the data to write */ static void WriteData(int data) { while((inb(EC_COMMAND_PORT) & 2));
outb(data, EC_DATA_PORT); }
/** * Read the Callbackinforamtions Envoiroment and returns the Index of the fan parameter * * @param info the nodejs CallbackInfo * * @return The index of the fan */ static int GetFanDutyIndexParameter(const Napi::CallbackInfo& info) { Napi::Env env = info.Env();
if (info.Length() != 1) { Napi::TypeError::New(env, "Wrong number of arguments").ThrowAsJavaScriptException(); return -1; }
if (!info[0].IsNumber()) { Napi::TypeError::New(env, "Wrong argument").ThrowAsJavaScriptException(); return -1; }
uint32_t index = info[0].As<Napi::Number>(); if(index < 1 || index > 3) { Napi::TypeError::New(env, "Wrong Index").ThrowAsJavaScriptException(); return -1; }
return index; }
/** * Read and return the Raw Fan duty of fan * * @param index the fan index * * @return the fan duty value */ static int RawFanDuty(int index) { EcInit(); EcFlush();
SendCommand(TEMP); WriteData(index);
ReadByte(); ReadByte(); int value = ReadByte();
return value; }
/** * Get the clean Fan Duty in percent * * @param info the nodejs CallbackInfo * * @return The current fan duty of fan in percent */ Napi::Number GetFanDuty(const Napi::CallbackInfo& info) { Napi::Env env = info.Env(); float fan_duty_perc = 0; int index = GetFanDutyIndexParameter(info);
/** * Return the raw fan duty (value 0 - 255) * * @param info the nodejs CallbackInfo * * @return The current raw fan duty of fan (value 0 - 255) */ Napi::Number GetRawFanDuty(const Napi::CallbackInfo& info) { Napi::Env env = info.Env(); int index = GetFanDutyIndexParameter(info);
int fanDutyValue = RawFanDuty(index);
return Napi::Number::New(env, fanDutyValue); }
/** * Read and returns the remote temp of the fan * * @param info the nodejs CallbackInfo * * @return the remote temp */ Napi::Number GetRemoteTemp(const Napi::CallbackInfo& info) { Napi::Env env = info.Env(); int index = GetFanDutyIndexParameter(info);
EcInit(); EcFlush();
SendCommand(TEMP); WriteData(index);
int value = ReadByte();
return Napi::Number::New(env, value); }
/** * Read and returns the local temp of the fan * * @param info the nodejs CallbackInfo * * @return the local temp */ Napi::Number GetLocalTemp(const Napi::CallbackInfo& info) { Napi::Env env = info.Env(); int index = GetFanDutyIndexParameter(info);
EcInit(); EcFlush();
SendCommand(TEMP); WriteData(index); ReadByte();
int value = ReadByte();
return Napi::Number::New(env, value); }
/** * Calculate the fan rpms * * @param raw_rpm_high The raw high rpm value of the fan * @param raw_rpm_low The raw low rpm value of the fan */ static int calculate_fan_rpms(int raw_rpm_high, int raw_rpm_low) { int raw_rpm = (raw_rpm_high << 8) + raw_rpm_low; return raw_rpm > 0 ? (2156220 / raw_rpm) : 0; }
/** * Read and returns the rpm of the fan * * @param info the nodejs CallbackInfo * * @return Returns the fan rpm */ Napi::Number GetFanRpm(const Napi::CallbackInfo& info) { Napi::Env env = info.Env(); int index = GetFanDutyIndexParameter(info); int value = 0;
if(index == 1) { EcInit(); EcFlush();
int raw_rpm_hi = EcIoRead(EC_REG_CPU_FAN_RPMS_HI); int raw_rpm_lo = EcIoRead(EC_REG_CPU_FAN_RPMS_LO);
value = calculate_fan_rpms(raw_rpm_hi, raw_rpm_lo); } else if(index == 2) { EcInit(); EcFlush(); int raw_rpm_hi = EcIoRead(EC_REG_GPU_FAN_RPMS_HI); int raw_rpm_lo = EcIoRead(EC_REG_GPU_FAN_RPMS_LO);
value = calculate_fan_rpms(raw_rpm_hi, raw_rpm_lo); } else if(index == 3) { EcInit(); EcFlush(); int raw_rpm_hi = EcIoRead(0xD4); int raw_rpm_lo = EcIoRead(0xD5);
value = calculate_fan_rpms(raw_rpm_hi, raw_rpm_lo); }
return Napi::Number::New(env, value); }
/** * Set the fan duty * * @param info the nodejs CallbackInfo * * @return Returns a bool to indicate was the operation sucessfully or not */ Napi::Boolean SetFanDuty(const Napi::CallbackInfo& info) { Napi::Env env = info.Env();
if (info.Length() != 2) { Napi::TypeError::New(env, "Wrong number of arguments").ThrowAsJavaScriptException(); return Napi::Boolean::New(env, false); }
if (!info[0].IsNumber()) { Napi::TypeError::New(env, "Wrong argument for index").ThrowAsJavaScriptException(); return Napi::Boolean::New(env, false); }
if (!info[1].IsNumber()) { Napi::TypeError::New(env, "Wrong argument for duty").ThrowAsJavaScriptException(); return Napi::Boolean::New(env, false); }
uint32_t index = info[0].As<Napi::Number>(); uint32_t fanDuty = info[1].As<Napi::Number>();
if (fanDuty < 1 || fanDuty > 255) { std::string message = "Wrong fan duty to write: " + std::to_string(fanDuty) + "\n"; Napi::Error::New(env, message).ThrowAsJavaScriptException();
return Napi::Boolean::New(env, false); }
EcInit(); SendCommand(0x99);
switch(index) { case 1: WriteData(0x01); break; case 2: WriteData(0x02); break; case 3: WriteData(0x03); break; default: return Napi::Boolean::New(env, false); }
WriteData(fanDuty);
return Napi::Boolean::New(env, true); }
/** * Set the fan duty on auto modus * * @param info the nodejs CallbackInfo */ void SetAutoFanDuty(const Napi::CallbackInfo& info) { Napi::Env env = info.Env(); if (info.Length() != 1) { Napi::TypeError::New(env, "Wrong number of arguments").ThrowAsJavaScriptException(); }
if (!info[0].IsNumber()) { Napi::TypeError::New(env, "Wrong argument").ThrowAsJavaScriptException(); }
uint32_t index = info[0].As<Napi::Number>(); if(index < 1 || index > 5) { Napi::TypeError::New(env, "Wrong Index").ThrowAsJavaScriptException(); }
EcInit();
SendCommand(0x99); WriteData(0xff);
switch (index) { case 1: WriteData(0x01); break; case 2: WriteData(0x02); break; case 3: WriteData(0x03); break; case 5: WriteData(0xff); WriteData(0xff); break; default: break; } }
Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 2
Вы не можете начинать темы Вы не можете отвечать на сообщения Вы не можете редактировать свои сообщения Вы не можете удалять свои сообщения Вы не можете добавлять вложения